aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorKai Pastor <dg0yt@darc.de>2021-08-27 23:24:56 +0200
committerGitHub <noreply@github.com>2021-08-27 14:24:56 -0700
commitc350a3b7129edc3240b7fe40dcda6ebd35e9175d (patch)
tree19a12c05105501b6b9439f551501baae8ff4a463
parentab3095a27d92eb7c9918d26464802cdbb3d9a5f8 (diff)
downloadvcpkg-c350a3b7129edc3240b7fe40dcda6ebd35e9175d.tar.gz
vcpkg-c350a3b7129edc3240b7fe40dcda6ebd35e9175d.zip
[gettext] Add "autopoint" tool to gettext[core] (#17317)
-rw-r--r--ports/gettext/install-autopoint.cmake49
-rw-r--r--ports/gettext/portfile.cmake25
-rw-r--r--ports/gettext/vcpkg.json4
-rw-r--r--versions/baseline.json2
-rw-r--r--versions/g-/gettext.json5
5 files changed, 70 insertions, 15 deletions
diff --git a/ports/gettext/install-autopoint.cmake b/ports/gettext/install-autopoint.cmake
new file mode 100644
index 000000000..45f806b4a
--- /dev/null
+++ b/ports/gettext/install-autopoint.cmake
@@ -0,0 +1,49 @@
+function(install_autopoint)
+ # variables for configuring autopoint.in
+ set(PACKAGE "gettext-tools")
+ set(VERSION "${GETTEXT_VERSION}")
+ set(ARCHIVE_VERSION "${GETTEXT_VERSION}")
+ set(ARCHIVE_FORMAT "dirgz")
+ set(bindir [[${prefix}/tools/gettext/bin]])
+ set(datadir [[${datarootdir}]])
+ set(exec_prefix [[${prefix}]])
+ set(PATH_SEPARATOR ":")
+ set(RELOCATABLE "yes")
+
+ file(STRINGS "${SOURCE_PATH}/gettext-tools/configure"
+ VERSIONS_FROM_CONFIGURE
+ REGEX "^ *(ARCHIVE_VERSION|VERSION)=.*$"
+ )
+ foreach(LINE IN LISTS VERSIONS_FROM_CONFIGURE)
+ if(LINE MATCHES "^ *(ARCHIVE_VERSION|VERSION)='?([0-9.]+)'?$")
+ set(${CMAKE_MATCH_1} "${CMAKE_MATCH_2}")
+ endif()
+ endforeach()
+
+ set(WORKING_DIR "${CURRENT_BUILDTREES_DIR}/${TARGET_TRIPLET}")
+ file(MAKE_DIRECTORY "${WORKING_DIR}")
+
+ # autopoint script
+ configure_file("${SOURCE_PATH}/gettext-tools/misc/autopoint.in" "${WORKING_DIR}/autopoint" @ONLY)
+
+ # data tarball
+ if(WIN32)
+ vcpkg_acquire_msys(MSYS_ROOT PACKAGES gzip)
+ vcpkg_add_to_path("${MSYS_ROOT}/usr/bin")
+ endif()
+ file(COPY "${SOURCE_PATH}/gettext-tools/misc/archive.dir.tar" DESTINATION "${WORKING_DIR}")
+ vcpkg_execute_required_process(
+ COMMAND gzip -f archive.dir.tar
+ WORKING_DIRECTORY "${WORKING_DIR}"
+ LOGNAME gzip-${TARGET_TRIPLET}
+ )
+
+ # installation
+ file(INSTALL "${WORKING_DIR}/autopoint" DESTINATION "${CURRENT_PACKAGES_DIR}/tools/${PORT}/bin"
+ FILE_PERMISSIONS
+ OWNER_WRITE OWNER_READ OWNER_EXECUTE
+ GROUP_READ GROUP_EXECUTE
+ WORLD_READ WORLD_EXECUTE
+ )
+ file(INSTALL "${WORKING_DIR}/archive.dir.tar.gz" DESTINATION "${CURRENT_PACKAGES_DIR}/share/gettext/gettext")
+endfunction()
diff --git a/ports/gettext/portfile.cmake b/ports/gettext/portfile.cmake
index 8bfceae8f..b4f7f845f 100644
--- a/ports/gettext/portfile.cmake
+++ b/ports/gettext/portfile.cmake
@@ -1,13 +1,7 @@
-if(VCPKG_TARGET_IS_LINUX)
- if (NOT EXISTS "/usr/include/libintl.h")
- message(FATAL_ERROR "When targeting Linux, `libintl.h` is expected to come from the C Runtime Library (glibc). "
- "Please use \"sudo apt-get install libc-dev\" or the equivalent to install development files."
- )
- endif()
- if(NOT "tools" IN_LIST FEATURES)
- set(VCPKG_POLICY_EMPTY_PACKAGE enabled)
- return()
- endif()
+if(VCPKG_TARGET_IS_LINUX AND NOT EXISTS "/usr/include/libintl.h")
+ message(FATAL_ERROR "When targeting Linux, `libintl.h` is expected to come from the C Runtime Library (glibc). "
+ "Please use \"sudo apt-get install libc-dev\" or the equivalent to install development files."
+ )
endif()
set(VCPKG_POLICY_ALLOW_RESTRICTED_HEADERS enabled)
@@ -134,8 +128,15 @@ if("tools" IN_LIST FEATURES)
file(RENAME "${CURRENT_PACKAGES_DIR}.release" "${CURRENT_PACKAGES_DIR}")
endif()
else()
- list(APPEND OPTIONS "--config-cache")
- build_libintl_only()
+ if(VCPKG_TARGET_IS_LINUX)
+ set(VCPKG_POLICY_EMPTY_PACKAGE enabled)
+ else()
+ list(APPEND OPTIONS "--config-cache")
+ build_libintl_only()
+ endif()
+ # A fast installation of the autopoint tool and data, needed for autotools
+ include("${CMAKE_CURRENT_LIST_DIR}/install-autopoint.cmake")
+ install_autopoint()
endif()
# Handle copyright
diff --git a/ports/gettext/vcpkg.json b/ports/gettext/vcpkg.json
index 7b166e22f..dc1cefc4e 100644
--- a/ports/gettext/vcpkg.json
+++ b/ports/gettext/vcpkg.json
@@ -1,8 +1,8 @@
{
"name": "gettext",
"version": "0.21",
- "port-version": 4,
- "description": "The GNU gettext utilities are a set of tools that provides a framework to help other GNU packages produce multi-lingual messages. Provides libintl.",
+ "port-version": 5,
+ "description": "GNU gettext provides libintl and a set of tools to help produce multi-lingual messages.",
"homepage": "https://www.gnu.org/software/gettext/",
"dependencies": [
"libiconv"
diff --git a/versions/baseline.json b/versions/baseline.json
index 9358be0b6..e372c7d6f 100644
--- a/versions/baseline.json
+++ b/versions/baseline.json
@@ -2286,7 +2286,7 @@
},
"gettext": {
"baseline": "0.21",
- "port-version": 4
+ "port-version": 5
},
"gettimeofday": {
"baseline": "2017-10-14-3",
diff --git a/versions/g-/gettext.json b/versions/g-/gettext.json
index d64ca34ee..afcf5f513 100644
--- a/versions/g-/gettext.json
+++ b/versions/g-/gettext.json
@@ -1,6 +1,11 @@
{
"versions": [
{
+ "git-tree": "d1089dfcf335a94ca47c5b918c56a7ab6fc0ae92",
+ "version": "0.21",
+ "port-version": 5
+ },
+ {
"git-tree": "b6cde01ab4095a258993eaf85eb31c1e845c64a6",
"version": "0.21",
"port-version": 4