123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436 |
- # ECOin - Copyright (c) - 2014/2024 - GPLv3 - epsylon@riseup.net (https://03c8.net)
- TEMPLATE = app
- TARGET = ecoin-qt
- VERSION = 0.0.4
- INCLUDEPATH += src src/json src/qt
- DEFINES += QT_GUI BOOST_THREAD_USE_LIB BOOST_SPIRIT_THREADSAFE
- CONFIG += no_include_pwd
- CONFIG += thread
- OBJECTS_DIR = build
- MOC_DIR = build
- UI_DIR = build
- QT += core gui widgets
- QT_NO_DEFAULT_CODEC = 1
- QMAKE_CXXFLAGS_WARN_ON = -Wno-unused-parameter -Wno-deprecated-declarations -Wno-stringop-overread -Wno-return-type
- # Disable stack-protector warnings
- QMAKE_CXXFLAGS += -Wno-stack-protector
- # Extra security measures for Windows
- win32:QMAKE_LFLAGS += -Wl,--dynamicbase -Wl,--nxcompat
- win32:QMAKE_LFLAGS += -static-libgcc -static-libstdc++
- # use: qmake "RELEASE=1"
- contains(RELEASE, 1) {
- # Mac: compile for maximum compatibility (10.5, 32-bit)
- macx:QMAKE_CXXFLAGS += -mmacosx-version-min=10.5 -arch x86_64 -isysroot /Developer/SDKs/MacOSX10.5.sdk
- !windows:!macx {
- # Linux: static link
- LIBS += -Wl,-Bstatic
- }
- }
- !win32 {
- # for extra security against potential buffer overflows: enable GCCs Stack Smashing Protection
- QMAKE_CXXFLAGS *= -fstack-protector-all --param ssp-buffer-size=1
- QMAKE_LFLAGS *= -fstack-protector-all --param ssp-buffer-size=1
- # We need to exclude this for 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 on Windows: enable ASLR and DEP via GCC linker flags
- win32:QMAKE_LFLAGS *= -Wl,--dynamicbase -Wl,--nxcompat
- win32:QMAKE_LFLAGS += -static-libgcc -static-libstdc++
- # 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_UPNP=1" ( enabled by default; default)
- # or: qmake "USE_UPNP=0" (disabled by default)
- # or: qmake "USE_UPNP=-" (not supported)
- # miniupnpc (http://miniupnp.free.fr/files/) must be installed for support
- contains(USE_UPNP, -) {
- message(Building without UPNP support)
- } else {
- message(Building with UPNP support)
- count(USE_UPNP, 0) {
- USE_UPNP=1
- }
- DEFINES += USE_UPNP=$$USE_UPNP STATICLIB
- INCLUDEPATH += $$MINIUPNPC_INCLUDE_PATH
- LIBS += $$join(MINIUPNPC_LIB_PATH,,-L,) -lminiupnpc
- win32:LIBS += -liphlpapi
- }
- # 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(ECOIN_NEED_QT_PLUGINS, 1) {
- DEFINES += ECOIN_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
- SOURCES += src/txdb-leveldb.cpp
- !win32 {
- # we use QMAKE_CXXFLAGS_RELEASE even without RELEASE=1 because we use RELEASE to indicate linking preferences not -O preferences
- genleveldb.commands = cd $$PWD/src/leveldb && CC=$$QMAKE_CC CXX=$$QMAKE_CXX $(MAKE) OPT=\"$$QMAKE_CXXFLAGS $$QMAKE_CXXFLAGS_RELEASE\" libleveldb.a libmemenv.a
- } else {
- # make an educated guess about what the ranlib command is called
- isEmpty(QMAKE_RANLIB) {
- QMAKE_RANLIB = $$replace(QMAKE_STRIP, strip, ranlib)
- }
- LIBS += -lshlwapi
- genleveldb.commands = cd $$PWD/src/leveldb && CC=$$QMAKE_CC CXX=$$QMAKE_CXX TARGET_OS=OS_WINDOWS_CROSSCOMPILE $(MAKE) OPT=\"$$QMAKE_CXXFLAGS $$QMAKE_CXXFLAGS_RELEASE\" libleveldb.a libmemenv.a && $$QMAKE_RANLIB $$PWD/src/leveldb/libleveldb.a && $$QMAKE_RANLIB $$PWD/src/leveldb/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
- !windows|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
- }
- contains(USE_O3, 1) {
- message(Building O3 optimization flag)
- QMAKE_CXXFLAGS_RELEASE -= -O2
- QMAKE_CFLAGS_RELEASE -= -O2
- QMAKE_CXXFLAGS += -O3
- QMAKE_CFLAGS += -O3
- }
- *-g++-32 {
- message("32 platform, adding -msse2 flag")
- QMAKE_CXXFLAGS += -msse2
- QMAKE_CFLAGS += -msse2
- }
- # Input
- DEPENDPATH += src src/json src/qt
- HEADERS += src/qt/ecoingui.h \
- src/qt/transactiontablemodel.h \
- src/qt/addresstablemodel.h \
- src/qt/optionsdialog.h \
- src/qt/coincontroldialog.h \
- src/qt/coincontroltreewidget.h \
- src/qt/sendcoinsdialog.h \
- src/qt/addressbookpage.h \
- src/qt/signverifymessagedialog.h \
- src/qt/aboutdialog.h \
- src/qt/editaddressdialog.h \
- src/qt/ecoinaddressvalidator.h \
- src/alert.h \
- src/addrman.h \
- src/base58.h \
- src/bignum.h \
- src/checkpoints.h \
- src/compat.h \
- src/coincontrol.h \
- src/sync.h \
- src/util.h \
- src/uint256.h \
- src/kernel.h \
- src/scrypt.h \
- src/pbkdf2.h \
- src/zerocoin/Accumulator.h \
- src/zerocoin/AccumulatorProofOfKnowledge.h \
- src/zerocoin/Coin.h \
- src/zerocoin/CoinSpend.h \
- src/zerocoin/Commitment.h \
- src/zerocoin/ParamGeneration.h \
- src/zerocoin/Params.h \
- src/zerocoin/SerialNumberSignatureOfKnowledge.h \
- src/zerocoin/SpendMetaData.h \
- src/zerocoin/ZeroTest.h \
- src/zerocoin/Zerocoin.h \
- src/serialize.h \
- src/strlcpy.h \
- src/main.h \
- src/miner.h \
- src/net.h \
- src/key.h \
- src/db.h \
- src/txdb.h \
- src/walletdb.h \
- src/script.h \
- src/init.h \
- src/irc.h \
- src/mruset.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 \
- 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/ecoinamountfield.h \
- src/wallet.h \
- src/keystore.h \
- src/qt/transactionfilterproxy.h \
- src/qt/transactionview.h \
- src/qt/walletmodel.h \
- src/ecoinrpc.h \
- src/qt/overviewpage.h \
- src/qt/csvmodelwriter.h \
- src/crypter.h \
- src/qt/sendcoinsentry.h \
- src/qt/qvalidatedlineedit.h \
- src/qt/ecoinunits.h \
- src/qt/qvaluecombobox.h \
- src/qt/askpassphrasedialog.h \
- src/protocol.h \
- src/qt/notificator.h \
- src/qt/qtipcserver.h \
- src/allocators.h \
- src/ui_interface.h \
- src/qt/rpcconsole.h \
- src/version.h \
- src/netbase.h \
- src/clientversion.h
- SOURCES += src/qt/ecoin.cpp src/qt/ecoingui.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/ecoinaddressvalidator.cpp \
- src/alert.cpp \
- src/version.cpp \
- src/sync.cpp \
- src/util.cpp \
- src/netbase.cpp \
- src/key.cpp \
- src/script.cpp \
- src/main.cpp \
- src/miner.cpp \
- src/init.cpp \
- src/net.cpp \
- src/irc.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/ecoinstrings.cpp \
- src/qt/ecoinamountfield.cpp \
- src/wallet.cpp \
- src/keystore.cpp \
- src/qt/transactionfilterproxy.cpp \
- src/qt/transactionview.cpp \
- src/qt/walletmodel.cpp \
- src/ecoinrpc.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/ecoinunits.cpp \
- src/qt/qvaluecombobox.cpp \
- src/qt/askpassphrasedialog.cpp \
- src/protocol.cpp \
- src/qt/notificator.cpp \
- src/qt/qtipcserver.cpp \
- src/qt/rpcconsole.cpp \
- src/noui.cpp \
- src/kernel.cpp \
- src/scrypt-arm.S \
- src/scrypt-x86.S \
- src/scrypt-x86_64.S \
- src/scrypt.cpp \
- src/pbkdf2.cpp \
- src/zerocoin/Accumulator.cpp \
- src/zerocoin/AccumulatorProofOfKnowledge.cpp \
- src/zerocoin/Coin.cpp \
- src/zerocoin/CoinSpend.cpp \
- src/zerocoin/Commitment.cpp \
- src/zerocoin/ParamGeneration.cpp \
- src/zerocoin/Params.cpp \
- src/zerocoin/SerialNumberSignatureOfKnowledge.cpp \
- src/zerocoin/SpendMetaData.cpp \
- src/zerocoin/ZeroTest.cpp
- RESOURCES += \
- src/qt/ecoin.qrc
- FORMS += \
- src/qt/forms/coincontroldialog.ui \
- src/qt/forms/sendcoinsdialog.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
- contains(USE_QRCODE, 1) {
- HEADERS += src/qt/qrcodedialog.h
- SOURCES += src/qt/qrcodedialog.cpp
- FORMS += src/qt/forms/qrcodedialog.ui
- }
- CODECFORTR = UTF-8
- # for lrelease/lupdate
- # also add new translations to src/qt/ecoin.qrc under translations/
- TRANSLATIONS = $$files(src/qt/locale/ecoin_*.ts)
- isEmpty(QMAKE_LRELEASE) {
- win32:QMAKE_LRELEASE = $$[QT_INSTALL_BINS]\\lrelease.exe
- else: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 += \
- doc/*.rst doc/*.txt doc/README README.md res/ecoin-qt.rc
- # platform specific defaults, if not overridden on command line
- isEmpty(BOOST_LIB_SUFFIX) {
- macx:BOOST_LIB_SUFFIX = -mt
- windows:BOOST_LIB_SUFFIX = -mgw44-mt-1_53
- }
- isEmpty(BOOST_THREAD_LIB_SUFFIX) {
- BOOST_THREAD_LIB_SUFFIX = $$BOOST_LIB_SUFFIX
- }
- isEmpty(BDB_LIB_PATH) {
- macx:BDB_LIB_PATH = /opt/local/lib/db48
- }
- isEmpty(BDB_LIB_SUFFIX) {
- macx:BDB_LIB_SUFFIX = -4.8
- }
- isEmpty(BDB_INCLUDE_PATH) {
- macx:BDB_INCLUDE_PATH = /opt/local/include/db48
- }
- isEmpty(BOOST_LIB_PATH) {
- macx:BOOST_LIB_PATH = /opt/local/lib
- }
- isEmpty(BOOST_INCLUDE_PATH) {
- macx:BOOST_INCLUDE_PATH = /opt/local/include
- }
- windows:DEFINES += WIN32
- windows:RC_FILE = src/qt/res/ecoin-qt.rc
- windows:!contains(MINGW_THREAD_BUGFIX, 0) {
- # At least qmake's win32-g++-cross profile is missing the -lmingwthrd
- # thread-safety flag. GCC has -mthreads to enable this, but it doesn't
- # work with static linking. -lmingwthrd must come BEFORE -lmingw, so
- # it is prepended to QMAKE_LIBS_QT_ENTRY.
- # It can be turned off with MINGW_THREAD_BUGFIX=0, just in case it causes
- # any problems on some untested qmake profile now or in the future.
- DEFINES += _MT BOOST_THREAD_PROVIDES_GENERIC_SHARED_MUTEX_ON_WIN
- QMAKE_LIBS_QT_ENTRY = -lmingwthrd $$QMAKE_LIBS_QT_ENTRY
- }
- !windows:!macx {
- DEFINES += LINUX
- LIBS += -lrt
- }
- macx:HEADERS += src/qt/macdockiconhandler.h
- macx:OBJECTIVE_SOURCES += src/qt/macdockiconhandler.mm
- macx:LIBS += -framework Foundation -framework ApplicationServices -framework AppKit
- macx:DEFINES += MAC_OSX MSG_NOSIGNAL=0
- macx:ICON = src/qt/res/icons/ecoin.icns
- macx:TARGET = "Ecoin-Qt"
- macx:QMAKE_CFLAGS_THREAD += -pthread
- macx:QMAKE_LFLAGS_THREAD += -pthread
- macx:QMAKE_CXXFLAGS_THREAD += -pthread
- # 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 -ldb_cxx$$BDB_LIB_SUFFIX
- # -lgdi32 has to happen after -lcrypto (see #681)
- windows:LIBS += -lws2_32 -lshlwapi -lmswsock -lole32 -loleaut32 -luuid -lgdi32
- LIBS += -lboost_system$$BOOST_LIB_SUFFIX -lboost_filesystem$$BOOST_LIB_SUFFIX -lboost_program_options$$BOOST_LIB_SUFFIX -lboost_thread$$BOOST_THREAD_LIB_SUFFIX
- windows:LIBS += -lboost_chrono$$BOOST_LIB_SUFFIX
- contains(RELEASE, 1) {
- !windows:!macx {
- # Linux: turn dynamic linking back on for c/c++ runtime libraries
- LIBS += -Wl,-Bdynamic
- }
- }
- system($$QMAKE_LRELEASE -silent $$_PRO_FILE_)
|