mirror of
https://github.com/monero-project/monero-gui.git
synced 2025-01-25 12:05:54 +00:00
fc131bd465
83efc38
Android: Disable password strength meter0ece8a9
Android dockerfile: add zmq dependencydab4d5a
Android: use new repo path
432 lines
12 KiB
Prolog
432 lines
12 KiB
Prolog
TEMPLATE = app
|
|
|
|
QT += qml quick widgets
|
|
|
|
WALLET_ROOT=$$PWD/monero
|
|
|
|
CONFIG += c++11
|
|
|
|
# cleaning "auto-generated" bitmonero directory on "make distclean"
|
|
QMAKE_DISTCLEAN += -r $$WALLET_ROOT
|
|
|
|
INCLUDEPATH += $$WALLET_ROOT/include \
|
|
$$PWD/src/libwalletqt \
|
|
$$PWD/src/QR-Code-generator \
|
|
$$PWD/src \
|
|
$$WALLET_ROOT/src
|
|
|
|
HEADERS += \
|
|
filter.h \
|
|
clipboardAdapter.h \
|
|
oscursor.h \
|
|
src/libwalletqt/WalletManager.h \
|
|
src/libwalletqt/Wallet.h \
|
|
src/libwalletqt/PendingTransaction.h \
|
|
src/libwalletqt/TransactionHistory.h \
|
|
src/libwalletqt/TransactionInfo.h \
|
|
src/libwalletqt/QRCodeImageProvider.h \
|
|
src/libwalletqt/Transfer.h \
|
|
oshelper.h \
|
|
TranslationManager.h \
|
|
src/model/TransactionHistoryModel.h \
|
|
src/model/TransactionHistorySortFilterModel.h \
|
|
src/QR-Code-generator/BitBuffer.hpp \
|
|
src/QR-Code-generator/QrCode.hpp \
|
|
src/QR-Code-generator/QrSegment.hpp \
|
|
src/model/AddressBookModel.h \
|
|
src/libwalletqt/AddressBook.h \
|
|
src/zxcvbn-c/zxcvbn.h \
|
|
src/libwalletqt/UnsignedTransaction.h \
|
|
MainApp.h
|
|
|
|
SOURCES += main.cpp \
|
|
filter.cpp \
|
|
clipboardAdapter.cpp \
|
|
oscursor.cpp \
|
|
src/libwalletqt/WalletManager.cpp \
|
|
src/libwalletqt/Wallet.cpp \
|
|
src/libwalletqt/PendingTransaction.cpp \
|
|
src/libwalletqt/TransactionHistory.cpp \
|
|
src/libwalletqt/TransactionInfo.cpp \
|
|
src/libwalletqt/QRCodeImageProvider.cpp \
|
|
oshelper.cpp \
|
|
TranslationManager.cpp \
|
|
src/model/TransactionHistoryModel.cpp \
|
|
src/model/TransactionHistorySortFilterModel.cpp \
|
|
src/QR-Code-generator/BitBuffer.cpp \
|
|
src/QR-Code-generator/QrCode.cpp \
|
|
src/QR-Code-generator/QrSegment.cpp \
|
|
src/model/AddressBookModel.cpp \
|
|
src/libwalletqt/AddressBook.cpp \
|
|
src/zxcvbn-c/zxcvbn.c \
|
|
src/libwalletqt/UnsignedTransaction.cpp \
|
|
MainApp.cpp
|
|
|
|
CONFIG(DISABLE_PASS_STRENGTH_METER) {
|
|
HEADERS -= src/zxcvbn-c/zxcvbn.h
|
|
SOURCES -= src/zxcvbn-c/zxcvbn.c
|
|
DEFINES += "DISABLE_PASS_STRENGTH_METER"
|
|
}
|
|
|
|
!ios {
|
|
HEADERS += src/daemon/DaemonManager.h
|
|
SOURCES += src/daemon/DaemonManager.cpp
|
|
}
|
|
|
|
lupdate_only {
|
|
SOURCES = *.qml \
|
|
components/*.qml \
|
|
pages/*.qml \
|
|
wizard/*.qml \
|
|
wizard/*js
|
|
}
|
|
|
|
|
|
ios:armv7 {
|
|
message("target is armv7")
|
|
LIBS += \
|
|
-L$$PWD/../ofxiOSBoost/build/libs/boost/lib/armv7 \
|
|
}
|
|
ios:arm64 {
|
|
message("target is arm64")
|
|
LIBS += \
|
|
-L$$PWD/../ofxiOSBoost/build/libs/boost/lib/arm64 \
|
|
}
|
|
!ios:!android {
|
|
LIBS += -L$$WALLET_ROOT/lib \
|
|
-lwallet_merged \
|
|
-lepee \
|
|
-lunbound \
|
|
-leasylogging \
|
|
-lreadline \
|
|
}
|
|
|
|
android {
|
|
message("Host is Android")
|
|
LIBS += -L$$WALLET_ROOT/lib \
|
|
-lwallet_merged \
|
|
-lepee \
|
|
-lunbound \
|
|
-leasylogging
|
|
}
|
|
|
|
|
|
|
|
|
|
ios {
|
|
message("Host is IOS")
|
|
|
|
QMAKE_LFLAGS += -v
|
|
QMAKE_IOS_DEVICE_ARCHS = arm64
|
|
CONFIG += arm64
|
|
LIBS += -L$$WALLET_ROOT/lib-ios \
|
|
-lwallet_merged \
|
|
-lepee \
|
|
-lunbound \
|
|
-leasylogging
|
|
|
|
LIBS+= \
|
|
-L$$PWD/../OpenSSL-for-iPhone/lib \
|
|
-L$$PWD/../ofxiOSBoost/build/libs/boost/lib/arm64 \
|
|
-lboost_serialization \
|
|
-lboost_thread \
|
|
-lboost_system \
|
|
-lboost_date_time \
|
|
-lboost_filesystem \
|
|
-lboost_regex \
|
|
-lboost_chrono \
|
|
-lboost_program_options \
|
|
-lssl \
|
|
-lcrypto \
|
|
-ldl
|
|
}
|
|
|
|
CONFIG(WITH_SCANNER) {
|
|
if( greaterThan(QT_MINOR_VERSION, 5) ) {
|
|
message("using camera scanner")
|
|
QT += multimedia
|
|
DEFINES += "WITH_SCANNER"
|
|
INCLUDEPATH += $$PWD/src/QR-Code-scanner
|
|
HEADERS += \
|
|
src/QR-Code-scanner/QrScanThread.h \
|
|
src/QR-Code-scanner/QrCodeScanner.h
|
|
SOURCES += \
|
|
src/QR-Code-scanner/QrScanThread.cpp \
|
|
src/QR-Code-scanner/QrCodeScanner.cpp
|
|
android {
|
|
INCLUDEPATH += $$PWD/../ZBar/include
|
|
LIBS += -lzbarjni -liconv
|
|
} else {
|
|
LIBS += -lzbar
|
|
}
|
|
} else {
|
|
message("Skipping camera scanner because of Incompatible Qt Version !")
|
|
}
|
|
}
|
|
|
|
|
|
# currently we only support x86 build as qt.io only provides prebuilt qt for x86 mingw
|
|
|
|
win32 {
|
|
|
|
# QMAKE_HOST.arch is unreliable, will allways report 32bit if mingw32 shell is run.
|
|
# Obtaining arch through uname should be reliable. This also fixes building the project in Qt creator without changes.
|
|
MSYS_HOST_ARCH = $$system(uname -a | grep -o "x86_64")
|
|
|
|
# WIN64 Host settings
|
|
contains(MSYS_HOST_ARCH, x86_64) {
|
|
message("Host is 64bit")
|
|
MSYS_ROOT_PATH=c:/msys64
|
|
|
|
# WIN32 Host settings
|
|
} else {
|
|
message("Host is 32bit")
|
|
MSYS_ROOT_PATH=c:/msys32
|
|
}
|
|
|
|
# WIN64 Target settings
|
|
contains(QMAKE_HOST.arch, x86_64) {
|
|
MSYS_MINGW_PATH=/mingw64
|
|
|
|
# WIN32 Target settings
|
|
} else {
|
|
MSYS_MINGW_PATH=/mingw32
|
|
}
|
|
|
|
MSYS_PATH=$$MSYS_ROOT_PATH$$MSYS_MINGW_PATH
|
|
|
|
# boost root path
|
|
BOOST_PATH=$$MSYS_PATH/boost
|
|
BOOST_MINGW_PATH=$$MSYS_MINGW_PATH/boost
|
|
|
|
LIBS+=-L$$MSYS_PATH/lib
|
|
LIBS+=-L$$MSYS_MINGW_PATH/lib
|
|
LIBS+=-L$$BOOST_PATH/lib
|
|
LIBS+=-L$$BOOST_MINGW_PATH/lib
|
|
|
|
LIBS+= \
|
|
-Wl,-Bstatic \
|
|
-lboost_serialization-mt-s \
|
|
-lboost_thread-mt-s \
|
|
-lboost_system-mt-s \
|
|
-lboost_date_time-mt-s \
|
|
-lboost_filesystem-mt-s \
|
|
-lboost_regex-mt-s \
|
|
-lboost_chrono-mt-s \
|
|
-lboost_program_options-mt-s \
|
|
-lssl \
|
|
-lcrypto \
|
|
-Wl,-Bdynamic \
|
|
-lws2_32 \
|
|
-lwsock32 \
|
|
-lIphlpapi \
|
|
-lgdi32
|
|
|
|
!contains(QMAKE_TARGET.arch, x86_64) {
|
|
message("Target is 32bit")
|
|
## Windows x86 (32bit) specific build here
|
|
## there's 2Mb stack in libwallet allocated internally, so we set stack=4Mb
|
|
## this fixes app crash for x86 Windows build
|
|
QMAKE_LFLAGS += -Wl,--stack,4194304
|
|
} else {
|
|
message("Target is 64bit")
|
|
}
|
|
|
|
}
|
|
|
|
linux {
|
|
CONFIG(static) {
|
|
message("using static libraries")
|
|
LIBS+= -Wl,-Bstatic
|
|
QMAKE_LFLAGS += -static-libgcc -static-libstdc++
|
|
# contains(QT_ARCH, x86_64) {
|
|
LIBS+= -lunbound
|
|
# }
|
|
} else {
|
|
# On some distro's we need to add dynload
|
|
LIBS+= -ldl
|
|
}
|
|
|
|
LIBS+= \
|
|
-lboost_serialization \
|
|
-lboost_thread \
|
|
-lboost_system \
|
|
-lboost_date_time \
|
|
-lboost_filesystem \
|
|
-lboost_regex \
|
|
-lboost_chrono \
|
|
-lboost_program_options \
|
|
-lssl \
|
|
-lcrypto
|
|
|
|
if(!android) {
|
|
LIBS+= \
|
|
-Wl,-Bdynamic \
|
|
-lGL
|
|
}
|
|
# currently monero has an issue with "static" build and linunwind-dev,
|
|
# so we link libunwind-dev only for non-Ubuntu distros
|
|
CONFIG(libunwind_off) {
|
|
message(Building without libunwind)
|
|
} else {
|
|
message(Building with libunwind)
|
|
LIBS += -Wl,-Bdynamic -lunwind
|
|
}
|
|
}
|
|
|
|
macx {
|
|
# mixing static and shared libs are not supported on mac
|
|
# CONFIG(static) {
|
|
# message("using static libraries")
|
|
# LIBS+= -Wl,-Bstatic
|
|
# }
|
|
LIBS+= \
|
|
-L/usr/local/lib \
|
|
-L/usr/local/opt/openssl/lib \
|
|
-L/usr/local/opt/boost/lib \
|
|
-lboost_serialization \
|
|
-lboost_thread-mt \
|
|
-lboost_system \
|
|
-lboost_date_time \
|
|
-lboost_filesystem \
|
|
-lboost_regex \
|
|
-lboost_chrono \
|
|
-lboost_program_options \
|
|
-lssl \
|
|
-lcrypto \
|
|
-ldl
|
|
|
|
}
|
|
|
|
|
|
# translation stuff
|
|
TRANSLATIONS = \ # English is default language, no explicit translation file
|
|
$$PWD/translations/monero-core.ts \ # translation source (copy this file when creating a new translation)
|
|
$$PWD/translations/monero-core_ar.ts \ # Arabic
|
|
$$PWD/translations/monero-core_pt-br.ts \ # Portuguese (Brazil)
|
|
$$PWD/translations/monero-core_de.ts \ # German
|
|
$$PWD/translations/monero-core_eo.ts \ # Esperanto
|
|
$$PWD/translations/monero-core_es.ts \ # Spanish
|
|
$$PWD/translations/monero-core_fi.ts \ # Finnish
|
|
$$PWD/translations/monero-core_fr.ts \ # French
|
|
$$PWD/translations/monero-core_hr.ts \ # Croatian
|
|
$$PWD/translations/monero-core_id.ts \ # Indonesian
|
|
$$PWD/translations/monero-core_hi.ts \ # Hindi
|
|
$$PWD/translations/monero-core_it.ts \ # Italian
|
|
$$PWD/translations/monero-core_ja.ts \ # Japanese
|
|
$$PWD/translations/monero-core_nl.ts \ # Dutch
|
|
$$PWD/translations/monero-core_pl.ts \ # Polish
|
|
$$PWD/translations/monero-core_ru.ts \ # Russian
|
|
$$PWD/translations/monero-core_sv.ts \ # Swedish
|
|
$$PWD/translations/monero-core_zh-cn.ts \ # Chinese (Simplified-China)
|
|
$$PWD/translations/monero-core_zh-tw.ts \ # Chinese (Traditional-Taiwan)
|
|
$$PWD/translations/monero-core_he.ts \ # Hebrew
|
|
$$PWD/translations/monero-core_ko.ts \ # Korean
|
|
$$PWD/translations/monero-core_ro.ts \ # Romanian
|
|
$$PWD/translations/monero-core_da.ts \ # Danish
|
|
$$PWD/translations/monero-core_cs.ts \ # Czech
|
|
$$PWD/translations/monero-core_sk.ts \ # Slovak
|
|
|
|
CONFIG(release, debug|release) {
|
|
DESTDIR = release/bin
|
|
LANGUPD_OPTIONS = -locations relative -no-ui-lines
|
|
LANGREL_OPTIONS = -compress -nounfinished -removeidentical
|
|
|
|
} else {
|
|
DESTDIR = debug/bin
|
|
LANGUPD_OPTIONS =
|
|
# LANGREL_OPTIONS = -markuntranslated "MISS_TR "
|
|
}
|
|
|
|
TARGET_FULL_PATH = $$OUT_PWD/$$DESTDIR
|
|
TRANSLATION_TARGET_DIR = $$TARGET_FULL_PATH/translations
|
|
|
|
macx {
|
|
TARGET_FULL_PATH = $$sprintf("%1/%2/%3.app", $$OUT_PWD, $$DESTDIR, $$TARGET)
|
|
TRANSLATION_TARGET_DIR = $$TARGET_FULL_PATH/Contents/Resources/translations
|
|
}
|
|
|
|
|
|
!ios {
|
|
isEmpty(QMAKE_LUPDATE) {
|
|
win32:LANGUPD = $$[QT_INSTALL_BINS]\lupdate.exe
|
|
else:LANGUPD = $$[QT_INSTALL_BINS]/lupdate
|
|
}
|
|
|
|
isEmpty(QMAKE_LRELEASE) {
|
|
win32:LANGREL = $$[QT_INSTALL_BINS]\lrelease.exe
|
|
else:LANGREL = $$[QT_INSTALL_BINS]/lrelease
|
|
}
|
|
|
|
langupd.command = \
|
|
$$LANGUPD $$LANGUPD_OPTIONS $$shell_path($$_PRO_FILE) -ts $$_PRO_FILE_PWD/$$TRANSLATIONS
|
|
|
|
|
|
|
|
langrel.depends = langupd
|
|
langrel.input = TRANSLATIONS
|
|
langrel.output = $$TRANSLATION_TARGET_DIR/${QMAKE_FILE_BASE}.qm
|
|
langrel.commands = \
|
|
$$LANGREL $$LANGREL_OPTIONS ${QMAKE_FILE_IN} -qm $$TRANSLATION_TARGET_DIR/${QMAKE_FILE_BASE}.qm
|
|
langrel.CONFIG += no_link
|
|
|
|
QMAKE_EXTRA_TARGETS += langupd deploy deploy_win
|
|
QMAKE_EXTRA_COMPILERS += langrel
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
# Update: no issues with the "slow link process" anymore,
|
|
# for development, just build debug version of libwallet_merged lib
|
|
# by invoking 'get_libwallet_api.sh Debug'
|
|
# so we update translations everytime even for debug build
|
|
|
|
PRE_TARGETDEPS += langupd compiler_langrel_make_all
|
|
|
|
RESOURCES += qml.qrc
|
|
CONFIG += qtquickcompiler
|
|
|
|
# Additional import path used to resolve QML modules in Qt Creator's code model
|
|
QML_IMPORT_PATH =
|
|
|
|
# Default rules for deployment.
|
|
include(deployment.pri)
|
|
macx {
|
|
deploy.commands += macdeployqt $$sprintf("%1/%2/%3.app", $$OUT_PWD, $$DESTDIR, $$TARGET) -qmldir=$$PWD
|
|
}
|
|
|
|
win32 {
|
|
deploy.commands += windeployqt $$sprintf("%1/%2/%3.exe", $$OUT_PWD, $$DESTDIR, $$TARGET) -release -qmldir=$$PWD
|
|
# Win64 msys2 deploy settings
|
|
contains(QMAKE_HOST.arch, x86_64) {
|
|
deploy.commands += $$escape_expand(\n\t) $$PWD/windeploy_helper.sh $$DESTDIR
|
|
}
|
|
}
|
|
|
|
linux:!android {
|
|
deploy.commands += $$escape_expand(\n\t) $$PWD/linuxdeploy_helper.sh $$DESTDIR $$TARGET
|
|
}
|
|
|
|
android{
|
|
deploy.commands += make install INSTALL_ROOT=$$DESTDIR && androiddeployqt --input android-libmonero-wallet-gui.so-deployment-settings.json --output $$DESTDIR --deployment bundled --android-platform android-21 --jdk /usr/lib/jvm/java-8-openjdk-amd64 -qmldir=$$PWD
|
|
}
|
|
|
|
|
|
OTHER_FILES += \
|
|
.gitignore \
|
|
$$TRANSLATIONS
|
|
|
|
DISTFILES += \
|
|
notes.txt \
|
|
monero/src/wallet/CMakeLists.txt \
|
|
components/MobileHeader.qml
|
|
|
|
|
|
# windows application icon
|
|
RC_FILE = monero-core.rc
|
|
|
|
# mac application icon
|
|
ICON = $$PWD/images/appicon.icns
|