glib2: split package into separate libraries
authorAlexandru Ardelean <redacted>
Tue, 28 Apr 2026 05:01:56 +0000 (08:01 +0300)
committerAlexandru Ardelean <redacted>
Fri, 1 May 2026 04:54:50 +0000 (07:54 +0300)
Existing package contains five libraries, some of which are > 1MB. Allow
packages which depend on only some of them to only pull in the ones they
need by splitting this package into finer-grained packages. Transition
can be done piecemeal as depending on glib2 will still pull in all the
libraries.

The original split commit (6bb0d6bd2) had a typo: the glib2 meta-package
used 'DEPENDS:+glib2-gthread +glib2-gio' (missing '='), which caused
the meta-package to have no effective dependencies. This meant packages
declaring '+glib2' did not get the sub-packages installed, causing APK
dependency checks to fail for all glib2 libraries across ~60 packages.

This re-applies the split with 'DEPENDS:=+glib2-gthread +glib2-gio'
(correct assignment syntax), so the meta-package properly pulls in all
sub-packages for consumers that still declare '+glib2'.

Signed-off-by: Alexandru Ardelean <redacted>
Signed-off-by: Alexandru Ardelean <redacted>
libs/glib2/Makefile

index 225fe07754a70b8b49cad92490775a0bef1c411d..680f1258ac831a2064f3552c0243e5aa6e7a6261 100644 (file)
@@ -9,7 +9,7 @@ include $(TOPDIR)/rules.mk
 
 PKG_NAME:=glib2
 PKG_VERSION:=2.82.0
-PKG_RELEASE:=2
+PKG_RELEASE:=3
 
 PKG_SOURCE:=glib-$(PKG_VERSION).tar.xz
 PKG_SOURCE_URL:=@GNOME/glib/$(basename $(PKG_VERSION))
@@ -33,14 +33,68 @@ include $(INCLUDE_DIR)/package.mk
 include $(INCLUDE_DIR)/nls.mk
 include $(INCLUDE_DIR)/meson.mk
 
-define Package/glib2
+define Package/glib2/default
   SECTION:=libs
   CATEGORY:=Libraries
-  DEPENDS:=$(ICONV_DEPENDS) $(INTL_DEPENDS) +zlib +libpthread +libffi +libattr +libpcre2
-  TITLE:=glib 2.0
   URL:=http://www.gtk.org/
 endef
 
+define Package/glib2-core
+$(call Package/glib2/default)
+  TITLE:=GLib 2.0 core library
+  DEPENDS:=$(ICONV_DEPENDS) $(INTL_DEPENDS) +libattr +libpcre2
+endef
+
+define Package/glib2-gmodule
+$(call Package/glib2/default)
+  TITLE:=GLib 2.0 gmodule library
+  DEPENDS:=+glib2-core
+endef
+
+define Package/glib2-gthread
+$(call Package/glib2/default)
+  TITLE:=GLib 2.0 gthread library
+  DEPENDS:=+glib2-core
+endef
+
+define Package/glib2-gobject
+$(call Package/glib2/default)
+  TITLE:=GLib 2.0 gobject library
+  DEPENDS:=+glib2-core +libffi
+endef
+
+define Package/glib2-gio
+$(call Package/glib2/default)
+  TITLE:=GLib 2.0 gio library
+  DEPENDS:=+glib2-core +glib2-gobject +glib2-gmodule +zlib +libffi
+endef
+
+define Package/glib2
+$(call Package/glib2/default)
+  TITLE:=Full GLib 2.0 library
+  DEPENDS:=+glib2-gthread +glib2-gio
+endef
+
+define Package/glib2-core/description
+  Common code and core library for GLib library of C routines
+endef
+
+define Package/glib2-gmodule/description
+  GLib library module functions
+endef
+
+define Package/glib2-gthread/description
+  GLib library thread functions
+endef
+
+define Package/glib2-gobject/description
+  GLib library object functions
+endef
+
+define Package/glib2-gio/description
+  GLib library io functions
+endef
+
 define Package/glib2/description
   The GLib library of C routines
 endef
@@ -122,12 +176,44 @@ define Build/InstallDev
                $(1)/usr/share/glib-2.0/
 endef
 
-define Package/glib2/install
+define Package/glib2-core/install
        $(INSTALL_DIR) $(1)/usr/lib
-       $(CP) \
-               $(PKG_INSTALL_DIR)/usr/lib/*.so* \
+       $(CP) $(PKG_INSTALL_DIR)/usr/lib/libglib-2.0.so* \
                $(1)/usr/lib/
 endef
 
+define Package/glib2-gmodule/install
+       $(INSTALL_DIR) $(1)/usr/lib
+       $(CP) $(PKG_INSTALL_DIR)/usr/lib/libgmodule-2.0.so* \
+               $(1)/usr/lib
+endef
+
+define Package/glib2-gthread/install
+       $(INSTALL_DIR) $(1)/usr/lib
+       $(CP) $(PKG_INSTALL_DIR)/usr/lib/libgthread-2.0.so* \
+               $(1)/usr/lib
+endef
+
+define Package/glib2-gobject/install
+       $(INSTALL_DIR) $(1)/usr/lib
+       $(CP) $(PKG_INSTALL_DIR)/usr/lib/libgobject-2.0.so* \
+               $(1)/usr/lib
+endef
+
+define Package/glib2-gio/install
+       $(INSTALL_DIR) $(1)/usr/lib
+       $(CP) $(PKG_INSTALL_DIR)/usr/lib/libgio-2.0.so* \
+               $(1)/usr/lib
+endef
+
+define Package/glib2/install
+       :
+endef
+
 $(eval $(call HostBuild))
+$(eval $(call BuildPackage,glib2-core))
+$(eval $(call BuildPackage,glib2-gmodule))
+$(eval $(call BuildPackage,glib2-gthread))
+$(eval $(call BuildPackage,glib2-gobject))
+$(eval $(call BuildPackage,glib2-gio))
 $(eval $(call BuildPackage,glib2))
git clone https://git.99rst.org/PROJECT