mirror of
https://github.com/monero-project/monero-gui.git
synced 2025-01-10 21:04:32 +00:00
Merge pull request #330
2eebe67
make static build optional on linux/mac (Jaquee)
This commit is contained in:
commit
05434a994f
3 changed files with 85 additions and 20 deletions
27
build.sh
27
build.sh
|
@ -1,8 +1,26 @@
|
||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
BUILD_TYPE=$1
|
BUILD_TYPE=$1
|
||||||
|
# default build type
|
||||||
if [ -z $BUILD_TYPE ]; then
|
if [ -z $BUILD_TYPE ]; then
|
||||||
BUILD_TYPE=Release
|
BUILD_TYPE=release
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ "$BUILD_TYPE" == "release" ]; then
|
||||||
|
echo "Building release"
|
||||||
|
CONFIG="CONFIG+=release";
|
||||||
|
BIN_PATH=release/bin
|
||||||
|
elif [ "$BUILD_TYPE" == "release-static" ]; then
|
||||||
|
echo "Building release-static"
|
||||||
|
CONFIG="CONFIG+=release static";
|
||||||
|
BIN_PATH=release/bin
|
||||||
|
elif [ "$BUILD_TYPE" == "debug" ]; then
|
||||||
|
echo "Building debug"
|
||||||
|
CONFIG="CONFIG+=debug"
|
||||||
|
BIN_PATH=debug/bin
|
||||||
|
else
|
||||||
|
echo "Valid build types are release, release-static and debug"
|
||||||
|
exit 1;
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
|
||||||
|
@ -22,13 +40,6 @@ make -C src/zxcvbn-c
|
||||||
|
|
||||||
if [ ! -d build ]; then mkdir build; fi
|
if [ ! -d build ]; then mkdir build; fi
|
||||||
|
|
||||||
if [ "$BUILD_TYPE" == "Release" ]; then
|
|
||||||
CONFIG="CONFIG+=release";
|
|
||||||
BIN_PATH=release/bin
|
|
||||||
else
|
|
||||||
CONFIG="CONFIG+=debug"
|
|
||||||
BIN_PATH=debug/bin
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Platform indepenent settings
|
# Platform indepenent settings
|
||||||
platform=$(get_platform)
|
platform=$(get_platform)
|
||||||
|
|
|
@ -6,10 +6,30 @@ MONERO_BRANCH=master
|
||||||
# MONERO_URL=https://github.com/mbg033/monero.git
|
# MONERO_URL=https://github.com/mbg033/monero.git
|
||||||
# MONERO_BRANCH=develop
|
# MONERO_BRANCH=develop
|
||||||
# Buidling "debug" build optionally
|
# Buidling "debug" build optionally
|
||||||
|
|
||||||
|
# default build type
|
||||||
BUILD_TYPE=$1
|
BUILD_TYPE=$1
|
||||||
if [ -z $BUILD_TYPE ]; then
|
if [ -z $BUILD_TYPE ]; then
|
||||||
BUILD_TYPE=Release
|
BUILD_TYPE=release
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
STATIC=false
|
||||||
|
if [ "$BUILD_TYPE" == "release" ]; then
|
||||||
|
echo "Building libwallet release"
|
||||||
|
CMAKE_BUILD_TYPE=Release
|
||||||
|
elif [ "$BUILD_TYPE" == "release-static" ]; then
|
||||||
|
echo "Building libwallet release-static"
|
||||||
|
CMAKE_BUILD_TYPE=Release
|
||||||
|
STATIC=true
|
||||||
|
elif [ "$BUILD_TYPE" == "debug" ]; then
|
||||||
|
echo "Building libwallet debug"
|
||||||
|
CMAKE_BUILD_TYPE=Debug
|
||||||
|
else
|
||||||
|
echo "Valid build types are release, release-static and debug"
|
||||||
|
exit 1;
|
||||||
|
fi
|
||||||
|
|
||||||
|
|
||||||
# thanks to SO: http://stackoverflow.com/a/20283965/4118915
|
# thanks to SO: http://stackoverflow.com/a/20283965/4118915
|
||||||
if test -z "$CPU_CORE_COUNT"; then
|
if test -z "$CPU_CORE_COUNT"; then
|
||||||
CPU_CORE_COUNT=$(grep -c ^processor /proc/cpuinfo 2>/dev/null || sysctl -n hw.ncpu)
|
CPU_CORE_COUNT=$(grep -c ^processor /proc/cpuinfo 2>/dev/null || sysctl -n hw.ncpu)
|
||||||
|
@ -46,31 +66,57 @@ pushd $MONERO_DIR/build/release
|
||||||
platform=$(get_platform)
|
platform=$(get_platform)
|
||||||
# default make executable
|
# default make executable
|
||||||
make_exec="make"
|
make_exec="make"
|
||||||
|
|
||||||
|
## OS X
|
||||||
if [ "$platform" == "darwin" ]; then
|
if [ "$platform" == "darwin" ]; then
|
||||||
# Do something under Mac OS X platform
|
|
||||||
echo "Configuring build for MacOS.."
|
echo "Configuring build for MacOS.."
|
||||||
cmake -D CMAKE_BUILD_TYPE=$BUILD_TYPE -D STATIC=ON -D ARCH="x86-64" -D BUILD_64=ON -D BUILD_GUI_DEPS=ON -D INSTALL_VENDORED_LIBUNBOUND=ON -D CMAKE_INSTALL_PREFIX="$MONERO_DIR" ../..
|
if [ "$STATIC" == true ]; then
|
||||||
|
cmake -D CMAKE_BUILD_TYPE=$CMAKE_BUILD_TYPE -D STATIC=ON -D ARCH="x86-64" -D BUILD_64=ON -D BUILD_GUI_DEPS=ON -D INSTALL_VENDORED_LIBUNBOUND=ON -D CMAKE_INSTALL_PREFIX="$MONERO_DIR" ../..
|
||||||
|
else
|
||||||
|
cmake -D CMAKE_BUILD_TYPE=$CMAKE_BUILD_TYPE -D BUILD_GUI_DEPS=ON -D INSTALL_VENDORED_LIBUNBOUND=ON -D CMAKE_INSTALL_PREFIX="$MONERO_DIR" ../..
|
||||||
|
fi
|
||||||
|
|
||||||
|
## LINUX 64
|
||||||
elif [ "$platform" == "linux64" ]; then
|
elif [ "$platform" == "linux64" ]; then
|
||||||
# Do something under GNU/Linux platform
|
|
||||||
echo "Configuring build for Linux x64"
|
echo "Configuring build for Linux x64"
|
||||||
cmake -D CMAKE_BUILD_TYPE=$BUILD_TYPE -D STATIC=ON -D ARCH="x86-64" -D BUILD_64=ON -D BUILD_GUI_DEPS=ON -D CMAKE_INSTALL_PREFIX="$MONERO_DIR" ../..
|
if [ "$STATIC" == true ]; then
|
||||||
|
cmake -D CMAKE_BUILD_TYPE=$CMAKE_BUILD_TYPE -D STATIC=ON -D ARCH="x86-64" -D BUILD_64=ON -D BUILD_GUI_DEPS=ON -D CMAKE_INSTALL_PREFIX="$MONERO_DIR" ../..
|
||||||
|
else
|
||||||
|
cmake -D CMAKE_BUILD_TYPE=$CMAKE_BUILD_TYPE -D BUILD_GUI_DEPS=ON -D CMAKE_INSTALL_PREFIX="$MONERO_DIR" ../..
|
||||||
|
fi
|
||||||
|
|
||||||
|
## LINUX 32
|
||||||
elif [ "$platform" == "linux32" ]; then
|
elif [ "$platform" == "linux32" ]; then
|
||||||
# Do something under GNU/Linux platform
|
|
||||||
echo "Configuring build for Linux i686"
|
echo "Configuring build for Linux i686"
|
||||||
cmake -D CMAKE_BUILD_TYPE=$BUILD_TYPE -D STATIC=ON -D ARCH="i686" -D BUILD_64=OFF -D BUILD_GUI_DEPS=ON -D CMAKE_INSTALL_PREFIX="$MONERO_DIR" ../..
|
if [ "$STATIC" == true ]; then
|
||||||
|
cmake -D CMAKE_BUILD_TYPE=$CMAKE_BUILD_TYPE -D STATIC=ON -D ARCH="i686" -D BUILD_64=OFF -D BUILD_GUI_DEPS=ON -D CMAKE_INSTALL_PREFIX="$MONERO_DIR" ../..
|
||||||
|
else
|
||||||
|
cmake -D CMAKE_BUILD_TYPE=$CMAKE_BUILD_TYPE -D BUILD_GUI_DEPS=ON -D CMAKE_INSTALL_PREFIX="$MONERO_DIR" ../..
|
||||||
|
fi
|
||||||
|
|
||||||
|
## LINUX other (arm7 for example)
|
||||||
elif [ "$platform" == "linux" ]; then
|
elif [ "$platform" == "linux" ]; then
|
||||||
echo "Configuring build for Linux general"
|
echo "Configuring build for Linux general"
|
||||||
cmake -D CMAKE_BUILD_TYPE=$BUILD_TYPE -D STATIC=ON -D BUILD_GUI_DEPS=ON -D CMAKE_INSTALL_PREFIX="$MONERO_DIR" ../..
|
if [ "$STATIC" == true ]; then
|
||||||
|
cmake -D CMAKE_BUILD_TYPE=$CMAKE_BUILD_TYPE -D STATIC=ON -D BUILD_GUI_DEPS=ON -D CMAKE_INSTALL_PREFIX="$MONERO_DIR" ../..
|
||||||
|
else
|
||||||
|
cmake -D CMAKE_BUILD_TYPE=$CMAKE_BUILD_TYPE -D BUILD_GUI_DEPS=ON -D CMAKE_INSTALL_PREFIX="$MONERO_DIR" ../..
|
||||||
|
fi
|
||||||
|
|
||||||
|
## Windows 64
|
||||||
|
## Windows is always static to work outside msys2
|
||||||
elif [ "$platform" == "mingw64" ]; then
|
elif [ "$platform" == "mingw64" ]; then
|
||||||
# Do something under Windows NT platform
|
# Do something under Windows NT platform
|
||||||
echo "Configuring build for MINGW64.."
|
echo "Configuring build for MINGW64.."
|
||||||
BOOST_ROOT=/mingw64/boost
|
BOOST_ROOT=/mingw64/boost
|
||||||
cmake -D CMAKE_BUILD_TYPE=$BUILD_TYPE -D STATIC=ON -D BOOST_ROOT="$BOOST_ROOT" -D ARCH="x86-64" -D BUILD_GUI_DEPS=ON -D INSTALL_VENDORED_LIBUNBOUND=ON -D CMAKE_INSTALL_PREFIX="$MONERO_DIR" -G "MSYS Makefiles" ../..
|
cmake -D CMAKE_BUILD_TYPE=$CMAKE_BUILD_TYPE -D STATIC=ON -D BOOST_ROOT="$BOOST_ROOT" -D ARCH="x86-64" -D BUILD_GUI_DEPS=ON -D INSTALL_VENDORED_LIBUNBOUND=ON -D CMAKE_INSTALL_PREFIX="$MONERO_DIR" -G "MSYS Makefiles" ../..
|
||||||
|
|
||||||
|
## Windows 32
|
||||||
elif [ "$platform" == "mingw32" ]; then
|
elif [ "$platform" == "mingw32" ]; then
|
||||||
# Do something under Windows NT platform
|
# Do something under Windows NT platform
|
||||||
echo "Configuring build for MINGW32.."
|
echo "Configuring build for MINGW32.."
|
||||||
BOOST_ROOT=/mingw32/boost
|
BOOST_ROOT=/mingw32/boost
|
||||||
cmake -D CMAKE_BUILD_TYPE=$BUILD_TYPE -D STATIC=ON -D Boost_DEBUG=ON -D BOOST_ROOT="$BOOST_ROOT" -D ARCH="i686" -D BUILD_64=OFF -D BUILD_GUI_DEPS=ON -D INSTALL_VENDORED_LIBUNBOUND=ON -D CMAKE_INSTALL_PREFIX="$MONERO_DIR" -G "MSYS Makefiles" ../..
|
cmake -D CMAKE_BUILD_TYPE=$CMAKE_BUILD_TYPE -D STATIC=ON -D Boost_DEBUG=ON -D BOOST_ROOT="$BOOST_ROOT" -D ARCH="i686" -D BUILD_64=OFF -D BUILD_GUI_DEPS=ON -D INSTALL_VENDORED_LIBUNBOUND=ON -D CMAKE_INSTALL_PREFIX="$MONERO_DIR" -G "MSYS Makefiles" ../..
|
||||||
make_exec="mingw32-make"
|
make_exec="mingw32-make"
|
||||||
else
|
else
|
||||||
echo "Unsupported platform: $platform"
|
echo "Unsupported platform: $platform"
|
||||||
|
@ -91,7 +137,7 @@ popd
|
||||||
if [ "$platform" != "mingw32" ]; then
|
if [ "$platform" != "mingw32" ]; then
|
||||||
pushd $MONERO_DIR/build/release/src/daemon
|
pushd $MONERO_DIR/build/release/src/daemon
|
||||||
eval make -j$CPU_CORE_COUNT
|
eval make -j$CPU_CORE_COUNT
|
||||||
eval make install -j$CPU_CORE_COUNT
|
eval make install -j$CPU_CORE_COUNT
|
||||||
popd
|
popd
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
|
|
@ -129,7 +129,10 @@ win32 {
|
||||||
}
|
}
|
||||||
|
|
||||||
linux {
|
linux {
|
||||||
LIBS+= -Wl,-Bstatic
|
CONFIG(static) {
|
||||||
|
message("using static libraries")
|
||||||
|
LIBS+= -Wl,-Bstatic
|
||||||
|
}
|
||||||
LIBS+= \
|
LIBS+= \
|
||||||
-lboost_serialization \
|
-lboost_serialization \
|
||||||
-lboost_thread \
|
-lboost_thread \
|
||||||
|
@ -154,6 +157,11 @@ linux {
|
||||||
}
|
}
|
||||||
|
|
||||||
macx {
|
macx {
|
||||||
|
# mixing static and shared libs are not supported on mac
|
||||||
|
# CONFIG(static) {
|
||||||
|
# message("using static libraries")
|
||||||
|
# LIBS+= -Wl,-Bstatic
|
||||||
|
# }
|
||||||
LIBS+= \
|
LIBS+= \
|
||||||
-L/usr/local/lib \
|
-L/usr/local/lib \
|
||||||
-L/usr/local/opt/openssl/lib \
|
-L/usr/local/opt/openssl/lib \
|
||||||
|
|
Loading…
Reference in a new issue