X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;f=tools%2Fx-win%2Fpackage.sh;h=9880727906a7785352ddc77c7b94c66610a74939;hb=8671e109fcc5089226da1e539bc8b7327b2cb5bf;hp=f18af6d9fb62a17469a2cb342351aba869704347;hpb=8d80d10d6e9b73765f79679d493e1c8f27499a34;p=ardour.git diff --git a/tools/x-win/package.sh b/tools/x-win/package.sh index f18af6d9fb..9880727906 100755 --- a/tools/x-win/package.sh +++ b/tools/x-win/package.sh @@ -36,13 +36,21 @@ PROGRAM_VERSION=${major_version} LOWERCASE_DIRNAME=ardour${major_version} STATEFILE_SUFFIX=ardour # see filename_extensions.cc +BIT_SUFFIX="" + if test -n "$MIXBUS"; then - PROGRAM_NAME=Mixbus - PRODUCT_NAME=mixbus + if test "$XARCH" = "x86_64"; then + PROGRAM_NAME=Mixbus + PRODUCT_NAME=mixbus + else + PROGRAM_NAME=Mixbus + PRODUCT_NAME=mixbus + BIT_SUFFIX="(x86)" + fi fi # derived variables -PRODUCT_ID=${PROGRAM_NAME}${PROGRAM_VERSION} +PRODUCT_ID=${PROGRAM_NAME}${PROGRAM_VERSION}${BIT_SUFFIX} PRODUCT_EXE=${PRODUCT_NAME}.exe PRODUCT_ICON=${PRODUCT_NAME}.ico @@ -124,6 +132,8 @@ cp build/libs/clearlooks-newer/clearlooks.dll $DESTDIR/lib/gtk-2.0/engines/libcl cp $PREFIX/bin/*dll $DESTDIR/bin/ cp $PREFIX/lib/*dll $DESTDIR/bin/ +# special case libportaudio (wasapi), old stack has no wasapi and hence no .xp +cp $PREFIX/bin/libportaudio-2.xp $DESTDIR/bin/ || cp $PREFIX/bin/libportaudio-2.dll $DESTDIR/bin/libportaudio-2.xp rm -rf $DESTDIR/bin/libjack*.dll cp `find build/libs/surfaces/ -iname "*.dll"` $ALIBDIR/surfaces/ @@ -214,7 +224,7 @@ if ! grep " using ./waf configure" build/config.log | grep -q -- "--optimize"; t cp -r ${SRCDIR}/gdb_$WARCH $DESTDIR/gdb cat > $DESTDIR/debug.bat << EOF cd bin -START ..\\gdb\\bin\\gdb.exe -iex "set logging overwrite on" -iex "set height 0" -iex "set logging on %UserProfile%\\${PRODUCT_NAME}-debug.log" ${PRODUCT_EXE} +START ..\\gdb\\bin\\gdb.exe -iex "set logging overwrite on" -iex "set height 0" -iex "set logging on %UserProfile%\\${PRODUCT_NAME}-debug.log" -iex "target exec ${PRODUCT_EXE}" -iex "run" EOF OUTFILE="${TMPDIR}/${PRODUCT_NAME}-${ARDOURVERSION}-dbg-${WARCH}-Setup.exe" VERSIONINFO="Debug Version." @@ -225,27 +235,53 @@ fi ################################################################################ ### Mixbus plugins, etc -if test -n "$MIXBUS"; then - +if test -n "$MIXBUS"; then # TODO use separate variable mkdir -p $ALIBDIR/LV2 - METERS_VERSION=$(curl -s -S http://gareus.org/x42/win/x42-meters.latest.txt) + + echo "Adding x42 Plugins" + + METERS_VERSION=$(curl -s -S http://x42-plugins.com/x42/win/x42-meters.latest.txt) rsync -a -q --partial \ - rsync://gareus.org/x42/win/x42-meters-lv2-${WARCH}-${METERS_VERSION}.zip \ + rsync://x42-plugins.com/x42/win/x42-meters-lv2-${WARCH}-${METERS_VERSION}.zip \ "${SRCDIR}/x42-meters-lv2-${WARCH}-${METERS_VERSION}.zip" - unzip -d "$ALIBDIR/LV2/" "${SRCDIR}/x42-meters-lv2-${WARCH}-${METERS_VERSION}.zip" + unzip -q -d "$ALIBDIR/LV3/" "${SRCDIR}/x42-meters-lv2-${WARCH}-${METERS_VERSION}.zip" - SETBFREE_VERSION=$(curl -s -S http://gareus.org/x42/win/setBfree.latest.txt) + SETBFREE_VERSION=$(curl -s -S http://x42-plugins.com/x42/win/setBfree.latest.txt) rsync -a -q --partial \ - rsync://gareus.org/x42/win/setBfree-lv2-${WARCH}-${SETBFREE_VERSION}.zip \ + rsync://x42-plugins.com/x42/win/setBfree-lv2-${WARCH}-${SETBFREE_VERSION}.zip \ "${SRCDIR}/setBfree-lv2-${WARCH}-${SETBFREE_VERSION}.zip" - unzip -d "$ALIBDIR/LV2/" "${SRCDIR}/setBfree-lv2-${WARCH}-${SETBFREE_VERSION}.zip" + unzip -q -d "$ALIBDIR/LV2/" "${SRCDIR}/setBfree-lv2-${WARCH}-${SETBFREE_VERSION}.zip" - MIDIFILTER_VERSION=$(curl -s -S http://gareus.org/x42/win/x42-midifilter.latest.txt) + MIDIFILTER_VERSION=$(curl -s -S http://x42-plugins.com/x42/win/x42-midifilter.latest.txt) rsync -a -q --partial \ - rsync://gareus.org/x42/win/x42-midifilter-lv2-${WARCH}-${MIDIFILTER_VERSION}.zip \ + rsync://x42-plugins.com/x42/win/x42-midifilter-lv2-${WARCH}-${MIDIFILTER_VERSION}.zip \ "${SRCDIR}/x42-midifilter-lv2-${WARCH}-${MIDIFILTER_VERSION}.zip" - unzip -d "$ALIBDIR/LV2/" "${SRCDIR}/x42-midifilter-lv2-${WARCH}-${MIDIFILTER_VERSION}.zip" + unzip -q -d "$ALIBDIR/LV2/" "${SRCDIR}/x42-midifilter-lv2-${WARCH}-${MIDIFILTER_VERSION}.zip" +fi + +if test -n "$MIXBUS"; then # TODO use separate variable + mkdir -p $ALIBDIR/LV2 + + echo "Including Harrison LV2s" + + curl -s -S --fail -# \ + -z "${SRCDIR}/harrison_lv2s.${WARCH}.zip" \ + -o "${SRCDIR}/harrison_lv2s.${WARCH}.zip" \ + http://www.harrisonconsoles.com/mixbus/mb3/${WARCH}/harrison_lv2s.zip + unzip -q -d "$ALIBDIR/LV2/" "${SRCDIR}/harrison_lv2s.${WARCH}.zip" +fi + +if test -n "$MIXBUS"; then + echo "Deploying Harrison Mixbus Channelstrip" + + mkdir -p $ALIBDIR/ladspa/strip + curl -s -S --fail -# \ + -z "${SRCDIR}/harrison_channelstrip.${WARCH}.dll" \ + -o "${SRCDIR}/harrison_channelstrip.${WARCH}.dll" \ + http://www.harrisonconsoles.com/mixbus/mb3/${WARCH}/harrison_channelstrip.dll + cp "${SRCDIR}/harrison_channelstrip.${WARCH}.dll" \ + "$ALIBDIR/ladspa/strip/rrison_channelstrip.dll" fi ################################################################################ @@ -254,8 +290,11 @@ NSISFILE=$DESTDIR/a3.nsis if test "$WARCH" = "w64"; then PGF=PROGRAMFILES64 + SFX= else PGF=PROGRAMFILES + # TODO we should only add this for 32bit on 64bit windows! + SFX=" (x86)" fi if test -n "$QUICKZIP" ; then @@ -273,6 +312,7 @@ cat >> $NSISFILE << EOF !addincludedir "${this_script_dir}\\nsis" !include MUI2.nsh !include FileAssociation.nsh +!include WinVer.nsh Name "${PROGRAM_NAME}${PROGRAM_VERSION}" OutFile "${OUTFILE}" @@ -287,10 +327,10 @@ if test -n "$MIXBUS"; then # TODO: proper welcome/finish text. cat >> $NSISFILE << EOF -!define MUI_FINISHPAGE_TITLE "Welcome to Mixbus" -!define MUI_FINISHPAGE_TEXT "Thank you for choosing Harrison Mixbus." -!define MUI_FINISHPAGE_LINK "Harrison Consoles Website" -!define MUI_FINISHPAGE_LINK_LOCATION "http://harrisonconsoles.com" +!define MUI_FINISHPAGE_TITLE "Welcome to Harrison Mixbus" +!define MUI_FINISHPAGE_TEXT "Thanks for your purchase of Mixbus!\$\\r\$\\nYou will find the Mixbus application in the Start Menu (or the All Apps panel for Windows 8) \$\\r\$\\nClick the link below to view the Mixbus manual, and learn ways to get involved with the Mixbus community." +!define MUI_FINISHPAGE_LINK "Mixbus Manual" +!define MUI_FINISHPAGE_LINK_LOCATION "http://www.harrisonconsoles.com/mixbus/mixbus3-live-manual" !define MUI_FINISHPAGE_NOREBOOTSUPPORT EOF @@ -298,9 +338,9 @@ else cat >> $NSISFILE << EOF !define MUI_FINISHPAGE_TITLE "Welcome to Ardour" -!define MUI_FINISHPAGE_TEXT "This windows versions or Ardour is provided as-is.\$\\r\$\\nThe ardour community currently has no expertise in supporting windows users, and there are no developers focusing on windows specific issues either.\$\\r\$\\nIf you like Ardour, please consider helping out." -!define MUI_FINISHPAGE_LINK "Ardour Manual" -!define MUI_FINISHPAGE_LINK_LOCATION "http://manual.ardour.org" +!define MUI_FINISHPAGE_TEXT "This windows versions or Ardour is provided as-is.\$\\r\$\\nThe Ardour community currently has no expertise in supporting windows users, and there are no developers focusing on windows specific issues either.\$\\r\$\\nIf you like Ardour, please consider helping out." +!define MUI_FINISHPAGE_LINK "Ardour on Windows" +!define MUI_FINISHPAGE_LINK_LOCATION "http://ardour.org/windows.html" #this would run as admin - see http://forums.winamp.com/showthread.php?t=353366 #!define MUI_FINISHPAGE_RUN "\$INSTDIR\\bin\\${PRODUCT_EXE}" !define MUI_FINISHPAGE_NOREBOOTSUPPORT @@ -323,7 +363,7 @@ cat >> $NSISFILE << EOF Function .onInit ReadRegStr \$R0 HKLM \ - "Software\\Microsoft\\Windows\\CurrentVersion\\Uninstall\\${PRODUCT_ID}" \ + "Software\\Microsoft\\Windows\\CurrentVersion\\Uninstall\\${PRODUCT_ID}-${WARCH}" \ "UninstallString" StrCmp \$R0 "" done @@ -338,7 +378,7 @@ Function .onInit IfErrors uninstall_error ReadRegStr \$R1 HKLM \ - "Software\\Microsoft\\Windows\\CurrentVersion\\Uninstall\\${PRODUCT_ID}" \ + "Software\\Microsoft\\Windows\\CurrentVersion\\Uninstall\\${PRODUCT_ID}-${WARCH}" \ "UninstallString" StrCmp \$R1 "" 0 done @@ -366,12 +406,18 @@ Section "${PROGRAM_NAME}${PROGRAM_VERSION} (required)" SecMainProg File /nonfatal debug.bat File /nonfatal /r gdb WriteRegStr HKLM "Software\\${PROGRAM_NAME}\\v${PROGRAM_VERSION}\\$WARCH" "Install_Dir" "\$INSTDIR" - WriteRegStr HKLM "Software\\Microsoft\\Windows\\CurrentVersion\\Uninstall\\${PRODUCT_ID}" "DisplayName" "${PROGRAM_NAME}${PROGRAM_VERSION}" - WriteRegStr HKLM "Software\\Microsoft\\Windows\\CurrentVersion\\Uninstall\\${PRODUCT_ID}" "UninstallString" '"\$INSTDIR\\uninstall.exe"' - WriteRegDWORD HKLM "Software\\Microsoft\\Windows\\CurrentVersion\\Uninstall\\${PRODUCT_ID}" "NoModify" 1 - WriteRegDWORD HKLM "Software\\Microsoft\\Windows\\CurrentVersion\\Uninstall\\${PRODUCT_ID}" "NoRepair" 1 + WriteRegStr HKLM "Software\\Microsoft\\Windows\\CurrentVersion\\Uninstall\\${PRODUCT_ID}-${WARCH}" "DisplayName" "${PROGRAM_NAME}${PROGRAM_VERSION}" + WriteRegStr HKLM "Software\\Microsoft\\Windows\\CurrentVersion\\Uninstall\\${PRODUCT_ID}-${WARCH}" "UninstallString" '"\$INSTDIR\\uninstall.exe"' + WriteRegDWORD HKLM "Software\\Microsoft\\Windows\\CurrentVersion\\Uninstall\\${PRODUCT_ID}-${WARCH}" "NoModify" 1 + WriteRegDWORD HKLM "Software\\Microsoft\\Windows\\CurrentVersion\\Uninstall\\${PRODUCT_ID}-${WARCH}" "NoRepair" 1 WriteUninstaller "\$INSTDIR\uninstall.exe" CreateShortCut "\$INSTDIR\\${PROGRAM_NAME}${PROGRAM_VERSION}.lnk" "\$INSTDIR\\bin\\${PRODUCT_EXE}" "" "\$INSTDIR\\bin\\${PRODUCT_EXE}" 0 + \${If} \${AtMostWinXP} + Delete "\$INSTDIR\\bin\\libportaudio-2.dll" + Rename "\$INSTDIR\\bin\\libportaudio-2.xp" "\$INSTDIR\\bin\\libportaudio-2.dll" + \${Else} + Delete "\$INSTDIR\\bin\\libportaudio-2.xp" + \${EndIf} \${registerExtension} "\$INSTDIR\\bin\\${STATEFILE_SUFFIX}" ".${PRODUCT_NAME}" "${PROGRAM_NAME} Session" SectionEnd EOF @@ -391,25 +437,25 @@ fi cat >> $NSISFILE << EOF Section "Start Menu Shortcuts" SecMenu SetShellVarContext all - CreateDirectory "\$SMPROGRAMS\\${PRODUCT_ID}" - CreateShortCut "\$SMPROGRAMS\\${PRODUCT_ID}\\${PROGRAM_NAME}${PROGRAM_VERSION}.lnk" "\$INSTDIR\\bin\\${PRODUCT_EXE}" "" "\$INSTDIR\\bin\\${PRODUCT_EXE}" 0 + CreateDirectory "\$SMPROGRAMS\\${PRODUCT_ID}${SFX}" + CreateShortCut "\$SMPROGRAMS\\${PRODUCT_ID}${SFX}\\${PROGRAM_NAME}${PROGRAM_VERSION}.lnk" "\$INSTDIR\\bin\\${PRODUCT_EXE}" "" "\$INSTDIR\\bin\\${PRODUCT_EXE}" 0 EOF if test -f "$DESTDIR/debug.bat"; then cat >> $NSISFILE << EOF - CreateShortCut "\$SMPROGRAMS\\${PRODUCT_ID}\\${PROGRAM_NAME}${PROGRAM_VERSION} GDB.lnk" "\$INSTDIR\\debug.bat" "" "\$INSTDIR\\share\\ardour_bug.ico" 0 + CreateShortCut "\$SMPROGRAMS\\${PRODUCT_ID}${SFX}\\${PROGRAM_NAME}${PROGRAM_VERSION} GDB.lnk" "\$INSTDIR\\debug.bat" "" "\$INSTDIR\\share\\ardour_bug.ico" 0 EOF fi if test -z "$NOVIDEOTOOLS"; then cat >> $NSISFILE << EOF IfFileExists "\$INSTDIR\\video\\xjadeo\\xjadeo.exe" 0 +2 - CreateShortCut "\$SMPROGRAMS\\${PRODUCT_ID}\\Video Monitor.lnk" "\$INSTDIR\\video\\xjadeo\\xjadeo.exe" "" "\$INSTDIR\\video\\xjadeo\\xjadeo.exe" 0 + CreateShortCut "\$SMPROGRAMS\\${PRODUCT_ID}${SFX}\\Video Monitor.lnk" "\$INSTDIR\\video\\xjadeo\\xjadeo.exe" "" "\$INSTDIR\\video\\xjadeo\\xjadeo.exe" 0 EOF fi cat >> $NSISFILE << EOF - CreateShortCut "\$SMPROGRAMS\\${PRODUCT_ID}\\Uninstall.lnk" "\$INSTDIR\\uninstall.exe" "" "\$INSTDIR\\uninstall.exe" 0 + CreateShortCut "\$SMPROGRAMS\\${PRODUCT_ID}${SFX}\\Uninstall.lnk" "\$INSTDIR\\uninstall.exe" "" "\$INSTDIR\\uninstall.exe" 0 SectionEnd LangString DESC_SecMainProg \${LANG_ENGLISH} "${PROGRAM_NAME} ${ARDOURVERSION}\$\\r\$\\n${VERSIONINFO}\$\\r\$\\n${ARDOURDATE}" EOF @@ -437,6 +483,7 @@ cat >> $NSISFILE << EOF !insertmacro MUI_FUNCTION_DESCRIPTION_END Section "Uninstall" SetShellVarContext all + DeleteRegKey HKLM "Software\\Microsoft\\Windows\\CurrentVersion\\Uninstall\\${PRODUCT_ID}-${WARCH}" DeleteRegKey HKLM "Software\\Microsoft\\Windows\\CurrentVersion\\Uninstall\\${PRODUCT_ID}" DeleteRegKey HKLM "Software\\${PROGRAM_NAME}\\v${PROGRAM_VERSION}" RMDir /r "\$INSTDIR\\bin" @@ -448,8 +495,8 @@ Section "Uninstall" Delete "\$INSTDIR\\uninstall.exe" Delete "\$INSTDIR\\${PROGRAM_NAME}${PROGRAM_VERSION}.lnk" RMDir "\$INSTDIR" - Delete "\$SMPROGRAMS\\${PRODUCT_ID}\\*.*" - RMDir "\$SMPROGRAMS\\${PRODUCT_ID}" + Delete "\$SMPROGRAMS\\${PRODUCT_ID}${SFX}\\*.*" + RMDir "\$SMPROGRAMS\\${PRODUCT_ID}${SFX}" \${unregisterExtension} ".${STATEFILE_SUFFIX}" "${PROGRAM_NAME} Session" SectionEnd EOF