forked from osmocom/wireshark
CMake: Initial PortableApps targets.
Add portableapps_app_dir and portableapps_package targets. Change-Id: Ifea3d952eef0e267de6364999d45807236d99102 Reviewed-on: https://code.wireshark.org/review/8025 Reviewed-by: Gerald Combs <gerald@wireshark.org>
This commit is contained in:
parent
1404605513
commit
495740f801
|
@ -2139,6 +2139,16 @@ if (WIN32)
|
||||||
ADD_NSIS_UNINSTALLER_TARGET()
|
ADD_NSIS_UNINSTALLER_TARGET()
|
||||||
ADD_NSIS_PACKAGE_TARGET()
|
ADD_NSIS_PACKAGE_TARGET()
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
|
find_package( PortableApps )
|
||||||
|
if (
|
||||||
|
NOT "${PORTABLEAPPS_LAUNCHER_GENERATOR_EXECUTABLE}" STREQUAL "PORTABLEAPPS_LAUNCHER_GENERATOR_EXECUTABLE-NOTFOUND"
|
||||||
|
AND
|
||||||
|
NOT "${PORTABLEAPPS_INSTALLER_EXECUTABLE}" STREQUAL "PORTABLEAPPS_INSTALLER_EXECUTABLE-NOTFOUND"
|
||||||
|
)
|
||||||
|
add_subdirectory( packaging/portableapps EXCLUDE_FROM_ALL )
|
||||||
|
ADD_PORTABLEAPPS_PACKAGE_TARGET()
|
||||||
|
endif()
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
if(BUILD_androiddump)
|
if(BUILD_androiddump)
|
||||||
|
|
|
@ -0,0 +1,26 @@
|
||||||
|
#
|
||||||
|
# - Find PortableApps
|
||||||
|
# Find the PortableApps LauncherGenerator and Installer commands
|
||||||
|
#
|
||||||
|
# PORTABLEAPPS_LAUNCHER_GENERATOR_EXECUTABLE - path to the PortableApps.comLauncherGenerator utility.
|
||||||
|
# PORTABLEAPPS_INSTALLER_EXECUTABLE - path to the PortableApps.comInstaller utility.
|
||||||
|
|
||||||
|
# Find PortableApps.comLauncherGenerator
|
||||||
|
find_program(PORTABLEAPPS_LAUNCHER_GENERATOR_EXECUTABLE PortableApps.comLauncherGenerator
|
||||||
|
PATH
|
||||||
|
"C:/PortableApps/PortableApps.comLauncher"
|
||||||
|
"$ENV{USERPROFILE}/PortableApps/PortableApps.comLauncher"
|
||||||
|
DOC "Path to the PortableApps.comLauncherGenerator utility."
|
||||||
|
)
|
||||||
|
|
||||||
|
# Find PortableApps.comInstaller
|
||||||
|
find_program(PORTABLEAPPS_INSTALLER_EXECUTABLE PortableApps.comInstaller
|
||||||
|
PATH
|
||||||
|
"C:/PortableApps/PortableApps.comInstaller"
|
||||||
|
"$ENV{USERPROFILE}/PortableApps/PortableApps.comInstaller"
|
||||||
|
DOC "Path to the PortableApps.comInstaller utility."
|
||||||
|
)
|
||||||
|
|
||||||
|
# Assume that FindNSIS has taken care of this for us.
|
||||||
|
# set(CMAKE_INSTALL_SYSTEM_RUNTIME_LIBS_SKIP TRUE)
|
||||||
|
# include(InstallRequiredSystemLibraries)
|
|
@ -22,6 +22,14 @@
|
||||||
# We should use CPack to generate the NSIS package. Even better,
|
# We should use CPack to generate the NSIS package. Even better,
|
||||||
# we should use CPack to create a .msi using WIX.
|
# we should use CPack to create a .msi using WIX.
|
||||||
|
|
||||||
|
set(NSIS_GENERATED_FILES
|
||||||
|
${CMAKE_CURRENT_BINARY_DIR}/all-manifest.nsh
|
||||||
|
${CMAKE_CURRENT_BINARY_DIR}/config.nsh
|
||||||
|
${CMAKE_CURRENT_BINARY_DIR}/gtk-dll-manifest.nsh
|
||||||
|
${CMAKE_CURRENT_BINARY_DIR}/qt-dll-manifest.nsh
|
||||||
|
PARENT_SCOPE
|
||||||
|
)
|
||||||
|
|
||||||
set(NSIS_FILES
|
set(NSIS_FILES
|
||||||
wireshark.nsi
|
wireshark.nsi
|
||||||
uninstall.nsi
|
uninstall.nsi
|
||||||
|
@ -30,10 +38,7 @@ set(NSIS_FILES
|
||||||
servicelib.nsh
|
servicelib.nsh
|
||||||
AdditionalTasksPage.ini
|
AdditionalTasksPage.ini
|
||||||
WinPcapPage.ini
|
WinPcapPage.ini
|
||||||
${CMAKE_CURRENT_BINARY_DIR}/all-manifest.nsh
|
${NSIS_GENERATED_FILES}
|
||||||
${CMAKE_CURRENT_BINARY_DIR}/config.nsh
|
|
||||||
${CMAKE_CURRENT_BINARY_DIR}/gtk-dll-manifest.nsh
|
|
||||||
${CMAKE_CURRENT_BINARY_DIR}/qt-dll-manifest.nsh
|
|
||||||
PARENT_SCOPE
|
PARENT_SCOPE
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -198,7 +203,7 @@ macro( ADD_NSIS_UNINSTALLER_TARGET )
|
||||||
endmacro( ADD_NSIS_UNINSTALLER_TARGET )
|
endmacro( ADD_NSIS_UNINSTALLER_TARGET )
|
||||||
|
|
||||||
macro( ADD_NSIS_PACKAGE_TARGET )
|
macro( ADD_NSIS_PACKAGE_TARGET )
|
||||||
set (_nsis_package ${CMAKE_BINARY_DIR}/packaging/nsis/wireshark-$(WIRESHARK_TARGET_PLATFORM)-$(VERSION).exe)
|
set (_nsis_package ${CMAKE_BINARY_DIR}/packaging/nsis/Wireshark-$(WIRESHARK_TARGET_PLATFORM)-$(VERSION).exe)
|
||||||
|
|
||||||
add_custom_target(nsis_package
|
add_custom_target(nsis_package
|
||||||
DEPENDS
|
DEPENDS
|
||||||
|
|
|
@ -0,0 +1,116 @@
|
||||||
|
# CMakeLists.txt
|
||||||
|
#
|
||||||
|
# Wireshark - Network traffic analyzer
|
||||||
|
# By Gerald Combs <gerald@wireshark.org>
|
||||||
|
# Copyright 1998 Gerald Combs
|
||||||
|
#
|
||||||
|
# This program is free software; you can redistribute it and/or
|
||||||
|
# modify it under the terms of the GNU General Public License
|
||||||
|
# as published by the Free Software Foundation; either version 2
|
||||||
|
# of the License, or (at your option) any later version.
|
||||||
|
#
|
||||||
|
# This program is distributed in the hope that it will be useful,
|
||||||
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
# GNU General Public License for more details.
|
||||||
|
#
|
||||||
|
# You should have received a copy of the GNU General Public License
|
||||||
|
# along with this program; if not, write to the Free Software
|
||||||
|
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
#
|
||||||
|
|
||||||
|
# To do:
|
||||||
|
# - Use CPack to generate the PortableApps package.
|
||||||
|
# - Copy the C runtime DLLs if they're available.
|
||||||
|
|
||||||
|
set(PORTABLEAPPS_NAME "${CMAKE_PROJECT_NAME}Portable")
|
||||||
|
set(PORTABLEAPPS_NAME ${PORTABLEAPPS_NAME} PARENT_SCOPE)
|
||||||
|
|
||||||
|
set (_launcher_dir "${CMAKE_CURRENT_BINARY_DIR}/${PORTABLEAPPS_NAME}")
|
||||||
|
set (PORTABLEAPPS_LAUNCHER_STAGING_DIR ${_launcher_dir} PARENT_SCOPE)
|
||||||
|
|
||||||
|
set(PORTABLEAPPS_DIRS
|
||||||
|
${_launcher_dir}
|
||||||
|
${_launcher_dir}/App
|
||||||
|
${_launcher_dir}/App/AppInfo
|
||||||
|
${_launcher_dir}/App/AppInfo/Launcher
|
||||||
|
${_launcher_dir}/Data
|
||||||
|
${_launcher_dir}/Other
|
||||||
|
${_launcher_dir}/Other/Source
|
||||||
|
PARENT_SCOPE
|
||||||
|
)
|
||||||
|
|
||||||
|
macro( ADD_PORTABLEAPPS_PACKAGE_TARGET )
|
||||||
|
# Copy our binaries, libraries, and data files to the PortableApps build directory.
|
||||||
|
set(_portableapps_app_dir "${PORTABLEAPPS_LAUNCHER_STAGING_DIR}/App/${CMAKE_PROJECT_NAME}")
|
||||||
|
file(TO_NATIVE_PATH "${_portableapps_app_dir}" _portableapps_app_dir_native)
|
||||||
|
file(TO_NATIVE_PATH "${DATAFILE_DIR}" _datafile_dir_native)
|
||||||
|
file(TO_NATIVE_PATH "${CMAKE_SOURCE_DIR}/packaging/portableapps/xcopy-deploy-exclude.txt" _xcopy_deploy_exclude)
|
||||||
|
add_custom_target(portableapps_app_dir
|
||||||
|
# We "Deploy using XCopy," which is described at
|
||||||
|
# https://msdn.microsoft.com/en-us/library/ms235291.aspx
|
||||||
|
# We also assume that the project has been built at this point.
|
||||||
|
COMMAND ${CMAKE_COMMAND} -E remove_directory ${_portableapps_app_dir}
|
||||||
|
COMMAND ${CMAKE_COMMAND} -E make_directory ${_portableapps_app_dir}
|
||||||
|
COMMAND xcopy ${_datafile_dir_native} ${_portableapps_app_dir_native} /D /I /E /Y /exclude:${_xcopy_deploy_exclude}
|
||||||
|
# XXX Copy C runtime DLLs.
|
||||||
|
)
|
||||||
|
set_target_properties(portableapps_app_dir PROPERTIES FOLDER "Packaging")
|
||||||
|
|
||||||
|
#Build the PortableApps package.
|
||||||
|
set (_portableapps_package ${CMAKE_BINARY_DIR}/packaging/portableapps/WiresharkPortable_$(VERSION).exe)
|
||||||
|
add_custom_target(portableapps_package
|
||||||
|
DEPENDS
|
||||||
|
portableapps_app_dir
|
||||||
|
${_portableapps_package}
|
||||||
|
)
|
||||||
|
set_target_properties(portableapps_package PROPERTIES FOLDER "Packaging")
|
||||||
|
|
||||||
|
set(PORTABLEAPPS_PACKAGE_VERSION "${VERSION_MAJOR}.${VERSION_MINOR}.${VERSION_MICRO}.0")
|
||||||
|
configure_file(
|
||||||
|
${CMAKE_SOURCE_DIR}/packaging/portableapps/appinfo.tmpl
|
||||||
|
${PORTABLEAPPS_LAUNCHER_STAGING_DIR}/App/AppInfo/appinfo.ini
|
||||||
|
NEWLINE_STYLE WIN32
|
||||||
|
)
|
||||||
|
|
||||||
|
foreach(_portableapps_dir ${PORTABLEAPPS_DIRS})
|
||||||
|
add_custom_command(OUTPUT ${_portableapps_dir}
|
||||||
|
COMMAND ${CMAKE_COMMAND} -E make_directory ${_portableapps_dir}
|
||||||
|
)
|
||||||
|
endforeach()
|
||||||
|
|
||||||
|
set(_portableapps_launcher_ini ${PORTABLEAPPS_LAUNCHER_STAGING_DIR}/App/AppInfo/Launcher/${PORTABLEAPPS_NAME}.ini)
|
||||||
|
add_custom_command(OUTPUT ${_portableapps_launcher_ini}
|
||||||
|
DEPENDS
|
||||||
|
${PORTABLEAPPS_DIRS}
|
||||||
|
${CMAKE_SOURCE_DIR}/packaging/portableapps/${PORTABLEAPPS_NAME}.ini
|
||||||
|
COMMAND ${CMAKE_COMMAND} -E copy_if_different ${CMAKE_SOURCE_DIR}/packaging/portableapps/${PORTABLEAPPS_NAME}.ini ${_portableapps_launcher_ini}
|
||||||
|
)
|
||||||
|
|
||||||
|
set(_portableapps_launcher_exe ${PORTABLEAPPS_LAUNCHER_STAGING_DIR}/${PORTABLEAPPS_NAME}.exe)
|
||||||
|
file(TO_NATIVE_PATH "${PORTABLEAPPS_LAUNCHER_STAGING_DIR}" _portableapps_native )
|
||||||
|
add_custom_command(OUTPUT ${_portableapps_launcher_exe}
|
||||||
|
DEPENDS
|
||||||
|
${_portableapps_launcher_ini}
|
||||||
|
COMMAND ${CMAKE_COMMAND} -E copy_if_different ${CMAKE_SOURCE_DIR}/packaging/portableapps/help.html ${PORTABLEAPPS_LAUNCHER_STAGING_DIR}/help.html
|
||||||
|
COMMAND ${CMAKE_COMMAND} -E copy_if_different ${CMAKE_SOURCE_DIR}/packaging/portableapps/help.html ${PORTABLEAPPS_LAUNCHER_STAGING_DIR}/help.html
|
||||||
|
COMMAND ${CMAKE_COMMAND} -E copy_if_different ${CMAKE_SOURCE_DIR}/image/wireshark.ico ${PORTABLEAPPS_LAUNCHER_STAGING_DIR}/App/AppInfo/appicon.ico
|
||||||
|
COMMAND ${CMAKE_COMMAND} -E copy_if_different ${CMAKE_SOURCE_DIR}/image/wsicon16.png ${PORTABLEAPPS_LAUNCHER_STAGING_DIR}/App/AppInfo/appicon_16.png
|
||||||
|
COMMAND ${CMAKE_COMMAND} -E copy_if_different ${CMAKE_SOURCE_DIR}/image/wsicon32.png ${PORTABLEAPPS_LAUNCHER_STAGING_DIR}/App/AppInfo/appicon_32.png
|
||||||
|
COMMAND ${CMAKE_COMMAND} -E copy_if_different ${CMAKE_SOURCE_DIR}/image/wsicon128.png ${PORTABLEAPPS_LAUNCHER_STAGING_DIR}/App/AppInfo/appicon_128.png
|
||||||
|
COMMAND ${PORTABLEAPPS_LAUNCHER_GENERATOR_EXECUTABLE} ${_portableapps_native}
|
||||||
|
)
|
||||||
|
|
||||||
|
add_custom_command(OUTPUT ${_portableapps_package}
|
||||||
|
DEPENDS
|
||||||
|
${PORTABLEAPPS_DIRS}
|
||||||
|
${CMAKE_BINARY_DIR}/packaging/portableapps/appinfo.ini
|
||||||
|
${_portableapps_launcher_exe}
|
||||||
|
COMMAND ${PORTABLEAPPS_INSTALLER_EXECUTABLE} ${_portableapps_native}
|
||||||
|
)
|
||||||
|
endmacro( ADD_PORTABLEAPPS_PACKAGE_TARGET )
|
||||||
|
|
||||||
|
#set(CLEAN_FILES
|
||||||
|
# ${_launcher_dir}
|
||||||
|
# ${_portableapps_package}
|
||||||
|
#)
|
|
@ -19,11 +19,6 @@ SOURCE = $(OTHER)\Source
|
||||||
APPINFO_INI = $(APPINFO)\appinfo.ini
|
APPINFO_INI = $(APPINFO)\appinfo.ini
|
||||||
LAUNCHER_INI = $(LAUNCHER_DIR)\$(PROGRAM_PORTABLE).ini
|
LAUNCHER_INI = $(LAUNCHER_DIR)\$(PROGRAM_PORTABLE).ini
|
||||||
|
|
||||||
WSMANIFEST = ../wireshark.manifest
|
|
||||||
|
|
||||||
NSIS_PLUGINS = nsis-plugins
|
|
||||||
FINDPROCDLL = $(WIRESHARK_LIB_DIR)\$(NSIS_PLUGINS)\FindProcDLL.dll
|
|
||||||
|
|
||||||
COPY = xcopy
|
COPY = xcopy
|
||||||
MKDIR = mkdir
|
MKDIR = mkdir
|
||||||
COPY_FLAGS = /d /y
|
COPY_FLAGS = /d /y
|
||||||
|
@ -31,8 +26,6 @@ COPY_FLAGS = /d /y
|
||||||
WIN32_SETUP_OPT = --download
|
WIN32_SETUP_OPT = --download
|
||||||
!ENDIF
|
!ENDIF
|
||||||
|
|
||||||
NSIS_DIR = $(TOPDIR)\packaging\nsis
|
|
||||||
|
|
||||||
# XXX This should be defined in config.nmake.
|
# XXX This should be defined in config.nmake.
|
||||||
!IF EXIST("$(TOPDIR)\wireshark-qt-release\wireshark.exe")
|
!IF EXIST("$(TOPDIR)\wireshark-qt-release\wireshark.exe")
|
||||||
QT_DIR = "$(TOPDIR)\wireshark-qt-release"
|
QT_DIR = "$(TOPDIR)\wireshark-qt-release"
|
||||||
|
@ -47,7 +40,7 @@ NEED_QT4_DLL = USE
|
||||||
UPX_FLAGS = -q
|
UPX_FLAGS = -q
|
||||||
|
|
||||||
PAPPS_VERSION=$(VERSION_MAJOR).$(VERSION_MINOR).$(VERSION_MICRO).0
|
PAPPS_VERSION=$(VERSION_MAJOR).$(VERSION_MINOR).$(VERSION_MICRO).0
|
||||||
PAPPS_PACKAGE=$(PROGRAM_PORTABLE)-$(VERSION).paf.exe
|
PAPPS_PACKAGE=$(PROGRAM_PORTABLE)_$(VERSION).paf.exe
|
||||||
|
|
||||||
all: package
|
all: package
|
||||||
|
|
||||||
|
@ -77,8 +70,8 @@ dirs:
|
||||||
#!ENDIF
|
#!ENDIF
|
||||||
|
|
||||||
$(APPINFO_INI): dirs appinfo.tmpl $(TOPDIR)\config.nmake
|
$(APPINFO_INI): dirs appinfo.tmpl $(TOPDIR)\config.nmake
|
||||||
sed -e 's/$$(PAPPS_VERSION)/$(PAPPS_VERSION)/g' \
|
sed -e 's/@PORTABLEAPPS_PACKAGE_VERSION@/$(PAPPS_VERSION)/g' \
|
||||||
-e 's/$$(VERSION)/$(VERSION)/g' \
|
-e 's/@VERSION@/$(VERSION)/g' \
|
||||||
< appinfo.tmpl > $@
|
< appinfo.tmpl > $@
|
||||||
|
|
||||||
$(LAUNCHER_INI): dirs $(PROGRAM_PORTABLE).ini
|
$(LAUNCHER_INI): dirs $(PROGRAM_PORTABLE).ini
|
||||||
|
|
|
@ -19,8 +19,8 @@ Freeware=true
|
||||||
CommercialUse=true
|
CommercialUse=true
|
||||||
|
|
||||||
[Version]
|
[Version]
|
||||||
PackageVersion=$(PAPPS_VERSION)
|
PackageVersion=@PORTABLEAPPS_PACKAGE_VERSION@
|
||||||
DisplayVersion=$(VERSION)
|
DisplayVersion=@VERSION@
|
||||||
|
|
||||||
[Control]
|
[Control]
|
||||||
Icons=1
|
Icons=1
|
||||||
|
|
|
@ -0,0 +1,2 @@
|
||||||
|
.ilk
|
||||||
|
.pdb
|
Loading…
Reference in New Issue