mirror of
https://github.com/monero-project/monero-gui.git
synced 2025-01-27 13:05:56 +00:00
Merge pull request #440
78302be
IOS specific settings (Jaquee)c6dc9a2
IOS build settings (Jaquee)
This commit is contained in:
commit
2901a33698
2 changed files with 89 additions and 29 deletions
23
main.cpp
23
main.cpp
|
@ -47,13 +47,17 @@
|
||||||
#include "TransactionHistory.h"
|
#include "TransactionHistory.h"
|
||||||
#include "model/TransactionHistoryModel.h"
|
#include "model/TransactionHistoryModel.h"
|
||||||
#include "model/TransactionHistorySortFilterModel.h"
|
#include "model/TransactionHistorySortFilterModel.h"
|
||||||
#include "daemon/DaemonManager.h"
|
|
||||||
#include "AddressBook.h"
|
#include "AddressBook.h"
|
||||||
#include "model/AddressBookModel.h"
|
#include "model/AddressBookModel.h"
|
||||||
|
|
||||||
|
// IOS exclusions
|
||||||
|
#ifndef Q_OS_IOS
|
||||||
|
#include "daemon/DaemonManager.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
int main(int argc, char *argv[])
|
int main(int argc, char *argv[])
|
||||||
{
|
{
|
||||||
|
|
||||||
QApplication app(argc, argv);
|
QApplication app(argc, argv);
|
||||||
|
|
||||||
qDebug() << "app startd";
|
qDebug() << "app startd";
|
||||||
|
@ -96,10 +100,10 @@ int main(int argc, char *argv[])
|
||||||
|
|
||||||
qmlRegisterUncreatableType<TransactionInfo>("moneroComponents.TransactionInfo", 1, 0, "TransactionInfo",
|
qmlRegisterUncreatableType<TransactionInfo>("moneroComponents.TransactionInfo", 1, 0, "TransactionInfo",
|
||||||
"TransactionHistory can't be instantiated directly");
|
"TransactionHistory can't be instantiated directly");
|
||||||
|
#ifndef Q_OS_IOS
|
||||||
qmlRegisterUncreatableType<DaemonManager>("moneroComponents.DaemonManager", 1, 0, "DaemonManager",
|
qmlRegisterUncreatableType<DaemonManager>("moneroComponents.DaemonManager", 1, 0, "DaemonManager",
|
||||||
"DaemonManager can't be instantiated directly");
|
"DaemonManager can't be instantiated directly");
|
||||||
|
#endif
|
||||||
qmlRegisterUncreatableType<AddressBookModel>("moneroComponents.AddressBookModel", 1, 0, "AddressBookModel",
|
qmlRegisterUncreatableType<AddressBookModel>("moneroComponents.AddressBookModel", 1, 0, "AddressBookModel",
|
||||||
"AddressBookModel can't be instantiated directly");
|
"AddressBookModel can't be instantiated directly");
|
||||||
|
|
||||||
|
@ -125,9 +129,13 @@ int main(int argc, char *argv[])
|
||||||
|
|
||||||
engine.addImageProvider(QLatin1String("qrcode"), new QRCodeImageProvider());
|
engine.addImageProvider(QLatin1String("qrcode"), new QRCodeImageProvider());
|
||||||
const QStringList arguments = QCoreApplication::arguments();
|
const QStringList arguments = QCoreApplication::arguments();
|
||||||
|
|
||||||
|
// Exclude daemon manager from IOS
|
||||||
|
#ifndef Q_OS_IOS
|
||||||
DaemonManager * daemonManager = DaemonManager::instance(&arguments);
|
DaemonManager * daemonManager = DaemonManager::instance(&arguments);
|
||||||
QObject::connect(&app, SIGNAL(aboutToQuit()), daemonManager, SLOT(closing()));
|
QObject::connect(&app, SIGNAL(aboutToQuit()), daemonManager, SLOT(closing()));
|
||||||
engine.rootContext()->setContextProperty("daemonManager", daemonManager);
|
engine.rootContext()->setContextProperty("daemonManager", daemonManager);
|
||||||
|
#endif
|
||||||
|
|
||||||
// export to QML monero accounts root directory
|
// export to QML monero accounts root directory
|
||||||
// wizard is talking about where
|
// wizard is talking about where
|
||||||
|
@ -135,13 +143,18 @@ int main(int argc, char *argv[])
|
||||||
// backups - I reckon we save that in My Documents\Monero Accounts\ on
|
// backups - I reckon we save that in My Documents\Monero Accounts\ on
|
||||||
// Windows, ~/Monero Accounts/ on nix / osx
|
// Windows, ~/Monero Accounts/ on nix / osx
|
||||||
bool isWindows = false;
|
bool isWindows = false;
|
||||||
|
bool isIOS = false;
|
||||||
#ifdef Q_OS_WIN
|
#ifdef Q_OS_WIN
|
||||||
isWindows = true;
|
isWindows = true;
|
||||||
QStringList moneroAccountsRootDir = QStandardPaths::standardLocations(QStandardPaths::DocumentsLocation);
|
QStringList moneroAccountsRootDir = QStandardPaths::standardLocations(QStandardPaths::DocumentsLocation);
|
||||||
|
#elif defined(Q_OS_IOS)
|
||||||
|
isIOS = true;
|
||||||
|
QStringList moneroAccountsRootDir = QStandardPaths::standardLocations(QStandardPaths::DocumentsLocation);
|
||||||
#elif defined(Q_OS_UNIX)
|
#elif defined(Q_OS_UNIX)
|
||||||
QStringList moneroAccountsRootDir = QStandardPaths::standardLocations(QStandardPaths::HomeLocation);
|
QStringList moneroAccountsRootDir = QStandardPaths::standardLocations(QStandardPaths::HomeLocation);
|
||||||
#endif
|
#endif
|
||||||
engine.rootContext()->setContextProperty("isWindows", isWindows);
|
engine.rootContext()->setContextProperty("isWindows", isWindows);
|
||||||
|
engine.rootContext()->setContextProperty("isIOS", isIOS);
|
||||||
|
|
||||||
if (!moneroAccountsRootDir.empty()) {
|
if (!moneroAccountsRootDir.empty()) {
|
||||||
QString moneroAccountsDir = moneroAccountsRootDir.at(0) + "/Monero/wallets";
|
QString moneroAccountsDir = moneroAccountsRootDir.at(0) + "/Monero/wallets";
|
||||||
|
@ -160,6 +173,8 @@ int main(int argc, char *argv[])
|
||||||
|
|
||||||
engine.rootContext()->setContextProperty("defaultAccountName", accountName);
|
engine.rootContext()->setContextProperty("defaultAccountName", accountName);
|
||||||
engine.rootContext()->setContextProperty("applicationDirectory", QApplication::applicationDirPath());
|
engine.rootContext()->setContextProperty("applicationDirectory", QApplication::applicationDirPath());
|
||||||
|
|
||||||
|
// Load main window (context properties needs to be defined obove this line)
|
||||||
engine.load(QUrl(QStringLiteral("qrc:///main.qml")));
|
engine.load(QUrl(QStringLiteral("qrc:///main.qml")));
|
||||||
QObject *rootObject = engine.rootObjects().first();
|
QObject *rootObject = engine.rootObjects().first();
|
||||||
|
|
||||||
|
@ -168,8 +183,6 @@ int main(int argc, char *argv[])
|
||||||
QObject::connect(eventFilter, SIGNAL(mousePressed(QVariant,QVariant,QVariant)), rootObject, SLOT(mousePressed(QVariant,QVariant,QVariant)));
|
QObject::connect(eventFilter, SIGNAL(mousePressed(QVariant,QVariant,QVariant)), rootObject, SLOT(mousePressed(QVariant,QVariant,QVariant)));
|
||||||
QObject::connect(eventFilter, SIGNAL(mouseReleased(QVariant,QVariant,QVariant)), rootObject, SLOT(mouseReleased(QVariant,QVariant,QVariant)));
|
QObject::connect(eventFilter, SIGNAL(mouseReleased(QVariant,QVariant,QVariant)), rootObject, SLOT(mouseReleased(QVariant,QVariant,QVariant)));
|
||||||
|
|
||||||
//WalletManager::instance()->setLogLevel(WalletManager::LogLevel_Max);
|
|
||||||
|
|
||||||
bool builtWithScanner = false;
|
bool builtWithScanner = false;
|
||||||
#ifdef WITH_SCANNER
|
#ifdef WITH_SCANNER
|
||||||
builtWithScanner = true;
|
builtWithScanner = true;
|
||||||
|
|
|
@ -34,7 +34,6 @@ HEADERS += \
|
||||||
src/QR-Code-generator/BitBuffer.hpp \
|
src/QR-Code-generator/BitBuffer.hpp \
|
||||||
src/QR-Code-generator/QrCode.hpp \
|
src/QR-Code-generator/QrCode.hpp \
|
||||||
src/QR-Code-generator/QrSegment.hpp \
|
src/QR-Code-generator/QrSegment.hpp \
|
||||||
src/daemon/DaemonManager.h \
|
|
||||||
src/model/AddressBookModel.h \
|
src/model/AddressBookModel.h \
|
||||||
src/libwalletqt/AddressBook.h \
|
src/libwalletqt/AddressBook.h \
|
||||||
src/zxcvbn-c/zxcvbn.h \
|
src/zxcvbn-c/zxcvbn.h \
|
||||||
|
@ -58,13 +57,17 @@ SOURCES += main.cpp \
|
||||||
src/QR-Code-generator/BitBuffer.cpp \
|
src/QR-Code-generator/BitBuffer.cpp \
|
||||||
src/QR-Code-generator/QrCode.cpp \
|
src/QR-Code-generator/QrCode.cpp \
|
||||||
src/QR-Code-generator/QrSegment.cpp \
|
src/QR-Code-generator/QrSegment.cpp \
|
||||||
src/daemon/DaemonManager.cpp \
|
|
||||||
src/model/AddressBookModel.cpp \
|
src/model/AddressBookModel.cpp \
|
||||||
src/libwalletqt/AddressBook.cpp \
|
src/libwalletqt/AddressBook.cpp \
|
||||||
src/zxcvbn-c/zxcvbn.c \
|
src/zxcvbn-c/zxcvbn.c \
|
||||||
src/libwalletqt/UnsignedTransaction.cpp \
|
src/libwalletqt/UnsignedTransaction.cpp \
|
||||||
src/QR-Code-scanner/QrCodeScanner.cpp
|
src/QR-Code-scanner/QrCodeScanner.cpp
|
||||||
|
|
||||||
|
!ios {
|
||||||
|
HEADERS += src/daemon/DaemonManager.h
|
||||||
|
SOURCES += src/daemon/DaemonManager.cpp
|
||||||
|
}
|
||||||
|
|
||||||
lupdate_only {
|
lupdate_only {
|
||||||
SOURCES = *.qml \
|
SOURCES = *.qml \
|
||||||
components/*.qml \
|
components/*.qml \
|
||||||
|
@ -73,10 +76,49 @@ SOURCES = *.qml \
|
||||||
wizard/*js
|
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 {
|
||||||
LIBS += -L$$WALLET_ROOT/lib \
|
LIBS += -L$$WALLET_ROOT/lib \
|
||||||
-lwallet_merged \
|
-lwallet_merged \
|
||||||
$$WALLET_ROOT/build/release/contrib/epee/src/libepee.a \
|
-lepee \
|
||||||
-lunbound
|
-lunbound
|
||||||
|
}
|
||||||
|
|
||||||
|
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
|
||||||
|
|
||||||
|
LIBS+= \
|
||||||
|
-L$$PWD/OpenSSL-for-iPhone/lib \
|
||||||
|
-lboost_serialization \
|
||||||
|
-lboost_thread \
|
||||||
|
-lboost_system \
|
||||||
|
-lboost_date_time \
|
||||||
|
-lboost_filesystem \
|
||||||
|
-lboost_regex \
|
||||||
|
-lboost_chrono \
|
||||||
|
-lboost_program_options \
|
||||||
|
-lssl \
|
||||||
|
-lcrypto \
|
||||||
|
-ldl
|
||||||
|
}
|
||||||
|
|
||||||
CONFIG(WITH_SCANNER) {
|
CONFIG(WITH_SCANNER) {
|
||||||
if( greaterThan(QT_MINOR_VERSION, 5) ) {
|
if( greaterThan(QT_MINOR_VERSION, 5) ) {
|
||||||
|
@ -95,6 +137,7 @@ CONFIG(WITH_SCANNER) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
# currently we only support x86 build as qt.io only provides prebuilt qt for x86 mingw
|
# currently we only support x86 build as qt.io only provides prebuilt qt for x86 mingw
|
||||||
|
|
||||||
win32 {
|
win32 {
|
||||||
|
@ -242,31 +285,35 @@ macx {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
!ios {
|
||||||
isEmpty(QMAKE_LUPDATE) {
|
isEmpty(QMAKE_LUPDATE) {
|
||||||
win32:LANGUPD = $$[QT_INSTALL_BINS]\lupdate.exe
|
win32:LANGUPD = $$[QT_INSTALL_BINS]\lupdate.exe
|
||||||
else:LANGUPD = $$[QT_INSTALL_BINS]/lupdate
|
else:LANGUPD = $$[QT_INSTALL_BINS]/lupdate
|
||||||
}
|
}
|
||||||
|
|
||||||
isEmpty(QMAKE_LRELEASE) {
|
isEmpty(QMAKE_LRELEASE) {
|
||||||
win32:LANGREL = $$[QT_INSTALL_BINS]\lrelease.exe
|
win32:LANGREL = $$[QT_INSTALL_BINS]\lrelease.exe
|
||||||
else:LANGREL = $$[QT_INSTALL_BINS]/lrelease
|
else:LANGREL = $$[QT_INSTALL_BINS]/lrelease
|
||||||
}
|
}
|
||||||
|
|
||||||
langupd.command = \
|
langupd.command = \
|
||||||
$$LANGUPD $$LANGUPD_OPTIONS $$shell_path($$_PRO_FILE) -ts $$_PRO_FILE_PWD/$$TRANSLATIONS
|
$$LANGUPD $$LANGUPD_OPTIONS $$shell_path($$_PRO_FILE) -ts $$_PRO_FILE_PWD/$$TRANSLATIONS
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
langrel.depends = langupd
|
langrel.depends = langupd
|
||||||
langrel.input = TRANSLATIONS
|
langrel.input = TRANSLATIONS
|
||||||
langrel.output = $$TRANSLATION_TARGET_DIR/${QMAKE_FILE_BASE}.qm
|
langrel.output = $$TRANSLATION_TARGET_DIR/${QMAKE_FILE_BASE}.qm
|
||||||
langrel.commands = \
|
langrel.commands = \
|
||||||
$$LANGREL $$LANGREL_OPTIONS ${QMAKE_FILE_IN} -qm $$TRANSLATION_TARGET_DIR/${QMAKE_FILE_BASE}.qm
|
$$LANGREL $$LANGREL_OPTIONS ${QMAKE_FILE_IN} -qm $$TRANSLATION_TARGET_DIR/${QMAKE_FILE_BASE}.qm
|
||||||
langrel.CONFIG += no_link
|
langrel.CONFIG += no_link
|
||||||
|
|
||||||
|
QMAKE_EXTRA_TARGETS += langupd deploy deploy_win
|
||||||
|
QMAKE_EXTRA_COMPILERS += langrel
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
QMAKE_EXTRA_TARGETS += langupd deploy deploy_win
|
|
||||||
QMAKE_EXTRA_COMPILERS += langrel
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue