diff options
| author | Ethan Morgan <ethan@gweithio.com> | 2026-02-14 16:44:06 +0000 |
|---|---|---|
| committer | Ethan Morgan <ethan@gweithio.com> | 2026-02-14 16:44:06 +0000 |
| commit | 54409423f767d8b1cf30cb7d0efca6b4ca138823 (patch) | |
| tree | d915ac7828703ce4b963efdd9728a1777ba18c1e /vcpkg/ports/vcpkg-qmake | |
Diffstat (limited to 'vcpkg/ports/vcpkg-qmake')
| -rw-r--r-- | vcpkg/ports/vcpkg-qmake/portfile.cmake | 10 | ||||
| -rw-r--r-- | vcpkg/ports/vcpkg-qmake/vcpkg-port-config.cmake | 7 | ||||
| -rw-r--r-- | vcpkg/ports/vcpkg-qmake/vcpkg.json | 18 | ||||
| -rw-r--r-- | vcpkg/ports/vcpkg-qmake/vcpkg_qmake_build.cmake | 72 | ||||
| -rw-r--r-- | vcpkg/ports/vcpkg-qmake/vcpkg_qmake_configure.cmake | 182 | ||||
| -rw-r--r-- | vcpkg/ports/vcpkg-qmake/vcpkg_qmake_install.cmake | 46 | ||||
| -rw-r--r-- | vcpkg/ports/vcpkg-qmake/z_vcpkg_qmake_fix_makefiles.cmake | 29 |
7 files changed, 364 insertions, 0 deletions
diff --git a/vcpkg/ports/vcpkg-qmake/portfile.cmake b/vcpkg/ports/vcpkg-qmake/portfile.cmake new file mode 100644 index 0000000..24e9eb1 --- /dev/null +++ b/vcpkg/ports/vcpkg-qmake/portfile.cmake @@ -0,0 +1,10 @@ +file(INSTALL + "${CMAKE_CURRENT_LIST_DIR}/vcpkg_qmake_configure.cmake" + "${CMAKE_CURRENT_LIST_DIR}/vcpkg_qmake_build.cmake" + "${CMAKE_CURRENT_LIST_DIR}/vcpkg_qmake_install.cmake" + "${CMAKE_CURRENT_LIST_DIR}/z_vcpkg_qmake_fix_makefiles.cmake" + "${CMAKE_CURRENT_LIST_DIR}/vcpkg-port-config.cmake" + DESTINATION "${CURRENT_PACKAGES_DIR}/share/${PORT}") + +file(INSTALL "${VCPKG_ROOT_DIR}/LICENSE.txt" DESTINATION "${CURRENT_PACKAGES_DIR}/share/${PORT}" RENAME copyright) +set(VCPKG_POLICY_CMAKE_HELPER_PORT enabled) diff --git a/vcpkg/ports/vcpkg-qmake/vcpkg-port-config.cmake b/vcpkg/ports/vcpkg-qmake/vcpkg-port-config.cmake new file mode 100644 index 0000000..b95854c --- /dev/null +++ b/vcpkg/ports/vcpkg-qmake/vcpkg-port-config.cmake @@ -0,0 +1,7 @@ +include_guard(GLOBAL) +include("${CMAKE_CURRENT_LIST_DIR}/../vcpkg-cmake-get-vars/vcpkg-port-config.cmake") +include("${CMAKE_CURRENT_LIST_DIR}/z_vcpkg_qmake_fix_makefiles.cmake") +include("${CMAKE_CURRENT_LIST_DIR}/vcpkg_qmake_configure.cmake") +include("${CMAKE_CURRENT_LIST_DIR}/vcpkg_qmake_build.cmake") +include("${CMAKE_CURRENT_LIST_DIR}/vcpkg_qmake_install.cmake") + diff --git a/vcpkg/ports/vcpkg-qmake/vcpkg.json b/vcpkg/ports/vcpkg-qmake/vcpkg.json new file mode 100644 index 0000000..390f655 --- /dev/null +++ b/vcpkg/ports/vcpkg-qmake/vcpkg.json @@ -0,0 +1,18 @@ +{ + "name": "vcpkg-qmake", + "version-date": "2025-05-19", + "documentation": "https://learn.microsoft.com/vcpkg/maintainers/functions/vcpkg_qmake_configure", + "license": "MIT", + "supports": "native", + "dependencies": [ + "pkgconf", + { + "name": "qtbase", + "default-features": false + }, + { + "name": "vcpkg-cmake-get-vars", + "host": true + } + ] +} diff --git a/vcpkg/ports/vcpkg-qmake/vcpkg_qmake_build.cmake b/vcpkg/ports/vcpkg-qmake/vcpkg_qmake_build.cmake new file mode 100644 index 0000000..1f269cf --- /dev/null +++ b/vcpkg/ports/vcpkg-qmake/vcpkg_qmake_build.cmake @@ -0,0 +1,72 @@ +include_guard(GLOBAL) + +function(z_run_jom_build invoke_command targets log_prefix log_suffix) + message(STATUS "Package ${log_prefix}-${TARGET_TRIPLET}-${log_suffix}") + vcpkg_execute_build_process( + COMMAND "${invoke_command}" -j ${VCPKG_CONCURRENCY} ${targets} + NO_PARALLEL_COMMAND "${invoke_command}" -j 1 ${targets} + WORKING_DIRECTORY "${CURRENT_BUILDTREES_DIR}/${TARGET_TRIPLET}-${log_suffix}" + LOGNAME "package-${log_prefix}-${TARGET_TRIPLET}-${log_suffix}" + ) +endfunction() + +function(vcpkg_qmake_build) + # parse parameters such that semicolons in options arguments to COMMAND don't get erased + cmake_parse_arguments(PARSE_ARGV 0 arg + "SKIP_MAKEFILES" + "BUILD_LOGNAME" + "TARGETS;RELEASE_TARGETS;DEBUG_TARGETS" + ) + + # Make sure that the linker finds the libraries used + vcpkg_backup_env_variables(VARS PATH LD_LIBRARY_PATH) + + if(CMAKE_HOST_WIN32) + if (VCPKG_QMAKE_USE_NMAKE) + find_program(NMAKE nmake) + set(invoke_command "${NMAKE}") + get_filename_component(nmake_exe_path "${NMAKE}" DIRECTORY) + vcpkg_host_path_list(APPEND ENV{PATH} "${nmake_exe_path}") + else() + vcpkg_find_acquire_program(JOM) + set(invoke_command "${JOM}") + endif() + else() + find_program(MAKE make) + set(invoke_command "${MAKE}") + endif() + + file(TO_NATIVE_PATH "${CURRENT_INSTALLED_DIR}" NATIVE_INSTALLED_DIR) + + if(NOT DEFINED arg_BUILD_LOGNAME) + set(arg_BUILD_LOGNAME build) + endif() + + set(short_name_debug "dbg") + set(path_suffix_debug "/debug") + set(targets_debug "${arg_DEBUG_TARGETS}") + + set(short_name_release "rel") + set(path_suffix_release "") + set(targets_release "${arg_RELEASE_TARGETS}") + + if(NOT DEFINED VCPKG_BUILD_TYPE) + set(items debug release) + else() + set(items release) + endif() + foreach(build_type IN ITEMS ${items}) + set(current_installed_prefix "${CURRENT_INSTALLED_DIR}${path_suffix_${build_type}}") + + vcpkg_add_to_path(PREPEND "${current_installed_prefix}/lib" "${current_installed_prefix}/bin") + + vcpkg_list(SET targets ${targets_${build_type}} ${arg_TARGETS}) + if(NOT arg_SKIP_MAKEFILES) + z_run_jom_build("${invoke_command}" qmake_all makefiles "${short_name_${build_type}}") + z_vcpkg_qmake_fix_makefiles("${CURRENT_BUILDTREES_DIR}/${TARGET_TRIPLET}-${short_name_${build_type}}") + endif() + z_run_jom_build("${invoke_command}" "${targets}" "${arg_BUILD_LOGNAME}" "${short_name_${build_type}}") + + vcpkg_restore_env_variables(VARS PATH LD_LIBRARY_PATH) + endforeach() +endfunction() diff --git a/vcpkg/ports/vcpkg-qmake/vcpkg_qmake_configure.cmake b/vcpkg/ports/vcpkg-qmake/vcpkg_qmake_configure.cmake new file mode 100644 index 0000000..cd7eae6 --- /dev/null +++ b/vcpkg/ports/vcpkg-qmake/vcpkg_qmake_configure.cmake @@ -0,0 +1,182 @@ +include_guard(GLOBAL)
+
+function(vcpkg_qmake_configure)
+ cmake_parse_arguments(PARSE_ARGV 0 arg "" "SOURCE_PATH" "QMAKE_OPTIONS;QMAKE_OPTIONS_RELEASE;QMAKE_OPTIONS_DEBUG;OPTIONS;OPTIONS_RELEASE;OPTIONS_DEBUG")
+
+ vcpkg_cmake_get_vars(detected_file)
+ include("${detected_file}")
+
+ if(VCPKG_LIBRARY_LINKAGE STREQUAL "static")
+ vcpkg_list(APPEND arg_QMAKE_OPTIONS "CONFIG-=shared")
+ vcpkg_list(APPEND arg_QMAKE_OPTIONS "CONFIG*=static")
+ else()
+ vcpkg_list(APPEND arg_QMAKE_OPTIONS "CONFIG-=static")
+ vcpkg_list(APPEND arg_QMAKE_OPTIONS "CONFIG*=shared")
+ vcpkg_list(APPEND arg_QMAKE_OPTIONS_DEBUG "CONFIG*=separate_debug_info")
+ endif()
+ if(VCPKG_TARGET_IS_WINDOWS AND VCPKG_CRT_LINKAGE STREQUAL "static")
+ vcpkg_list(APPEND arg_QMAKE_OPTIONS "CONFIG*=static-runtime")
+ endif()
+
+ set(ENV{PKG_CONFIG} "${CURRENT_HOST_INSTALLED_DIR}/tools/pkgconf/pkgconf${VCPKG_HOST_EXECUTABLE_SUFFIX}")
+ get_filename_component(PKGCONFIG_PATH "${PKGCONFIG}" DIRECTORY)
+ vcpkg_add_to_path("${PKGCONFIG_PATH}")
+
+ set(buildtypes "")
+ if(NOT VCPKG_BUILD_TYPE OR "${VCPKG_BUILD_TYPE}" STREQUAL "debug")
+ list(APPEND buildtypes "DEBUG") # Using uppercase to also access the detected cmake variables with it
+ set(path_suffix_DEBUG "debug/")
+ set(short_name_DEBUG "dbg")
+ set(qmake_config_DEBUG CONFIG+=debug CONFIG-=release)
+ endif()
+ if(NOT VCPKG_BUILD_TYPE OR "${VCPKG_BUILD_TYPE}" STREQUAL "release")
+ list(APPEND buildtypes "RELEASE")
+ set(path_suffix_RELEASE "")
+ set(short_name_RELEASE "rel")
+ set(qmake_config_RELEASE CONFIG-=debug CONFIG+=release)
+ endif()
+
+ function(qmake_append_program var qmake_var value)
+ # Danger zone: qmake poorly handles tools in C:/Program Files etc.
+ # IOW for MSVC it expects short command names, found via PATH.
+ if(value MATCHES " ")
+ get_filename_component(prog "${value}" NAME)
+ find_program("z_vcpkg_qmake_${qmake_var}" NAMES "${prog}" PATHS ENV PATH NO_DEFAULT_PATH NO_CACHE)
+ cmake_path(COMPARE "${z_vcpkg_qmake_${qmake_var}}" EQUAL "${value}" expected_program_in_path)
+ if(NOT expected_program_in_path)
+ message(FATAL_ERROR
+ "Detected path mismatch for '${qmake_var}=${prog}'.\n"
+ " Actual: ${z_vcpkg_qmake_${qmake_var}}\n"
+ " Expected: ${value}\n"
+ "Please correct environment variable PATH!"
+ )
+ endif()
+ else()
+ set(prog "${value}")
+ endif()
+ vcpkg_list(APPEND "${var}" "${qmake_var}=${prog}")
+ set("${var}" "${${var}}" PARENT_SCOPE)
+ endfunction()
+ # Setup Build tools
+ if(NOT VCPKG_QMAKE_COMMAND) # For users using outside Qt6
+ set(VCPKG_QMAKE_COMMAND "${CURRENT_HOST_INSTALLED_DIR}/tools/Qt6/bin/qmake${VCPKG_HOST_EXECUTABLE_SUFFIX}")
+ endif()
+
+ if(VCPKG_TARGET_IS_OSX)
+ # Get Qt version
+ execute_process(
+ COMMAND ${VCPKG_QMAKE_COMMAND} -query QT_VERSION
+ OUTPUT_VARIABLE QT_VERSION
+ OUTPUT_STRIP_TRAILING_WHITESPACE
+ )
+
+ if(DEFINED VCPKG_OSX_DEPLOYMENT_TARGET)
+ vcpkg_list(APPEND arg_QMAKE_OPTIONS "QMAKE_MACOSX_DEPLOYMENT_TARGET=${VCPKG_OSX_DEPLOYMENT_TARGET}")
+ elseif(${QT_VERSION} VERSION_GREATER_EQUAL 6)
+ # https://doc.qt.io/qt-6/macos.html
+ vcpkg_list(APPEND arg_QMAKE_OPTIONS "QMAKE_MACOSX_DEPLOYMENT_TARGET=10.15")
+ else() # Qt5
+ # https://doc.qt.io/qt-5/macos.html
+ vcpkg_list(APPEND arg_QMAKE_OPTIONS "QMAKE_MACOSX_DEPLOYMENT_TARGET=10.13")
+ endif()
+ endif()
+
+ set(qmake_build_tools "")
+ qmake_append_program(qmake_build_tools "QMAKE_CC" "${VCPKG_DETECTED_CMAKE_C_COMPILER}")
+ qmake_append_program(qmake_build_tools "QMAKE_CXX" "${VCPKG_DETECTED_CMAKE_CXX_COMPILER}")
+ qmake_append_program(qmake_build_tools "QMAKE_AR" "${VCPKG_DETECTED_CMAKE_AR}")
+ qmake_append_program(qmake_build_tools "QMAKE_RANLIB" "${VCPKG_DETECTED_CMAKE_RANLIB}")
+ qmake_append_program(qmake_build_tools "QMAKE_STRIP" "${VCPKG_DETECTED_CMAKE_STRIP}")
+ qmake_append_program(qmake_build_tools "QMAKE_NM" "${VCPKG_DETECTED_CMAKE_NM}")
+ qmake_append_program(qmake_build_tools "QMAKE_RC" "${VCPKG_DETECTED_CMAKE_RC_COMPILER}")
+ qmake_append_program(qmake_build_tools "QMAKE_MT" "${VCPKG_DETECTED_CMAKE_MT}")
+
+ if(NOT VCPKG_TARGET_IS_WINDOWS OR VCPKG_DETECTED_CMAKE_AR MATCHES "ar$")
+ vcpkg_list(APPEND qmake_build_tools "QMAKE_AR+=qc")
+ endif()
+
+ if(VCPKG_TARGET_IS_WINDOWS AND NOT VCPKG_TARGET_IS_MINGW)
+ qmake_append_program(qmake_build_tools "QMAKE_LIB" "${VCPKG_DETECTED_CMAKE_AR}")
+ qmake_append_program(qmake_build_tools "QMAKE_LINK" "${VCPKG_DETECTED_CMAKE_LINKER}")
+ else()
+ qmake_append_program(qmake_build_tools "QMAKE_LINK" "${VCPKG_DETECTED_CMAKE_CXX_COMPILER}")
+ qmake_append_program(qmake_build_tools "QMAKE_LINK_SHLIB" "${VCPKG_DETECTED_CMAKE_CXX_COMPILER}")
+ qmake_append_program(qmake_build_tools "QMAKE_LINK_C" "${VCPKG_DETECTED_CMAKE_C_COMPILER}")
+ qmake_append_program(qmake_build_tools "QMAKE_LINK_C_SHLIB" "${VCPKG_DETECTED_CMAKE_C_COMPILER}")
+ endif()
+
+ if(DEFINED VCPKG_QT_TARGET_MKSPEC)
+ vcpkg_list(APPEND arg_QMAKE_OPTIONS "-spec" "${VCPKG_QT_TARGET_MKSPEC}")
+ endif()
+
+ foreach(buildtype IN LISTS buildtypes)
+ set(short "${short_name_${buildtype}}")
+ string(TOLOWER "${buildtype}" lowerbuildtype)
+ set(prefix "${CURRENT_INSTALLED_DIR}${path_suffix_${buildtype}}")
+ set(prefix_package "${CURRENT_PACKAGES_DIR}${path_suffix_${buildtype}}")
+ set(config_triplet "${TARGET_TRIPLET}-${short}")
+ # Cleanup build directories
+ file(REMOVE_RECURSE "${CURRENT_BUILDTREES_DIR}/${config_triplet}")
+
+ set(qmake_comp_flags "")
+ macro(qmake_add_flags qmake_var operation flags)
+ string(STRIP "${flags}" striped_flags)
+ if(striped_flags)
+ vcpkg_list(APPEND qmake_comp_flags "${qmake_var}${operation}${striped_flags}")
+ endif()
+ endmacro()
+
+ qmake_add_flags("QMAKE_LIBS" "+=" "${VCPKG_DETECTED_CMAKE_C_STANDARD_LIBRARIES} ${VCPKG_DETECTED_CMAKE_CXX_STANDARD_LIBRARIES}")
+ qmake_add_flags("QMAKE_RC" "+=" "${VCPKG_COMBINED_RC_FLAGS_${buildtype}}") # not exported by vcpkg_cmake_get_vars yet
+ qmake_add_flags("QMAKE_CFLAGS_${buildtype}" "+=" "${VCPKG_COMBINED_C_FLAGS_${buildtype}}")
+ qmake_add_flags("QMAKE_CXXFLAGS_${buildtype}" "+=" "${VCPKG_COMBINED_CXX_FLAGS_${buildtype}}")
+ qmake_add_flags("QMAKE_LFLAGS" "+=" "${VCPKG_COMBINED_STATIC_LINKER_FLAGS_${buildtype}}")
+ qmake_add_flags("QMAKE_LFLAGS_SHLIB" "+=" "${VCPKG_COMBINED_SHARED_LINKER_FLAGS_${buildtype}}")
+ qmake_add_flags("QMAKE_LFLAGS_PLUGIN" "+=" "${VCPKG_COMBINED_MODULE_LINKER_FLAGS_${buildtype}}")
+ qmake_add_flags("QMAKE_LIBFLAGS" "+=" "${VCPKG_COMBINED_STATIC_LINKER_FLAGS_${buildtype}}")
+ qmake_add_flags("QMAKE_LIBFLAGS_${buildtype}" "+=" "${VCPKG_COMBINED_STATIC_LINKER_FLAGS_${buildtype}}")
+ vcpkg_list(APPEND qmake_build_tools "QMAKE_AR+=${VCPKG_COMBINED_STATIC_LINKER_FLAGS_${buildtype}}")
+
+ # QMAKE_CXXFLAGS_SHLIB
+
+ # Setup qt.conf
+ if(NOT VCPKG_QT_CONF_${buildtype})
+ set(VCPKG_QT_CONF_${buildtype} "${CURRENT_INSTALLED_DIR}/tools/Qt6/qt_${lowerbuildtype}.conf")
+ else()
+ # Let a supplied qt.conf override everything.
+ # The file will still be configured so users might use the variables within this scope.
+ set(qmake_build_tools "")
+ set(qmake_comp_flags "")
+ endif()
+ configure_file("${VCPKG_QT_CONF_${buildtype}}" "${CURRENT_BUILDTREES_DIR}/${config_triplet}/qt.conf")
+
+ vcpkg_backup_env_variables(VARS PKG_CONFIG_PATH)
+ vcpkg_host_path_list(PREPEND PKG_CONFIG_PATH "${prefix}/lib/pkgconfig" "${CURRENT_INSTALLED_DIR}/share/pkgconfig")
+
+ message(STATUS "Configuring ${config_triplet}")
+ if(DEFINED arg_OPTIONS OR DEFINED arg_OPTIONS_${buildtype})
+ set(options -- ${arg_OPTIONS} ${arg_OPTIONS_${buildtype}})
+ endif()
+ # Options might need to go into a response file? I am a bit concerned about cmd line length.
+ vcpkg_execute_required_process(
+ COMMAND ${VCPKG_QMAKE_COMMAND} ${qmake_config_${buildtype}}
+ ${arg_QMAKE_OPTIONS} ${arg_QMAKE_OPTIONS_${buildtype}}
+ ${VCPKG_QMAKE_OPTIONS} ${VCPKG_QMAKE_OPTIONS_${buildtype}} # Advanced users need a way to inject QMAKE variables via the triplet.
+ ${qmake_build_tools} ${qmake_comp_flags}
+ "${arg_SOURCE_PATH}"
+ -qtconf "${CURRENT_BUILDTREES_DIR}/${config_triplet}/qt.conf"
+ ${options}
+ WORKING_DIRECTORY "${CURRENT_BUILDTREES_DIR}/${config_triplet}"
+ LOGNAME config-${config_triplet}
+ SAVE_LOG_FILES config.log
+ )
+ z_vcpkg_qmake_fix_makefiles("${CURRENT_BUILDTREES_DIR}/${config_triplet}")
+ message(STATUS "Configuring ${config_triplet} done")
+
+ vcpkg_restore_env_variables(VARS PKG_CONFIG_PATH)
+ if(EXISTS "${CURRENT_BUILDTREES_DIR}/${config_triplet}/config.log")
+ file(REMOVE "${CURRENT_BUILDTREES_DIR}/internal-config-${config_triplet}.log")
+ file(RENAME "${CURRENT_BUILDTREES_DIR}/${config_triplet}/config.log" "${CURRENT_BUILDTREES_DIR}/internal-config-${config_triplet}.log")
+ endif()
+ endforeach()
+endfunction()
\ No newline at end of file diff --git a/vcpkg/ports/vcpkg-qmake/vcpkg_qmake_install.cmake b/vcpkg/ports/vcpkg-qmake/vcpkg_qmake_install.cmake new file mode 100644 index 0000000..ce2e206 --- /dev/null +++ b/vcpkg/ports/vcpkg-qmake/vcpkg_qmake_install.cmake @@ -0,0 +1,46 @@ +#[===[.md:
+# vcpkg_qmake_install
+
+Build and install a qmake project.
+
+## Usage:
+```cmake
+vcpkg_qmake_install(...)
+```
+
+## Parameters:
+See [`vcpkg_qmake_build()`](vcpkg_qmake_build.md).
+
+## Notes:
+This command transparently forwards to [`vcpkg_qmake_build()`](vcpkg_qmake_build.md).
+and appends the 'install' target
+
+#]===]
+
+function(z_vcpkg_qmake_fix_prl PACKAGE_DIR PRL_FILES)
+ file(TO_CMAKE_PATH "${PACKAGE_DIR}/lib" CMAKE_LIB_PATH)
+ file(TO_CMAKE_PATH "${PACKAGE_DIR}/include/Qt6" CMAKE_INCLUDE_PATH_QT6)
+ file(TO_CMAKE_PATH "${PACKAGE_DIR}/include" CMAKE_INCLUDE_PATH)
+ file(TO_CMAKE_PATH "${CURRENT_INSTALLED_DIR}" CMAKE_INSTALLED_PREFIX)
+ foreach(PRL_FILE IN LISTS PRL_FILES)
+ file(READ "${PRL_FILE}" _contents)
+ string(REPLACE "${CMAKE_LIB_PATH}" "\$\$[QT_INSTALL_LIBS]" _contents "${_contents}")
+ string(REPLACE "${CMAKE_INCLUDE_PATH_QT6}" "\$\$[QT_INSTALL_HEADERS]" _contents "${_contents}")
+ string(REPLACE "${CMAKE_INCLUDE_PATH}" "\$\$[QT_INSTALL_HEADERS]/../" _contents "${_contents}")
+ string(REPLACE "${CMAKE_INSTALLED_PREFIX}" "\$\$[QT_INSTALL_PREFIX]" _contents "${_contents}")
+ string(REGEX REPLACE "QMAKE_PRL_BUILD_DIR[^\\\n]+" "QMAKE_PRL_BUILD_DIR =" _contents "${_contents}")
+ #Note: This only works without an extra if case since QT_INSTALL_PREFIX is the same for debug and release
+ file(WRITE "${PRL_FILE}" "${_contents}")
+ endforeach()
+endfunction()
+
+function(vcpkg_qmake_install)
+ z_vcpkg_function_arguments(args)
+ vcpkg_qmake_build(${args})
+ vcpkg_qmake_build(SKIP_MAKEFILES BUILD_LOGNAME "install" TARGETS "install")
+
+ # Fix absolute paths in prl files
+ file(GLOB_RECURSE prl_files "${CURRENT_PACKAGES_DIR}/**.prl")
+ debug_message(STATUS "prl_files:${prl_files}")
+ z_vcpkg_qmake_fix_prl("${CURRENT_PACKAGES_DIR}" "${prl_files}")
+endfunction()
diff --git a/vcpkg/ports/vcpkg-qmake/z_vcpkg_qmake_fix_makefiles.cmake b/vcpkg/ports/vcpkg-qmake/z_vcpkg_qmake_fix_makefiles.cmake new file mode 100644 index 0000000..1a940e0 --- /dev/null +++ b/vcpkg/ports/vcpkg-qmake/z_vcpkg_qmake_fix_makefiles.cmake @@ -0,0 +1,29 @@ +include_guard(GLOBAL)
+function(z_vcpkg_qmake_fix_makefiles BUILD_DIR)
+ #Fix the installation location
+ file(TO_NATIVE_PATH "${CURRENT_INSTALLED_DIR}" NATIVE_INSTALLED_DIR)
+ file(TO_NATIVE_PATH "${CURRENT_PACKAGES_DIR}" NATIVE_PACKAGES_DIR)
+
+ if(CMAKE_HOST_WIN32)
+ string(SUBSTRING "${NATIVE_INSTALLED_DIR}" 2 -1 INSTALLED_DIR_WITHOUT_DRIVE)
+ string(SUBSTRING "${NATIVE_PACKAGES_DIR}" 2 -1 PACKAGES_DIR_WITHOUT_DRIVE)
+ string(SUBSTRING "${NATIVE_INSTALLED_DIR}" 0 2 INSTALLED_DRIVE)
+ string(SUBSTRING "${NATIVE_PACKAGES_DIR}" 0 2 PACKAGES_DRIVE)
+ else()
+ set(INSTALLED_DRIVE "")
+ set(PACKAGES_DRIVE "")
+ set(INSTALLED_DIR_WITHOUT_DRIVE "${NATIVE_INSTALLED_DIR}")
+ set(PACKAGES_DIR_WITHOUT_DRIVE "${NATIVE_PACKAGES_DIR}")
+ endif()
+
+ file(GLOB_RECURSE MAKEFILES "${BUILD_DIR}/**Makefile**")
+
+ foreach(MAKEFILE ${MAKEFILES})
+ #Set the correct install directory to packages
+ vcpkg_replace_string("${MAKEFILE}"
+ "${INSTALLED_DRIVE}$(INSTALL_ROOT)${INSTALLED_DIR_WITHOUT_DRIVE}"
+ "${PACKAGES_DRIVE}$(INSTALL_ROOT)${PACKAGES_DIR_WITHOUT_DRIVE}"
+ IGNORE_UNCHANGED)
+ endforeach()
+
+endfunction()
\ No newline at end of file |