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/glib | |
Diffstat (limited to 'vcpkg/ports/glib')
| -rw-r--r-- | vcpkg/ports/glib/libintl.patch | 17 | ||||
| -rw-r--r-- | vcpkg/ports/glib/portfile.cmake | 156 | ||||
| -rw-r--r-- | vcpkg/ports/glib/use-libiconv-on-windows.patch | 28 | ||||
| -rw-r--r-- | vcpkg/ports/glib/vcpkg.json | 42 |
4 files changed, 243 insertions, 0 deletions
diff --git a/vcpkg/ports/glib/libintl.patch b/vcpkg/ports/glib/libintl.patch new file mode 100644 index 0000000..48a518e --- /dev/null +++ b/vcpkg/ports/glib/libintl.patch @@ -0,0 +1,17 @@ +diff --git a/meson.build b/meson.build +--- a/meson.build ++++ b/meson.build +@@ -2134,10 +2135,10 @@ libz_dep = dependency('zlib') + # proxy-libintl subproject. + # FIXME: glib-gettext.m4 has much more checks to detect broken/uncompatible + # implementations. This could be extended if issues are found in some platforms. +-libintl_deps = [] + libintl_prefix = '#include <libintl.h>' +-libintl = dependency('intl', required: false) +-if libintl.found() and libintl.type_name() != 'internal' ++libintl = dependency('intl', required : true) ++libintl_deps = [libintl] ++if false + # libintl supports different threading APIs, which may not + # require additional flags, but it defaults to using pthreads if + # found. Meson's "threads" dependency does not allow you to diff --git a/vcpkg/ports/glib/portfile.cmake b/vcpkg/ports/glib/portfile.cmake new file mode 100644 index 0000000..1fef498 --- /dev/null +++ b/vcpkg/ports/glib/portfile.cmake @@ -0,0 +1,156 @@ +# vcpkg_from_* is not used because the project uses submodules. +string(REGEX MATCH "^([0-9]*[.][0-9]*)" GLIB_MAJOR_MINOR "${VERSION}") +vcpkg_download_distfile(GLIB_ARCHIVE + URLS "https://download.gnome.org/sources/glib/${GLIB_MAJOR_MINOR}/glib-${VERSION}.tar.xz" + FILENAME "glib-${VERSION}.tar.xz" + SHA512 430928d7d7a442fc3927ca943f2569035fe8768768a0ebc6720ae1ef152b56fc5f8d4215d21b4828cc2f39a8632c907ed2c52a0c8566da1c533a2e049a1a121f +) + +vcpkg_extract_source_archive(SOURCE_PATH + ARCHIVE "${GLIB_ARCHIVE}" + PATCHES + use-libiconv-on-windows.patch + libintl.patch +) + +set(LANGUAGES C CXX) +if(VCPKG_TARGET_IS_OSX OR VCPKG_TARGET_IS_IOS) + list(APPEND LANGUAGES OBJC OBJCXX) +endif() + +vcpkg_list(SET OPTIONS) +if (selinux IN_LIST FEATURES) + if(NOT EXISTS "/usr/include/selinux") + message(WARNING "SELinux was not found in its typical system location. Your build may fail. You can install SELinux with \"apt-get install selinux libselinux1-dev\".") + endif() + list(APPEND OPTIONS -Dselinux=enabled) +else() + list(APPEND OPTIONS -Dselinux=disabled) +endif() + +if (libmount IN_LIST FEATURES) + list(APPEND OPTIONS -Dlibmount=enabled) +else() + list(APPEND OPTIONS -Dlibmount=disabled) +endif() + +vcpkg_list(SET ADDITIONAL_BINARIES) +if(VCPKG_HOST_IS_WINDOWS) + # Presence of bash and sh enables installation of auxiliary components. + vcpkg_list(APPEND ADDITIONAL_BINARIES "bash = ['${CMAKE_COMMAND}', '-E', 'false']") + vcpkg_list(APPEND ADDITIONAL_BINARIES "sh = ['${CMAKE_COMMAND}', '-E', 'false']") +endif() + +vcpkg_configure_meson( + SOURCE_PATH "${SOURCE_PATH}" + LANGUAGES ${LANGUAGES} + ADDITIONAL_BINARIES + ${ADDITIONAL_BINARIES} + OPTIONS + ${OPTIONS} + -Ddocumentation=false + -Ddtrace=disabled + -Dinstalled_tests=false + -Dintrospection=disabled + -Dlibelf=disabled + -Dman-pages=disabled + -Dsysprof=disabled + -Dtests=false + -Dxattr=false +) +vcpkg_install_meson(ADD_BIN_TO_PATH) +vcpkg_copy_pdbs() + +file(MAKE_DIRECTORY "${CURRENT_PACKAGES_DIR}/tools/${PORT}") +set(GLIB_SCRIPTS + gdbus-codegen + glib-genmarshal + glib-gettextize + glib-mkenums + gtester-report +) +foreach(script IN LISTS GLIB_SCRIPTS) + file(RENAME "${CURRENT_PACKAGES_DIR}/bin/${script}" "${CURRENT_PACKAGES_DIR}/tools/${PORT}/${script}") + file(REMOVE "${CURRENT_PACKAGES_DIR}/debug/bin/${script}") +endforeach() + +set(GLIB_TOOLS + gapplication + gdbus + gi-compile-repository + gi-decompile-typelib + gi-inspect-typelib + gio + gio-querymodules + glib-compile-resources + glib-compile-schemas + gobject-query + gresource + gsettings + gtester +) +if(VCPKG_TARGET_IS_WINDOWS) + list(REMOVE_ITEM GLIB_TOOLS gapplication gtester) + if(VCPKG_TARGET_ARCHITECTURE MATCHES "x64|arm64") + list(APPEND GLIB_TOOLS gspawn-win64-helper gspawn-win64-helper-console) + elseif(VCPKG_TARGET_ARCHITECTURE STREQUAL "x86") + list(APPEND GLIB_TOOLS gspawn-win32-helper gspawn-win32-helper-console) + endif() +elseif(VCPKG_TARGET_IS_OSX) + list(REMOVE_ITEM GLIB_TOOLS gapplication) +endif() +vcpkg_copy_tools(TOOL_NAMES ${GLIB_TOOLS} AUTO_CLEAN) + +vcpkg_fixup_pkgconfig() + +if(VCPKG_TARGET_IS_WINDOWS) + set(LIBINTL_NAME "intl.lib") +else() + set(LIBINTL_NAME "libintl") + if(VCPKG_LIBRARY_LINKAGE STREQUAL dynamic) + string(APPEND LIBINTL_NAME "${VCPKG_TARGET_SHARED_LIBRARY_SUFFIX}") + else() + string(APPEND LIBINTL_NAME "${VCPKG_TARGET_STATIC_LIBRARY_SUFFIX}") + endif() +endif() + +set(pc_replace_intl_path gio glib gmodule-no-export gobject gthread) +foreach(pc_prefix IN LISTS pc_replace_intl_path) + vcpkg_replace_string("${CURRENT_PACKAGES_DIR}/lib/pkgconfig/${pc_prefix}-2.0.pc" "\"" "") + vcpkg_replace_string("${CURRENT_PACKAGES_DIR}/lib/pkgconfig/${pc_prefix}-2.0.pc" "\${prefix}/debug/lib/${LIBINTL_NAME}" "-lintl" IGNORE_UNCHANGED) + vcpkg_replace_string("${CURRENT_PACKAGES_DIR}/lib/pkgconfig/${pc_prefix}-2.0.pc" "\${prefix}/lib/${LIBINTL_NAME}" "-lintl" IGNORE_UNCHANGED) + if(NOT VCPKG_BUILD_TYPE) + vcpkg_replace_string("${CURRENT_PACKAGES_DIR}/debug/lib/pkgconfig/${pc_prefix}-2.0.pc" "\"" "") + vcpkg_replace_string("${CURRENT_PACKAGES_DIR}/debug/lib/pkgconfig/${pc_prefix}-2.0.pc" "\${prefix}/lib/${LIBINTL_NAME}" "-lintl" IGNORE_UNCHANGED) + endif() +endforeach() + +vcpkg_replace_string("${CURRENT_PACKAGES_DIR}/lib/pkgconfig/gio-2.0.pc" "\${bindir}" "\${prefix}/tools/${PORT}") +vcpkg_replace_string("${CURRENT_PACKAGES_DIR}/lib/pkgconfig/glib-2.0.pc" "\${bindir}" "\${prefix}/tools/${PORT}") +if(NOT VCPKG_BUILD_TYPE) + vcpkg_replace_string("${CURRENT_PACKAGES_DIR}/debug/lib/pkgconfig/gio-2.0.pc" "\${bindir}" "\${prefix}/../tools/${PORT}") + vcpkg_replace_string("${CURRENT_PACKAGES_DIR}/debug/lib/pkgconfig/glib-2.0.pc" "\${bindir}" "\${prefix}/../tools/${PORT}") +endif() + +# Fix python scripts +set(_file "${CURRENT_PACKAGES_DIR}/tools/${PORT}/gdbus-codegen") +file(READ "${_file}" _contents) +string(REPLACE "elif os.path.basename(filedir) == 'bin':" "elif os.path.basename(filedir) == 'tools':" _contents "${_contents}") +string(REPLACE "path = os.path.join(filedir, '..', 'share', 'glib-2.0')" "path = os.path.join(filedir, '../..', 'share', 'glib-2.0')" _contents "${_contents}") +string(REPLACE "path = os.path.join(filedir, '..')" "path = os.path.join(filedir, '../../share/glib-2.0')" _contents "${_contents}") +string(REPLACE "path = os.path.join('${CURRENT_PACKAGES_DIR}/share', 'glib-2.0')" "path = os.path.join('unuseable/share', 'glib-2.0')" _contents "${_contents}") +file(WRITE "${_file}" "${_contents}") + +if(EXISTS "${CURRENT_PACKAGES_DIR}/tools/${PORT}/glib-gettextize") + vcpkg_replace_string("${CURRENT_PACKAGES_DIR}/tools/${PORT}/glib-gettextize" "${CURRENT_PACKAGES_DIR}" "`dirname $0`/../..") +endif() + +file(REMOVE_RECURSE + "${CURRENT_PACKAGES_DIR}/debug/include" + "${CURRENT_PACKAGES_DIR}/debug/share" + "${CURRENT_PACKAGES_DIR}/share/gdb" + "${CURRENT_PACKAGES_DIR}/debug/lib/gio" + "${CURRENT_PACKAGES_DIR}/lib/gio" +) + +vcpkg_install_copyright(FILE_LIST "${SOURCE_PATH}/LICENSES/LGPL-2.1-or-later.txt") diff --git a/vcpkg/ports/glib/use-libiconv-on-windows.patch b/vcpkg/ports/glib/use-libiconv-on-windows.patch new file mode 100644 index 0000000..e9a7ac2 --- /dev/null +++ b/vcpkg/ports/glib/use-libiconv-on-windows.patch @@ -0,0 +1,28 @@ +diff --git a/glib/gconvert.c b/glib/gconvert.c +index 829fe38de..e01ad8884 100644 +--- a/glib/gconvert.c ++++ b/glib/gconvert.c +@@ -33,7 +33,8 @@ + + #ifdef G_OS_WIN32 + #include <windows.h> +-#include "win_iconv.c" ++#define USE_LIBICONV_GNU ++#include <iconv.h> + #endif + + #include "gconvert.h" +diff --git a/meson.build b/meson.build +index d465253af..34ce69e4d 100644 +--- a/meson.build ++++ b/meson.build +@@ -2038,7 +2038,8 @@ glibconfig_conf.set10('G_HAVE_GROWING_STACK', growing_stack) + if host_system == 'windows' + # We have a #include "win_iconv.c" in gconvert.c on Windows, so we don't need + # any external library for it +- libiconv = [] ++ libiconv = [cc.find_library('iconv')] ++ found_iconv = true + else + libiconv = dependency('iconv') + endif diff --git a/vcpkg/ports/glib/vcpkg.json b/vcpkg/ports/glib/vcpkg.json new file mode 100644 index 0000000..7c7a115 --- /dev/null +++ b/vcpkg/ports/glib/vcpkg.json @@ -0,0 +1,42 @@ +{ + "name": "glib", + "version": "2.84.2", + "port-version": 2, + "description": "Portable, general-purpose utility library.", + "homepage": "https://developer.gnome.org/glib/", + "license": "LGPL-2.1-or-later", + "supports": "!uwp & !xbox", + "dependencies": [ + "dirent", + { + "name": "gettext", + "host": true, + "default-features": false, + "features": [ + "tools" + ] + }, + "gettext-libintl", + "libffi", + "libiconv", + "pcre2", + { + "name": "vcpkg-tool-meson", + "host": true + }, + "zlib" + ], + "features": { + "libmount": { + "description": "Build with libmount support.", + "supports": "linux", + "dependencies": [ + "libmount" + ] + }, + "selinux": { + "description": "Build with selinux support.", + "supports": "linux" + } + } +} |