X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=tools%2Fx-win%2Fpackage.sh;h=62cb5a78e839c28f34ef0341012cc43afcad9c71;hb=a9a6d6da4e4990833d6b00b6415c2ed8d038ddda;hp=429de085dbec64279a4bb70f970f5637ed4cef4f;hpb=d22768f96f46c3c3fbb42277bfd0a316b8640778;p=ardour.git diff --git a/tools/x-win/package.sh b/tools/x-win/package.sh index 429de085db..62cb5a78e8 100755 --- a/tools/x-win/package.sh +++ b/tools/x-win/package.sh @@ -15,7 +15,8 @@ test -f gtk2_ardour/wscript || exit 1 : ${ROOT=/home/ardour} : ${MAKEFLAGS=-j4} : ${TMPDIR=/var/tmp} -: ${SRCDIR=/var/tmp/winsrc} # source-code tgz cache +: ${SRCCACHE=/var/tmp/winsrc} # source-code tgz cache +: ${HARRISONCHANNELSTRIP=harrison_channelstrip} # TODO: grep from build/config.log instead while [ $# -gt 0 ] ; do @@ -23,7 +24,10 @@ while [ $# -gt 0 ] ; do case $1 in --mixbus) MIXBUS=1 + WITH_HARRISON_LV2=1 ; + WITH_X42_LV2=1 ; shift ;; + --chanstrip) HARRISONCHANNELSTRIP=$2 ; shift; shift ;; esac done @@ -36,21 +40,13 @@ PROGRAM_VERSION=${major_version} LOWERCASE_DIRNAME=ardour${major_version} STATEFILE_SUFFIX=ardour # see filename_extensions.cc -BIT_SUFFIX="" - if test -n "$MIXBUS"; then - if test "$XARCH" = "x86_64"; then - PROGRAM_NAME=Mixbus - PRODUCT_NAME=mixbus - else - PROGRAM_NAME=Mixbus - PRODUCT_NAME=mixbus - BIT_SUFFIX="(x86)" - fi + PROGRAM_NAME=Mixbus + PRODUCT_NAME=mixbus fi # derived variables -PRODUCT_ID=${PROGRAM_NAME}${PROGRAM_VERSION}${BIT_SUFFIX} +PRODUCT_ID=${PROGRAM_NAME}${PROGRAM_VERSION} PRODUCT_EXE=${PRODUCT_NAME}.exe PRODUCT_ICON=${PRODUCT_NAME}.ico @@ -69,7 +65,7 @@ else fi : ${PREFIX=${ROOT}/win-stack-$WARCH} -export SRCDIR +export SRCCACHE if [ "$(id -u)" = "0" ]; then apt-get -y install nsis curl @@ -78,7 +74,7 @@ fi function download { echo "--- Downloading.. $2" -test -f ${SRCDIR}/$1 || curl -k -L -o ${SRCDIR}/$1 $2 +test -f ${SRCCACHE}/$1 || curl -k -L -o ${SRCCACHE}/$1 $2 } ################################################################################ @@ -123,6 +119,7 @@ cp build/libs/timecode/timecode.dll $DESTDIR/bin/ cp build/libs/qm-dsp/qmdsp-*.dll $DESTDIR/bin/ cp build/libs/canvas/canvas-*.dll $DESTDIR/bin/ cp build/libs/pbd/pbd-*.dll $DESTDIR/bin/ +cp build/libs/ptformat/ptformat-*.dll $DESTDIR/bin/ cp build/libs/audiographer/audiographer-*.dll $DESTDIR/bin/ cp build/libs/fst/ardour-vst-scanner.exe $DESTDIR/bin/ || true cp `ls -t build/gtk2_ardour/ardour-*.exe | head -n1` $DESTDIR/bin/${PRODUCT_EXE} @@ -132,6 +129,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/ @@ -182,8 +181,6 @@ echo " === bundle completed, cleaning up" echo " === complete" du -sh $DESTDIR -( cd $DESTDIR ; find . ) > ${TMPDIR}/file_list.txt - ################################################################################ ### get video tools if test -z "$NOVIDEOTOOLS"; then @@ -193,15 +190,15 @@ if test -z "$NOVIDEOTOOLS"; then rsync -a -q --partial \ rsync://ardour.org/video-tools/harvid_win-${HARVID_VERSION}.tar.xz \ - "${SRCDIR}/harvid_win-${HARVID_VERSION}.tar.xz" + "${SRCCACHE}/harvid_win-${HARVID_VERSION}.tar.xz" rsync -a -q --partial \ rsync://ardour.org/video-tools/xjadeo_win-${XJADEO_VERSION}.tar.xz \ - "${SRCDIR}/xjadeo_win-${XJADEO_VERSION}.tar.xz" + "${SRCCACHE}/xjadeo_win-${XJADEO_VERSION}.tar.xz" mkdir $DESTDIR/video - tar -xf "${SRCDIR}/harvid_win-${HARVID_VERSION}.tar.xz" -C "$DESTDIR/video/" - tar -xf "${SRCDIR}/xjadeo_win-${XJADEO_VERSION}.tar.xz" -C "$DESTDIR/video/" + tar -xf "${SRCCACHE}/harvid_win-${HARVID_VERSION}.tar.xz" -C "$DESTDIR/video/" + tar -xf "${SRCCACHE}/xjadeo_win-${XJADEO_VERSION}.tar.xz" -C "$DESTDIR/video/" echo " === unzipped" du -sh $DESTDIR/video @@ -214,12 +211,12 @@ fi ### http://sourceforge.net/projects/mingw-w64/files/Toolchains%20targetting%20Win64/Personal%20Builds/mingw-builds/4.9.1/threads-win32/sjlj/x86_64-4.9.1-release-win32-sjlj-rt_v3-rev1.7z if ! grep " using ./waf configure" build/config.log | grep -q -- "--optimize"; then download gdb-static-win3264.tar.xz http://robin.linuxaudio.org/gdb-static-win3264.tar.xz - cd ${SRCDIR} + cd ${SRCCACHE} tar xf gdb-static-win3264.tar.xz cd - > /dev/null echo " === Creating debug.bat" - cp -r ${SRCDIR}/gdb_$WARCH $DESTDIR/gdb + cp -r ${SRCCACHE}/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" -iex "target exec ${PRODUCT_EXE}" -iex "run" @@ -233,7 +230,7 @@ fi ################################################################################ ### Mixbus plugins, etc -if test -n "$MIXBUS"; then # TODO use separate variable +if test x$WITH_X42_LV2 != x ; then mkdir -p $ALIBDIR/LV2 echo "Adding x42 Plugins" @@ -241,32 +238,38 @@ if test -n "$MIXBUS"; then # TODO use separate variable METERS_VERSION=$(curl -s -S http://x42-plugins.com/x42/win/x42-meters.latest.txt) rsync -a -q --partial \ rsync://x42-plugins.com/x42/win/x42-meters-lv2-${WARCH}-${METERS_VERSION}.zip \ - "${SRCDIR}/x42-meters-lv2-${WARCH}-${METERS_VERSION}.zip" - unzip -q -d "$ALIBDIR/LV3/" "${SRCDIR}/x42-meters-lv2-${WARCH}-${METERS_VERSION}.zip" + "${SRCCACHE}/x42-meters-lv2-${WARCH}-${METERS_VERSION}.zip" + unzip -q -d "$ALIBDIR/LV2/" "${SRCCACHE}/x42-meters-lv2-${WARCH}-${METERS_VERSION}.zip" + + EQ_VERSION=$(curl -s -S http://x42-plugins.com/x42/win/x42-eq.latest.txt) + rsync -a -q --partial \ + rsync://x42-plugins.com/x42/win/x42-eq-lv2-${WARCH}-${EQ_VERSION}.zip \ + "${SRCCACHE}/x42-eq-lv2-${WARCH}-${EQ_VERSION}.zip" + unzip -q -d "$ALIBDIR/LV2/" "${SRCCACHE}/x42-eq-lv2-${WARCH}-${EQ_VERSION}.zip" SETBFREE_VERSION=$(curl -s -S http://x42-plugins.com/x42/win/setBfree.latest.txt) rsync -a -q --partial \ rsync://x42-plugins.com/x42/win/setBfree-lv2-${WARCH}-${SETBFREE_VERSION}.zip \ - "${SRCDIR}/setBfree-lv2-${WARCH}-${SETBFREE_VERSION}.zip" - unzip -q -d "$ALIBDIR/LV2/" "${SRCDIR}/setBfree-lv2-${WARCH}-${SETBFREE_VERSION}.zip" + "${SRCCACHE}/setBfree-lv2-${WARCH}-${SETBFREE_VERSION}.zip" + unzip -q -d "$ALIBDIR/LV2/" "${SRCCACHE}/setBfree-lv2-${WARCH}-${SETBFREE_VERSION}.zip" MIDIFILTER_VERSION=$(curl -s -S http://x42-plugins.com/x42/win/x42-midifilter.latest.txt) rsync -a -q --partial \ rsync://x42-plugins.com/x42/win/x42-midifilter-lv2-${WARCH}-${MIDIFILTER_VERSION}.zip \ - "${SRCDIR}/x42-midifilter-lv2-${WARCH}-${MIDIFILTER_VERSION}.zip" - unzip -q -d "$ALIBDIR/LV2/" "${SRCDIR}/x42-midifilter-lv2-${WARCH}-${MIDIFILTER_VERSION}.zip" + "${SRCCACHE}/x42-midifilter-lv2-${WARCH}-${MIDIFILTER_VERSION}.zip" + unzip -q -d "$ALIBDIR/LV2/" "${SRCCACHE}/x42-midifilter-lv2-${WARCH}-${MIDIFILTER_VERSION}.zip" fi -if test -n "$MIXBUS"; then # TODO use separate variable +if test x$WITH_HARRISON_LV2 != x ; then 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" + -z "${SRCCACHE}/harrison_lv2s.${WARCH}.zip" \ + -o "${SRCCACHE}/harrison_lv2s.${WARCH}.zip" \ + "http://www.harrisonconsoles.com/mixbus/mb3/beta/harrison-dsp/harrison_lv2s.${WARCH}.zip" + unzip -q -d "$ALIBDIR/LV2/" "${SRCCACHE}/harrison_lv2s.${WARCH}.zip" fi if test -n "$MIXBUS"; then @@ -274,14 +277,16 @@ if test -n "$MIXBUS"; then 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 + -z "${SRCCACHE}/${HARRISONCHANNELSTRIP}.${WARCH}.dll" \ + -o "${SRCCACHE}/${HARRISONCHANNELSTRIP}.${WARCH}.dll" \ + "http://www.harrisonconsoles.com/mixbus/mb3/beta/harrison-dsp/${HARRISONCHANNELSTRIP}.${WARCH}.dll" - cp "${SRCDIR}/harrison_channelstrip.${WARCH}.dll" \ - "$ALIBDIR/ladspa/strip/rrison_channelstrip.dll" + cp "${SRCCACHE}/${HARRISONCHANNELSTRIP}.${WARCH}.dll" \ + "$ALIBDIR/ladspa/strip/${HARRISONCHANNELSTRIP}.dll" fi +( cd $DESTDIR ; find . ) > ${TMPDIR}/file_list.txt + ################################################################################ echo " === Preparing Windows Installer" NSISFILE=$DESTDIR/a3.nsis @@ -310,6 +315,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}" @@ -356,44 +362,6 @@ cat >> $NSISFILE << EOF !insertmacro MUI_UNPAGE_INSTFILES !insertmacro MUI_LANGUAGE "English" - -Function .onInit - - ReadRegStr \$R0 HKLM \ - "Software\\Microsoft\\Windows\\CurrentVersion\\Uninstall\\${PRODUCT_ID}-${WARCH}" \ - "UninstallString" - StrCmp \$R0 "" done - - MessageBox MB_OKCANCEL|MB_ICONEXCLAMATION \ - "${PROGRAM_NAME} is already installed. Click 'OK' to remove the previous version or 'Cancel' to cancel this upgrade." \ - IDOK uninst - Abort - - uninst: - ClearErrors - ExecWait '\$R0 _?=\$INSTDIR' - IfErrors uninstall_error - - ReadRegStr \$R1 HKLM \ - "Software\\Microsoft\\Windows\\CurrentVersion\\Uninstall\\${PRODUCT_ID}-${WARCH}" \ - "UninstallString" - StrCmp \$R1 "" 0 done - - Delete "\$INSTDIR\\uninstall.exe" - RMDir "\$INSTDIR" - goto done - - uninstall_error: - - MessageBox MB_OK|MB_ICONEXCLAMATION \ - "Uninstaller did not complete successfully. Continue at your own risk..." \ - IDOK done - - done: - -FunctionEnd - - Section "${PROGRAM_NAME}${PROGRAM_VERSION} (required)" SecMainProg SectionIn RO SetOutPath \$INSTDIR @@ -411,6 +379,9 @@ Section "${PROGRAM_NAME}${PROGRAM_VERSION} (required)" SecMainProg CreateShortCut "\$INSTDIR\\${PROGRAM_NAME}${PROGRAM_VERSION}.lnk" "\$INSTDIR\\bin\\${PRODUCT_EXE}" "" "\$INSTDIR\\bin\\${PRODUCT_EXE}" 0 \${registerExtension} "\$INSTDIR\\bin\\${STATEFILE_SUFFIX}" ".${PRODUCT_NAME}" "${PROGRAM_NAME} Session" SectionEnd + +Section "WASAPI sound driver" SecWASAPI +SectionEnd EOF if test -z "$NOVIDEOTOOLS"; then @@ -449,6 +420,7 @@ cat >> $NSISFILE << EOF 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}" +LangString DESC_SecWASAPI \${LANG_ENGLISH} "WASAPI Audio Driver\$\\r\$\\nOnly works on Vista or later. Windows 10 Users may currently also experience issues if this is installed." EOF if test -z "$NOVIDEOTOOLS"; then @@ -461,6 +433,7 @@ cat >> $NSISFILE << EOF LangString DESC_SecMenu \${LANG_ENGLISH} "Create Start-Menu Shortcuts (recommended)." !insertmacro MUI_FUNCTION_DESCRIPTION_BEGIN !insertmacro MUI_DESCRIPTION_TEXT \${SecMainProg} \$(DESC_SecMainProg) +!insertmacro MUI_DESCRIPTION_TEXT \${SecWASAPI} \$(DESC_SecWASAPI) EOF if test -z "$NOVIDEOTOOLS"; then @@ -490,6 +463,75 @@ Section "Uninstall" RMDir "\$SMPROGRAMS\\${PRODUCT_ID}${SFX}" \${unregisterExtension} ".${STATEFILE_SUFFIX}" "${PROGRAM_NAME} Session" SectionEnd + + +Function .onInit + + ReadRegStr \$R0 HKLM \ + "Software\\Microsoft\\Windows\\CurrentVersion\\Uninstall\\${PRODUCT_ID}-${WARCH}" \ + "UninstallString" + StrCmp \$R0 "" done + + MessageBox MB_OKCANCEL|MB_ICONEXCLAMATION \ + "${PROGRAM_NAME} is already installed. Click 'OK' to remove the previous version or 'Cancel' to cancel this upgrade." \ + IDOK uninst + Abort + + uninst: + ClearErrors + ExecWait '\$R0 _?=\$INSTDIR' + IfErrors uninstall_error + + ReadRegStr \$R1 HKLM \ + "Software\\Microsoft\\Windows\\CurrentVersion\\Uninstall\\${PRODUCT_ID}-${WARCH}" \ + "UninstallString" + StrCmp \$R1 "" 0 done + + Delete "\$INSTDIR\\uninstall.exe" + RMDir "\$INSTDIR" + goto done + + uninstall_error: + + MessageBox MB_OK|MB_ICONEXCLAMATION \ + "Uninstaller did not complete successfully. Continue at your own risk..." \ + IDOK done + + done: + + \${If} \${AtMostWinXP} + SectionSetFlags \${SecWASAPI} \${SF_RO} + \${Else} + SectionSetFlags \${SecWASAPI} \${SF_SELECTED} + \${EndIf} + +FunctionEnd + +Function .onInstSuccess + + \${If} \${AtMostWinXP} + goto pa_no_wasapi + \${EndIf} + + SectionGetFlags \${SecWASAPI} \$R0 + + IntOp \$R0 \$R0 & \${SF_SELECTED} + IntCmp \$R0 \${SF_SELECTED} pa_with_wasapi pa_no_wasapi + + pa_with_wasapi: +; VISTA .. 9, libportaudio with WASAPI is good. + Delete "\$INSTDIR\\bin\\libportaudio-2.xp" + goto endportaudio + +; Windows XP lacks support for WASAPI, Windows10 on some system has issues +; http://tracker.ardour.org/view.php?id=6507 + pa_no_wasapi: + Delete "\$INSTDIR\\bin\\libportaudio-2.dll" + Rename "\$INSTDIR\\bin\\libportaudio-2.xp" "\$INSTDIR\\bin\\libportaudio-2.dll" + + endportaudio: + +FunctionEnd EOF rm -f ${OUTFILE}