#!/bin/bash MONERO_URL=https://github.com/monero-project/monero.git MONERO_BRANCH=master pushd $(pwd) ROOT_DIR="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )" source $ROOT_DIR/utils.sh INSTALL_DIR=$ROOT_DIR/wallet MONERO_DIR=$ROOT_DIR/monero BUILD_LIBWALLET=false # init and update monero submodule if [ ! -d $MONERO_DIR/src ]; then git submodule init monero fi git submodule update --remote git -C $MONERO_DIR fetch git -C $MONERO_DIR checkout v0.16.0.3 # get monero core tag pushd $MONERO_DIR get_tag popd # create local monero branch git -C $MONERO_DIR checkout -B $VERSIONTAG # Merge monero PR dependencies # Workaround for git username requirements # Save current user settings and revert back when we are done with merging PR's OLD_GIT_USER=$(git -C $MONERO_DIR config --local user.name) OLD_GIT_EMAIL=$(git -C $MONERO_DIR config --local user.email) git -C $MONERO_DIR config user.name "Monero GUI" git -C $MONERO_DIR config user.email "gui@monero.local" # check for PR requirements in most recent commit message (i.e requires #xxxx) for PR in $(git log --format=%B -n 1 | grep -io "requires #[0-9]*" | sed 's/[^0-9]*//g'); do echo "Merging monero push request #$PR" # fetch pull request and merge git -C $MONERO_DIR fetch origin pull/$PR/head:PR-$PR git -C $MONERO_DIR merge --quiet PR-$PR -m "Merge monero PR #$PR" BUILD_LIBWALLET=true done # revert back to old git config $(git -C $MONERO_DIR config user.name "$OLD_GIT_USER") $(git -C $MONERO_DIR config user.email "$OLD_GIT_EMAIL") git -C $MONERO_DIR submodule init git -C $MONERO_DIR submodule update # Build libwallet if it doesnt exist if [ ! -f $MONERO_DIR/lib/libwallet_merged.a ]; then echo "libwallet_merged.a not found - Building libwallet" BUILD_LIBWALLET=true # Build libwallet if no previous version file exists elif [ ! -f $MONERO_DIR/version.sh ]; then echo "monero/version.h not found - Building libwallet" BUILD_LIBWALLET=true ## Compare previously built version with submodule + merged PR's version. else source $MONERO_DIR/version.sh # compare submodule version with latest build pushd "$MONERO_DIR" get_tag popd echo "latest libwallet version: $GUI_MONERO_VERSION" echo "Installed libwallet version: $VERSIONTAG" # check if recent if [ "$VERSIONTAG" != "$GUI_MONERO_VERSION" ]; then echo "Building new libwallet version $GUI_MONERO_VERSION" BUILD_LIBWALLET=true else echo "latest libwallet ($GUI_MONERO_VERSION) is already built. Remove monero/lib/libwallet_merged.a to force rebuild" fi fi if [ "$BUILD_LIBWALLET" != true ]; then exit 0 fi echo "GUI_MONERO_VERSION=\"$VERSIONTAG\"" > $MONERO_DIR/version.sh ## Continue building libwallet # default build type BUILD_TYPE=$1 if [ -z $BUILD_TYPE ]; then BUILD_TYPE=release fi BUILD_TREZOR_FLAGS=" -DUSE_DEVICE_TREZOR=ON" if [ "$BUILD_TREZOR" == false ]; then BUILD_TREZOR_FLAGS=" -DUSE_DEVICE_TREZOR=OFF" fi BUILD_TREZOR_FLAGS=" -DUSE_DEVICE_TREZOR_UDP_RELEASE=ON ${BUILD_TREZOR_FLAGS}" STATIC=false ANDROID=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" == "release-android" ]; then echo "Building libwallet release-static for ANDROID" CMAKE_BUILD_TYPE=Release STATIC=true ANDROID=true elif [ "$BUILD_TYPE" == "debug-android" ]; then echo "Building libwallet debug-static for ANDROID" CMAKE_BUILD_TYPE=Debug STATIC=true ANDROID=true elif [ "$BUILD_TYPE" == "debug" ]; then echo "Building libwallet debug" CMAKE_BUILD_TYPE=Debug STATIC=true else echo "Valid build types are release, release-static, release-android, debug-android and debug" exit 1; fi echo "cleaning up existing monero build dir, libs and includes" rm -fr $MONERO_DIR/build rm -fr $MONERO_DIR/lib rm -fr $MONERO_DIR/include rm -fr $MONERO_DIR/bin mkdir -p $MONERO_DIR/build/$BUILD_TYPE pushd $MONERO_DIR/build/$BUILD_TYPE # reusing function from "utils.sh" platform=$(get_platform) # default make executable make_exec="make" if [ -z "$ARCH" ]; then ARCH="native" if [ "$platform" == "darwin" ]; then if [ "$STATIC" == true ]; then ARCH="x86-64" fi elif [ "$platform" == "linux64" ]; then if [ "$ANDROID" == true ]; then ARCH="armv7-a" elif [ "$STATIC" == true ]; then ARCH="x86-64" fi elif [ "$platform" == "linux32" ]; then if [ "$STATIC" == true ]; then ARCH="i686" fi elif [ "$platform" == "linuxarmv7" ]; then ARCH="armv7-a" elif [ "$platform" == "mingw32" ]; then ARCH="i686" elif [ "$platform" == "mingw64" ]; then ARCH="x86-64" fi fi echo "Building for ARCH=$ARCH" ## OS X if [ "$platform" == "darwin" ]; then echo "Configuring build for MacOS.." if [ "$STATIC" == true ]; then cmake -D CMAKE_BUILD_TYPE=$CMAKE_BUILD_TYPE -D STATIC=ON -D ARCH="$ARCH" -D BUILD_64=ON -D BUILD_TAG="mac-x64" -D BUILD_GUI_DEPS=ON -D INSTALL_VENDORED_LIBUNBOUND=ON $BUILD_TREZOR_FLAGS -D CMAKE_INSTALL_PREFIX="$MONERO_DIR" ../.. else cmake -D CMAKE_BUILD_TYPE=$CMAKE_BUILD_TYPE -D ARCH="$ARCH" -D BUILD_TAG="mac-x64" -D BUILD_GUI_DEPS=ON -D INSTALL_VENDORED_LIBUNBOUND=ON $BUILD_TREZOR_FLAGS -D CMAKE_INSTALL_PREFIX="$MONERO_DIR" ../.. fi ## LINUX 64 elif [ "$platform" == "linux64" ]; then echo "Configuring build for Linux x64" if [ "$ANDROID" == true ]; then echo "Configuring build for Android on Linux host" cmake -D CMAKE_BUILD_TYPE=$CMAKE_BUILD_TYPE -D STATIC=ON -D ARCH="$ARCH" -D ANDROID=true -D BUILD_GUI_DEPS=ON -D USE_LTO=OFF -D INSTALL_VENDORED_LIBUNBOUND=ON $BUILD_TREZOR_FLAGS -D CMAKE_INSTALL_PREFIX="$MONERO_DIR" ../.. elif [ "$STATIC" == true ]; then cmake -D CMAKE_BUILD_TYPE=$CMAKE_BUILD_TYPE -D STATIC=ON -D ARCH="$ARCH" -D BUILD_64=ON -D BUILD_TAG="linux-x64" -D BUILD_GUI_DEPS=ON -D INSTALL_VENDORED_LIBUNBOUND=ON $BUILD_TREZOR_FLAGS -D CMAKE_INSTALL_PREFIX="$MONERO_DIR" ../.. else cmake -D CMAKE_BUILD_TYPE=$CMAKE_BUILD_TYPE -D ARCH="$ARCH" -D BUILD_TAG="linux-x64" -D BUILD_GUI_DEPS=ON $BUILD_TREZOR_FLAGS -D CMAKE_INSTALL_PREFIX="$MONERO_DIR" ../.. fi ## LINUX 32 elif [ "$platform" == "linux32" ]; then echo "Configuring build for Linux i686" if [ "$STATIC" == true ]; then cmake -D CMAKE_BUILD_TYPE=$CMAKE_BUILD_TYPE -D STATIC=ON -D ARCH="$ARCH" -D BUILD_64=OFF -D BUILD_GUI_DEPS=ON -D INSTALL_VENDORED_LIBUNBOUND=ON $BUILD_TREZOR_FLAGS -D CMAKE_INSTALL_PREFIX="$MONERO_DIR" ../.. else cmake -D CMAKE_BUILD_TYPE=$CMAKE_BUILD_TYPE -D ARCH="$ARCH" -D BUILD_GUI_DEPS=ON $BUILD_TREZOR_FLAGS -D CMAKE_INSTALL_PREFIX="$MONERO_DIR" ../.. fi ## LINUX ARMv7 elif [ "$platform" == "linuxarmv7" ]; then echo "Configuring build for Linux armv7" if [ "$STATIC" == true ]; then cmake -D BUILD_TESTS=OFF -D ARCH="$ARCH" -D STATIC=ON -D BUILD_64=OFF -D BUILD_GUI_DEPS=ON $BUILD_TREZOR_FLAGS -D CMAKE_INSTALL_PREFIX="$MONERO_DIR" ../.. else cmake -D BUILD_TESTS=OFF -D ARCH="$ARCH" -D -D BUILD_64=OFF -D BUILD_GUI_DEPS=ON $BUILD_TREZOR_FLAGS -D CMAKE_INSTALL_PREFIX="$MONERO_DIR" ../.. fi ## LINUX other elif [ "$platform" == "linux" ]; then echo "Configuring build for Linux general" if [ "$STATIC" == true ]; then cmake -D CMAKE_BUILD_TYPE=$CMAKE_BUILD_TYPE -D STATIC=ON -D ARCH="$ARCH" -D BUILD_GUI_DEPS=ON -D INSTALL_VENDORED_LIBUNBOUND=ON $BUILD_TREZOR_FLAGS -D CMAKE_INSTALL_PREFIX="$MONERO_DIR" ../.. else cmake -D CMAKE_BUILD_TYPE=$CMAKE_BUILD_TYPE -D ARCH="$ARCH" -D BUILD_GUI_DEPS=ON $BUILD_TREZOR_FLAGS -D CMAKE_INSTALL_PREFIX="$MONERO_DIR" ../.. fi ## Windows 64 ## Windows is always static to work outside msys2 elif [ "$platform" == "mingw64" ]; then # Do something under Windows NT platform echo "Configuring build for MINGW64.." BOOST_ROOT=/mingw64/boost cmake -D CMAKE_BUILD_TYPE=$CMAKE_BUILD_TYPE -D STATIC=ON -D BOOST_ROOT="$BOOST_ROOT" -D ARCH="$ARCH" -D BUILD_TAG="win-x64" -D BUILD_GUI_DEPS=ON -D INSTALL_VENDORED_LIBUNBOUND=ON $BUILD_TREZOR_FLAGS -D CMAKE_INSTALL_PREFIX="$MONERO_DIR" -G "MSYS Makefiles" -D CMAKE_TOOLCHAIN_FILE=../../cmake/64-bit-toolchain.cmake -D MSYS2_FOLDER=$(cd $MINGW_PREFIX/.. && pwd -W) ../.. ## Windows 32 elif [ "$platform" == "mingw32" ]; then # Do something under Windows NT platform echo "Configuring build for MINGW32.." BOOST_ROOT=/mingw32/boost cmake -D CMAKE_BUILD_TYPE=$CMAKE_BUILD_TYPE -D STATIC=ON -D Boost_DEBUG=ON -D BOOST_ROOT="$BOOST_ROOT" -D ARCH="$ARCH" -D BUILD_64=OFF -D BUILD_GUI_DEPS=ON -D INSTALL_VENDORED_LIBUNBOUND=ON $BUILD_TREZOR_FLAGS -D CMAKE_INSTALL_PREFIX="$MONERO_DIR" -G "MSYS Makefiles" -D CMAKE_TOOLCHAIN_FILE=../../cmake/32-bit-toolchain.cmake -D MSYS2_FOLDER=$(cd $MINGW_PREFIX/.. && pwd -W) ../.. make_exec="mingw32-make" else echo "Unknown platform, configuring general build" if [ "$STATIC" == true ]; then cmake -D CMAKE_BUILD_TYPE=$CMAKE_BUILD_TYPE -D STATIC=ON -D ARCH="$ARCH" -D BUILD_GUI_DEPS=ON $BUILD_TREZOR_FLAGS -D CMAKE_INSTALL_PREFIX="$MONERO_DIR" ../.. else cmake -D CMAKE_BUILD_TYPE=$CMAKE_BUILD_TYPE -D ARCH="$ARCH" -D BUILD_GUI_DEPS=ON $BUILD_TREZOR_FLAGS -D CMAKE_INSTALL_PREFIX="$MONERO_DIR" ../.. fi fi # set CPU core count # thanks to SO: http://stackoverflow.com/a/20283965/4118915 if test -z "$CPU_CORE_COUNT"; then CPU_CORE_COUNT=$(grep -c ^processor /proc/cpuinfo 2>/dev/null || sysctl -n hw.ncpu) fi # Build libwallet_merged pushd $MONERO_DIR/build/$BUILD_TYPE/src/wallet eval $make_exec version -C ../.. eval $make_exec -j$CPU_CORE_COUNT eval $make_exec install -j$CPU_CORE_COUNT popd # Build monerod # win32 need to build daemon manually with msys2 toolchain if [ "$platform" != "mingw32" ] && [ "$ANDROID" != true ]; then pushd $MONERO_DIR/build/$BUILD_TYPE/src/daemon eval make -j$CPU_CORE_COUNT eval make install -j$CPU_CORE_COUNT popd fi # build install epee eval make -C $MONERO_DIR/build/$BUILD_TYPE/contrib/epee all install # install easylogging eval make -C $MONERO_DIR/build/$BUILD_TYPE/external/easylogging++ all install # install lmdb eval make -C $MONERO_DIR/build/$BUILD_TYPE/external/db_drivers/liblmdb all install # Install libunbound if [ -d $MONERO_DIR/build/$BUILD_TYPE/external/unbound ]; then echo "Installing libunbound..." pushd $MONERO_DIR/build/$BUILD_TYPE/external/unbound # no need to make, it was already built as dependency for libwallet # make -j$CPU_CORE_COUNT $make_exec install -j$CPU_CORE_COUNT popd fi # install randomx eval make -C $MONERO_DIR/build/$BUILD_TYPE/external/randomx all install popd