Skip to content

Commit

Permalink
update glib to meson
Browse files Browse the repository at this point in the history
  • Loading branch information
Neumann-A committed Nov 18, 2020
1 parent 3217e25 commit 3c68c5c
Show file tree
Hide file tree
Showing 3 changed files with 225 additions and 28 deletions.
4 changes: 2 additions & 2 deletions ports/glib/CONTROL
Original file line number Diff line number Diff line change
Expand Up @@ -3,8 +3,8 @@ Version: 2.52.3
Port-Version: 23
Homepage: https://developer.gnome.org/glib/
Description: Portable, general-purpose utility library.
Build-Depends: zlib, pcre, libffi, gettext, libiconv
Supports: !uwp
Build-Depends: zlib, pcre, libffi, gettext, libiconv, dirent
Supports: !uwp|!(windows&static)

Feature: selinux
Description: Build with selinux support.
215 changes: 189 additions & 26 deletions ports/glib/portfile.cmake
Original file line number Diff line number Diff line change
Expand Up @@ -6,54 +6,217 @@ if (VCPKG_TARGET_IS_WINDOWS)
vcpkg_check_linkage(ONLY_DYNAMIC_LIBRARY)
endif()

set(GLIB_VERSION 2.52.3)
set(GLIB_VERSION 2.65.2)
vcpkg_download_distfile(ARCHIVE
URLS "https://ftp.gnome.org/pub/gnome/sources/glib/2.52/glib-${GLIB_VERSION}.tar.xz"
URLS "https://ftp.gnome.org/pub/gnome/sources/glib/2.65/glib-${GLIB_VERSION}.tar.xz"
FILENAME "glib-${GLIB_VERSION}.tar.xz"
SHA512 a068f2519cfb82de8d4b7f004e7c1f15e841cad4046430a83b02b359d011e0c4077cdff447a1687ed7c68f1a11b4cf66b9ed9fc23ab5f0c7c6be84eb0ddc3017)
SHA512 9a2ebd226b2d0bcd7fbfeeff7a0dd48f7a604636a19672dae5c0547dd8abe5f2bf3bd505e48797095f740775bac5e8eeb1230e754b9d03171d7d04c2363432fc)

vcpkg_extract_source_archive_ex(
OUT_SOURCE_PATH SOURCE_PATH
ARCHIVE ${ARCHIVE}
REF ${GLIB_VERSION}
PATCHES
use-libiconv-on-windows.patch
arm64-defines.patch
fix-arm-builds.patch
remove_tests.patch
#use-libiconv-on-windows.patch
#arm64-defines.patch
#fix-arm-builds.patch
)

configure_file(${CMAKE_CURRENT_LIST_DIR}/CMakeLists.txt ${SOURCE_PATH}/CMakeLists.txt COPYONLY)
file(COPY ${CMAKE_CURRENT_LIST_DIR}/cmake DESTINATION ${SOURCE_PATH})
file(REMOVE_RECURSE ${SOURCE_PATH}/glib/pcre)
file(WRITE ${SOURCE_PATH}/glib/pcre/Makefile.in)
file(REMOVE ${SOURCE_PATH}/glib/win_iconv.c)

if (selinux IN_LIST FEATURES AND NOT VCPKG_TARGET_IS_WINDOWS AND NOT EXISTS "/usr/include/selinux")
message("Selinux was not found in its typical system location. Your build may fail. You can install Selinux with \"apt-get install selinux\".")
list(APPEND OPTIONS -Dselinux=enabled)
else()
list(APPEND OPTIONS -Dselinux=disabled)
endif()

vcpkg_check_features(OUT_FEATURE_OPTIONS FEATURE_OPTIONS
selinux HAVE_SELINUX
)
if(VCPKG_TARGET_IS_WINDOWS)
list(APPEND OPTIONS -Diconv=external)
else()
#list(APPEND OPTIONS -Diconv=libc) ?
endif()

