From c2c7ee90e2e785ca19eedc33da2e11daaf380393 Mon Sep 17 00:00:00 2001 From: Maxim Biro Date: Sun, 4 Oct 2020 08:30:16 -0400 Subject: [PATCH 01/10] chore(windows): update OpenSSL to 1.1.1h --- windows/cross-compile/build.sh | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/windows/cross-compile/build.sh b/windows/cross-compile/build.sh index dece9fede..7b865488d 100644 --- a/windows/cross-compile/build.sh +++ b/windows/cross-compile/build.sh @@ -232,9 +232,9 @@ store_apt_cache() # OpenSSL OPENSSL_PREFIX_DIR="$DEP_DIR/libopenssl" -OPENSSL_VERSION=1.1.1g +OPENSSL_VERSION=1.1.1h # hash from https://www.openssl.org/source/ -OPENSSL_HASH="ddb04774f1e32f0c49751e21b67216ac87852ceb056b75209af2443400636d46" +OPENSSL_HASH="5c9ca8774bd7b03e5784f26ae9e9e6d749c9da2438545077e6b3d755a06595d9" OPENSSL_FILENAME="openssl-$OPENSSL_VERSION.tar.gz" if [ ! -f "$OPENSSL_PREFIX_DIR/done" ] then From dc78f410f0901ae45c974aed777cccac39eef900 Mon Sep 17 00:00:00 2001 From: Maxim Biro Date: Sun, 4 Oct 2020 08:32:47 -0400 Subject: [PATCH 02/10] chore(windows): update Qt to 5.12.9 --- windows/cross-compile/build.sh | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/windows/cross-compile/build.sh b/windows/cross-compile/build.sh index 7b865488d..04d1d2582 100644 --- a/windows/cross-compile/build.sh +++ b/windows/cross-compile/build.sh @@ -275,10 +275,10 @@ fi QT_PREFIX_DIR="$DEP_DIR/libqt5" QT_MAJOR=5 QT_MINOR=12 -QT_PATCH=8 +QT_PATCH=9 QT_VERSION=$QT_MAJOR.$QT_MINOR.$QT_PATCH -# hash from https://download.qt.io/archive/qt/5.12/5.12.8/single/qt-everywhere-src-5.12.8.tar.xz.mirrorlist -QT_HASH="9142300dfbd641ebdea853546511a352e4bd547c4c7f25d61a40cd997af1f0cf" +# hash from https://download.qt.io/archive/qt/5.12/5.12.9/single/qt-everywhere-src-5.12.9.tar.xz.mirrorlist +QT_HASH="a628186814b73e93594ee8e72f975116599f946919ae6bd86611981b739acff0" QT_FILENAME="qt-everywhere-src-$QT_VERSION.tar.xz" if [ ! -f "$QT_PREFIX_DIR/done" ] then From ea3d61822363ef1c8341ff51bc5591ba09e0460a Mon Sep 17 00:00:00 2001 From: Maxim Biro Date: Sun, 4 Oct 2020 08:52:54 -0400 Subject: [PATCH 03/10] chore(windows): update FFmpeg to 4.3.1 --- windows/cross-compile/build.sh | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/windows/cross-compile/build.sh b/windows/cross-compile/build.sh index 04d1d2582..b7040cf42 100644 --- a/windows/cross-compile/build.sh +++ b/windows/cross-compile/build.sh @@ -434,8 +434,8 @@ fi # FFmpeg FFMPEG_PREFIX_DIR="$DEP_DIR/libffmpeg" -FFMPEG_VERSION=4.2.3 -FFMPEG_HASH="9df6c90aed1337634c1fb026fb01c154c29c82a64ea71291ff2da9aacb9aad31" +FFMPEG_VERSION=4.3.1 +FFMPEG_HASH="ad009240d46e307b4e03a213a0f49c11b650e445b1f8be0dda2a9212b34d2ffb" FFMPEG_FILENAME="ffmpeg-$FFMPEG_VERSION.tar.xz" if [ ! -f "$FFMPEG_PREFIX_DIR/done" ] then From cca17b2341cfa6b6c9f5d58f69dc9e763694c018 Mon Sep 17 00:00:00 2001 From: Maxim Biro Date: Sun, 4 Oct 2020 09:05:00 -0400 Subject: [PATCH 04/10] chore(windows): update QREncode to 4.1.1 --- windows/cross-compile/build.sh | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/windows/cross-compile/build.sh b/windows/cross-compile/build.sh index b7040cf42..4450f452f 100644 --- a/windows/cross-compile/build.sh +++ b/windows/cross-compile/build.sh @@ -599,8 +599,8 @@ fi # QREncode QRENCODE_PREFIX_DIR="$DEP_DIR/libqrencode" -QRENCODE_VERSION=4.0.2 -QRENCODE_HASH="c9cb278d3b28dcc36b8d09e8cad51c0eca754eb004cb0247d4703cb4472b58b4" +QRENCODE_VERSION=4.1.1 +QRENCODE_HASH="e455d9732f8041cf5b9c388e345a641fd15707860f928e94507b1961256a6923" QRENCODE_FILENAME="qrencode-$QRENCODE_VERSION.tar.bz2" if [ ! -f "$QRENCODE_PREFIX_DIR/done" ] then From 2e1999e2cabb5908561411d902b8a9762cc1204a Mon Sep 17 00:00:00 2001 From: Maxim Biro Date: Sun, 4 Oct 2020 09:12:11 -0400 Subject: [PATCH 05/10] chore(windows): update VPX to 1.9.0 --- windows/cross-compile/build.sh | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/windows/cross-compile/build.sh b/windows/cross-compile/build.sh index 4450f452f..a4344d2bf 100644 --- a/windows/cross-compile/build.sh +++ b/windows/cross-compile/build.sh @@ -789,8 +789,8 @@ fi # VPX VPX_PREFIX_DIR="$DEP_DIR/libvpx" -VPX_VERSION=v1.8.2 -VPX_HASH="8735d9fcd1a781ae6917f28f239a8aa358ce4864ba113ea18af4bb2dc8b474ac" +VPX_VERSION=v1.9.0 +VPX_HASH="d279c10e4b9316bf11a570ba16c3d55791e1ad6faa4404c67422eb631782c80a" VPX_FILENAME="libvpx-$VPX_VERSION.tar.gz" if [ ! -f "$VPX_PREFIX_DIR/done" ] then From a59c960d81e44b5f61f76f900ffc0eb38d7affb0 Mon Sep 17 00:00:00 2001 From: Maxim Biro Date: Sun, 4 Oct 2020 09:16:37 -0400 Subject: [PATCH 06/10] chore(windows): update Expat to 2.2.10 --- windows/cross-compile/build.sh | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/windows/cross-compile/build.sh b/windows/cross-compile/build.sh index a4344d2bf..9f09680f7 100644 --- a/windows/cross-compile/build.sh +++ b/windows/cross-compile/build.sh @@ -1064,8 +1064,8 @@ set -u # Expat EXPAT_PREFIX_DIR="$DEP_DIR/libexpat" - EXPAT_VERSION="2.2.9" - EXPAT_HASH="1ea6965b15c2106b6bbe883397271c80dfa0331cdf821b2c319591b55eadc0a4" + EXPAT_VERSION="2.2.10" + EXPAT_HASH="5dfe538f8b5b63f03e98edac520d7d9a6a4d22e482e5c96d4d06fcc5485c25f2" EXPAT_FILENAME="expat-$EXPAT_VERSION.tar.xz" if [ ! -f "$EXPAT_PREFIX_DIR/done" ] then From 7803a7e0d602aa9d9ffeaddb071cf210ccc72764 Mon Sep 17 00:00:00 2001 From: Maxim Biro Date: Sun, 4 Oct 2020 09:38:25 -0400 Subject: [PATCH 07/10] refactor(windows): Snorenotify build script Fixing 7409e6b4cc584f1d1737e180b4066be371303801. --- windows/cross-compile/build.sh | 75 ++++++++++++++++++++++------------ 1 file changed, 49 insertions(+), 26 deletions(-) diff --git a/windows/cross-compile/build.sh b/windows/cross-compile/build.sh index 9f09680f7..ed64c60a0 100644 --- a/windows/cross-compile/build.sh +++ b/windows/cross-compile/build.sh @@ -130,10 +130,12 @@ apt-get update apt-get install -y --no-install-recommends \ autoconf \ automake \ - build-essential \ bsdtar \ + build-essential \ ca-certificates \ cmake \ + curl \ + extra-cmake-modules \ git \ libtool \ nsis \ @@ -142,10 +144,8 @@ apt-get install -y --no-install-recommends \ tclsh \ texinfo \ unzip \ - curl \ yasm \ - zip \ - extra-cmake-modules + zip if [[ "$ARCH" == "i686" ]] then @@ -664,6 +664,7 @@ else echo "Using cached build of Exif `cat $EXIF_PREFIX_DIR/done`" fi + # Snorenotify SNORE_PREFIX_DIR="$DEP_DIR/snorenotify" @@ -680,45 +681,46 @@ then bsdtar --no-same-owner --no-same-permissions -xf $SNORE_FILENAME rm $SNORE_FILENAME cd snorenotify* + mkdir _build && cd _build - PKG_CONFIG_PATH="" - PKG_CONFIG_LIBDIR="" - CMAKE_FIND_ROOT_PATH="" - for PREFIX_DIR in $DEP_DIR/*; do - if [ -d $PREFIX_DIR/lib/pkgconfig ] - then - export PKG_CONFIG_PATH="$PKG_CONFIG_PATH:$PREFIX_DIR/lib/pkgconfig" - export PKG_CONFIG_LIBDIR="$PKG_CONFIG_LIBDIR:$PREFIX_DIR/lib/pkgconfig" - fi - CMAKE_FIND_ROOT_PATH="$CMAKE_FIND_ROOT_PATH $PREFIX_DIR" - done + export PKG_CONFIG_PATH="$QT_PREFIX_DIR/lib/pkgconfig" + export PKG_CONFIG_LIBDIR="/usr/$ARCH-w64-mingw32" -echo " - SET(CMAKE_SYSTEM_NAME Windows) - SET(CMAKE_C_COMPILER $ARCH-w64-mingw32-gcc) - SET(CMAKE_CXX_COMPILER $ARCH-w64-mingw32-g++) - SET(CMAKE_RC_COMPILER $ARCH-w64-mingw32-windres) - SET(CMAKE_FIND_ROOT_PATH /usr/$ARCH-w64-mingw32 $CMAKE_FIND_ROOT_PATH) -" > toolchain.cmake + echo " + SET(CMAKE_SYSTEM_NAME Windows) - cmake -DCMAKE_TOOLCHAIN_FILE=./toolchain.cmake \ + SET(CMAKE_C_COMPILER $ARCH-w64-mingw32-gcc) + SET(CMAKE_CXX_COMPILER $ARCH-w64-mingw32-g++) + SET(CMAKE_RC_COMPILER $ARCH-w64-mingw32-windres) + + SET(CMAKE_FIND_ROOT_PATH /usr/$ARCH-w64-mingw32 $QT_PREFIX_DIR) + " > toolchain.cmake + + cmake -DCMAKE_INSTALL_PREFIX="$SNORE_PREFIX_DIR" \ -DCMAKE_BUILD_TYPE=Relase \ - -DCMAKE_INSTALL_PREFIX="$SNORE_PREFIX_DIR" \ -DBUILD_daemon=OFF \ -DBUILD_settings=OFF \ -DBUILD_snoresend=OFF \ + -DCMAKE_TOOLCHAIN_FILE=./toolchain.cmake \ .. + make make install - cd .. echo -n $SNORE_VERSION > $SNORE_PREFIX_DIR/done + + unset PKG_CONFIG_PATH + unset PKG_CONFIG_LIBDIR + + cd .. + cd .. rm -rf ./snorenotify* else echo "Using cached build of snorenotify `cat $SNORE_PREFIX_DIR/done`" fi + # Opus OPUS_PREFIX_DIR="$DEP_DIR/libopus" @@ -1285,6 +1287,7 @@ cp -r $QT_PREFIX_DIR/plugins/imageformats \ $QT_PREFIX_DIR/plugins/iconengines \ $QTOX_PREFIX_DIR cp {$OPENSSL_PREFIX_DIR,$SQLCIPHER_PREFIX_DIR,$FFMPEG_PREFIX_DIR,$OPENAL_PREFIX_DIR,$QRENCODE_PREFIX_DIR,$EXIF_PREFIX_DIR,$OPUS_PREFIX_DIR,$SODIUM_PREFIX_DIR,$VPX_PREFIX_DIR,$TOXCORE_PREFIX_DIR}/bin/*.dll $QTOX_PREFIX_DIR + cp "$SNORE_PREFIX_DIR/bin/libsnore-qt5.dll" $QTOX_PREFIX_DIR mkdir -p "$QTOX_PREFIX_DIR/libsnore-qt5" cp "$SNORE_PREFIX_DIR/lib/plugins/libsnore-qt5/libsnore_backend_windowstoast.dll" "$QTOX_PREFIX_DIR/libsnore-qt5" @@ -1304,7 +1307,7 @@ then fi winecfg -# dll checks +# qtox.exe dll checks (32-bit on i686, 64-bit on x86_64) python3 $MINGW_LDD_PREFIX_DIR/bin/mingw-ldd.py $QTOX_PREFIX_DIR/qtox.exe --dll-lookup-dirs $QTOX_PREFIX_DIR ~/.wine/drive_c/windows/system32 > /tmp/$ARCH-qtox-ldd find "$QTOX_PREFIX_DIR" -name '*.dll' > /tmp/$ARCH-qtox-dll-find # dlls loded at run time that don't showup as a link time dependency @@ -1346,6 +1349,26 @@ do done < /tmp/$ARCH-qtox-dll-find +# SnoreToast.exe dll checks (always 32-bit) +if [[ "$ARCH" == "i686" ]] +then + SNORETOAST_WINE_DLLS=/root/.wine/drive_c/windows/system32 +elif [[ "$ARCH" == "x86_64" ]] +then + SNORETOAST_WINE_DLLS=/root/.wine/drive_c/windows/syswow64 +fi + +python3 $MINGW_LDD_PREFIX_DIR/bin/mingw-ldd.py $QTOX_PREFIX_DIR/SnoreToast.exe --dll-lookup-dirs $SNORETOAST_WINE_DLLS > /tmp/$ARCH-SnoreToast-ldd + +# Check that all dlls are in place +if grep 'not found' /tmp/$ARCH-SnoreToast-ldd +then + cat /tmp/$ARCH-SnoreToast-ldd + echo "Error: Missing some dlls." + exit 1 +fi + + # Run tests (only on Travis) set +u if [[ -n "$TRAVIS_CI_STAGE" ]] From 827b2c22103489b8cdbb0ca6ba973be14181780e Mon Sep 17 00:00:00 2001 From: Maxim Biro Date: Tue, 6 Oct 2020 19:06:08 -0400 Subject: [PATCH 08/10] fix(windows): libsnore-qt5 not being installed --- windows/qtox.nsi | 5 +++++ windows/qtox64.nsi | 5 +++++ 2 files changed, 10 insertions(+) diff --git a/windows/qtox.nsi b/windows/qtox.nsi index 7910913b2..386cb5c18 100644 --- a/windows/qtox.nsi +++ b/windows/qtox.nsi @@ -266,6 +266,11 @@ Section "Install" ${SetOutPath} "$INSTDIR\bin\platforms" File /nonfatal "qtox\platforms\*.*" ${SetOutPath} "$INSTDIR\bin" + + ${CreateDirectory} "$INSTDIR\bin\libsnore-qt5" + ${SetOutPath} "$INSTDIR\bin\libsnore-qt5" + File /nonfatal "qtox\libsnore-qt5\*.*" + ${SetOutPath} "$INSTDIR\bin" # Create shortcuts ${CreateDirectory} "$SMPROGRAMS\qTox" diff --git a/windows/qtox64.nsi b/windows/qtox64.nsi index 7b751a265..3926e59ed 100755 --- a/windows/qtox64.nsi +++ b/windows/qtox64.nsi @@ -267,6 +267,11 @@ Section "Install" File /nonfatal "qtox\platforms\*.*" ${SetOutPath} "$INSTDIR\bin" + ${CreateDirectory} "$INSTDIR\bin\libsnore-qt5" + ${SetOutPath} "$INSTDIR\bin\libsnore-qt5" + File /nonfatal "qtox\libsnore-qt5\*.*" + ${SetOutPath} "$INSTDIR\bin" + # Create shortcuts ${CreateDirectory} "$SMPROGRAMS\qTox" ${CreateShortCut} "$SMPROGRAMS\qTox\qTox.lnk" "$INSTDIR\${MAIN_APP_EXE}" "" "" "" From 169009f550a4735705039b592f80a0ebcf962715 Mon Sep 17 00:00:00 2001 From: Maxim Biro Date: Tue, 6 Oct 2020 19:20:56 -0400 Subject: [PATCH 09/10] refactor(Windows): unify whitespaces in NSIS scripts While two files differ only by 3 lines, there were many unnecessary whitespace differences between them. --- windows/qtox.nsi | 191 ++++++++++++++++++++++----------------------- windows/qtox64.nsi | 97 ++++++++++++----------- 2 files changed, 143 insertions(+), 145 deletions(-) diff --git a/windows/qtox.nsi b/windows/qtox.nsi index 386cb5c18..8a1408cba 100644 --- a/windows/qtox.nsi +++ b/windows/qtox.nsi @@ -36,72 +36,71 @@ VIAddVersionKey "FileVersion" "${VERSION}" !macro AddItem Path FileWrite $UninstLog "${Path}$\r$\n" !macroend - + ;File macro !macro File FileName IfFileExists "$OUTDIR\${FileName}" +2 FileWrite $UninstLog "$OUTDIR\${FileName}$\r$\n" File "${FileName}" !macroend - + ;CreateShortcut macro !macro CreateShortcut FilePath FilePointer Pamameters Icon IconIndex FileWrite $UninstLog "${FilePath}$\r$\n" CreateShortcut "${FilePath}" "${FilePointer}" "${Pamameters}" "${Icon}" "${IconIndex}" !macroend - + ;Copy files macro !macro CopyFiles SourcePath DestPath IfFileExists "${DestPath}" +2 FileWrite $UninstLog "${DestPath}$\r$\n" CopyFiles "${SourcePath}" "${DestPath}" !macroend - + ;Rename macro !macro Rename SourcePath DestPath IfFileExists "${DestPath}" +2 FileWrite $UninstLog "${DestPath}$\r$\n" Rename "${SourcePath}" "${DestPath}" !macroend - + ;CreateDirectory macro !macro CreateDirectory Path CreateDirectory "${Path}" FileWrite $UninstLog "${Path}$\r$\n" !macroend - + ;SetOutPath macro !macro SetOutPath Path SetOutPath "${Path}" FileWrite $UninstLog "${Path}$\r$\n" !macroend - + ;WriteUninstaller macro !macro WriteUninstaller Path WriteUninstaller "${Path}" FileWrite $UninstLog "${Path}$\r$\n" !macroend - + ;WriteIniStr macro !macro WriteIniStr IniFile SectionName EntryName NewValue IfFileExists "${IniFile}" +2 FileWrite $UninstLog "${IniFile}$\r$\n" WriteIniStr "${IniFile}" "${SectionName}" "${EntryName}" "${NewValue}" !macroend - + ;WriteRegStr macro !macro WriteRegStr RegRoot UnInstallPath Key Value FileWrite $UninstLog "${RegRoot} ${UnInstallPath}$\r$\n" WriteRegStr "${RegRoot}" "${UnInstallPath}" "${Key}" "${Value}" !macroend - - + ;WriteRegDWORD macro !macro WriteRegDWORD RegRoot UnInstallPath Key Value FileWrite $UninstLog "${RegRoot} ${UnInstallPath}$\r$\n" WriteRegDWORD "${RegRoot}" "${UnInstallPath}" "${Key}" "${Value}" !macroend - + ;BackupFile macro !macro BackupFile FILE_DIR FILE BACKUP_TO IfFileExists "${BACKUP_TO}\*.*" +2 @@ -109,13 +108,13 @@ VIAddVersionKey "FileVersion" "${VERSION}" IfFileExists "${FILE_DIR}\${FILE}" 0 +2 Rename "${FILE_DIR}\${FILE}" "${BACKUP_TO}\${FILE}" !macroend - + ;RestoreFile macro !macro RestoreFile BUP_DIR FILE RESTORE_TO IfFileExists "${BUP_DIR}\${FILE}" 0 +2 Rename "${BUP_DIR}\${FILE}" "${RESTORE_TO}\${FILE}" !macroend - + ;BackupFiles macro !macro BackupFiles FILE_DIR FILE BACKUP_TO IfFileExists "${BACKUP_TO}\*.*" +2 @@ -128,7 +127,7 @@ VIAddVersionKey "FileVersion" "${VERSION}" SetOutPath "${FILE_DIR}" File "${FILE}" #After the Original file is backed up write the new file. !macroend - + ;RestoreFiles macro !macro RestoreFiles BUP_FILE RESTORE_FILE IfFileExists "${BUP_FILE}" 0 +2 @@ -141,52 +140,52 @@ VIAddVersionKey "FileVersion" "${VERSION}" ;Set the name of the uninstall log !define UninstLog "uninstall.log" Var UninstLog - + ;Uninstall log file missing. LangString UninstLogMissing ${LANG_ENGLISH} "${UninstLog} not found!$\r$\nUninstallation cannot proceed!" - + ;AddItem macro !define AddItem "!insertmacro AddItem" - + ;BackupFile macro - !define BackupFile "!insertmacro BackupFile" - + !define BackupFile "!insertmacro BackupFile" + ;BackupFiles macro - !define BackupFiles "!insertmacro BackupFiles" - + !define BackupFiles "!insertmacro BackupFiles" + ;Copy files macro !define CopyFiles "!insertmacro CopyFiles" - + ;CreateDirectory macro !define CreateDirectory "!insertmacro CreateDirectory" - + ;CreateShortcut macro !define CreateShortcut "!insertmacro CreateShortcut" - + ;File macro !define File "!insertmacro File" - + ;Rename macro !define Rename "!insertmacro Rename" - + ;RestoreFile macro - !define RestoreFile "!insertmacro RestoreFile" - + !define RestoreFile "!insertmacro RestoreFile" + ;RestoreFiles macro !define RestoreFiles "!insertmacro RestoreFiles" - + ;SetOutPath macro !define SetOutPath "!insertmacro SetOutPath" - + ;WriteRegDWORD macro - !define WriteRegDWORD "!insertmacro WriteRegDWORD" - + !define WriteRegDWORD "!insertmacro WriteRegDWORD" + ;WriteRegStr macro !define WriteRegStr "!insertmacro WriteRegStr" - + ;WriteUninstaller macro !define WriteUninstaller "!insertmacro WriteUninstaller" - + Section -openlogfile CreateDirectory "$INSTDIR" IfFileExists "$INSTDIR\${UninstLog}" +3 @@ -207,12 +206,12 @@ VIAddVersionKey "FileVersion" "${VERSION}" !insertmacro MUI_PAGE_WELCOME !insertmacro MUI_PAGE_DIRECTORY !ifdef REG_START_MENU - !define MUI_STARTMENUPAGE_NODISABLE - !define MUI_STARTMENUPAGE_DEFAULTFOLDER "qTox" - !define MUI_STARTMENUPAGE_REGISTRY_ROOT "${REG_ROOT}" - !define MUI_STARTMENUPAGE_REGISTRY_KEY "${UNINSTALL_PATH}" - !define MUI_STARTMENUPAGE_REGISTRY_VALUENAME "${REG_START_MENU}" - !insertmacro MUI_PAGE_STARTMENU Application $SM_Folder + !define MUI_STARTMENUPAGE_NODISABLE + !define MUI_STARTMENUPAGE_DEFAULTFOLDER "qTox" + !define MUI_STARTMENUPAGE_REGISTRY_ROOT "${REG_ROOT}" + !define MUI_STARTMENUPAGE_REGISTRY_KEY "${UNINSTALL_PATH}" + !define MUI_STARTMENUPAGE_REGISTRY_VALUENAME "${REG_START_MENU}" + !insertmacro MUI_PAGE_STARTMENU Application $SM_Folder !endif !insertmacro MUI_PAGE_INSTFILES @@ -243,60 +242,60 @@ FunctionEnd !insertmacro MUI_UNPAGE_FINISH !insertmacro MUI_LANGUAGE "English" - + ################# #INSTALL ################# Section "Install" - SetShellVarContext all - # Install files - ${SetOutPath} "$INSTDIR" - ${WriteUninstaller} "uninstall.exe" - - ${CreateDirectory} "$INSTDIR\bin" - ${SetOutPath} "$INSTDIR\bin" - ${File} "qtox\*.*" - - ${CreateDirectory} "$INSTDIR\bin\imageformats" - ${SetOutPath} "$INSTDIR\bin\imageformats" - File /nonfatal "qtox\imageformats\*.*" - ${SetOutPath} "$INSTDIR\bin" - - ${CreateDirectory} "$INSTDIR\bin\platforms" - ${SetOutPath} "$INSTDIR\bin\platforms" - File /nonfatal "qtox\platforms\*.*" - ${SetOutPath} "$INSTDIR\bin" - - ${CreateDirectory} "$INSTDIR\bin\libsnore-qt5" - ${SetOutPath} "$INSTDIR\bin\libsnore-qt5" - File /nonfatal "qtox\libsnore-qt5\*.*" - ${SetOutPath} "$INSTDIR\bin" + SetShellVarContext all + # Install files + ${SetOutPath} "$INSTDIR" + ${WriteUninstaller} "uninstall.exe" - # Create shortcuts - ${CreateDirectory} "$SMPROGRAMS\qTox" - ${CreateShortCut} "$SMPROGRAMS\qTox\qTox.lnk" "$INSTDIR\${MAIN_APP_EXE}" "" "" "" - ${CreateShortCut} "$SMPROGRAMS\qTox\Uninstall qTox.lnk" "$INSTDIR\uninstall.exe" "" "" "" + ${CreateDirectory} "$INSTDIR\bin" + ${SetOutPath} "$INSTDIR\bin" + ${File} "qtox\*.*" - # Write setup/app info into the registry - ${WriteRegStr} "${REG_ROOT}" "${REG_APP_PATH}" "" "$INSTDIR\${MAIN_APP_EXE}" - ${WriteRegStr} "${REG_ROOT}" "${REG_APP_PATH}" "Path" "$INSTDIR\bin\" - ${WriteRegStr} ${REG_ROOT} "${UNINSTALL_PATH}" "DisplayName" "qTox" - ${WriteRegStr} ${REG_ROOT} "${UNINSTALL_PATH}" "DisplayVersion" "1.17.2" - ${WriteRegStr} ${REG_ROOT} "${UNINSTALL_PATH}" "Publisher" "The qTox Project" - ${WriteRegStr} ${REG_ROOT} "${UNINSTALL_PATH}" "UninstallString" "$INSTDIR\uninstall.exe" - ${WriteRegStr} ${REG_ROOT} "${UNINSTALL_PATH}" "URLInfoAbout" "https://qtox.github.io" + ${CreateDirectory} "$INSTDIR\bin\imageformats" + ${SetOutPath} "$INSTDIR\bin\imageformats" + File /nonfatal "qtox\imageformats\*.*" + ${SetOutPath} "$INSTDIR\bin" - # Register the tox: protocol - ${WriteRegStr} HKCR "tox" "" "URL:tox Protocol" - ${WriteRegStr} HKCR "tox" "URL Protocol" "" - ${WriteRegStr} HKCR "tox\shell\open\command" "" "$INSTDIR\${MAIN_APP_EXE} %1" + ${CreateDirectory} "$INSTDIR\bin\platforms" + ${SetOutPath} "$INSTDIR\bin\platforms" + File /nonfatal "qtox\platforms\*.*" + ${SetOutPath} "$INSTDIR\bin" - # Register the .tox file associations - ${WriteRegStr} "HKCR" "Applications\qtox.exe\SupportedTypes" ".tox" "" - ${WriteRegStr} HKCR ".tox" "" "toxsave" - ${WriteRegStr} HKCR "toxsave" "" "Tox save file" - ${WriteRegStr} HKCR "toxsave\DefaultIcon" "" "$INSTDIR\${MAIN_APP_EXE}" - ${WriteRegStr} HKCR "toxsave\shell\open\command" "" "$INSTDIR\${MAIN_APP_EXE} %1" + ${CreateDirectory} "$INSTDIR\bin\libsnore-qt5" + ${SetOutPath} "$INSTDIR\bin\libsnore-qt5" + File /nonfatal "qtox\libsnore-qt5\*.*" + ${SetOutPath} "$INSTDIR\bin" + + # Create shortcuts + ${CreateDirectory} "$SMPROGRAMS\qTox" + ${CreateShortCut} "$SMPROGRAMS\qTox\qTox.lnk" "$INSTDIR\${MAIN_APP_EXE}" "" "" "" + ${CreateShortCut} "$SMPROGRAMS\qTox\Uninstall qTox.lnk" "$INSTDIR\uninstall.exe" "" "" "" + + # Write setup/app info into the registry + ${WriteRegStr} "${REG_ROOT}" "${REG_APP_PATH}" "" "$INSTDIR\${MAIN_APP_EXE}" + ${WriteRegStr} "${REG_ROOT}" "${REG_APP_PATH}" "Path" "$INSTDIR\bin\" + ${WriteRegStr} ${REG_ROOT} "${UNINSTALL_PATH}" "DisplayName" "qTox" + ${WriteRegStr} ${REG_ROOT} "${UNINSTALL_PATH}" "DisplayVersion" "1.17.2" + ${WriteRegStr} ${REG_ROOT} "${UNINSTALL_PATH}" "Publisher" "The qTox Project" + ${WriteRegStr} ${REG_ROOT} "${UNINSTALL_PATH}" "UninstallString" "$INSTDIR\uninstall.exe" + ${WriteRegStr} ${REG_ROOT} "${UNINSTALL_PATH}" "URLInfoAbout" "https://qtox.github.io" + + # Register the tox: protocol + ${WriteRegStr} HKCR "tox" "" "URL:tox Protocol" + ${WriteRegStr} HKCR "tox" "URL Protocol" "" + ${WriteRegStr} HKCR "tox\shell\open\command" "" "$INSTDIR\${MAIN_APP_EXE} %1" + + # Register the .tox file associations + ${WriteRegStr} "HKCR" "Applications\qtox.exe\SupportedTypes" ".tox" "" + ${WriteRegStr} HKCR ".tox" "" "toxsave" + ${WriteRegStr} HKCR "toxsave" "" "Tox save file" + ${WriteRegStr} HKCR "toxsave\DefaultIcon" "" "$INSTDIR\${MAIN_APP_EXE}" + ${WriteRegStr} HKCR "toxsave\shell\open\command" "" "$INSTDIR\${MAIN_APP_EXE} %1" SectionEnd @@ -308,28 +307,28 @@ Section Uninstall ;If there's no uninstall log, we'll try anyway to clean what we can IfFileExists "$INSTDIR\${UninstLog}" +3 Goto noLog - + Push $R0 Push $R1 Push $R2 SetFileAttributes "$INSTDIR\${UninstLog}" NORMAL FileOpen $UninstLog "$INSTDIR\${UninstLog}" r StrCpy $R1 -1 - + GetLineCount: ClearErrors FileRead $UninstLog $R0 IntOp $R1 $R1 + 1 StrCpy $R0 $R0 -2 - Push $R0 + Push $R0 IfErrors 0 GetLineCount - + Pop $R0 - + LoopRead: StrCmp $R1 0 LoopDone Pop $R0 - + IfFileExists "$R0\*.*" 0 +3 RMDir $R0 #is dir Goto +9 @@ -341,7 +340,7 @@ Section Uninstall Goto +3 StrCmp $R0 "${REG_ROOT} ${UNINSTALL_PATH}" 0 +2 DeleteRegKey ${REG_ROOT} "${UNINSTALL_PATH}" #is Reg Element - + IntOp $R1 $R1 - 1 Goto LoopRead LoopDone: @@ -354,10 +353,10 @@ Section Uninstall Pop $R2 Pop $R1 Pop $R0 - + ;Remove start menu entries RMDir /r /REBOOTOK "$SMPROGRAMS\qTox" - + ;Remove registry keys DeleteRegKey ${REG_ROOT} "${REG_APP_PATH}" DeleteRegKey ${REG_ROOT} "${UNINSTALL_PATH}" diff --git a/windows/qtox64.nsi b/windows/qtox64.nsi index 3926e59ed..020064aa6 100755 --- a/windows/qtox64.nsi +++ b/windows/qtox64.nsi @@ -95,7 +95,6 @@ VIAddVersionKey "FileVersion" "${VERSION}" WriteRegStr "${RegRoot}" "${UnInstallPath}" "${Key}" "${Value}" !macroend - ;WriteRegDWORD macro !macro WriteRegDWORD RegRoot UnInstallPath Key Value FileWrite $UninstLog "${RegRoot} ${UnInstallPath}$\r$\n" @@ -207,12 +206,12 @@ VIAddVersionKey "FileVersion" "${VERSION}" !insertmacro MUI_PAGE_WELCOME !insertmacro MUI_PAGE_DIRECTORY !ifdef REG_START_MENU - !define MUI_STARTMENUPAGE_NODISABLE - !define MUI_STARTMENUPAGE_DEFAULTFOLDER "qTox" - !define MUI_STARTMENUPAGE_REGISTRY_ROOT "${REG_ROOT}" - !define MUI_STARTMENUPAGE_REGISTRY_KEY "${UNINSTALL_PATH}" - !define MUI_STARTMENUPAGE_REGISTRY_VALUENAME "${REG_START_MENU}" - !insertmacro MUI_PAGE_STARTMENU Application $SM_Folder + !define MUI_STARTMENUPAGE_NODISABLE + !define MUI_STARTMENUPAGE_DEFAULTFOLDER "qTox" + !define MUI_STARTMENUPAGE_REGISTRY_ROOT "${REG_ROOT}" + !define MUI_STARTMENUPAGE_REGISTRY_KEY "${UNINSTALL_PATH}" + !define MUI_STARTMENUPAGE_REGISTRY_VALUENAME "${REG_START_MENU}" + !insertmacro MUI_PAGE_STARTMENU Application $SM_Folder !endif !insertmacro MUI_PAGE_INSTFILES @@ -248,56 +247,56 @@ FunctionEnd #INSTALL ################# Section "Install" - SetShellVarContext all - # Install files - ${SetOutPath} "$INSTDIR" - ${WriteUninstaller} "uninstall.exe" + SetShellVarContext all + # Install files + ${SetOutPath} "$INSTDIR" + ${WriteUninstaller} "uninstall.exe" - ${CreateDirectory} "$INSTDIR\bin" - ${SetOutPath} "$INSTDIR\bin" - ${File} "qtox\*.*" + ${CreateDirectory} "$INSTDIR\bin" + ${SetOutPath} "$INSTDIR\bin" + ${File} "qtox\*.*" - ${CreateDirectory} "$INSTDIR\bin\imageformats" - ${SetOutPath} "$INSTDIR\bin\imageformats" - File /nonfatal "qtox\imageformats\*.*" - ${SetOutPath} "$INSTDIR\bin" + ${CreateDirectory} "$INSTDIR\bin\imageformats" + ${SetOutPath} "$INSTDIR\bin\imageformats" + File /nonfatal "qtox\imageformats\*.*" + ${SetOutPath} "$INSTDIR\bin" - ${CreateDirectory} "$INSTDIR\bin\platforms" - ${SetOutPath} "$INSTDIR\bin\platforms" - File /nonfatal "qtox\platforms\*.*" - ${SetOutPath} "$INSTDIR\bin" + ${CreateDirectory} "$INSTDIR\bin\platforms" + ${SetOutPath} "$INSTDIR\bin\platforms" + File /nonfatal "qtox\platforms\*.*" + ${SetOutPath} "$INSTDIR\bin" - ${CreateDirectory} "$INSTDIR\bin\libsnore-qt5" - ${SetOutPath} "$INSTDIR\bin\libsnore-qt5" - File /nonfatal "qtox\libsnore-qt5\*.*" - ${SetOutPath} "$INSTDIR\bin" + ${CreateDirectory} "$INSTDIR\bin\libsnore-qt5" + ${SetOutPath} "$INSTDIR\bin\libsnore-qt5" + File /nonfatal "qtox\libsnore-qt5\*.*" + ${SetOutPath} "$INSTDIR\bin" - # Create shortcuts - ${CreateDirectory} "$SMPROGRAMS\qTox" - ${CreateShortCut} "$SMPROGRAMS\qTox\qTox.lnk" "$INSTDIR\${MAIN_APP_EXE}" "" "" "" - ${CreateShortCut} "$SMPROGRAMS\qTox\Uninstall qTox.lnk" "$INSTDIR\uninstall.exe" "" "" "" + # Create shortcuts + ${CreateDirectory} "$SMPROGRAMS\qTox" + ${CreateShortCut} "$SMPROGRAMS\qTox\qTox.lnk" "$INSTDIR\${MAIN_APP_EXE}" "" "" "" + ${CreateShortCut} "$SMPROGRAMS\qTox\Uninstall qTox.lnk" "$INSTDIR\uninstall.exe" "" "" "" - # Write setup/app info into the registry - SetRegView 64 - ${WriteRegStr} "${REG_ROOT}" "${REG_APP_PATH}" "" "$INSTDIR\${MAIN_APP_EXE}" - ${WriteRegStr} "${REG_ROOT}" "${REG_APP_PATH}" "Path" "$INSTDIR\bin\" - ${WriteRegStr} ${REG_ROOT} "${UNINSTALL_PATH}" "DisplayName" "qTox" - ${WriteRegStr} ${REG_ROOT} "${UNINSTALL_PATH}" "DisplayVersion" "1.17.2" - ${WriteRegStr} ${REG_ROOT} "${UNINSTALL_PATH}" "Publisher" "The qTox Project" - ${WriteRegStr} ${REG_ROOT} "${UNINSTALL_PATH}" "UninstallString" "$INSTDIR\uninstall.exe" - ${WriteRegStr} ${REG_ROOT} "${UNINSTALL_PATH}" "URLInfoAbout" "https://qtox.github.io" + # Write setup/app info into the registry + SetRegView 64 + ${WriteRegStr} "${REG_ROOT}" "${REG_APP_PATH}" "" "$INSTDIR\${MAIN_APP_EXE}" + ${WriteRegStr} "${REG_ROOT}" "${REG_APP_PATH}" "Path" "$INSTDIR\bin\" + ${WriteRegStr} ${REG_ROOT} "${UNINSTALL_PATH}" "DisplayName" "qTox" + ${WriteRegStr} ${REG_ROOT} "${UNINSTALL_PATH}" "DisplayVersion" "1.17.2" + ${WriteRegStr} ${REG_ROOT} "${UNINSTALL_PATH}" "Publisher" "The qTox Project" + ${WriteRegStr} ${REG_ROOT} "${UNINSTALL_PATH}" "UninstallString" "$INSTDIR\uninstall.exe" + ${WriteRegStr} ${REG_ROOT} "${UNINSTALL_PATH}" "URLInfoAbout" "https://qtox.github.io" - # Register the tox: protocol - ${WriteRegStr} HKCR "tox" "" "URL:tox Protocol" - ${WriteRegStr} HKCR "tox" "URL Protocol" "" - ${WriteRegStr} HKCR "tox\shell\open\command" "" "$INSTDIR\${MAIN_APP_EXE} %1" + # Register the tox: protocol + ${WriteRegStr} HKCR "tox" "" "URL:tox Protocol" + ${WriteRegStr} HKCR "tox" "URL Protocol" "" + ${WriteRegStr} HKCR "tox\shell\open\command" "" "$INSTDIR\${MAIN_APP_EXE} %1" - # Register the .tox file associations - ${WriteRegStr} "HKCR" "Applications\qtox.exe\SupportedTypes" ".tox" "" - ${WriteRegStr} HKCR ".tox" "" "toxsave" - ${WriteRegStr} HKCR "toxsave" "" "Tox save file" - ${WriteRegStr} HKCR "toxsave\DefaultIcon" "" "$INSTDIR\${MAIN_APP_EXE}" - ${WriteRegStr} HKCR "toxsave\shell\open\command" "" "$INSTDIR\${MAIN_APP_EXE} %1" + # Register the .tox file associations + ${WriteRegStr} "HKCR" "Applications\qtox.exe\SupportedTypes" ".tox" "" + ${WriteRegStr} HKCR ".tox" "" "toxsave" + ${WriteRegStr} HKCR "toxsave" "" "Tox save file" + ${WriteRegStr} HKCR "toxsave\DefaultIcon" "" "$INSTDIR\${MAIN_APP_EXE}" + ${WriteRegStr} HKCR "toxsave\shell\open\command" "" "$INSTDIR\${MAIN_APP_EXE} %1" SectionEnd From 1e50c123dc906ad61dc093526ba5b4886fd4a471 Mon Sep 17 00:00:00 2001 From: Maxim Biro Date: Tue, 6 Oct 2020 19:28:41 -0400 Subject: [PATCH 10/10] fix(windows): iconengines not being installed --- windows/qtox.nsi | 5 +++++ windows/qtox64.nsi | 5 +++++ 2 files changed, 10 insertions(+) diff --git a/windows/qtox.nsi b/windows/qtox.nsi index 8a1408cba..35d214fb3 100644 --- a/windows/qtox.nsi +++ b/windows/qtox.nsi @@ -261,6 +261,11 @@ Section "Install" File /nonfatal "qtox\imageformats\*.*" ${SetOutPath} "$INSTDIR\bin" + ${CreateDirectory} "$INSTDIR\bin\iconengines" + ${SetOutPath} "$INSTDIR\bin\iconengines" + File /nonfatal "qtox\iconengines\*.*" + ${SetOutPath} "$INSTDIR\bin" + ${CreateDirectory} "$INSTDIR\bin\platforms" ${SetOutPath} "$INSTDIR\bin\platforms" File /nonfatal "qtox\platforms\*.*" diff --git a/windows/qtox64.nsi b/windows/qtox64.nsi index 020064aa6..f1a04e1a5 100755 --- a/windows/qtox64.nsi +++ b/windows/qtox64.nsi @@ -261,6 +261,11 @@ Section "Install" File /nonfatal "qtox\imageformats\*.*" ${SetOutPath} "$INSTDIR\bin" + ${CreateDirectory} "$INSTDIR\bin\iconengines" + ${SetOutPath} "$INSTDIR\bin\iconengines" + File /nonfatal "qtox\iconengines\*.*" + ${SetOutPath} "$INSTDIR\bin" + ${CreateDirectory} "$INSTDIR\bin\platforms" ${SetOutPath} "$INSTDIR\bin\platforms" File /nonfatal "qtox\platforms\*.*"