summaryrefslogtreecommitdiffstats
path: root/CMakeScripts
diff options
context:
space:
mode:
authorEduard Braun <eduard.braun2@gmx.de>2017-07-24 19:41:12 +0000
committerEduard Braun <eduard.braun2@gmx.de>2017-07-24 20:10:54 +0000
commite6f64503b09d71e8d6c08d1956637d4f15a2dbd7 (patch)
treef960e5e1a80ad136714bd6d39140c9cb52fb6a58 /CMakeScripts
parentAdd C++ based Gtk::Action for choosing one item out of many. (diff)
downloadinkscape-e6f64503b09d71e8d6c08d1956637d4f15a2dbd7.tar.gz
inkscape-e6f64503b09d71e8d6c08d1956637d4f15a2dbd7.zip
CI/AppVeyor: Use dist-win targets and create installers on tag
Use a globbing expression to get WiX location as it's dependent on the version installed. Add note about the .msi installer still not being created properly and wix exiting with an error code (mostly to make CI happy). Somebody should figure this out eventually but the .msi format cost me too many hours of my life already...
Diffstat (limited to 'CMakeScripts')
-rw-r--r--CMakeScripts/Dist.cmake28
1 files changed, 15 insertions, 13 deletions
diff --git a/CMakeScripts/Dist.cmake b/CMakeScripts/Dist.cmake
index f54deabc4..9b40d36c8 100644
--- a/CMakeScripts/Dist.cmake
+++ b/CMakeScripts/Dist.cmake
@@ -6,9 +6,6 @@ set(INKSCAPE_DIST_PREFIX "${PROJECT_NAME}-${INKSCAPE_VERSION}")
set(INKSCAPE_SOURCE_DIR ${CMAKE_SOURCE_DIR})
include(CMakeScripts/inkscape-version.cmake)
-if(INKSCAPE_VERSION_SUFFIX AND INKSCAPE_REVISION_DATE AND INKSCAPE_REVISION_HASH)
- set(INKSCAPE_DIST_PREFIX ${INKSCAPE_DIST_PREFIX}_${INKSCAPE_REVISION_DATE}_${INKSCAPE_REVISION_HASH})
-endif()
# -----------------------------------------------------------------------------
@@ -29,6 +26,9 @@ add_custom_target(dist
# 'dist-win' - Windows Targets
# -----------------------------------------------------------------------------
if(WIN32)
+ if(INKSCAPE_REVISION_DATE AND INKSCAPE_REVISION_HASH)
+ set(INKSCAPE_DIST_PREFIX ${INKSCAPE_DIST_PREFIX}_${INKSCAPE_REVISION_DATE}_${INKSCAPE_REVISION_HASH})
+ endif()
if(HAVE_MINGW64)
set(bitness "x64")
else()
@@ -39,8 +39,8 @@ if(WIN32)
# -----------------------------------------------------------------------------
# 'dist-win-7z' - generate binary 7z archive for Windows
# -----------------------------------------------------------------------------
- find_program(7z 7z PATHS "C:\\Program Files\\7-Zip"
- "C:\\Program Files (x86)\\7-Zip")
+ find_program(7z 7z PATHS "C:/Program Files/7-Zip"
+ "C:/Program Files (x86)/7-Zip")
if(NOT 7z)
set(7z echo "Could not find '7z'. Please add it to your search path." && exit 1 &&)
endif()
@@ -65,8 +65,8 @@ if(WIN32)
# -----------------------------------------------------------------------------
# 'dist-win-exe' - generate .exe installer (NSIS) for Windows
# -----------------------------------------------------------------------------
- find_program (makensis makensis PATHS "C:\\Program Files\\NSIS"
- "C:\\Program Files (x86)\\NSIS")
+ find_program (makensis makensis PATHS "C:/Program Files/NSIS"
+ "C:/Program Files (x86)/NSIS")
if(NOT makensis)
set(makensis echo "Could not find 'makensis'. Please add it to your search path." && exit 1 &&)
endif()
@@ -90,10 +90,10 @@ if(WIN32)
# -----------------------------------------------------------------------------
# 'dist-win-msi' - generate .exe installer (NSIS) for Windows
# -----------------------------------------------------------------------------
- find_program (candle candle PATHS "C:\\Program Files\\WiX Toolset v3.10\\bin"
- "C:\\Program Files (x86)\\WiX Toolset v3.10\\bin")
- find_program (light light PATHS "C:\\Program Files\\WiX Toolset v3.10\\bin"
- "C:\\Program Files (x86)\\WiX Toolset v3.10\\bin")
+ file(GLOB wix_dirs "C:/Program Files/WiX Toolset*/bin")
+ file(GLOB wix_dirs_x86 "C:/Program Files (x86)/WiX Toolset*/bin")
+ find_program (candle candle PATHS ${wix_dirs} ${wix_dirs_x86})
+ find_program (light light PATHS ${wix_dirs} ${wix_dirs_x86})
if(NOT candle)
set(candle echo "Could not find 'candle' (part of WiX Toolset). Please add it to your search path." && exit 1 &&)
endif()
@@ -112,7 +112,8 @@ if(WIN32)
COMMAND ${candle} inkscape.wxs -ext WiXUtilExtension
COMMAND ${candle} files.wxs
COMMAND ${light} -ext WixUIExtension -ext WiXUtilExtension inkscape.wixobj files.wixobj
- -o ${CMAKE_BINARY_DIR}/${INKSCAPE_DIST_PREFIX}.msi)
+ -o ${CMAKE_BINARY_DIR}/${INKSCAPE_DIST_PREFIX}.msi
+ || echo "WiX exited with non-zero exit code (which is a known issue and usually does not prevent creation of an installer). If you can, please fix it, though!")
# moderately fast target with no compression for testing
add_custom_target(dist-win-msi-fast
@@ -126,7 +127,8 @@ if(WIN32)
COMMAND ${candle} inkscape.wxs -ext WiXUtilExtension
COMMAND ${candle} files.wxs
COMMAND ${light} -ext WixUIExtension -ext WiXUtilExtension inkscape.wixobj files.wixobj
- -o ${CMAKE_BINARY_DIR}/${INKSCAPE_DIST_PREFIX}.msi)
+ -o ${CMAKE_BINARY_DIR}/${INKSCAPE_DIST_PREFIX}.msi
+ || echo "WiX exited with non-zero exit code (which is a known issue and usually does not prevent creation of an installer). If you can, please fix it, though!")
add_dependencies(dist-win-msi install/strip)
add_dependencies(dist-win-msi-fast install/strip)