vcpkg_configure_cmake(
vcpkg_configure_meson(
SOURCE_PATH ${SOURCE_PATH}
PREFER_NINJA
OPTIONS ${FEATURE_OPTIONS}
-DGLIB_VERSION=${GLIB_VERSION}
OPTIONS_DEBUG
-DGLIB_SKIP_HEADERS=ON
-DGLIB_SKIP_TOOLS=ON
OPTIONS
-Dbuild_tests=false
${OPTIONS}

)

vcpkg_install_cmake()
vcpkg_fixup_cmake_targets(CONFIG_PATH share/unofficial-glib TARGET_PATH share/unofficial-glib)
vcpkg_install_meson()

vcpkg_copy_pdbs()
vcpkg_copy_tool_dependencies(${CURRENT_PACKAGES_DIR}/tools/${PORT})

file(REMOVE_RECURSE ${CURRENT_PACKAGES_DIR}/debug/include)
set(GLIB_TOOLS gdbus
gio
gio-querymodules
glib-compile-resources
glib-compile-schemas
gobject-query
gresource
gsettings
)
if(NOT VCPKG_TARGET_IS_WINDOWS)
list(APPEND GLIB_TOOLS gapplication glib-gettextize gtester)
endif()
set(GLIB_SCRIPTS gdbus-codegen glib-genmarshal glib-mkenums gtester-report)

vcpkg_fixup_pkgconfig()

if(VCPKG_TARGET_IS_WINDOWS AND VCPKG_TARGET_ARCHITECTURE MATCHES "x64|arm64")
list(APPEND GLIB_TOOLS gspawn-win64-helper${VCPKG_EXECUTABLE_SUFFIX}
gspawn-win64-helper-console${VCPKG_EXECUTABLE_SUFFIX})
elseif(VCPKG_TARGET_IS_WINDOWS AND VCPKG_TARGET_ARCHITECTURE STREQUAL "x86")
list(APPEND GLIB_TOOLS gspawn-win32-helper${VCPKG_EXECUTABLE_SUFFIX}
gspawn-win32-helper-console${VCPKG_EXECUTABLE_SUFFIX})
endif()
vcpkg_copy_tools(TOOL_NAMES ${GLIB_TOOLS} AUTO_CLEAN)
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()

file(REMOVE_RECURSE "${CURRENT_PACKAGES_DIR}/debug/include")
file(REMOVE_RECURSE "${CURRENT_PACKAGES_DIR}/debug/share")
if(VCPKG_LIBRARY_LINKAGE STREQUAL "static")
file(REMOVE_RECURSE "${CURRENT_PACKAGES_DIR}/bin" "${CURRENT_PACKAGES_DIR}/debug/bin")
endif()

IF(VCPKG_TARGET_IS_WINDOWS)
set(SYSTEM_LIBRARIES dnsapi iphlpapi winmm lshlwapi)
else()
set(SYSTEM_LIBRARIES resolv mount blkid selinux)
endif()
if(EXISTS "${CURRENT_PACKAGES_DIR}/lib/pkgconfig/gio-2.0.pc")
vcpkg_replace_string("${CURRENT_PACKAGES_DIR}/lib/pkgconfig/gio-2.0.pc" "\${bindir}" "\${bindir}/../tools/${PORT}")
endif()
if(EXISTS "${CURRENT_PACKAGES_DIR}/debug/lib/pkgconfig/gio-2.0.pc")
vcpkg_replace_string("${CURRENT_PACKAGES_DIR}/debug/lib/pkgconfig/gio-2.0.pc" "\${bindir}" "\${bindir}/../../tools/${PORT}")
endif()
if(EXISTS "${CURRENT_PACKAGES_DIR}/lib/pkgconfig/glib-2.0.pc")
vcpkg_replace_string("${CURRENT_PACKAGES_DIR}/lib/pkgconfig/glib-2.0.pc" "\${bindir}" "\${bindir}/../tools/${PORT}")
endif()
if(EXISTS "${CURRENT_PACKAGES_DIR}/debug/lib/pkgconfig/glib-2.0.pc")
vcpkg_replace_string("${CURRENT_PACKAGES_DIR}/debug/lib/pkgconfig/glib-2.0.pc" "\${bindir}" "\${bindir}/../../tools/${PORT}")
endif()
vcpkg_fixup_pkgconfig(NOT_STATIC_PKGCONFIG SYSTEM_LIBRARIES ${SYSTEM_LIBRARIES} IGNORE_FLAGS "-Wl,--export-dynamic")

file(INSTALL ${SOURCE_PATH}/COPYING DESTINATION ${CURRENT_PACKAGES_DIR}/share/${PORT} RENAME copyright)



# option('runtime_libdir',
# type : 'string',
# value : '',
# description : 'install runtime libraries relative to libdir')

# option('iconv',
# type : 'combo',
# choices : ['auto', 'libc', 'external'],
# value : 'auto',
# description : 'iconv implementation to use (\'libc\' = \'Part of the C library\'; \'external\' = \'External libiconv\'; \'auto\' = \'Auto-detect which iconv is available\')')

# option('charsetalias_dir',
# type : 'string',
# value : '',
# description : 'directory for charset.alias dir (default to \'libdir\' if unset)')

# option('gio_module_dir',
# type : 'string',
# value : '',
# description : 'load gio modules from this directory (default to \'libdir/gio/modules\' if unset)')

# option('selinux',
# type : 'feature',
# value : 'auto',
# description : 'build with selinux support')

# option('xattr',
# type : 'boolean',
# value : true,
# description : 'build with xattr support')

# option('libmount',
# type : 'feature',
# value : 'auto',
# description : 'build with libmount support')

# option('internal_pcre',
# type : 'boolean',
# value : false,
# description : 'whether to use internal PCRE')

# option('man',
# type : 'boolean',
# value : false,
# description : 'generate man pages (requires xsltproc)')

# option('dtrace',
# type : 'boolean',
# value : false,
# description : 'include tracing support for dtrace')

# option('systemtap',
# type : 'boolean',
# value : false,
# description : 'include tracing support for systemtap')

# option('tapset_install_dir',
# type : 'string',
# value : '',
# description : 'path where systemtap tapsets are installed')

# option('sysprof',
# type : 'feature',
# value : 'disabled',
# description : 'include tracing support for sysprof')

# option('gtk_doc',
# type : 'boolean',
# value : false,
# description : 'use gtk-doc to build documentation')

# option('bsymbolic_functions',
# type : 'boolean',
# value : true,
# description : 'link with -Bsymbolic-functions if supported')

# option('force_posix_threads',
# type : 'boolean',
# value : false,
# description : 'Also use posix threads in case the platform defaults to another implementation (on Windows for example)')

# option('fam',
# type : 'boolean',
# value : false,
# description : 'Use fam for file system monitoring')

# option('installed_tests',
# type : 'boolean',
# value : false,
# description : 'enable installed tests')

# option('nls',
# type : 'feature',
# value : 'auto',
# yield: true,
# description : 'Enable native language support (translations)')

# option('oss_fuzz',
# type : 'feature',
# value : 'disabled',
# description : 'Indicate oss-fuzz build environment')

# option('glib_assert',
# type : 'boolean',
# value : true,
# yield : true,
# description : 'Enable GLib assertion (see docs/macros.txt)')

# option('glib_checks',
# type : 'boolean',
# value : true,
# yield : true,
# description : 'Enable GLib checks such as API guards (see docs/macros.txt)')

34 changes: 34 additions & 0 deletions ports/glib/remove_tests.patch
Original file line number Diff line number Diff line change
@@ -0,0 +1,34 @@
diff --git a/gio/meson.build b/gio/meson.build
index 40a9ca6d0..538652e61 100644
--- a/gio/meson.build
+++ b/gio/meson.build
@@ -1002,9 +1002,9 @@ if enable_systemtap
endif

subdir('fam')
-if build_tests
- subdir('tests')
-endif
+#if build_tests
+# subdir('tests')
+#endif

# The following is an example for building internal marshallers that are used
# by GIO. We cannot guarantee glib-genmarshal availability while building GLib
diff --git a/meson.build b/meson.build
index 947a4058c..ad4f5793e 100644
--- a/meson.build
+++ b/meson.build
@@ -2295,9 +2295,9 @@ subdir('gthread')
subdir('gmodule')
subdir('gio')
subdir('fuzzing')
-if build_tests
- subdir('tests')
-endif
+#if build_tests
+# subdir('tests')
+#endif

# xgettext is optional (on Windows for instance)
if find_program('xgettext', required : get_option('nls')).found()

0 comments on commit 3c68c5c

Please sign in to comment.