mirror of
https://github.com/qgis/QGIS.git
synced 2025-04-16 00:03:12 -04:00
more mac bundling cleanup and streamlining
This commit is contained in:
parent
e6558bee07
commit
dbd9e22817
@ -1,4 +1,4 @@
|
|||||||
# Mac Bundle Macros
|
# QGIS Mac Bundle Macros
|
||||||
|
|
||||||
# BundleUtilities has functions to bundle and fixup libraries into an
|
# BundleUtilities has functions to bundle and fixup libraries into an
|
||||||
# application package, but it's all-or-nothing and is missing some features:
|
# application package, but it's all-or-nothing and is missing some features:
|
||||||
@ -6,6 +6,27 @@
|
|||||||
# - @loader_path
|
# - @loader_path
|
||||||
# - helper functions can't get install_name, just dependencies
|
# - helper functions can't get install_name, just dependencies
|
||||||
|
|
||||||
|
# the following cmakecache vars must be set, redefine them
|
||||||
|
# with config-file substitutions in install-run scripts:
|
||||||
|
#
|
||||||
|
# CPACK_PACKAGE_VERSION_MAJOR, CPACK_PACKAGE_VERSION_MINOR
|
||||||
|
# CMAKE_INSTALL_PREFIX, CMAKE_VERBOSE_MAKEFILE, CMAKE_BUILD_TYPE
|
||||||
|
# CMAKE_OSX_ARCHITECTURES, OSX_HAVE_LOADERPATH
|
||||||
|
# QGIS_APP_NAME
|
||||||
|
# QGIS_MACAPP_PREFIX
|
||||||
|
# QGIS_*_SUBDIR, QGIS_*_SUBDIR_REV
|
||||||
|
# WITH_*
|
||||||
|
|
||||||
|
# this file must only be included after target installation is complete
|
||||||
|
|
||||||
|
# message only if verbose makefiles
|
||||||
|
|
||||||
|
FUNCTION (MYMESSAGE MSG)
|
||||||
|
IF (@CMAKE_VERBOSE_MAKEFILE@)
|
||||||
|
MESSAGE (STATUS "${MSG}")
|
||||||
|
ENDIF (@CMAKE_VERBOSE_MAKEFILE@)
|
||||||
|
ENDFUNCTION (MYMESSAGE)
|
||||||
|
|
||||||
# get the install_name of a library or framework
|
# get the install_name of a library or framework
|
||||||
# regex stuff taken from GetPrerequisites
|
# regex stuff taken from GetPrerequisites
|
||||||
|
|
||||||
@ -26,9 +47,9 @@ FUNCTION (INSTALLNAMETOOL_CHANGE CHANGE CHANGETO CHANGEBIN)
|
|||||||
EXECUTE_PROCESS (COMMAND install_name_tool -change ${CHANGE} ${CHANGETO} "${CHANGEBIN}")
|
EXECUTE_PROCESS (COMMAND install_name_tool -change ${CHANGE} ${CHANGETO} "${CHANGEBIN}")
|
||||||
ENDFUNCTION (INSTALLNAMETOOL_CHANGE)
|
ENDFUNCTION (INSTALLNAMETOOL_CHANGE)
|
||||||
|
|
||||||
# copy a framework, only specified archs, current version
|
# copy a framework, only specified archs, current version, debug dep on CMAKE_BUILD_TYPE
|
||||||
# pass CMAKE_BUILD_TYPE to FWDEBUG
|
|
||||||
FUNCTION (COPY_FRAMEWORK FWPREFIX FWNAME FWARCHS FWDEBUG FWDEST)
|
FUNCTION (COPY_FRAMEWORK FWPREFIX FWNAME FWDEST)
|
||||||
# reconstruct framework to avoid excessive copying, then deleting
|
# reconstruct framework to avoid excessive copying, then deleting
|
||||||
# especially when debug variants are present
|
# especially when debug variants are present
|
||||||
# find current version
|
# find current version
|
||||||
@ -41,7 +62,7 @@ FUNCTION (COPY_FRAMEWORK FWPREFIX FWNAME FWARCHS FWDEBUG FWDEST)
|
|||||||
STRING (REGEX MATCH "[^/\n]+$" FWVER "${FWDIRPHYS}")
|
STRING (REGEX MATCH "[^/\n]+$" FWVER "${FWDIRPHYS}")
|
||||||
EXECUTE_PROCESS (COMMAND mkdir -p "${FWDEST}/${FWNAME}.framework/Versions/${FWVER}")
|
EXECUTE_PROCESS (COMMAND mkdir -p "${FWDEST}/${FWNAME}.framework/Versions/${FWVER}")
|
||||||
EXECUTE_PROCESS (COMMAND ln -sfh ${FWVER} "${FWDEST}/${FWNAME}.framework/Versions/Current")
|
EXECUTE_PROCESS (COMMAND ln -sfh ${FWVER} "${FWDEST}/${FWNAME}.framework/Versions/Current")
|
||||||
EXECUTE_PROCESS (COMMAND ditto ${FWARCHS} "${FWPREFIX}/${FWNAME}.framework/Versions/${FWVER}/${FWNAME}" "${FWDEST}/${FWNAME}.framework/Versions/${FWVER}/${FWNAME}")
|
EXECUTE_PROCESS (COMMAND ditto ${QARCHS} "${FWPREFIX}/${FWNAME}.framework/Versions/${FWVER}/${FWNAME}" "${FWDEST}/${FWNAME}.framework/Versions/${FWVER}/${FWNAME}")
|
||||||
EXECUTE_PROCESS (COMMAND ln -sf Versions/Current/${FWNAME} "${FWDEST}/${FWNAME}.framework/${FWNAME}")
|
EXECUTE_PROCESS (COMMAND ln -sf Versions/Current/${FWNAME} "${FWDEST}/${FWNAME}.framework/${FWNAME}")
|
||||||
IF (IS_DIRECTORY "${FWPREFIX}/${FWNAME}.framework/Versions/${FWVER}/Resources")
|
IF (IS_DIRECTORY "${FWPREFIX}/${FWNAME}.framework/Versions/${FWVER}/Resources")
|
||||||
EXECUTE_PROCESS (COMMAND cp -Rfp "${FWPREFIX}/${FWNAME}.framework/Versions/${FWVER}/Resources" "${FWDEST}/${FWNAME}.framework/Versions/${FWVER}")
|
EXECUTE_PROCESS (COMMAND cp -Rfp "${FWPREFIX}/${FWNAME}.framework/Versions/${FWVER}/Resources" "${FWDEST}/${FWNAME}.framework/Versions/${FWVER}")
|
||||||
@ -50,10 +71,114 @@ FUNCTION (COPY_FRAMEWORK FWPREFIX FWNAME FWARCHS FWDEBUG FWDEST)
|
|||||||
# debug variants
|
# debug variants
|
||||||
SET (FWD "${FWNAME}_debug")
|
SET (FWD "${FWNAME}_debug")
|
||||||
IF ("${FWDEBUG}" STREQUAL "Debug" AND EXISTS "${FWPREFIX}/${FWNAME}.framework/Versions/${FWVER}/${FWD}")
|
IF ("${FWDEBUG}" STREQUAL "Debug" AND EXISTS "${FWPREFIX}/${FWNAME}.framework/Versions/${FWVER}/${FWD}")
|
||||||
EXECUTE_PROCESS (COMMAND ditto ${FWARCHS} "${FWPREFIX}/${FWNAME}.framework/Versions/${FWVER}/${FWD}" "${FWDEST}/${FWNAME}.framework/Versions/${FWVER}/${FWD}")
|
EXECUTE_PROCESS (COMMAND ditto ${QARCHS} "${FWPREFIX}/${FWNAME}.framework/Versions/${FWVER}/${FWD}" "${FWDEST}/${FWNAME}.framework/Versions/${FWVER}/${FWD}")
|
||||||
EXECUTE_PROCESS (COMMAND ln -sf Versions/Current/${FWD} "${FWDEST}/${FWNAME}.framework/${FWD}")
|
EXECUTE_PROCESS (COMMAND ln -sf Versions/Current/${FWD} "${FWDEST}/${FWNAME}.framework/${FWD}")
|
||||||
IF (IS_DIRECTORY "${FWPREFIX}/${FWNAME}.framework/${FWD}.dSYM")
|
IF (IS_DIRECTORY "${FWPREFIX}/${FWNAME}.framework/${FWD}.dSYM")
|
||||||
EXECUTE_PROCESS (COMMAND ditto -X ${FWARCHS} "${FWPREFIX}/${FWNAME}.framework/${FWD}.dSYM" "${FWDEST}/${FWNAME}.framework")
|
EXECUTE_PROCESS (COMMAND ditto -X ${QARCHS} "${FWPREFIX}/${FWNAME}.framework/${FWD}.dSYM" "${FWDEST}/${FWNAME}.framework")
|
||||||
ENDIF ()
|
ENDIF ()
|
||||||
ENDIF ()
|
ENDIF ()
|
||||||
ENDFUNCTION (COPY_FRAMEWORK)
|
ENDFUNCTION (COPY_FRAMEWORK)
|
||||||
|
|
||||||
|
# update a library path in all QGIS binary files
|
||||||
|
# if dylib, change LIBFROM to LIBTO as is
|
||||||
|
# else assumes it's a framework, change LIBFROM to LIBTO.framework/LIBTO
|
||||||
|
|
||||||
|
FUNCTION (UPDATEQGISPATHS LIBFROM LIBTO)
|
||||||
|
IF (LIBFROM)
|
||||||
|
STRING (REGEX MATCH "\\.dylib$" ISLIB "${LIBTO}")
|
||||||
|
IF (ISLIB)
|
||||||
|
SET (LIBPOST "${LIBTO}")
|
||||||
|
SET (LIBMID "${QGIS_LIB_SUBDIR}")
|
||||||
|
ElSE ()
|
||||||
|
SET (LIBPOST "${LIBTO}.framework/${LIBTO}")
|
||||||
|
SET (LIBMID "${QGIS_FW_SUBDIR}")
|
||||||
|
ENDIF ()
|
||||||
|
SET (LIB_CHG_TO "${ATEXECUTABLE}/${LIBMID}/${LIBPOST}")
|
||||||
|
# app - always @executable_path
|
||||||
|
INSTALLNAMETOOL_CHANGE (${LIBFROM} ${LIB_CHG_TO} "${QAPPDIR}/${QGIS_APP_NAME}")
|
||||||
|
# qgis_help, qbrowser - doesn't link anything else than Qt/Qgis
|
||||||
|
INSTALLNAMETOOL_CHANGE (${LIBFROM} ${LIB_CHG_TO} "${QBINDIR}/qgis_help.app/Contents/MacOS/qgis_help")
|
||||||
|
INSTALLNAMETOOL_CHANGE (${LIBFROM} ${LIB_CHG_TO} "${QBINDIR}/qbrowser.app/Contents/MacOS/qbrowser")
|
||||||
|
# qgis-mapserver
|
||||||
|
IF (${WITH_MAPSERVER})
|
||||||
|
IF (${OSX_HAVE_LOADERPATH})
|
||||||
|
SET (LIB_CHG_TO "${ATEXECUTABLE}/${QGIS_CGIBIN_SUBDIR_REV}/${LIBMID}/${LIBPOST}")
|
||||||
|
ENDIF ()
|
||||||
|
INSTALLNAMETOOL_CHANGE (${LIBFROM} ${LIB_CHG_TO} "${QCGIDIR}/qgis_mapserv.fcgi")
|
||||||
|
ENDIF ()
|
||||||
|
# libs
|
||||||
|
IF (${OSX_HAVE_LOADERPATH})
|
||||||
|
# bundled frameworks can use short relative path
|
||||||
|
IF (ISLIB})
|
||||||
|
SET (LIB_CHG_TO "${ATLOADER}/${QGIS_FW_SUBDIR_REV}/${LIBMID}/${LIBPOST}")
|
||||||
|
ElSE ()
|
||||||
|
SET (LIB_CHG_TO "${ATLOADER}/../../../${LIBPOST}")
|
||||||
|
ENDIF ()
|
||||||
|
ENDIF ()
|
||||||
|
FOREACH (QL ${QGFWLIST})
|
||||||
|
INSTALLNAMETOOL_CHANGE (${LIBFROM} ${LIB_CHG_TO} "${QFWDIR}/${QL}.framework/${QL}")
|
||||||
|
ENDFOREACH (QL)
|
||||||
|
# libqgispython is not a framework
|
||||||
|
IF (${OSX_HAVE_LOADERPATH})
|
||||||
|
SET (LIB_CHG_TO "${ATLOADER}/${QGIS_LIB_SUBDIR_REV}/${LIBMID}/${LIBPOST}")
|
||||||
|
ENDIF ()
|
||||||
|
INSTALLNAMETOOL_CHANGE (${LIBFROM} ${LIB_CHG_TO} "${QLIBDIR}/libqgispython.dylib")
|
||||||
|
# GRASS libexec stuff
|
||||||
|
IF (EXISTS "${QLIBXDIR}/grass/bin/qgis.g.browser")
|
||||||
|
IF (${OSX_HAVE_LOADERPATH})
|
||||||
|
SET (LIB_CHG_TO "${ATLOADER}/../../${QGIS_LIBEXEC_SUBDIR_REV}/${LIBMID}/${LIBPOST}")
|
||||||
|
ENDIF ()
|
||||||
|
INSTALLNAMETOOL_CHANGE (${LIBFROM} ${LIB_CHG_TO} "${QLIBXDIR}/grass/bin/qgis.g.browser")
|
||||||
|
ENDIF ()
|
||||||
|
# plugins
|
||||||
|
IF (${OSX_HAVE_LOADERPATH})
|
||||||
|
SET (LIB_CHG_TO "${ATLOADER}/${QGIS_PLUGIN_SUBDIR_REV}/${LIBMID}/${LIBPOST}")
|
||||||
|
ENDIF ()
|
||||||
|
FOREACH (QP ${QGPLUGLIST})
|
||||||
|
INSTALLNAMETOOL_CHANGE (${LIBFROM} ${LIB_CHG_TO} "${QP}")
|
||||||
|
ENDFOREACH (QP)
|
||||||
|
# qgis python
|
||||||
|
IF (${OSX_HAVE_LOADERPATH})
|
||||||
|
SET (LIB_CHG_TO "${ATLOADER}/../../${QGIS_DATA_SUBDIR_REV}/${LIBMID}/${LIBPOST}")
|
||||||
|
ENDIF ()
|
||||||
|
FOREACH (PG ${QGPYLIST})
|
||||||
|
INSTALLNAMETOOL_CHANGE (${LIBFROM} ${LIB_CHG_TO} "${PG}")
|
||||||
|
ENDFOREACH (PG)
|
||||||
|
# bin - nothing yet
|
||||||
|
#IF (${OSX_HAVE_LOADERPATH})
|
||||||
|
# SET (LIB_CHG_TO "${ATLOADER}/${QGIS_BIN_SUBDIR_REV}/${LIBMID}/${LIBPOST}")
|
||||||
|
#ENDIF ()
|
||||||
|
#FOREACH (PB ...)
|
||||||
|
# INSTALLNAMETOOL_CHANGE (${LIBFROM} ${LIB_CHG_TO} "${QBINDIR}/${PB}")
|
||||||
|
#ENDFOREACH (PB)
|
||||||
|
ENDIF (LIBFROM)
|
||||||
|
ENDFUNCTION (UPDATEQGISPATHS)
|
||||||
|
|
||||||
|
SET (ATEXECUTABLE "@executable_path")
|
||||||
|
SET (ATLOADER "@loader_path")
|
||||||
|
SET (Q_FWVER ${CPACK_PACKAGE_VERSION_MAJOR}.${CPACK_PACKAGE_VERSION_MINOR})
|
||||||
|
|
||||||
|
# install destinations
|
||||||
|
SET (QAPPDIRC "$ENV{DESTDIR}${QGIS_MACAPP_PREFIX}")
|
||||||
|
SET (QAPPDIR "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}")
|
||||||
|
SET (QFWDIR "${QAPPDIR}/${QGIS_FW_SUBDIR}")
|
||||||
|
SET (QBINDIR "${QAPPDIR}/${QGIS_BIN_SUBDIR}")
|
||||||
|
SET (QCGIDIR "${QAPPDIR}/${QGIS_CGIBIN_SUBDIR}")
|
||||||
|
SET (QLIBDIR "${QAPPDIR}/${QGIS_LIB_SUBDIR}")
|
||||||
|
SET (QLIBXDIR "${QAPPDIR}/${QGIS_LIBEXEC_SUBDIR}")
|
||||||
|
SET (QDATADIR "${QAPPDIR}/${QGIS_DATA_SUBDIR}")
|
||||||
|
SET (QPLUGDIR "${QAPPDIR}/${QGIS_PLUGIN_SUBDIR}")
|
||||||
|
SET (QGISPYDIR "${QAPPDIR}/${QGIS_DATA_SUBDIR}/python")
|
||||||
|
|
||||||
|
# build arches
|
||||||
|
SET (QARCHS "")
|
||||||
|
FOREACH (QARCH ${CMAKE_OSX_ARCHITECTURES})
|
||||||
|
SET (QARCHS ${QARCHS} "--arch" "${QARCH}")
|
||||||
|
ENDFOREACH (QARCH)
|
||||||
|
|
||||||
|
# common file lists
|
||||||
|
FILE (GLOB QGFWLIST RELATIVE ${QFWDIR} ${QFWDIR}/qgis*.framework)
|
||||||
|
# for some reason, REPLACE is stripping list seps
|
||||||
|
STRING(REPLACE ".framework" ";" QGFWLIST ${QGFWLIST})
|
||||||
|
FILE (GLOB QGPLUGLIST ${QPLUGDIR}/*.so)
|
||||||
|
FILE (GLOB QGPYLIST ${QGISPYDIR}/qgis/*.so)
|
||||||
|
@ -3,6 +3,7 @@
|
|||||||
IF (APPLE)
|
IF (APPLE)
|
||||||
# for included scripts that set policies (ie OS X bundling)
|
# for included scripts that set policies (ie OS X bundling)
|
||||||
INSTALL (CODE "cmake_policy(SET CMP0011 NEW)")
|
INSTALL (CODE "cmake_policy(SET CMP0011 NEW)")
|
||||||
|
CONFIGURE_FILE (cmake/0vars.cmake.in 0vars.cmake @ONLY)
|
||||||
CONFIGURE_FILE (cmake/0qgis.cmake.in 0qgis.cmake @ONLY)
|
CONFIGURE_FILE (cmake/0qgis.cmake.in 0qgis.cmake @ONLY)
|
||||||
INSTALL (SCRIPT ${CMAKE_BINARY_DIR}/mac/0qgis.cmake)
|
INSTALL (SCRIPT ${CMAKE_BINARY_DIR}/mac/0qgis.cmake)
|
||||||
IF (QGIS_MACAPP_BUNDLE GREATER 0)
|
IF (QGIS_MACAPP_BUNDLE GREATER 0)
|
||||||
|
@ -6,39 +6,9 @@
|
|||||||
# kill boolean warnings
|
# kill boolean warnings
|
||||||
CMAKE_POLICY (SET CMP0012 NEW)
|
CMAKE_POLICY (SET CMP0012 NEW)
|
||||||
|
|
||||||
SET (QAPPDIRC "$ENV{DESTDIR}@QGIS_MACAPP_PREFIX@")
|
INCLUDE (@CMAKE_BINARY_DIR@/mac/0vars.cmake)
|
||||||
SET (QAPPDIR "$ENV{DESTDIR}@CMAKE_INSTALL_PREFIX@")
|
|
||||||
SET (QFWDIR "${QAPPDIR}/@QGIS_FW_SUBDIR@")
|
|
||||||
SET (QBINDIR "${QAPPDIR}/@QGIS_BIN_SUBDIR@")
|
|
||||||
SET (QCGIDIR "${QAPPDIR}/@QGIS_CGIBIN_SUBDIR@")
|
|
||||||
SET (QLIBDIR "${QAPPDIR}/@QGIS_LIB_SUBDIR@")
|
|
||||||
SET (QLIBXDIR "${QAPPDIR}/@QGIS_LIBEXEC_SUBDIR@")
|
|
||||||
SET (QDATADIR "${QAPPDIR}/@QGIS_DATA_SUBDIR@")
|
|
||||||
SET (QPLUGDIR "${QAPPDIR}/@QGIS_PLUGIN_SUBDIR@")
|
|
||||||
SET (QGISPYDIR "${QAPPDIR}/@QGIS_DATA_SUBDIR@/python")
|
|
||||||
SET (Q_FWVER @CPACK_PACKAGE_VERSION_MAJOR@.@CPACK_PACKAGE_VERSION_MINOR@)
|
|
||||||
# Qt framework version is major version
|
|
||||||
SET (QT_FWVER @QT_VERSION_MAJOR@)
|
|
||||||
|
|
||||||
# so config-file doesn't try to replace @
|
|
||||||
SET (ATEXECUTABLE "@executable_path")
|
|
||||||
SET (ATLOADER "@loader_path")
|
|
||||||
|
|
||||||
INCLUDE (@CMAKE_SOURCE_DIR@/cmake/MacBundleMacros.cmake)
|
INCLUDE (@CMAKE_SOURCE_DIR@/cmake/MacBundleMacros.cmake)
|
||||||
|
|
||||||
# message only if verbose makefiles
|
|
||||||
FUNCTION (MYMESSAGE MSG)
|
|
||||||
IF (@CMAKE_VERBOSE_MAKEFILE@)
|
|
||||||
MESSAGE (STATUS "${MSG}")
|
|
||||||
ENDIF (@CMAKE_VERBOSE_MAKEFILE@)
|
|
||||||
ENDFUNCTION (MYMESSAGE)
|
|
||||||
|
|
||||||
FILE (GLOB QGFWLIST RELATIVE ${QFWDIR} ${QFWDIR}/qgis*.framework)
|
|
||||||
# for some reason, REPLACE is stripping list seps
|
|
||||||
STRING(REPLACE ".framework" ";" QGFWLIST ${QGFWLIST})
|
|
||||||
FILE (GLOB QGPLUGLIST ${QPLUGDIR}/*.so)
|
|
||||||
FILE (GLOB QGPYLIST ${QGISPYDIR}/qgis/*.so)
|
|
||||||
|
|
||||||
# assume all install_names start with CMAKE_INSTALL_NAME_DIR
|
# assume all install_names start with CMAKE_INSTALL_NAME_DIR
|
||||||
# so we don't have to extract it from binaries
|
# so we don't have to extract it from binaries
|
||||||
# leave main qgis executable and qgis_help with executable_paths
|
# leave main qgis executable and qgis_help with executable_paths
|
||||||
|
42
mac/cmake/0vars.cmake.in
Normal file
42
mac/cmake/0vars.cmake.in
Normal file
@ -0,0 +1,42 @@
|
|||||||
|
# 0vars - redefine cmakecache vars, needed by all other bundling scripts
|
||||||
|
# ! cmakecache vars not available to external scripts
|
||||||
|
# so we configure it first to do substitutions
|
||||||
|
# make sure to use @varname@
|
||||||
|
|
||||||
|
# kill boolean warnings
|
||||||
|
CMAKE_POLICY (SET CMP0012 NEW)
|
||||||
|
|
||||||
|
# cmake
|
||||||
|
SET (CPACK_PACKAGE_VERSION_MAJOR @CPACK_PACKAGE_VERSION_MAJOR@)
|
||||||
|
SET (CPACK_PACKAGE_VERSION_MINOR @CPACK_PACKAGE_VERSION_MINOR@)
|
||||||
|
SET (CMAKE_VERBOSE_MAKEFILE "@CMAKE_VERBOSE_MAKEFILE@")
|
||||||
|
SET (CMAKE_INSTALL_PREFIX "@CMAKE_INSTALL_PREFIX@")
|
||||||
|
SET (CMAKE_BUILD_TYPE "@CMAKE_BUILD_TYPE@")
|
||||||
|
|
||||||
|
# OS X options
|
||||||
|
SET (CMAKE_OSX_ARCHITECTURES "@CMAKE_OSX_ARCHITECTURES@")
|
||||||
|
SET (OSX_HAVE_LOADERPATH @OSX_HAVE_LOADERPATH@)
|
||||||
|
|
||||||
|
# QGIS
|
||||||
|
SET (QGIS_APP_NAME "@QGIS_APP_NAME@")
|
||||||
|
SET (QGIS_MACAPP_PREFIX "@QGIS_MACAPP_PREFIX@")
|
||||||
|
SET (QGIS_FW_SUBDIR "@QGIS_FW_SUBDIR@")
|
||||||
|
SET (QGIS_FW_SUBDIR_REV "@QGIS_FW_SUBDIR_REV@")
|
||||||
|
SET (QGIS_BIN_SUBDIR "@QGIS_BIN_SUBDIR@")
|
||||||
|
SET (QGIS_BIN_SUBDIR_REV "@QGIS_BIN_SUBDIR_REV@")
|
||||||
|
SET (QGIS_CGIBIN_SUBDIR "@QGIS_CGIBIN_SUBDIR@")
|
||||||
|
SET (QGIS_CGIBIN_SUBDIR_REV "@QGIS_CGIBIN_SUBDIR_REV@")
|
||||||
|
SET (QGIS_LIB_SUBDIR "@QGIS_LIB_SUBDIR@")
|
||||||
|
SET (QGIS_LIB_SUBDIR_REV "@QGIS_LIB_SUBDIR_REV@")
|
||||||
|
SET (QGIS_LIBEXEC_SUBDIR "@QGIS_LIBEXEC_SUBDIR@")
|
||||||
|
SET (QGIS_LIBEXEC_SUBDIR_REV "@QGIS_LIBEXEC_SUBDIR_REV@")
|
||||||
|
SET (QGIS_PLUGIN_SUBDIR "@QGIS_PLUGIN_SUBDIR@")
|
||||||
|
SET (QGIS_PLUGIN_SUBDIR_REV "@QGIS_PLUGIN_SUBDIR_REV@")
|
||||||
|
SET (QGIS_DATA_SUBDIR "@QGIS_DATA_SUBDIR@")
|
||||||
|
SET (QGIS_DATA_SUBDIR_REV "@QGIS_DATA_SUBDIR_REV@")
|
||||||
|
|
||||||
|
# optional components
|
||||||
|
SET (WITH_GLOBE "@WITH_GLOBE@")
|
||||||
|
SET (WITH_GRASS "@WITH_GRASS@")
|
||||||
|
SET (WITH_MAPSERVER "@WITH_MAPSERVER@")
|
||||||
|
SET (WITH_POSTGRESQL "@WITH_POSTGRESQL@")
|
@ -6,31 +6,11 @@
|
|||||||
# kill boolean warnings
|
# kill boolean warnings
|
||||||
CMAKE_POLICY (SET CMP0012 NEW)
|
CMAKE_POLICY (SET CMP0012 NEW)
|
||||||
|
|
||||||
SET (QAPPDIRC "$ENV{DESTDIR}@QGIS_MACAPP_PREFIX@")
|
INCLUDE (@CMAKE_BINARY_DIR@/mac/0vars.cmake)
|
||||||
SET (QAPPDIR "$ENV{DESTDIR}@CMAKE_INSTALL_PREFIX@")
|
|
||||||
SET (QFWDIR "${QAPPDIR}/@QGIS_FW_SUBDIR@")
|
|
||||||
SET (QBINDIR "${QAPPDIR}/@QGIS_BIN_SUBDIR@")
|
|
||||||
SET (QCGIDIR "${QAPPDIR}/@QGIS_CGIBIN_SUBDIR@")
|
|
||||||
SET (QLIBDIR "${QAPPDIR}/@QGIS_LIB_SUBDIR@")
|
|
||||||
SET (QLIBXDIR "${QAPPDIR}/@QGIS_LIBEXEC_SUBDIR@")
|
|
||||||
SET (QDATADIR "${QAPPDIR}/@QGIS_DATA_SUBDIR@")
|
|
||||||
SET (QPLUGDIR "${QAPPDIR}/@QGIS_PLUGIN_SUBDIR@")
|
|
||||||
SET (QGISPYDIR "${QAPPDIR}/@QGIS_DATA_SUBDIR@/python")
|
|
||||||
# Qt framework version is major version
|
|
||||||
SET (QT_FWVER @QT_VERSION_MAJOR@)
|
|
||||||
|
|
||||||
# so config-file doesn't try to replace @
|
|
||||||
SET (ATEXECUTABLE "@executable_path")
|
|
||||||
SET (ATLOADER "@loader_path")
|
|
||||||
|
|
||||||
INCLUDE (@CMAKE_SOURCE_DIR@/cmake/MacBundleMacros.cmake)
|
INCLUDE (@CMAKE_SOURCE_DIR@/cmake/MacBundleMacros.cmake)
|
||||||
|
|
||||||
# message only if verbose makefiles
|
# Qt framework version is major version
|
||||||
FUNCTION (MYMESSAGE MSG)
|
SET (QT_FWVER @QT_VERSION_MAJOR@)
|
||||||
IF (@CMAKE_VERBOSE_MAKEFILE@)
|
|
||||||
MESSAGE (STATUS "${MSG}")
|
|
||||||
ENDIF (@CMAKE_VERBOSE_MAKEFILE@)
|
|
||||||
ENDFUNCTION (MYMESSAGE)
|
|
||||||
|
|
||||||
# build list of Qt frameworks to bundle
|
# build list of Qt frameworks to bundle
|
||||||
|
|
||||||
@ -75,12 +55,6 @@ IF (@OSGEARTH_FOUND@)
|
|||||||
ENDIF (@OSGEARTH_FOUND@)
|
ENDIF (@OSGEARTH_FOUND@)
|
||||||
MYMESSAGE ("Qt list: ${QTLISTQG}")
|
MYMESSAGE ("Qt list: ${QTLISTQG}")
|
||||||
|
|
||||||
# build arches
|
|
||||||
FOREACH (QARCH @CMAKE_OSX_ARCHITECTURES@)
|
|
||||||
SET (QARCHS ${QARCHS} "--arch" "${QARCH}")
|
|
||||||
ENDFOREACH (QARCH)
|
|
||||||
MYMESSAGE("Archs: ${QARCHS}")
|
|
||||||
|
|
||||||
# symlinks when only @executable_path used
|
# symlinks when only @executable_path used
|
||||||
|
|
||||||
IF (NOT @OSX_HAVE_LOADERPATH@)
|
IF (NOT @OSX_HAVE_LOADERPATH@)
|
||||||
@ -91,13 +65,15 @@ IF (NOT @OSX_HAVE_LOADERPATH@)
|
|||||||
EXECUTE_PROCESS (COMMAND ln -sfh @QGIS_CGIBIN_SUBDIR_REV@/@QGIS_LIB_SUBDIR@ "${QCGIDIR}/lib")
|
EXECUTE_PROCESS (COMMAND ln -sfh @QGIS_CGIBIN_SUBDIR_REV@/@QGIS_LIB_SUBDIR@ "${QCGIDIR}/lib")
|
||||||
ENDIF (NOT @OSX_HAVE_LOADERPATH@)
|
ENDIF (NOT @OSX_HAVE_LOADERPATH@)
|
||||||
|
|
||||||
|
### copy files
|
||||||
|
|
||||||
# Qt frameworks
|
# Qt frameworks
|
||||||
|
|
||||||
MESSAGE (STATUS "Copying Qt frameworks...")
|
MESSAGE (STATUS "Copying Qt frameworks...")
|
||||||
EXECUTE_PROCESS (COMMAND mkdir -p "${QFWDIR}")
|
EXECUTE_PROCESS (COMMAND mkdir -p "${QFWDIR}")
|
||||||
FOREACH (QFW ${QTLISTQG})
|
FOREACH (QFW ${QTLISTQG})
|
||||||
IF (NOT IS_DIRECTORY "${QFWDIR}/${QFW}.framework")
|
IF (NOT IS_DIRECTORY "${QFWDIR}/${QFW}.framework")
|
||||||
COPY_FRAMEWORK("@QT_LIBRARY_DIR@" ${QFW} "${QARCHS}" @CMAKE_BUILD_TYPE@ "${QFWDIR}")
|
COPY_FRAMEWORK("@QT_LIBRARY_DIR@" ${QFW} "${QFWDIR}")
|
||||||
ENDIF ()
|
ENDIF ()
|
||||||
ENDFOREACH (QFW)
|
ENDFOREACH (QFW)
|
||||||
|
|
||||||
@ -190,13 +166,7 @@ FILE (WRITE "${QAPPDIRC}/Resources/qt.conf" "")
|
|||||||
FILE (WRITE "${QBINDIR}/qgis_help.app/Contents/Resources/qt.conf" "")
|
FILE (WRITE "${QBINDIR}/qgis_help.app/Contents/Resources/qt.conf" "")
|
||||||
FILE (WRITE "${QBINDIR}/qbrowser.app/Contents/Resources/qt.conf" "")
|
FILE (WRITE "${QBINDIR}/qbrowser.app/Contents/Resources/qt.conf" "")
|
||||||
|
|
||||||
FILE (GLOB QGFWLIST RELATIVE ${QFWDIR} ${QFWDIR}/qgis*.framework)
|
### update lib paths
|
||||||
# for some reason, REPLACE is stripping list seps
|
|
||||||
STRING(REPLACE ".framework" ";" QGFWLIST ${QGFWLIST})
|
|
||||||
FILE (GLOB QGPLUGLIST ${QPLUGDIR}/*.so)
|
|
||||||
FILE (GLOB QGPYLIST ${QGISPYDIR}/qgis/*.so)
|
|
||||||
|
|
||||||
# main Qt framework loop
|
|
||||||
|
|
||||||
MESSAGE (STATUS "Updating Qt library paths...")
|
MESSAGE (STATUS "Updating Qt library paths...")
|
||||||
|
|
||||||
@ -205,83 +175,46 @@ FOREACH (QFW ${QTLISTQG})
|
|||||||
# from a previous install attempt
|
# from a previous install attempt
|
||||||
GET_INSTALL_NAME ("@QT_LIBRARY_DIR@/${QFW}.framework/${QFW}" ${QFW}.framework QQ)
|
GET_INSTALL_NAME ("@QT_LIBRARY_DIR@/${QFW}.framework/${QFW}" ${QFW}.framework QQ)
|
||||||
SET (QFW_CHG "${QQ}")
|
SET (QFW_CHG "${QQ}")
|
||||||
SET (QFW_CHG_TO "${ATEXECUTABLE}/@QGIS_FW_SUBDIR@/${QFW}.framework/${QFW}")
|
# qgis stuff
|
||||||
# app - always @executable_path
|
UPDATEQGISPATHS ("${QFW_CHG}" ${QFW})
|
||||||
INSTALLNAMETOOL_CHANGE (${QFW_CHG} ${QFW_CHG_TO} "${QAPPDIR}/@QGIS_APP_NAME@")
|
|
||||||
# qgis_help, qbrowser - use symlink, even when have loader_path,
|
SET (LIBPOST "${QFW}.framework/${QFW}")
|
||||||
# applications behave better that way
|
# Qwt
|
||||||
INSTALLNAMETOOL_CHANGE (${QFW_CHG} ${QFW_CHG_TO} "${QBINDIR}/qgis_help.app/Contents/MacOS/qgis_help")
|
IF (@OSX_HAVE_LOADERPATH@)
|
||||||
INSTALLNAMETOOL_CHANGE (${QFW_CHG} ${QFW_CHG_TO} "${QBINDIR}/qbrowser.app/Contents/MacOS/qbrowser")
|
SET (QFW_CHG_TO "${ATLOADER}/${QGIS_LIB_SUBDIR_REV}/${QGIS_FW_SUBDIR}/${LIBPOST}")
|
||||||
# qgis-mapserver
|
ENDIF ()
|
||||||
IF (@WITH_MAPSERVER@)
|
INSTALLNAMETOOL_CHANGE (${QFW_CHG} ${QFW_CHG_TO} "${QLIBDIR}/libqwt.dylib")
|
||||||
IF (@OSX_HAVE_LOADERPATH@)
|
# qt plugs
|
||||||
SET (QFW_CHG_TO "${ATEXECUTABLE}/@QGIS_CGIBIN_SUBDIR_REV@/@QGIS_FW_SUBDIR@/${QFW}.framework/${QFW}")
|
IF (@OSX_HAVE_LOADERPATH@)
|
||||||
ENDIF (@OSX_HAVE_LOADERPATH@)
|
SET (QFW_CHG_TO "${ATLOADER}/@QGIS_PLUGIN_SUBDIR_REV@/${QGIS_FW_SUBDIR}/${LIBPOST}")
|
||||||
INSTALLNAMETOOL_CHANGE (${QFW_CHG} ${QFW_CHG_TO} "${QCGIDIR}/qgis_mapserv.fcgi")
|
|
||||||
ENDIF ()
|
ENDIF ()
|
||||||
# libs
|
|
||||||
IF (@OSX_HAVE_LOADERPATH@)
|
|
||||||
SET (QFW_CHG_TO "${ATLOADER}/../../../${QFW}.framework/${QFW}")
|
|
||||||
ENDIF (@OSX_HAVE_LOADERPATH@)
|
|
||||||
FOREACH (QL ${QGFWLIST})
|
|
||||||
INSTALLNAMETOOL_CHANGE (${QFW_CHG} ${QFW_CHG_TO} "${QFWDIR}/${QL}.framework/${QL}")
|
|
||||||
ENDFOREACH (QL)
|
|
||||||
# libqgispython is not a framework
|
|
||||||
IF (@OSX_HAVE_LOADERPATH@)
|
|
||||||
SET (QFW_CHG_TO "${ATLOADER}/@QGIS_LIB_SUBDIR_REV@/@QGIS_FW_SUBDIR@/${QFW}.framework/${QFW}")
|
|
||||||
ENDIF (@OSX_HAVE_LOADERPATH@)
|
|
||||||
INSTALLNAMETOOL_CHANGE (${QFW_CHG} ${QFW_CHG_TO} "${QLIBDIR}/libqgispython.dylib")
|
|
||||||
IF (@OSX_HAVE_LOADERPATH@)
|
|
||||||
SET (QFW_CHG_TO "${ATLOADER}/@QGIS_LIB_SUBDIR_REV@/@QGIS_FW_SUBDIR@/${QFW}.framework/${QFW}")
|
|
||||||
ENDIF (@OSX_HAVE_LOADERPATH@)
|
|
||||||
# Qwt
|
|
||||||
INSTALLNAMETOOL_CHANGE (${QFW_CHG} ${QFW_CHG_TO} "${QLIBDIR}/libqwt.dylib")
|
|
||||||
# GRASS libexec stuff
|
|
||||||
IF (EXISTS "${QLIBXDIR}/grass/bin/qgis.g.browser")
|
|
||||||
IF (@OSX_HAVE_LOADERPATH@)
|
|
||||||
SET (QFW_CHG_TO "${ATLOADER}/../../@QGIS_LIBEXEC_SUBDIR_REV@/@QGIS_FW_SUBDIR@/${QFW}.framework/${QFW}")
|
|
||||||
ENDIF (@OSX_HAVE_LOADERPATH@)
|
|
||||||
INSTALLNAMETOOL_CHANGE (${QFW_CHG} ${QFW_CHG_TO} "${QLIBXDIR}/grass/bin/qgis.g.browser")
|
|
||||||
ENDIF ()
|
|
||||||
# plugins
|
|
||||||
IF (@OSX_HAVE_LOADERPATH@)
|
|
||||||
SET (QFW_CHG_TO "${ATLOADER}/@QGIS_PLUGIN_SUBDIR_REV@/@QGIS_FW_SUBDIR@/${QFW}.framework/${QFW}")
|
|
||||||
ENDIF (@OSX_HAVE_LOADERPATH@)
|
|
||||||
FOREACH (QP ${QGPLUGLIST})
|
|
||||||
INSTALLNAMETOOL_CHANGE (${QFW_CHG} ${QFW_CHG_TO} "${QP}")
|
|
||||||
ENDFOREACH (QP)
|
|
||||||
# qt plugs - same relative path
|
|
||||||
INSTALLNAMETOOL_CHANGE (${QFW_CHG} ${QFW_CHG_TO} "${QAPPDIRC}/PlugIns/imageformats/libqjpeg.dylib")
|
INSTALLNAMETOOL_CHANGE (${QFW_CHG} ${QFW_CHG_TO} "${QAPPDIRC}/PlugIns/imageformats/libqjpeg.dylib")
|
||||||
FOREACH (QC cn;jp;kr;tw)
|
FOREACH (QC cn;jp;kr;tw)
|
||||||
INSTALLNAMETOOL_CHANGE (${QFW_CHG} ${QFW_CHG_TO} "${QAPPDIRC}/PlugIns/codecs/libq${QC}codecs.dylib")
|
INSTALLNAMETOOL_CHANGE (${QFW_CHG} ${QFW_CHG_TO} "${QAPPDIRC}/PlugIns/codecs/libq${QC}codecs.dylib")
|
||||||
ENDFOREACH (QC)
|
ENDFOREACH (QC)
|
||||||
# qt fw
|
# qt fw
|
||||||
IF (@OSX_HAVE_LOADERPATH@)
|
IF (@OSX_HAVE_LOADERPATH@)
|
||||||
SET (QFW_CHG_TO "${ATLOADER}/../../../${QFW}.framework/${QFW}")
|
SET (QFW_CHG_TO "${ATLOADER}/../../../${LIBPOST}")
|
||||||
ENDIF (@OSX_HAVE_LOADERPATH@)
|
ENDIF ()
|
||||||
FOREACH (QF ${QTLISTQG})
|
FOREACH (QF ${QTLISTQG})
|
||||||
INSTALLNAMETOOL_CHANGE (${QFW_CHG} ${QFW_CHG_TO} "${QFWDIR}/${QF}.framework/${QF}")
|
INSTALLNAMETOOL_CHANGE (${QFW_CHG} ${QFW_CHG_TO} "${QFWDIR}/${QF}.framework/${QF}")
|
||||||
ENDFOREACH (QF)
|
ENDFOREACH (QF)
|
||||||
# PyQt
|
# PyQt
|
||||||
IF (@OSX_HAVE_LOADERPATH@)
|
IF (@OSX_HAVE_LOADERPATH@)
|
||||||
SET (QFW_CHG_TO "${ATLOADER}/../../@QGIS_DATA_SUBDIR_REV@/@QGIS_FW_SUBDIR@/${QFW}.framework/${QFW}")
|
SET (QFW_CHG_TO "${ATLOADER}/../../@QGIS_DATA_SUBDIR_REV@/${QGIS_FW_SUBDIR}/${LIBPOST}")
|
||||||
ENDIF (@OSX_HAVE_LOADERPATH@)
|
ENDIF ()
|
||||||
FOREACH (PQ ${PYQTLIST})
|
FOREACH (PQ ${PYQTLIST})
|
||||||
INSTALLNAMETOOL_CHANGE (${QFW_CHG} ${QFW_CHG_TO} "${QGISPYDIR}/PyQt${QT_FWVER}/${PQ}.so")
|
INSTALLNAMETOOL_CHANGE (${QFW_CHG} ${QFW_CHG_TO} "${QGISPYDIR}/PyQt${QT_FWVER}/${PQ}.so")
|
||||||
ENDFOREACH (PQ)
|
ENDFOREACH (PQ)
|
||||||
# qgis python
|
|
||||||
FOREACH (PG ${QGPYLIST})
|
|
||||||
INSTALLNAMETOOL_CHANGE (${QFW_CHG} ${QFW_CHG_TO} "${PG}")
|
|
||||||
ENDFOREACH (PG)
|
|
||||||
# PyQwt
|
# PyQwt
|
||||||
IF (@OSX_HAVE_LOADERPATH@)
|
IF (@OSX_HAVE_LOADERPATH@)
|
||||||
SET (QFW_CHG_TO "${ATLOADER}/../../../@QGIS_DATA_SUBDIR_REV@/@QGIS_FW_SUBDIR@/${QFW}.framework/${QFW}")
|
SET (QFW_CHG_TO "${ATLOADER}/../../../@QGIS_DATA_SUBDIR_REV@/${QGIS_FW_SUBDIR}/${LIBPOST}")
|
||||||
ENDIF (@OSX_HAVE_LOADERPATH@)
|
ENDIF ()
|
||||||
FOREACH (PW _iqt;Qwt)
|
FOREACH (PW _iqt;Qwt)
|
||||||
INSTALLNAMETOOL_CHANGE (${QFW_CHG} ${QFW_CHG_TO} "${QGISPYDIR}/PyQt${QT_FWVER}/Qwt5/${PW}.so")
|
INSTALLNAMETOOL_CHANGE (${QFW_CHG} ${QFW_CHG_TO} "${QGISPYDIR}/PyQt${QT_FWVER}/Qwt5/${PW}.so")
|
||||||
ENDFOREACH (PW)
|
ENDFOREACH (PW)
|
||||||
# bin - PyQt utils
|
# bin - PyQt utils
|
||||||
SET (QFW_CHG_TO "${ATEXECUTABLE}/@QGIS_BIN_SUBDIR_REV@/@QGIS_FW_SUBDIR@/${QFW}.framework/${QFW}")
|
SET (QFW_CHG_TO "${ATEXECUTABLE}/@QGIS_BIN_SUBDIR_REV@/${QGIS_FW_SUBDIR}/${LIBPOST}")
|
||||||
FOREACH (PB pylupdate4;pyrcc4)
|
FOREACH (PB pylupdate4;pyrcc4)
|
||||||
INSTALLNAMETOOL_CHANGE (${QFW_CHG} ${QFW_CHG_TO} "${QBINDIR}/${PB}")
|
INSTALLNAMETOOL_CHANGE (${QFW_CHG} ${QFW_CHG_TO} "${QBINDIR}/${PB}")
|
||||||
ENDFOREACH (PB)
|
ENDFOREACH (PB)
|
||||||
|
@ -10,94 +10,9 @@
|
|||||||
# kill boolean warnings
|
# kill boolean warnings
|
||||||
CMAKE_POLICY (SET CMP0012 NEW)
|
CMAKE_POLICY (SET CMP0012 NEW)
|
||||||
|
|
||||||
SET (QAPPDIRC "$ENV{DESTDIR}@QGIS_MACAPP_PREFIX@")
|
INCLUDE (@CMAKE_BINARY_DIR@/mac/0vars.cmake)
|
||||||
SET (QAPPDIR "$ENV{DESTDIR}@CMAKE_INSTALL_PREFIX@")
|
|
||||||
SET (QFWDIR "${QAPPDIR}/@QGIS_FW_SUBDIR@")
|
|
||||||
SET (QBINDIR "${QAPPDIR}/@QGIS_BIN_SUBDIR@")
|
|
||||||
SET (QCGIDIR "${QAPPDIR}/@QGIS_CGIBIN_SUBDIR@")
|
|
||||||
SET (QLIBDIR "${QAPPDIR}/@QGIS_LIB_SUBDIR@")
|
|
||||||
SET (QLIBXDIR "${QAPPDIR}/@QGIS_LIBEXEC_SUBDIR@")
|
|
||||||
SET (QDATADIR "${QAPPDIR}/@QGIS_DATA_SUBDIR@")
|
|
||||||
SET (QPLUGDIR "${QAPPDIR}/@QGIS_PLUGIN_SUBDIR@")
|
|
||||||
SET (QGISPYDIR "${QAPPDIR}/@QGIS_DATA_SUBDIR@/python")
|
|
||||||
# Qt framework version is major version
|
|
||||||
SET (QT_FWVER @QT_VERSION_MAJOR@)
|
|
||||||
|
|
||||||
# so config-file doesn't try to replace @
|
|
||||||
SET (ATEXECUTABLE "@executable_path")
|
|
||||||
SET (ATLOADER "@loader_path")
|
|
||||||
|
|
||||||
INCLUDE (@CMAKE_SOURCE_DIR@/cmake/MacBundleMacros.cmake)
|
INCLUDE (@CMAKE_SOURCE_DIR@/cmake/MacBundleMacros.cmake)
|
||||||
|
|
||||||
# message only if verbose makefiles
|
|
||||||
FUNCTION (MYMESSAGE MSG)
|
|
||||||
IF (@CMAKE_VERBOSE_MAKEFILE@)
|
|
||||||
MESSAGE (STATUS "${MSG}")
|
|
||||||
ENDIF (@CMAKE_VERBOSE_MAKEFILE@)
|
|
||||||
ENDFUNCTION (MYMESSAGE)
|
|
||||||
|
|
||||||
FUNCTION (UPDATEQGISPATHS LIBFROM LIBTO)
|
|
||||||
IF (LIBFROM)
|
|
||||||
SET (LIB_CHG_TO "${ATEXECUTABLE}/@QGIS_LIB_SUBDIR@/${LIBTO}")
|
|
||||||
# app - always @executable_path
|
|
||||||
INSTALLNAMETOOL_CHANGE (${LIBFROM} ${LIB_CHG_TO} "${QAPPDIR}/@QGIS_APP_NAME@")
|
|
||||||
# qgis_help, qbrowser - doesn't link anything else than Qt/Qgis
|
|
||||||
# qgis-mapserver
|
|
||||||
IF (@WITH_MAPSERVER@)
|
|
||||||
IF (@OSX_HAVE_LOADERPATH@)
|
|
||||||
SET (LIB_CHG_TO "${ATEXECUTABLE}/@QGIS_CGIBIN_SUBDIR_REV@/@QGIS_LIB_SUBDIR@/${LIBTO}")
|
|
||||||
ENDIF (@OSX_HAVE_LOADERPATH@)
|
|
||||||
INSTALLNAMETOOL_CHANGE (${LIBFROM} ${LIB_CHG_TO} "${QCGIDIR}/qgis_mapserv.fcgi")
|
|
||||||
ENDIF ()
|
|
||||||
# libs
|
|
||||||
IF (@OSX_HAVE_LOADERPATH@)
|
|
||||||
SET (LIB_CHG_TO "${ATLOADER}/@QGIS_LIB_SUBDIR_REV@/@QGIS_LIB_SUBDIR@/${LIBTO}")
|
|
||||||
ENDIF (@OSX_HAVE_LOADERPATH@)
|
|
||||||
FOREACH (QL ${QGFWLIST})
|
|
||||||
INSTALLNAMETOOL_CHANGE (${LIBFROM} ${LIB_CHG_TO} "${QFWDIR}/${QL}.framework/${QL}")
|
|
||||||
ENDFOREACH (QL)
|
|
||||||
# GRASS libexec stuff
|
|
||||||
#IF (EXISTS "${QLIBXDIR}/grass/bin/qgis.g.browser")
|
|
||||||
# IF (@OSX_HAVE_LOADERPATH@)
|
|
||||||
# SET (LIB_CHG_TO "${ATLOADER}/../../@QGIS_LIBEXEC_SUBDIR_REV@/@QGIS_LIB_SUBDIR@/${LIBTO}")
|
|
||||||
# ENDIF (@OSX_HAVE_LOADERPATH@)
|
|
||||||
# INSTALLNAMETOOL_CHANGE (${LIBFROM} ${LIB_CHG_TO} "${QLIBXDIR}/grass/bin/qgis.g.browser")
|
|
||||||
#ENDIF ()
|
|
||||||
# plugins
|
|
||||||
IF (@OSX_HAVE_LOADERPATH@)
|
|
||||||
SET (LIB_CHG_TO "${ATLOADER}/@QGIS_PLUGIN_SUBDIR_REV@/@QGIS_LIB_SUBDIR@/${LIBTO}")
|
|
||||||
ENDIF (@OSX_HAVE_LOADERPATH@)
|
|
||||||
FOREACH (QP ${QGPLUGLIST})
|
|
||||||
INSTALLNAMETOOL_CHANGE (${LIBFROM} ${LIB_CHG_TO} "${QP}")
|
|
||||||
ENDFOREACH (QP)
|
|
||||||
# qgis python
|
|
||||||
IF (@OSX_HAVE_LOADERPATH@)
|
|
||||||
SET (LIB_CHG_TO "${ATLOADER}/../../@QGIS_DATA_SUBDIR_REV@/@QGIS_LIB_SUBDIR@/${LIBTO}")
|
|
||||||
ENDIF (@OSX_HAVE_LOADERPATH@)
|
|
||||||
FOREACH (PG ${QGPYLIST})
|
|
||||||
INSTALLNAMETOOL_CHANGE (${LIBFROM} ${LIB_CHG_TO} "${PG}")
|
|
||||||
ENDFOREACH (PG)
|
|
||||||
# bin - nothing yet
|
|
||||||
#IF (@OSX_HAVE_LOADERPATH@)
|
|
||||||
# SET (LIB_CHG_TO "${ATLOADER}/@QGIS_BIN_SUBDIR_REV@/@QGIS_LIB_SUBDIR@/${LIBTO}")
|
|
||||||
#ENDIF (@OSX_HAVE_LOADERPATH@)
|
|
||||||
#FOREACH (PB ...)
|
|
||||||
# INSTALLNAMETOOL_CHANGE (${LIBFROM} ${LIB_CHG_TO} "${QBINDIR}/${PB}")
|
|
||||||
#ENDFOREACH (PB)
|
|
||||||
ENDIF (LIBFROM)
|
|
||||||
ENDFUNCTION (UPDATEQGISPATHS)
|
|
||||||
|
|
||||||
# arches
|
|
||||||
FOREACH (QARCH @CMAKE_OSX_ARCHITECTURES@)
|
|
||||||
SET (QARCHS ${QARCHS} "--arch" "${QARCH}")
|
|
||||||
ENDFOREACH (QARCH)
|
|
||||||
|
|
||||||
FILE (GLOB QGFWLIST RELATIVE ${QFWDIR} ${QFWDIR}/qgis*.framework)
|
|
||||||
# for some reason, REPLACE is stripping list seps
|
|
||||||
STRING(REPLACE ".framework" ";" QGFWLIST ${QGFWLIST})
|
|
||||||
FILE (GLOB QGPLUGLIST ${QPLUGDIR}/*.so)
|
|
||||||
FILE (GLOB QGPYLIST ${QGISPYDIR}/qgis/*.so)
|
|
||||||
|
|
||||||
# Postgres
|
# Postgres
|
||||||
|
|
||||||
IF (@POSTGRES_LIBRARY@ MATCHES ".*libpq.dylib")
|
IF (@POSTGRES_LIBRARY@ MATCHES ".*libpq.dylib")
|
||||||
|
@ -3,89 +3,13 @@
|
|||||||
# so we configure it first to do substitutions
|
# so we configure it first to do substitutions
|
||||||
# make sure to use @varname@
|
# make sure to use @varname@
|
||||||
|
|
||||||
MESSAGE (STATUS "Bundling frameworks is not functional yet, skipping...")
|
MESSAGE (STATUS "Bundling other frameworks is not functional yet, skipping...")
|
||||||
|
|
||||||
# kill boolean warnings
|
# kill boolean warnings
|
||||||
CMAKE_POLICY (SET CMP0012 NEW)
|
CMAKE_POLICY (SET CMP0012 NEW)
|
||||||
|
|
||||||
SET (QAPPDIRC "$ENV{DESTDIR}@QGIS_MACAPP_PREFIX@")
|
INCLUDE (@CMAKE_BINARY_DIR@/mac/0vars.cmake)
|
||||||
SET (QAPPDIR "$ENV{DESTDIR}@CMAKE_INSTALL_PREFIX@")
|
|
||||||
SET (QFWDIR "${QAPPDIR}/@QGIS_FW_SUBDIR@")
|
|
||||||
SET (QBINDIR "${QAPPDIR}/@QGIS_BIN_SUBDIR@")
|
|
||||||
SET (QCGIDIR "${QAPPDIR}/@QGIS_CGIBIN_SUBDIR@")
|
|
||||||
SET (QLIBDIR "${QAPPDIR}/@QGIS_LIB_SUBDIR@")
|
|
||||||
SET (QLIBXDIR "${QAPPDIR}/@QGIS_LIBEXEC_SUBDIR@")
|
|
||||||
SET (QDATADIR "${QAPPDIR}/@QGIS_DATA_SUBDIR@")
|
|
||||||
SET (QPLUGDIR "${QAPPDIR}/@QGIS_PLUGIN_SUBDIR@")
|
|
||||||
SET (QGISPYDIR "${QAPPDIR}/@QGIS_DATA_SUBDIR@/python")
|
|
||||||
# Qt framework version is major version
|
|
||||||
SET (QT_FWVER @QT_VERSION_MAJOR@)
|
|
||||||
|
|
||||||
# so config-file doesn't try to replace @
|
|
||||||
SET (ATEXECUTABLE "@executable_path")
|
|
||||||
SET (ATLOADER "@loader_path")
|
|
||||||
|
|
||||||
INCLUDE (@CMAKE_SOURCE_DIR@/cmake/MacBundleMacros.cmake)
|
INCLUDE (@CMAKE_SOURCE_DIR@/cmake/MacBundleMacros.cmake)
|
||||||
|
|
||||||
FUNCTION (UPDATEQGISPATHS LIBFROM LIBTO)
|
|
||||||
IF (LIBFROM)
|
|
||||||
SET (LIB_CHG_TO "${ATEXECUTABLE}/@QGIS_LIB_SUBDIR@/${LIBTO}")
|
|
||||||
# app - always @executable_path
|
|
||||||
INSTALLNAMETOOL_CHANGE (${LIBFROM} ${LIB_CHG_TO} "${QAPPDIR}/@QGIS_APP_NAME@")
|
|
||||||
# qgis_help - doesn't link anything else than Qt/Qgis
|
|
||||||
# qgis-mapserver
|
|
||||||
IF (@WITH_MAPSERVER@)
|
|
||||||
IF (@OSX_HAVE_LOADERPATH@)
|
|
||||||
SET (LIB_CHG_TO "${ATEXECUTABLE}/@QGIS_CGIBIN_SUBDIR_REV@/@QGIS_LIB_SUBDIR@/${LIBTO}")
|
|
||||||
ENDIF (@OSX_HAVE_LOADERPATH@)
|
|
||||||
INSTALLNAMETOOL_CHANGE (${LIBFROM} ${LIB_CHG_TO} "${QCGIDIR}/qgis_mapserv.fcgi")
|
|
||||||
ENDIF ()
|
|
||||||
# libs
|
|
||||||
IF (@OSX_HAVE_LOADERPATH@)
|
|
||||||
SET (LIB_CHG_TO "${ATLOADER}/@QGIS_LIB_SUBDIR_REV@/@QGIS_LIB_SUBDIR@/${LIBTO}")
|
|
||||||
ENDIF (@OSX_HAVE_LOADERPATH@)
|
|
||||||
FOREACH (QL ${QGLIBLIST})
|
|
||||||
INSTALLNAMETOOL_CHANGE (${LIBFROM} ${LIB_CHG_TO} "${QL}")
|
|
||||||
ENDFOREACH (QL)
|
|
||||||
# GRASS libexec stuff
|
|
||||||
#IF (EXISTS "${QLIBXDIR}/grass/bin/qgis.g.browser")
|
|
||||||
# IF (@OSX_HAVE_LOADERPATH@)
|
|
||||||
# SET (LIB_CHG_TO "${ATLOADER}/../../@QGIS_LIBEXEC_SUBDIR_REV@/@QGIS_LIB_SUBDIR@/${LIBTO}")
|
|
||||||
# ENDIF (@OSX_HAVE_LOADERPATH@)
|
|
||||||
# INSTALLNAMETOOL_CHANGE (${LIBFROM} ${LIB_CHG_TO} "${QLIBXDIR}/grass/bin/qgis.g.browser")
|
|
||||||
#ENDIF ()
|
|
||||||
# plugins
|
|
||||||
IF (@OSX_HAVE_LOADERPATH@)
|
|
||||||
SET (LIB_CHG_TO "${ATLOADER}/@QGIS_PLUGIN_SUBDIR_REV@/@QGIS_LIB_SUBDIR@/${LIBTO}")
|
|
||||||
ENDIF (@OSX_HAVE_LOADERPATH@)
|
|
||||||
FOREACH (QP ${QGPLUGLIST})
|
|
||||||
INSTALLNAMETOOL_CHANGE (${LIBFROM} ${LIB_CHG_TO} "${QP}")
|
|
||||||
ENDFOREACH (QP)
|
|
||||||
# qgis python
|
|
||||||
IF (@OSX_HAVE_LOADERPATH@)
|
|
||||||
SET (LIB_CHG_TO "${ATLOADER}/../../@QGIS_DATA_SUBDIR_REV@/@QGIS_LIB_SUBDIR@/${LIBTO}")
|
|
||||||
ENDIF (@OSX_HAVE_LOADERPATH@)
|
|
||||||
FOREACH (PG ${QGPYLIST})
|
|
||||||
INSTALLNAMETOOL_CHANGE (${LIBFROM} ${LIB_CHG_TO} "${PG}")
|
|
||||||
ENDFOREACH (PG)
|
|
||||||
# bin - nothing yet
|
|
||||||
#IF (@OSX_HAVE_LOADERPATH@)
|
|
||||||
# SET (LIB_CHG_TO "${ATLOADER}/@QGIS_BIN_SUBDIR_REV@/@QGIS_LIB_SUBDIR@/${LIBTO}")
|
|
||||||
#ENDIF (@OSX_HAVE_LOADERPATH@)
|
|
||||||
#FOREACH (PB ...)
|
|
||||||
# INSTALLNAMETOOL_CHANGE (${LIBFROM} ${LIB_CHG_TO} "${QBINDIR}/${PB}")
|
|
||||||
#ENDFOREACH (PB)
|
|
||||||
ENDIF (LIBFROM)
|
|
||||||
ENDFUNCTION (UPDATEQGISPATHS)
|
|
||||||
|
|
||||||
# arches
|
|
||||||
FOREACH (QARCH @CMAKE_OSX_ARCHITECTURES@)
|
|
||||||
SET (QARCHS ${QARCHS} "--arch" "${QARCH}")
|
|
||||||
ENDFOREACH (QARCH)
|
|
||||||
|
|
||||||
FILE (GLOB QGLIBLIST ${QLIBDIR}/libqgis*.dylib)
|
|
||||||
FILE (GLOB QGPLUGLIST ${QPLUGDIR}/*.so)
|
|
||||||
FILE (GLOB QGPYLIST ${QGISPYDIR}/qgis/*.so)
|
|
||||||
|
|
||||||
#
|
#
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user