diff --git a/nymea-app.pro b/nymea-app.pro index 1fad926e..a29e0284 100644 --- a/nymea-app.pro +++ b/nymea-app.pro @@ -12,29 +12,24 @@ withtests: { tests.depends = libnymea-app } -equals(OVERLAY_PATH, "") { - PACKAGE_BASE_DIR = $$shell_path($$PWD)\packaging -} else { - PACKAGE_BASE_DIR = $${OVERLAY_PATH}\packaging -} - # Building a Windows installer: # Make sure your environment has the toolchain you want (e.g. msvc17 64 bit) by executing the command: # $ call "C:\Program Files (x86)\Microsoft Visual Studio\2017\Community\VC\Auxiliary\Build\vcvars64.bat" # $ make wininstaller wininstaller.depends = nymea-app -PACKAGE_DIR = $${PACKAGE_BASE_DIR}\windows + + OLDSTRING=".*" NEWSTRING="$${APP_VERSION}" -wininstaller.commands += @powershell -Command \"(gc $${PACKAGE_DIR}\packages\\$${PACKAGE_URN}\meta\package.xml) -replace \'$${OLDSTRING}\',\'$${NEWSTRING}\' | sc $${PACKAGE_DIR}\packages\\$${PACKAGE_URN}\meta\package.xml\" && -wininstaller.commands += rmdir /S /Q $${PACKAGE_DIR}\packages\\$${PACKAGE_URN}\data & mkdir $${PACKAGE_DIR}\packages\\$${PACKAGE_URN}\data && -wininstaller.commands += copy $${PACKAGE_DIR}\packages\\$${PACKAGE_URN}\meta\logo.ico $${PACKAGE_DIR}\packages\\$${PACKAGE_URN}\data\logo.ico && -CONFIG(debug,debug|release):wininstaller.commands += copy nymea-app\debug\\$${APPLICATION_NAME}.exe $${PACKAGE_DIR}\packages\\$${PACKAGE_URN}\data\\$${APPLICATION_NAME}.exe && -CONFIG(release,debug|release):wininstaller.commands += copy nymea-app\release\\$${APPLICATION_NAME}.exe $${PACKAGE_DIR}\packages\\$${PACKAGE_URN}\data\\$${APPLICATION_NAME}.exe && -wininstaller.commands += copy \"$${top_srcdir}\"\3rdParty\windows\windows_openssl\*.dll $${PACKAGE_DIR}\packages\\$${PACKAGE_URN}\data && -wininstaller.commands += windeployqt --compiler-runtime --qmldir \"$${top_srcdir}\"\nymea-app\ui $${PACKAGE_DIR}\packages\\$${PACKAGE_URN}\data\ && -wininstaller.commands += binarycreator -c $${PACKAGE_DIR}\config\config.xml -p $${PACKAGE_DIR}\packages\ $${PACKAGE_NAME}-installer-$${APP_VERSION} -win32:message("Windows installer package directory: $${PACKAGE_DIR}") +wininstaller.commands += @powershell -Command \"(gc $${WIN_PACKAGE_DIR}\packages\\$${PACKAGE_URN}\meta\package.xml) -replace \'$${OLDSTRING}\',\'$${NEWSTRING}\' | sc $${WIN_PACKAGE_DIR}\packages\\$${PACKAGE_URN}\meta\package.xml\" && +wininstaller.commands += rmdir /S /Q $${WIN_PACKAGE_DIR}\packages\\$${WIN_PACKAGE_URN}\data & mkdir $${WIN_PACKAGE_DIR}\packages\\$${PACKAGE_URN}\data && +wininstaller.commands += copy $${WIN_PACKAGE_DIR}\packages\\$${PACKAGE_URN}\meta\logo.ico $${WIN_PACKAGE_DIR}\packages\\$${PACKAGE_URN}\data\logo.ico && +CONFIG(debug,debug|release):wininstaller.commands += copy nymea-app\debug\\$${APPLICATION_NAME}.exe $${WIN_PACKAGE_DIR}\packages\\$${PACKAGE_URN}\data\\$${APPLICATION_NAME}.exe && +CONFIG(release,debug|release):wininstaller.commands += copy nymea-app\release\\$${APPLICATION_NAME}.exe $${WIN_PACKAGE_DIR}\packages\\$${PACKAGE_URN}\data\\$${APPLICATION_NAME}.exe && +wininstaller.commands += copy \"$${top_srcdir}\"\3rdParty\windows\windows_openssl\*.dll $${WIN_PACKAGE_DIR}\packages\\$${PACKAGE_URN}\data && +wininstaller.commands += windeployqt --compiler-runtime --qmldir \"$${top_srcdir}\"\nymea-app\ui $${WIN_PACKAGE_DIR}\packages\\$${WIN_PACKAGE_URN}\data\ && +wininstaller.commands += binarycreator -c $${WIN_PACKAGE_DIR}\config\config.xml -p $${WIN_PACKAGE_DIR}\packages\ $${PACKAGE_NAME}-$${APP_VERSION} +win32:message("Windows installer package directory: $${WIN_PACKAGE_DIR}") QMAKE_EXTRA_TARGETS += wininstaller @@ -46,17 +41,20 @@ QMAKE_EXTRA_TARGETS += wininstaller # and we're using the WebView instead anyways. (IMHO a bug that macdeployqt -appstore-compliant even adds it) osxbundle.depends = nymea-app osxbundle.commands += cd nymea-app && rm -f ../*.dmg ../*pkg *.dmg || true && -osxbundle.commands += hdiutil eject /Volumes/nymea-app || true && -osxbundle.commands += macdeployqt nymea-app.app -appstore-compliant -qmldir=$$top_srcdir/nymea-app/ui -dmg && -osxbundle.commands += rm -r nymea-app.app/Contents/Frameworks/QtWebEngineCore.framework && -osxbundle.commands += codesign -s \"3rd Party Mac Developer Application\" --entitlements $$top_srcdir/packaging/osx/nymea-app.entitlements --deep nymea-app.app && -osxbundle.commands += hdiutil convert nymea-app.dmg -format UDRW -o nymea-app_writable.dmg && -osxbundle.commands += hdiutil attach -readwrite -noverify nymea-app_writable.dmg && sleep 2 && -osxbundle.commands += mv /Volumes/nymea-app/nymea-app.app /Volumes/nymea-app/nymea\:app.app && -osxbundle.commands += tar -xpf $$top_srcdir/packaging/osx/template.tar -C /Volumes/nymea-app/ && -osxbundle.commands += hdiutil eject /Volumes/nymea-app && -osxbundle.commands += hdiutil convert nymea-app_writable.dmg -format UDRO -o ../nymea-app-osx-bundle-$${APP_VERSION}.dmg && -osxbundle.commands += rm nymea-app.dmg nymea-app_writable.dmg +osxbundle.commands += hdiutil eject /Volumes/$${APPLICATION_NAME} || true && +osxbundle.commands += echo "Creating bundle" && +osxbundle.commands += macdeployqt $${APPLICATION_NAME}.app -appstore-compliant -qmldir=$$top_srcdir/nymea-app/ui -dmg && +osxbundle.commands += echo "Removing QtWebEngineCore from bundle" && +osxbundle.commands += rm -r $${APPLICATION_NAME}.app/Contents/Frameworks/QtWebEngineCore.framework && +osxbundle.commands += echo "Signing application bundle" && +osxbundle.commands += codesign -s \"3rd Party Mac Developer Application\" --entitlements $${MACX_PACKAGE_DIR}/$${APPLICATION_NAME}.entitlements --deep $${APPLICATION_NAME}.app && +osxbundle.commands += echo "converting to writable bundle" && +osxbundle.commands += hdiutil convert $${APPLICATION_NAME}.dmg -format UDRW -o $${APPLICATION_NAME}_writable.dmg && +osxbundle.commands += hdiutil attach -readwrite -noverify $${APPLICATION_NAME}_writable.dmg && sleep 2 && +osxbundle.commands += tar -xpf $${MACX_PACKAGE_DIR}/template.tar -C /Volumes/$${APPLICATION_NAME}/ && +osxbundle.commands += hdiutil eject /Volumes/$${APPLICATION_NAME} && +osxbundle.commands += hdiutil convert $${APPLICATION_NAME}_writable.dmg -format UDRO -o ../$${APPLICATION_NAME}-osx-bundle-$${APP_VERSION}.dmg && +osxbundle.commands += rm $${APPLICATION_NAME}.dmg #$${APPLICATION_NAME}_writable.dmg QMAKE_EXTRA_TARGETS += osxbundle # Create a .pkg osx installer. diff --git a/nymea-app/nymea-app.pro b/nymea-app/nymea-app.pro index 90f41593..06bbb6d9 100644 --- a/nymea-app/nymea-app.pro +++ b/nymea-app/nymea-app.pro @@ -92,17 +92,17 @@ macx: { QMAKE_TARGET_BUNDLE_PREFIX = io.nymea QMAKE_BUNDLE = nymeaApp.mac - plist.input = ../packaging/osx/Info.plist.in + plist.input = $${MACX_PACKAGE_DIR}/Info.plist.in plist.output = $$OUT_PWD/Info.plist QMAKE_SUBSTITUTES += plist QMAKE_INFO_PLIST = $$OUT_PWD/Info.plist - OTHER_FILES += ../packaging/osx/Info.plist.in \ - ../packaging/osx/nymea-app.entitlements + OTHER_FILES += $${MACX_PACKAGE_DIR}/Info.plist.in \ + $${MACX_PACKAGE_DIR}/$${APPLICATION_NAME}.entitlements - ICON = ../packaging/osx/AppIcon.icns + ICON = $${MACX_PACKAGE_DIR}/AppIcon.icns OSX_ENTITLEMENTS.name = CODE_SIGN_ENTITLEMENTS - OSX_ENTITLEMENTS.value = $$files($$PWD/../packaging/ios/nymea-app.entitlements) + OSX_ENTITLEMENTS.value = $$files($${MACX_PACKAGE_DIR}/$${APPLICATION_NAME}.entitlements) QMAKE_MAC_XCODE_SETTINGS += OSX_ENTITLEMENTS } diff --git a/shared.pri b/shared.pri index d9168630..759fc88c 100644 --- a/shared.pri +++ b/shared.pri @@ -21,6 +21,12 @@ INCLUDEPATH += $${top_builddir} # On Windows, -Wall goes mental, so not using it there !win32:QMAKE_CXXFLAGS += -Wall +equals(OVERLAY_PATH, "") { + PACKAGE_BASE_DIR = $$shell_path($$PWD/packaging) +} else { + PACKAGE_BASE_DIR = $$shell_path($${OVERLAY_PATH}/packaging) +} + # As of Qt 5.15, lots of things are deprecated inside Qt in preparation for Qt6 but no replacement to actually fix those yet. linux:!android { QMAKE_CXXFLAGS += -Wno-deprecated-declarations -Wno-deprecated-copy @@ -29,11 +35,7 @@ linux:!android { android: { QMAKE_CXXFLAGS += -Wno-deprecated-declarations - equals(OVERLAY_PATH, "") { - ANDROID_PACKAGE_SOURCE_DIR = $${top_srcdir}/packaging/android - } else { - ANDROID_PACKAGE_SOURCE_DIR = $${OVERLAY_PATH}/packaging/android - } + ANDROID_PACKAGE_SOURCE_DIR = $${PACKAGE_BASE_DIR}/android message("Android package directory: $${ANDROID_PACKAGE_SOURCE_DIR}") !no-firebase:DEFINES+=WITH_FIREBASE @@ -42,3 +44,11 @@ android: { ios: { !no-firebase:DEFINES+=WITH_FIREBASE } + +macx: { + MACX_PACKAGE_DIR = $${PACKAGE_BASE_DIR}/osx/ +} + +win32: { + WIN_PACKAGE_DIR = $${PACKAGE_BASE_DIR}\windows +}