Date: Friday, April 21, 2023 @ 18:57:02
Author: heftig
Revision: 1448189
archrelease: copy trunk to multilib-staging-x86_64
Added:
lib32-glib2/repos/multilib-staging-x86_64/
lib32-glib2/repos/multilib-staging-x86_64/0002-glocalfile-Sum-apparent-size-only-for-files-and-syml.patch
(from rev 1448188,
lib32-glib2/trunk/0002-glocalfile-Sum-apparent-size-only-for-files-and-syml.patch)
lib32-glib2/repos/multilib-staging-x86_64/0003-tests-file-Do-not-rely-on-du-bytes-behaviour.patch
(from rev 1448188,
lib32-glib2/trunk/0003-tests-file-Do-not-rely-on-du-bytes-behaviour.patch)
lib32-glib2/repos/multilib-staging-x86_64/PKGBUILD
(from rev 1448188, lib32-glib2/trunk/PKGBUILD)
lib32-glib2/repos/multilib-staging-x86_64/gio-querymodules-32.hook
(from rev 1448188, lib32-glib2/trunk/gio-querymodules-32.hook)
-----------------------------------------------------------------+
0002-glocalfile-Sum-apparent-size-only-for-files-and-syml.patch | 68 ++++
0003-tests-file-Do-not-rely-on-du-bytes-behaviour.patch | 160
++++++++++
PKGBUILD | 114 +++++++
gio-querymodules-32.hook | 11
4 files changed, 353 insertions(+)
Copied:
lib32-glib2/repos/multilib-staging-x86_64/0002-glocalfile-Sum-apparent-size-only-for-files-and-syml.patch
(from rev 1448188,
lib32-glib2/trunk/0002-glocalfile-Sum-apparent-size-only-for-files-and-syml.patch)
===================================================================
---
multilib-staging-x86_64/0002-glocalfile-Sum-apparent-size-only-for-files-and-syml.patch
(rev 0)
+++
multilib-staging-x86_64/0002-glocalfile-Sum-apparent-size-only-for-files-and-syml.patch
2023-04-21 18:57:02 UTC (rev 1448189)
@@ -0,0 +1,68 @@
+From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
+From: Joan Bruguera <[email protected]>
+Date: Thu, 23 Mar 2023 02:24:30 +0000
+Subject: [PATCH] glocalfile: Sum apparent size only for files and symlinks
+
+Since GNU Coreutils 9.2 (commit 110bcd28386b1f47a4cd876098acb708fdcbbb25),
+`du --apparent-size` (including `du --bytes`) no longer counts all kinds of
+files (directories, FIFOs, etc.), but only those for which `st_size` in
+`struct stat` is defined by POSIX, namely regular files and symlinks
+(and also rarely supported memory objects).
+
+This aligns the behaviour of GLib's `G_FILE_MEASURE_APPARENT_SIZE` flag
+with the new GNU Coreutils `du` and correct POSIX use.
+
+Note that this may be a breaking change for some uses.
+
+Link: https://lists.gnu.org/archive/html/bug-coreutils/2023-03/msg00007.html
+Fixes: https://gitlab.gnome.org/GNOME/glib/-/issues/2965
+---
+ gio/glocalfile.c | 21 +++++++++++++++++++++
+ 1 file changed, 21 insertions(+)
+
+diff --git a/gio/glocalfile.c b/gio/glocalfile.c
+index 67d4b99fb741..e53216962faf 100644
+--- a/gio/glocalfile.c
++++ b/gio/glocalfile.c
+@@ -86,6 +86,9 @@
+ #define FILE_READ_ONLY_VOLUME 0x00080000
+ #endif
+
++#ifndef S_ISREG
++#define S_ISREG(m) (((m) & _S_IFMT) == _S_IFREG)
++#endif
+ #ifndef S_ISDIR
+ #define S_ISDIR(m) (((m) & _S_IFMT) == _S_IFDIR)
+ #endif
+@@ -2777,6 +2780,23 @@ g_local_file_measure_size_of_contents (gint
fd,
+ MeasureState *state,
+ GError **error);
+
++inline static gboolean _g_stat_is_size_usable (const GLocalFileStat *buf)
++{
++#ifndef HAVE_STATX
++ // Memory objects are defined by POSIX, but are not supported by statx nor
Windows
++#ifdef S_TYPEISSHM
++ if (S_TYPEISSHM (buf))
++ return TRUE;
++#endif
++#ifdef S_TYPEISTMO
++ if (S_TYPEISTMO (buf))
++ return TRUE;
++#endif
++#endif
++
++ return S_ISREG (_g_stat_mode (buf)) || S_ISLNK (_g_stat_mode (buf));
++}
++
+ static gboolean
+ g_local_file_measure_size_of_file (gint parent_fd,
+ GSList *name,
+@@ -2836,6 +2856,7 @@ g_local_file_measure_size_of_file (gint
parent_fd,
+ state->disk_usage += _g_stat_blocks (&buf) * G_GUINT64_CONSTANT (512);
+ else
+ #endif
++ if (_g_stat_is_size_usable (&buf))
+ state->disk_usage += _g_stat_size (&buf);
+
+ if (S_ISDIR (_g_stat_mode (&buf)))
Copied:
lib32-glib2/repos/multilib-staging-x86_64/0003-tests-file-Do-not-rely-on-du-bytes-behaviour.patch
(from rev 1448188,
lib32-glib2/trunk/0003-tests-file-Do-not-rely-on-du-bytes-behaviour.patch)
===================================================================
---
multilib-staging-x86_64/0003-tests-file-Do-not-rely-on-du-bytes-behaviour.patch
(rev 0)
+++
multilib-staging-x86_64/0003-tests-file-Do-not-rely-on-du-bytes-behaviour.patch
2023-04-21 18:57:02 UTC (rev 1448189)
@@ -0,0 +1,160 @@
+From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
+From: Joan Bruguera <[email protected]>
+Date: Thu, 23 Mar 2023 02:19:03 +0000
+Subject: [PATCH] tests/file: Do not rely on du --bytes behaviour
+
+As explained in the previous commit, GNU Coreutils 9.2 changes the behaviour
+of `du --bytes` to only count regular files and symlinks.
+
+The previous commit makes the test pass with GNU Coreutils >=9.2, but the
+machine running the tests may have an older version, or perhaps even a
+reimplementation such as uutils. So we can't rely on the size returned by `du`
+to be the consistent across systems any more.
+
+However, the plus side of the new behaviour is that the size reported by `du`
+/ `G_FILE_MEASURE_APPARENT_SIZE` is now well-defined across filesystems
+(as the sum of the sizes of regular files & symlinks), so we can hardcode it.
+
+Fixes: https://gitlab.gnome.org/GNOME/glib/-/issues/2965
+---
+ gio/tests/file.c | 85 ++----------------------------------------------
+ 1 file changed, 3 insertions(+), 82 deletions(-)
+
+diff --git a/gio/tests/file.c b/gio/tests/file.c
+index d16eda5c0b8c..ad2f945f9397 100644
+--- a/gio/tests/file.c
++++ b/gio/tests/file.c
+@@ -2515,105 +2515,33 @@ test_copy_preserve_mode (void)
+ #endif
+ }
+
+-static gchar *
+-splice_to_string (GInputStream *stream,
+- GError **error)
+-{
+- GMemoryOutputStream *buffer = NULL;
+- char *ret = NULL;
+-
+- buffer = (GMemoryOutputStream*)g_memory_output_stream_new (NULL, 0,
g_realloc, g_free);
+- if (g_output_stream_splice ((GOutputStream*)buffer, stream, 0, NULL, error)
< 0)
+- goto out;
+-
+- if (!g_output_stream_write ((GOutputStream*)buffer, "\0", 1, NULL, error))
+- goto out;
+-
+- if (!g_output_stream_close ((GOutputStream*)buffer, NULL, error))
+- goto out;
+-
+- ret = g_memory_output_stream_steal_data (buffer);
+- out:
+- g_clear_object (&buffer);
+- return ret;
+-}
+-
+-static gboolean
+-get_size_from_du (const gchar *path, guint64 *size)
+-{
+- GSubprocess *du;
+- gboolean ok;
+- gchar *result;
+- gchar *endptr;
+- GError *error = NULL;
+- gchar *du_path = NULL;
+-
+-#ifndef __APPLE__
+- du_path = g_find_program_in_path ("du");
+-#endif
+-
+- /* If we can’t find du, don’t try and run the test. */
+- if (du_path == NULL)
+- return FALSE;
+-
+- g_free (du_path);
+-
+- du = g_subprocess_new (G_SUBPROCESS_FLAGS_STDOUT_PIPE,
+- &error,
+- "du", "--bytes", "-s", path, NULL);
+- g_assert_no_error (error);
+-
+- result = splice_to_string (g_subprocess_get_stdout_pipe (du), &error);
+- g_assert_no_error (error);
+-
+- *size = g_ascii_strtoll (result, &endptr, 10);
+-
+- g_subprocess_wait (du, NULL, &error);
+- g_assert_no_error (error);
+-
+- ok = g_subprocess_get_successful (du);
+-
+- g_object_unref (du);
+- g_free (result);
+-
+- return ok;
+-}
+-
+ static void
+ test_measure (void)
+ {
+ GFile *file;
+- guint64 size;
+ guint64 num_bytes;
+ guint64 num_dirs;
+ guint64 num_files;
+ GError *error = NULL;
+ gboolean ok;
+ gchar *path;
+
+ path = g_test_build_filename (G_TEST_DIST, "desktop-files", NULL);
+ file = g_file_new_for_path (path);
+
+- if (!get_size_from_du (path, &size))
+- {
+- g_test_message ("du not found or fail to run, skipping byte
measurement");
+- size = 0;
+- }
+-
+ ok = g_file_measure_disk_usage (file,
+ G_FILE_MEASURE_APPARENT_SIZE,
+ NULL,
+ NULL,
+ NULL,
+ &num_bytes,
+ &num_dirs,
+ &num_files,
+ &error);
+ g_assert_true (ok);
+ g_assert_no_error (error);
+
+- if (size > 0)
+- g_assert_cmpuint (num_bytes, ==, size);
++ g_assert_cmpuint (num_bytes, ==, 74478);
+ g_assert_cmpuint (num_dirs, ==, 6);
+ g_assert_cmpuint (num_files, ==, 32);
+
+@@ -2665,8 +2593,7 @@ measure_done (GObject *source,
+ g_assert_true (ok);
+ g_assert_no_error (error);
+
+- if (data->expected_bytes > 0)
+- g_assert_cmpuint (data->expected_bytes, ==, num_bytes);
++ g_assert_cmpuint (data->expected_bytes, ==, num_bytes);
+ g_assert_cmpuint (data->expected_dirs, ==, num_dirs);
+ g_assert_cmpuint (data->expected_files, ==, num_files);
+
+@@ -2695,15 +2622,9 @@ test_measure_async (void)
+
+ path = g_test_build_filename (G_TEST_DIST, "desktop-files", NULL);
+ file = g_file_new_for_path (path);
+-
+- if (!get_size_from_du (path, &data->expected_bytes))
+- {
+- g_test_message ("du not found or fail to run, skipping byte
measurement");
+- data->expected_bytes = 0;
+- }
+-
+ g_free (path);
+
++ data->expected_bytes = 74478;
+ data->expected_dirs = 6;
+ data->expected_files = 32;
+
Copied: lib32-glib2/repos/multilib-staging-x86_64/PKGBUILD (from rev 1448188,
lib32-glib2/trunk/PKGBUILD)
===================================================================
--- multilib-staging-x86_64/PKGBUILD (rev 0)
+++ multilib-staging-x86_64/PKGBUILD 2023-04-21 18:57:02 UTC (rev 1448189)
@@ -0,0 +1,114 @@
+# Maintainer: Jan Alexander Steffens (heftig) <[email protected]>
+# Contributor: Ionut Biru <[email protected]>
+# Contributor: Pierre Schmitz <[email protected]>
+# Contributor: Mikko Seppälä <[email protected]>
+
+pkgbase=lib32-glib2
+pkgname=(lib32-glib2)
+pkgver=2.76.2
+pkgrel=1
+pkgdesc="Low level core library - 32-bit"
+url="https://wiki.gnome.org/Projects/GLib"
+license=(LGPL)
+arch=(x86_64)
+depends=(
+ glib2
+ lib32-libffi
+ lib32-pcre2
+ lib32-util-linux
+ lib32-zlib
+)
+makedepends=(
+ gettext
+ git
+ gtk-doc
+ lib32-dbus
+ lib32-libelf
+ meson
+ python
+ shared-mime-info
+ util-linux
+)
+checkdepends=(
+ desktop-file-utils
+ lib32-glib2
+)
+options=(
+ debug
+)
+_commit=41ae5b5632ce9f6b2b5613ec1912821f769166c2 # tags/2.76.2^0
+source=(
+ "git+https://gitlab.gnome.org/GNOME/glib.git#commit=$_commit"
+ "git+https://gitlab.gnome.org/GNOME/gvdb.git"
+ 0002-glocalfile-Sum-apparent-size-only-for-files-and-syml.patch
+ 0003-tests-file-Do-not-rely-on-du-bytes-behaviour.patch
+ gio-querymodules-32.hook
+)
+b2sums=('SKIP'
+ 'SKIP'
+
'6bcbcba60208162f7221701d6a642eabfc92c2fc6a476bcb42da5967577f8f0c75b688d149be01c9c48cd644aafa7fbdd63d9086385b8f7607fc981756d71a68'
+
'257bf37d304cc161dedcde0a2c4d01e297f8263cde48b49d3ee47ca95a8fb9ad44bbb9bf99da51ec766ffb6f9d502e0a8fdc6b86346e6755373ee515e23b9419'
+
'678ea2d010fd64b6c55106510096363c54c357d65615c666e9cc3a0e280c0878257a45e646dd88f6bdd0623f7268c4afd2d4f98f82a5489bbfc028c5864252f1')
+
+pkgver() {
+ cd glib
+ git describe --tags | sed 's/[^-]*-g/r&/;s/-/+/g'
+}
+
+prepare() {
+ cd glib
+
+ # fix test suite issues with coreutils >=9.2
+ # https://gitlab.gnome.org/GNOME/glib/-/merge_requests/3358
+ git apply -3
../0002-glocalfile-Sum-apparent-size-only-for-files-and-syml.patch
+ git apply -3 ../0003-tests-file-Do-not-rely-on-du-bytes-behaviour.patch
+
+ git submodule init
+ git submodule set-url subprojects/gvdb "$srcdir/gvdb"
+ git -c protocol.file.allow=always submodule update
+}
+
+build() {
+ local meson_options=(
+ --libdir=/usr/lib32
+ -D glib_debug=disabled
+ -D gtk_doc=false
+ -D man=false
+ -D selinux=disabled
+ -D sysprof=disabled
+ )
+
+ export CC="gcc -m32 -mstackrealign"
+ export CXX="g++ -m32 -mstackrealign"
+ export PKG_CONFIG="i686-pc-linux-gnu-pkg-config"
+
+ # Produce more debug info: GLib has a lot of useful macros
+ CFLAGS+=" -g3"
+ CXXFLAGS+=" -g3"
+
+ arch-meson glib build "${meson_options[@]}"
+ meson compile -C build
+}
+
+check() {
+ meson test -C build --no-suite flaky --no-suite slow --print-errorlogs
+}
+
+package_lib32-glib2() {
+ depends+=(
+ libffi.so
+ libmount.so
+ )
+ provides+=(libg{lib,io,module,object,thread}-2.0.so)
+
+ meson install -C build --destdir "$pkgdir"
+
+ rm -r "$pkgdir"/usr/{lib,share,include}
+ find "$pkgdir/usr/bin" -type f -not -name gio-querymodules -printf 'Removing
%P\n' -delete
+ mv "$pkgdir"/usr/bin/gio-querymodules{,-32}
+
+ install -Dt "$pkgdir/usr/share/libalpm/hooks" -m644 *.hook
+ touch "$pkgdir/usr/lib32/gio/modules/.keep"
+}
+
+# vim:set sw=2 sts=-1 et:
Copied: lib32-glib2/repos/multilib-staging-x86_64/gio-querymodules-32.hook
(from rev 1448188, lib32-glib2/trunk/gio-querymodules-32.hook)
===================================================================
--- multilib-staging-x86_64/gio-querymodules-32.hook
(rev 0)
+++ multilib-staging-x86_64/gio-querymodules-32.hook 2023-04-21 18:57:02 UTC
(rev 1448189)
@@ -0,0 +1,11 @@
+[Trigger]
+Type = Path
+Operation = Install
+Operation = Upgrade
+Operation = Remove
+Target = usr/lib32/gio/modules/*.so
+
+[Action]
+Description = Updating 32-bit GIO module cache...
+When = PostTransaction
+Exec = /usr/bin/gio-querymodules-32 /usr/lib32/gio/modules