mirror of
https://github.com/rizinorg/cutter.git
synced 2025-01-05 20:38:18 +00:00
bf72e4c2b7
Old behaviour was only to accept "Y". The prompt suggested, however, that "y" was the default behaviour, so accepting "return" as confirmation of that choice is the sane behaviour with least user experience disruption.
59 lines
1.3 KiB
Bash
Executable File
59 lines
1.3 KiB
Bash
Executable File
#!/bin/sh
|
|
|
|
# This script is a work in progress
|
|
|
|
#### Constants ####
|
|
BUILDR2=1
|
|
|
|
#### User variables ####
|
|
BUILD="build"
|
|
#QMAKE_CONF="CONFIG+=CUTTER_ENABLE_JUPYTER CONFIG+=CUTTER_ENABLE_QTWEBENGINE"
|
|
QMAKE_CONF=""
|
|
|
|
# Checking for radare2
|
|
r2 -v >/dev/null 2>&1
|
|
if [ $? = 0 ]; then
|
|
R2COMMIT=$(r2 -v | tail -n1 | sed "s,commit: \\(.*\\) build.*,\\1,")
|
|
SUBMODULE=$(git submodule | awk '{print $1}')
|
|
if [ "$R2COMMIT" = "$SUBMODULE" ]; then
|
|
BUILDR2=0
|
|
fi
|
|
fi
|
|
|
|
# Check if qmake is available
|
|
qmakepath=$(which qmake)
|
|
if [ -z "$qmakepath" ]; then
|
|
echo "You need qmake to build Cutter."
|
|
echo "Please make sure qmake is in your PATH environment variable."
|
|
exit 1
|
|
fi
|
|
|
|
# Build radare2
|
|
if [ $BUILDR2 -eq 1 ]; then
|
|
answer="Y"
|
|
echo -n "A (new?) version of radare2 will be installed. Do you agree? [Y/n] "
|
|
read answer
|
|
if [ -z "$answer" -o "$answer" = "Y" -o "$answer" = "y" ]; then
|
|
git submodule init && git submodule update
|
|
cd radare2 || exit 1
|
|
./sys/install.sh
|
|
cd ..
|
|
else
|
|
echo "Sorry but this script won't work otherwise. Read the README."
|
|
exit 1
|
|
fi
|
|
else
|
|
echo "Correct radare2 version found, skipping..."
|
|
fi
|
|
|
|
# Build
|
|
mkdir "$BUILD"
|
|
cd "$BUILD" || exit 1
|
|
qmake "$QMAKE_CONF" ../src/Cutter.pro
|
|
make
|
|
cd ..
|
|
|
|
# Done
|
|
echo "Build complete. Binary available at: $BUILD/Cutter"
|
|
|