TEMPLATE = app TARGET = gostcoin-qt VERSION = 0.8.5.8 INCLUDEPATH += ../src ../src/json ../src/qt ../i2psam QT += core gui network androidextras greaterThan(QT_MAJOR_VERSION, 4): QT += widgets DEFINES += QT_GUI BOOST_THREAD_USE_LIB BOOST_SPIRIT_THREADSAFE BOOST_NO_CXX11_SCOPED_ENUMS CONFIG += no_include_pwd CONFIG += thread QMAKE_CXXFLAGS=-fstack-protector-strong -DANDROID -fno-builtin-memmove --sysroot=/home/user/SDKS/ANDROID/NDK/android-ndk-r13b/platforms/android-9/arch-arm/ -std=c++11 # for boost 1.37, add -mt to the boost libraries # use: qmake BOOST_LIB_SUFFIX=-mt # for boost thread win32 with _win32 sufix # use: BOOST_THREAD_LIB_SUFFIX=_win32-... # or when linking against a specific BerkelyDB version: BDB_LIB_SUFFIX=-4.8 # Dependency library locations can be customized with: # BOOST_INCLUDE_PATH, BOOST_LIB_PATH, BDB_INCLUDE_PATH, # BDB_LIB_PATH, OPENSSL_INCLUDE_PATH and OPENSSL_LIB_PATH respectively OBJECTS_DIR = build MOC_DIR = build UI_DIR = build USE_IPV6=0 USE_LEVELDB=1 USE_ASM=1 android { message("Using Android settings") # change to your own path, where you will store all needed libraries with 'git clone' commands below. MAIN_PATH = /path/to/libraries # change to your own Android NDK path NDK_PATH = /home/user/SDKS/ANDROID/NDK/android-ndk-r13b # git clone https://github.com/PurpleI2P/MiniUPnP-for-Android-Prebuilt.git # git clone git@github.com:hypnosis-i2p/android-ifaddrs-from-android-source.git #boost 53, 62 are not ok BOOST_PATH = $$MAIN_PATH/take3/boost_1_57_0 #/stage/lib OPENSSL_PATH = $$MAIN_PATH/take3/openssl-1.0.2l #MINIUPNP_PATH = $$MAIN_PATH/MiniUPnP-for-Android-Prebuilt IFADDRS_PATH = $$MAIN_PATH/android-ifaddrs-from-android-source BDB_PATH = $$MAIN_PATH/take3/db-6.0.20/build_unix DEFINES += ANDROID=1 DEFINES += __ANDROID__ CONFIG += mobility MOBILITY = INCLUDEPATH += \ $$NDK_PATH/sources/cxx-stl/gnu-libstdc++/4.9/include \ $$NDK_PATH/sources/cxx-stl/gnu-libstdc++/4.9/libs/armeabi-v7a/include \ $$BOOST_PATH \ $$OPENSSL_PATH/include \ $$IFADDRS_PATH \ $$BDB_PATH \ build # $$NDK_PATH/platforms/android-9/arch-arm/usr/include/ \ # $$NDK_PATH/sources/cxx-stl/stlport/stlport/ -I $NDK_PATH/sources/cxx-stl/system/include/ #\ # $$MINIUPNP_PATH/miniupnp-2.0/include \ DISTFILES += AndroidManifest.xml ANDROID_PACKAGE_SOURCE_DIR = $$PWD/ SOURCES += $$IFADDRS_PATH/ifaddrs.cpp $$IFADDRS_PATH/bionic_netlink.cpp HEADERS += $$IFADDRS_PATH/ifaddrs.h $$IFADDRS_PATH/ErrnoRestorer.h $$IFADDRS_PATH/bionic_netlink.h $$IFADDRS_PATH/bionic_macros.h equals(ANDROID_TARGET_ARCH, armeabi-v7a){ DEFINES += ANDROID_ARM7A # http://stackoverflow.com/a/30235934/529442 # LIBS += -L$$BOOST_PATH/boost_1_53_0/armeabi-v7a/lib \ # -lboost_system-gcc-mt-1_53 -lboost_atomic-gcc-mt-1_53 \ # -lboost_filesystem-gcc-mt-1_53 -lboost_chrono-gcc-mt-1_53 -lboost_thread-gcc-mt-1_53 -lboost_program_options-gcc-mt-1_53 \ # -L$$OPENSSL_PATH/armeabi-v7a/lib/ -lcrypto -lssl #\ # -L$$MINIUPNP_PATH/miniupnp-2.0/armeabi-v7a/lib/ -lminiupnpc BOOST_POSTFIX=-gcc-mt-1_57 LIBS += -L$$BOOST_PATH/stage/lib \ -lboost_atomic$$BOOST_POSTFIX \ -lboost_chrono$$BOOST_POSTFIX \ -lboost_filesystem$$BOOST_POSTFIX \ -lboost_program_options$$BOOST_POSTFIX \ -lboost_system$$BOOST_POSTFIX \ -lboost_thread$$BOOST_POSTFIX \ -L$$OPENSSL_PATH -lcrypto -lssl #\ # -L$$MINIUPNP_PATH/miniupnp-2.0/armeabi-v7a/lib/ -lminiupnpc PRE_TARGETDEPS += $$OPENSSL_PATH/libcrypto.a \ $$OPENSSL_PATH/libssl.a DEPENDPATH += $$OPENSSL_PATH/include # ANDROID_EXTRA_LIBS += $$OPENSSL_PATH/armeabi-v7a/lib/libcrypto_1_0_0.so \ # $$OPENSSL_PATH/armeabi-v7a/lib/libssl_1_0_0.so #\ # $$MINIUPNP_PATH/miniupnp-2.0/armeabi-v7a/lib/libminiupnpc.so } equals(ANDROID_TARGET_ARCH, x86){ error("Android BDB: don't know how to build BDB for Android x86") # http://stackoverflow.com/a/30235934/529442 LIBS += -L$$BOOST_PATH/boost_1_62_0/x86/lib \ -lboost_system-gcc-mt-1_62 -lboost_date_time-gcc-mt-1_62 \ -lboost_filesystem-gcc-mt-1_62 -lboost_program_options-gcc-mt-1_62 \ -L$$OPENSSL_PATH/openssl-1.1.0/x86/lib/ -lcrypto -lssl #\ # -L$$MINIUPNP_PATH/miniupnp-2.0/x86/lib/ -lminiupnpc PRE_TARGETDEPS += $$OPENSSL_PATH/openssl-1.1.0/x86/lib/libcrypto.a \ $$OPENSSL_PATH/openssl-1.1.0/x86/lib/libssl.a DEPENDPATH += $$OPENSSL_PATH/openssl-1.1.0/include ANDROID_EXTRA_LIBS += $$OPENSSL_PATH/openssl-1.1.0/x86/lib/libcrypto_1_0_0.so \ $$OPENSSL_PATH/openssl-1.1.0/x86/lib/libssl_1_0_0.so #\ # $$MINIUPNP_PATH/miniupnp-2.0/x86/lib/libminiupnpc.so } } !win32 { # for extra security against potential buffer overflows: enable GCCs Stack Smashing Protection # QMAKE_CXXFLAGS *= -fstack-protector-all # QMAKE_CFLAGS *= -fstack-protector-all # QMAKE_LFLAGS *= -fstack-protector-all # Exclude on Windows cross compile with MinGW 4.2.x, as it will result in a non-working executable! # This can be enabled for Windows, when we switch to MinGW >= 4.4.x. } # for extra security (see: https://wiki.debian.org/Hardening): this flag is GCC compiler-specific #-D_FORTIFY_SOURCE=2 QMAKE_CXXFLAGS *= -std=c++11 # use: qmake "USE_QRCODE=1" # libqrencode (http://fukuchi.org/works/qrencode/index.en.html) must be installed for support contains(USE_QRCODE, 1) { message(Building with QRCode support) DEFINES += USE_QRCODE LIBS += -lqrencode } # use: qmake "USE_DBUS=1" contains(USE_DBUS, 1) { message(Building with DBUS (Freedesktop notifications) support) DEFINES += USE_DBUS QT += dbus } # use: qmake "USE_IPV6=1" ( enabled by default; default) # or: qmake "USE_IPV6=0" (disabled by default) # or: qmake "USE_IPV6=-" (not supported) contains(USE_IPV6, -) { message(Building without IPv6 support) } else { count(USE_IPV6, 0) { USE_IPV6=1 } DEFINES += USE_IPV6=$$USE_IPV6 } contains(BITCOIN_NEED_QT_PLUGINS, 1) { DEFINES += BITCOIN_NEED_QT_PLUGINS QTPLUGIN += qcncodecs qjpcodecs qtwcodecs qkrcodecs qtaccessiblewidgets } INCLUDEPATH += ../src/leveldb/include ../src/leveldb/helpers LIBS += $$PWD/../src/leveldb/libleveldb.a $$PWD/../src/leveldb/libmemenv.a !win32 { # we use QMAKE_CXXFLAGS_RELEASE even without RELEASE=1 because we use RELEASE to indicate linking preferences not -O preferences !android { genleveldb.commands = echo "QMAKE_CXXFLAGS $$QMAKE_CXXFLAGS" && cd $$PWD/../src/leveldb && TARGET_OS=OS_ANDROID_CROSSCOMPILE CC=$$QMAKE_CC CXX=$$QMAKE_CXX AR=$$NDK_PATH/toolchains/arm-linux-androideabi-4.9/prebuilt/linux-x86_64/bin/arm-linux-androideabi-ar $(MAKE) OPT=\"-I $$NDK_PATH/platforms/android-9/arch-arm/usr/include/ -I $$NDK_PATH/sources/cxx-stl/gnu-libstdc++/4.9/include -I $$NDK_PATH/sources/cxx-stl/gnu-libstdc++/4.9/libs/armeabi-v7a/include/ $$QMAKE_CXXFLAGS \" libleveldb.a libmemenv.a } } genleveldb.target = $$PWD/../src/leveldb/libleveldb.a genleveldb.depends = FORCE PRE_TARGETDEPS += $$PWD/../src/leveldb/libleveldb.a QMAKE_EXTRA_TARGETS += genleveldb # Gross ugly hack that depends on qmake internals, unfortunately there is no other way to do it. QMAKE_CLEAN += $$PWD/../src/leveldb/libleveldb.a; cd $$PWD/../src/leveldb ; $(MAKE) clean # regenerate ../src/build.h #!win32|contains(USE_BUILD_INFO, 1) { # genbuild.depends = FORCE # genbuild.commands = cd $$PWD; /bin/sh ../share/genbuild.sh $$OUT_PWD/build/build.h # genbuild.target = $$OUT_PWD/build/build.h # PRE_TARGETDEPS += $$OUT_PWD/build/build.h # QMAKE_EXTRA_TARGETS += genbuild # DEFINES += HAVE_BUILD_INFO #} QMAKE_CXXFLAGS_WARN_ON = -fdiagnostics-show-option -Wall -Wextra -Wformat -Wformat-security -Wno-unused-parameter -Wstack-protector # Input DEPENDPATH += ../src ../src/json ../src/qt HEADERS += ../src/qt/bitcoingui.h \ ../src/qt/transactiontablemodel.h \ ../src/qt/addresstablemodel.h \ ../src/qt/optionsdialog.h \ ../src/qt/sendcoinsdialog.h \ ../src/qt/coincontroldialog.h \ ../src/qt/coincontroltreewidget.h \ ../src/qt/addressbookpage.h \ ../src/qt/signverifymessagedialog.h \ ../src/qt/aboutdialog.h \ ../src/qt/editaddressdialog.h \ ../src/qt/bitcoinaddressvalidator.h \ ../src/alert.h \ ../src/addrman.h \ ../src/base58.h \ ../src/bignum.h \ ../src/checkpoints.h \ ../src/coincontrol.h \ ../src/compat.h \ ../src/sync.h \ ../src/util.h \ ../src/hash.h \ ../src/uint256.h \ ../src/serialize.h \ ../src/main.h \ ../src/net.h \ ../src/key.h \ ../src/db.h \ ../src/walletdb.h \ ../src/script.h \ ../src/init.h \ ../src/bloom.h \ ../src/mruset.h \ ../src/checkqueue.h \ ../src/json/json_spirit_writer_template.h \ ../src/json/json_spirit_writer.h \ ../src/json/json_spirit_value.h \ ../src/json/json_spirit_utils.h \ ../src/json/json_spirit_stream_reader.h \ ../src/json/json_spirit_reader_template.h \ ../src/json/json_spirit_reader.h \ ../src/json/json_spirit_error_position.h \ ../src/json/json_spirit.h \ ../i2psam/i2psam.h \ ../src/qt/clientmodel.h \ ../src/qt/guiutil.h \ ../src/qt/transactionrecord.h \ ../src/qt/guiconstants.h \ ../src/qt/optionsmodel.h \ ../src/qt/monitoreddatamapper.h \ ../src/qt/transactiondesc.h \ ../src/qt/transactiondescdialog.h \ ../src/qt/bitcoinamountfield.h \ ../src/wallet.h \ ../src/keystore.h \ ../src/qt/transactionfilterproxy.h \ ../src/qt/transactionview.h \ ../src/qt/walletmodel.h \ ../src/qt/walletview.h \ ../src/qt/walletstack.h \ ../src/qt/walletframe.h \ ../src/bitcoinrpc.h \ ../src/qt/overviewpage.h \ ../src/qt/csvmodelwriter.h \ ../src/crypter.h \ ../src/qt/sendcoinsentry.h \ ../src/qt/qvalidatedlineedit.h \ ../src/qt/bitcoinunits.h \ ../src/qt/qvaluecombobox.h \ ../src/qt/askpassphrasedialog.h \ ../src/protocol.h \ ../src/qt/notificator.h \ ../src/qt/paymentserver.h \ ../src/allocators.h \ ../src/ui_interface.h \ ../src/qt/rpcconsole.h \ ../src/i2p.h \ ../src/Gost.h \ ../src/version.h \ ../src/netbase.h \ ../src/clientversion.h \ ../src/txdb.h \ ../src/leveldb.h \ ../src/threadsafety.h \ ../src/limitedmap.h \ ../src/qt/macnotificationhandler.h \ ../src/qt/splashscreen.h \ ../src/qt/showi2paddresses.h \ ../src/qt/i2poptionswidget.h \ ../src/qt/setupdarknet.h SOURCES += ../src/qt/gostcoin.cpp \ ../src/qt/bitcoingui.cpp \ ../src/qt/transactiontablemodel.cpp \ ../src/qt/addresstablemodel.cpp \ ../src/qt/optionsdialog.cpp \ ../src/qt/sendcoinsdialog.cpp \ ../src/qt/coincontroldialog.cpp \ ../src/qt/coincontroltreewidget.cpp \ ../src/qt/addressbookpage.cpp \ ../src/qt/signverifymessagedialog.cpp \ ../src/qt/aboutdialog.cpp \ ../src/qt/editaddressdialog.cpp \ ../src/qt/bitcoinaddressvalidator.cpp \ ../src/alert.cpp \ ../src/version.cpp \ ../src/sync.cpp \ ../src/util.cpp \ ../src/hash.cpp \ ../src/netbase.cpp \ ../src/key.cpp \ ../src/script.cpp \ ../src/main.cpp \ ../src/init.cpp \ ../src/net.cpp \ ../src/bloom.cpp \ ../src/checkpoints.cpp \ ../src/addrman.cpp \ ../src/db.cpp \ ../src/walletdb.cpp \ ../src/qt/clientmodel.cpp \ ../src/qt/guiutil.cpp \ ../src/qt/transactionrecord.cpp \ ../src/qt/optionsmodel.cpp \ ../src/qt/monitoreddatamapper.cpp \ ../src/qt/transactiondesc.cpp \ ../src/qt/transactiondescdialog.cpp \ ../src/qt/bitcoinstrings.cpp \ ../src/qt/bitcoinamountfield.cpp \ ../src/wallet.cpp \ ../src/keystore.cpp \ ../src/qt/transactionfilterproxy.cpp \ ../src/qt/transactionview.cpp \ ../src/qt/walletmodel.cpp \ ../src/qt/walletview.cpp \ ../src/qt/walletstack.cpp \ ../src/qt/walletframe.cpp \ ../src/bitcoinrpc.cpp \ ../src/rpcdump.cpp \ ../src/rpcnet.cpp \ ../src/rpcmining.cpp \ ../src/rpcwallet.cpp \ ../src/rpcblockchain.cpp \ ../src/rpcrawtransaction.cpp \ ../src/qt/overviewpage.cpp \ ../src/qt/csvmodelwriter.cpp \ ../src/crypter.cpp \ ../src/qt/sendcoinsentry.cpp \ ../src/qt/qvalidatedlineedit.cpp \ ../src/qt/bitcoinunits.cpp \ ../src/qt/qvaluecombobox.cpp \ ../src/qt/askpassphrasedialog.cpp \ ../src/protocol.cpp \ ../src/qt/notificator.cpp \ ../src/qt/paymentserver.cpp \ ../src/qt/rpcconsole.cpp \ ../src/i2p.cpp \ ../src/Gost.cpp \ ../src/noui.cpp \ ../src/leveldb.cpp \ ../src/txdb.cpp \ ../src/qt/splashscreen.cpp \ ../src/qt/showi2paddresses.cpp \ ../src/qt/i2poptionswidget.cpp \ ../i2psam/i2psam.cpp \ ../src/qt/setupdarknet.cpp RESOURCES += ../src/qt/bitcoin.qrc FORMS += ../src/qt/forms/sendcoinsdialog.ui \ ../src/qt/forms/coincontroldialog.ui \ ../src/qt/forms/addressbookpage.ui \ ../src/qt/forms/signverifymessagedialog.ui \ ../src/qt/forms/aboutdialog.ui \ ../src/qt/forms/editaddressdialog.ui \ ../src/qt/forms/transactiondescdialog.ui \ ../src/qt/forms/overviewpage.ui \ ../src/qt/forms/sendcoinsentry.ui \ ../src/qt/forms/askpassphrasedialog.ui \ ../src/qt/forms/rpcconsole.ui \ ../src/qt/forms/optionsdialog.ui \ ../src/qt/forms/showi2paddresses.ui \ ../src/qt/forms/i2poptionswidget.ui contains(USE_QRCODE, 1) { HEADERS += ../src/qt/qrcodedialog.h SOURCES += ../src/qt/qrcodedialog.cpp FORMS += ../src/qt/forms/qrcodedialog.ui } contains(BITCOIN_QT_TEST, 1) { SOURCES += ../src/qt/test/test_main.cpp \ ../src/qt/test/uritests.cpp HEADERS += ../src/qt/test/uritests.h DEPENDPATH += ../src/qt/test QT += testlib TARGET = anoncoin-qt_test DEFINES += BITCOIN_QT_TEST macx: CONFIG -= app_bundle } contains(USE_SSE2, 1) { DEFINES += USE_SSE2 gccsse2.input = SOURCES_SSE2 gccsse2.output = $$PWD/build/${QMAKE_FILE_BASE}.o gccsse2.commands = $(CXX) -c $(CXXFLAGS) $(INCPATH) -o ${QMAKE_FILE_OUT} ${QMAKE_FILE_NAME} -msse2 -mstackrealign QMAKE_EXTRA_COMPILERS += gccsse2 #SOURCES_SSE2 += ../src/scrypt-sse2.cpp } greaterThan(QT_MAJOR_VERSION, 4): { } else { CODECFORTR = UTF-8 } # for lrelease/lupdate # also add new translations to ../src/qt/bitcoin.qrc under translations/ TRANSLATIONS = $$files(../src/qt/locale/bitcoin_*.ts) isEmpty(QMAKE_LRELEASE) { QMAKE_LRELEASE = $$[QT_INSTALL_BINS]/lrelease } isEmpty(QM_DIR):QM_DIR = $$PWD/../src/qt/locale # automatically build translations, so they can be included in resource file TSQM.name = lrelease ${QMAKE_FILE_IN} TSQM.input = TRANSLATIONS TSQM.output = $$QM_DIR/${QMAKE_FILE_BASE}.qm TSQM.commands = $$QMAKE_LRELEASE ${QMAKE_FILE_IN} -qm ${QMAKE_FILE_OUT} TSQM.CONFIG = no_link QMAKE_EXTRA_COMPILERS += TSQM # "Other files" to show in Qt Creator OTHER_FILES += README.md \ doc/*.rst \ doc/*.txt \ doc/*.md \ ../src/qt/res/bitcoin-qt.rc \ ../src/test/*.cpp \ ../src/test/*.h \ ../src/qt/test/*.cpp \ ../src/qt/test/*.h # platform specific defaults, if not overridden on command line isEmpty(BOOST_THREAD_LIB_SUFFIX) { BOOST_THREAD_LIB_SUFFIX = $$BOOST_LIB_SUFFIX } isEmpty(BDB_LIB_SUFFIX) { android:BDB_LIB_SUFFIX = -6.0 } !win32:!macx { android { #LIBS += $$BDB_PATH/libdb.a $$BDB_PATH/libdb_cxx.a LIBS += -L$$BDB_PATH } # _FILE_OFFSET_BITS=64 lets 32-bit fopen transparently support large files. DEFINES += _FILE_OFFSET_BITS=64 } # Set libraries and includes at end, to use platform-defined defaults if not overridden INCLUDEPATH += $$BOOST_INCLUDE_PATH $$BDB_INCLUDE_PATH $$OPENSSL_INCLUDE_PATH $$QRENCODE_INCLUDE_PATH LIBS += $$join(BOOST_LIB_PATH,,-L,) $$join(BDB_LIB_PATH,,-L,) $$join(OPENSSL_LIB_PATH,,-L,) $$join(QRENCODE_LIB_PATH,,-L,) LIBS += -lssl -lcrypto LIBS += -lz !win32:LIBS += -ldl android { CXXFLAGS += -O0 -g # LIBS += $$NDK_PATH/sources/cxx-stl/stlport/libs/armeabi-v7a/libstlport_static.a LIBS +=$$BDB_PATH/libdb_cxx.a $$BDB_PATH/libdb.a } system($$QMAKE_LRELEASE -silent $$TRANSLATIONS) android { DISTFILES += \ AndroidManifest.xml \ res/values/libs.xml } DISTFILES += \ ../../../S2_ATHOME/git_gostcoin/gostcoin/android/AndroidManifest.xml \ ../../../S2_ATHOME/git_gostcoin/gostcoin/android/res/values/libs.xml \ ../../../S2_ATHOME/git_gostcoin/gostcoin/android/build.gradle \ ../docs/gost_android_take3.txt