X-Git-Url: https://git.novaco.in/?a=blobdiff_plain;f=novacoin-qt.pro;h=9513cd35604451a5141957edff8e3bdc011f7c89;hb=83b83771a62d81e0d4d27d540d816a9e102ffa9f;hp=6e699a89ef29ce0304ea49f8b52cd42a49d8deec;hpb=fc1120071f80e8c4c15befc2f0579a6b9f790daa;p=novacoin.git diff --git a/novacoin-qt.pro b/novacoin-qt.pro index 6e699a8..9513cd3 100644 --- a/novacoin-qt.pro +++ b/novacoin-qt.pro @@ -31,6 +31,8 @@ contains(RELEASE, 1) { } } +QMAKE_LFLAGS *= -fopenmp + !win32 { # for extra security against potential buffer overflows: enable GCCs Stack Smashing Protection QMAKE_CXXFLAGS *= -fstack-protector-all --param ssp-buffer-size=1 @@ -40,6 +42,7 @@ QMAKE_LFLAGS *= -fstack-protector-all --param ssp-buffer-size=1 } # 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 @@ -90,6 +93,34 @@ contains(BITCOIN_NEED_QT_PLUGINS, 1) { QTPLUGIN += qcncodecs qjpcodecs qtwcodecs qkrcodecs qtaccessiblewidgets } +contains(USE_LEVELDB, -) { + message(Building without LevelDB) + SOURCES += src/txdb-bdb.cpp +} else { + message(Building with LevelDB) + DEFINES += USE_LEVELDB + + 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) { @@ -101,9 +132,23 @@ contains(BITCOIN_NEED_QT_PLUGINS, 1) { DEFINES += HAVE_BUILD_INFO } -QMAKE_CXXFLAGS += -msse2 -QMAKE_CFLAGS += -msse2 -QMAKE_CXXFLAGS_WARN_ON = -fdiagnostics-show-option -Wall -Wextra -Wformat -Wformat-security -Wno-unused-parameter -Wstack-protector +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 +} + +QMAKE_CXXFLAGS +=-fopenmp +QMAKE_CXXFLAGS_WARN_ON = -fdiagnostics-show-option -Wall -Wextra -Wno-ignored-qualifiers -Wformat -Wformat-security -Wno-unused-parameter -Wstack-protector # Input DEPENDPATH += src src/json src/qt @@ -129,6 +174,17 @@ HEADERS += src/qt/bitcoingui.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 \ @@ -136,6 +192,7 @@ HEADERS += src/qt/bitcoingui.h \ src/net.h \ src/key.h \ src/db.h \ + src/txdb.h \ src/walletdb.h \ src/script.h \ src/init.h \ @@ -244,10 +301,21 @@ SOURCES += src/qt/bitcoin.cpp src/qt/bitcoingui.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/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/bitcoin.qrc @@ -344,7 +412,7 @@ windows:!contains(MINGW_THREAD_BUGFIX, 0) { # 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 + DEFINES += _MT BOOST_THREAD_PROVIDES_GENERIC_SHARED_MUTEX_ON_WIN QMAKE_LIBS_QT_ENTRY = -lmingwthrd $$QMAKE_LIBS_QT_ENTRY }