Blame flatpak-trim-unused-shared-library-linkages.patch

2e3aca0
From efe5c943a8c6c3ae842ea737908ea6a8e3ad807d Mon Sep 17 00:00:00 2001
2e3aca0
From: Debarshi Ray <debarshir@gnome.org>
2e3aca0
Date: Tue, 13 Aug 2019 15:46:17 +0200
2e3aca0
Subject: [PATCH 1/4] build: Link against libarchive only when necessary
2e3aca0
2e3aca0
The libarchive API is used in a relatively few places inside the
2e3aca0
'common' sub-directory. It's definitely not as widespread as GLib. A
2e3aca0
subsequent commit will leverage this to prevent unused shared
2e3aca0
libraries from being linked to the session helper.
2e3aca0
2e3aca0
Closes: #3052
2e3aca0
Approved by: alexlarsson
2e3aca0
---
2e3aca0
 common/Makefile.am.inc | 3 ++-
2e3aca0
 configure.ac           | 3 ++-
2e3aca0
 2 files changed, 4 insertions(+), 2 deletions(-)
2e3aca0
2e3aca0
diff --git a/common/Makefile.am.inc b/common/Makefile.am.inc
2e3aca0
index 5483ac4ea5ac..56dbb7cab0ba 100644
2e3aca0
--- a/common/Makefile.am.inc
2e3aca0
+++ b/common/Makefile.am.inc
2e3aca0
@@ -131,6 +131,7 @@ libflatpak_common_la_SOURCES = \
2e3aca0
 libflatpak_common_la_CFLAGS = \
2e3aca0
 	-DFLATPAK_COMPILATION \
2e3aca0
 	$(AM_CFLAGS) \
2e3aca0
+	$(ARCHIVE_CFLAGS) \
2e3aca0
 	$(BASE_CFLAGS) \
2e3aca0
 	$(HIDDEN_VISIBILITY_CFLAGS) \
2e3aca0
 	$(OSTREE_CFLAGS) \
2e3aca0
@@ -144,7 +145,7 @@ libflatpak_common_la_CFLAGS = \
2e3aca0
 	-DLIBEXECDIR=\"$(libexecdir)\" \
2e3aca0
 	-I$(srcdir)/dbus-proxy \
2e3aca0
 	$(NULL)
2e3aca0
-libflatpak_common_la_LIBADD = $(AM_LIBADD) libglnx.la $(BASE_LIBS) $(OSTREE_LIBS) $(SOUP_LIBS) $(JSON_LIBS) $(XAUTH_LIBS) $(LIBSECCOMP_LIBS) $(INTERNAL_GPGME_LIBS) $(SYSTEMD_LIBS) $(DCONF_LIBS)
2e3aca0
+libflatpak_common_la_LIBADD = $(AM_LIBADD) libglnx.la $(ARCHIVE_LIBS) $(BASE_LIBS) $(OSTREE_LIBS) $(SOUP_LIBS) $(JSON_LIBS) $(XAUTH_LIBS) $(LIBSECCOMP_LIBS) $(INTERNAL_GPGME_LIBS) $(SYSTEMD_LIBS) $(DCONF_LIBS)
2e3aca0
 
2e3aca0
 
2e3aca0
 libflatpak_la_SOURCES = \
2e3aca0
diff --git a/configure.ac b/configure.ac
2e3aca0
index 2cd7af6a484b..49bc0b72f037 100644
2e3aca0
--- a/configure.ac
2e3aca0
+++ b/configure.ac
2e3aca0
@@ -210,7 +210,8 @@ AC_SUBST([GDBUS_CODEGEN], [`$PKG_CONFIG --variable gdbus_codegen gio-2.0`])
2e3aca0
 
2e3aca0
 POLKIT_GOBJECT_REQUIRED=0.98
2e3aca0
 
2e3aca0
-PKG_CHECK_MODULES(BASE, [glib-2.0 >= $GLIB_REQS gio-2.0 gio-unix-2.0 libarchive >= 2.8.0 libxml-2.0 >= 2.4 ])
2e3aca0
+PKG_CHECK_MODULES(ARCHIVE, [libarchive >= 2.8.0])
2e3aca0
+PKG_CHECK_MODULES(BASE, [glib-2.0 >= $GLIB_REQS gio-2.0 gio-unix-2.0 libxml-2.0 >= 2.4 ])
2e3aca0
 PKG_CHECK_MODULES(SOUP, [libsoup-2.4])
2e3aca0
 PKG_CHECK_MODULES(DCONF, [dconf >= 0.26], [have_dconf=yes], [have_dconf=no])
2e3aca0
 if test $have_dconf = yes; then
2e3aca0
-- 
2e3aca0
2.20.1
2e3aca0
2e3aca0
2e3aca0
From 8ffb98e65dae539d65acdd281221d5a83f4f1acb Mon Sep 17 00:00:00 2001
2e3aca0
From: Debarshi Ray <debarshir@gnome.org>
2e3aca0
Date: Tue, 13 Aug 2019 16:47:02 +0200
2e3aca0
Subject: [PATCH 2/4] build: Link against libxml only when necessary
2e3aca0
2e3aca0
The libxml API is used in a relatively few places inside the 'common'
2e3aca0
sub-directory. It's definitely not as widespread as GLib. A subsequent
2e3aca0
commit will leverage this to prevent unused shared libraries from
2e3aca0
being linked to the session helper.
2e3aca0
2e3aca0
Closes: #3052
2e3aca0
Approved by: alexlarsson
2e3aca0
---
2e3aca0
 common/Makefile.am.inc | 3 ++-
2e3aca0
 configure.ac           | 3 ++-
2e3aca0
 2 files changed, 4 insertions(+), 2 deletions(-)
2e3aca0
2e3aca0
diff --git a/common/Makefile.am.inc b/common/Makefile.am.inc
2e3aca0
index 56dbb7cab0ba..3019802f2ae9 100644
2e3aca0
--- a/common/Makefile.am.inc
2e3aca0
+++ b/common/Makefile.am.inc
2e3aca0
@@ -138,6 +138,7 @@ libflatpak_common_la_CFLAGS = \
2e3aca0
 	$(SOUP_CFLAGS) \
2e3aca0
 	$(JSON_CFLAGS) \
2e3aca0
 	$(XAUTH_CFLAGS) \
2e3aca0
+	$(XML_CFLAGS) \
2e3aca0
 	$(LIBSECCOMP_CFLAGS) \
2e3aca0
 	$(INTERNAL_GPGME_CFLAGS) \
2e3aca0
 	$(SYSTEMD_CFLAGS) \
2e3aca0
@@ -145,7 +146,7 @@ libflatpak_common_la_CFLAGS = \
2e3aca0
 	-DLIBEXECDIR=\"$(libexecdir)\" \
2e3aca0
 	-I$(srcdir)/dbus-proxy \
2e3aca0
 	$(NULL)
2e3aca0
-libflatpak_common_la_LIBADD = $(AM_LIBADD) libglnx.la $(ARCHIVE_LIBS) $(BASE_LIBS) $(OSTREE_LIBS) $(SOUP_LIBS) $(JSON_LIBS) $(XAUTH_LIBS) $(LIBSECCOMP_LIBS) $(INTERNAL_GPGME_LIBS) $(SYSTEMD_LIBS) $(DCONF_LIBS)
2e3aca0
+libflatpak_common_la_LIBADD = $(AM_LIBADD) libglnx.la $(ARCHIVE_LIBS) $(BASE_LIBS) $(OSTREE_LIBS) $(SOUP_LIBS) $(JSON_LIBS) $(XAUTH_LIBS) $(XML_LIBS) $(LIBSECCOMP_LIBS) $(INTERNAL_GPGME_LIBS) $(SYSTEMD_LIBS) $(DCONF_LIBS)
2e3aca0
 
2e3aca0
 
2e3aca0
 libflatpak_la_SOURCES = \
2e3aca0
diff --git a/configure.ac b/configure.ac
2e3aca0
index 49bc0b72f037..7b85258df962 100644
2e3aca0
--- a/configure.ac
2e3aca0
+++ b/configure.ac
2e3aca0
@@ -211,8 +211,9 @@ AC_SUBST([GDBUS_CODEGEN], [`$PKG_CONFIG --variable gdbus_codegen gio-2.0`])
2e3aca0
 POLKIT_GOBJECT_REQUIRED=0.98
2e3aca0
 
2e3aca0
 PKG_CHECK_MODULES(ARCHIVE, [libarchive >= 2.8.0])
2e3aca0
-PKG_CHECK_MODULES(BASE, [glib-2.0 >= $GLIB_REQS gio-2.0 gio-unix-2.0 libxml-2.0 >= 2.4 ])
2e3aca0
+PKG_CHECK_MODULES(BASE, [glib-2.0 >= $GLIB_REQS gio-2.0 gio-unix-2.0])
2e3aca0
 PKG_CHECK_MODULES(SOUP, [libsoup-2.4])
2e3aca0
+PKG_CHECK_MODULES(XML, [libxml-2.0 >= 2.4])
2e3aca0
 PKG_CHECK_MODULES(DCONF, [dconf >= 0.26], [have_dconf=yes], [have_dconf=no])
2e3aca0
 if test $have_dconf = yes; then
2e3aca0
   AC_DEFINE(HAVE_DCONF, 1, [Define if dconf is available])
2e3aca0
-- 
2e3aca0
2.20.1
2e3aca0
2e3aca0
2e3aca0
From f72ce1891ba955167a7344b67451f6e4c5c32e1c Mon Sep 17 00:00:00 2001
2e3aca0
From: Debarshi Ray <debarshir@gnome.org>
2e3aca0
Date: Tue, 13 Aug 2019 18:01:30 +0200
2e3aca0
Subject: [PATCH 3/4] common, session-helper: Make the session helper more
2e3aca0
 self-contained
2e3aca0
2e3aca0
... by moving the definition of FlatpakHostCommandFlags from the
2e3aca0
'common' sub-directory to 'session-helper'. It hasn't been used by
2e3aca0
anything else ever since flatpak-builder was moved to a separate
2e3aca0
repository in commit 52bd14656151fe63.
2e3aca0
2e3aca0
Closes: #3052
2e3aca0
Approved by: alexlarsson
2e3aca0
---
2e3aca0
 common/flatpak-utils-private.h          | 5 -----
2e3aca0
 session-helper/flatpak-session-helper.c | 5 +++++
2e3aca0
 2 files changed, 5 insertions(+), 5 deletions(-)
2e3aca0
2e3aca0
diff --git a/common/flatpak-utils-private.h b/common/flatpak-utils-private.h
2e3aca0
index a5c03ceb5a76..0151b5253d2a 100644
2e3aca0
--- a/common/flatpak-utils-private.h
2e3aca0
+++ b/common/flatpak-utils-private.h
2e3aca0
@@ -37,11 +37,6 @@
2e3aca0
 
2e3aca0
 #define AUTOFS_SUPER_MAGIC 0x0187
2e3aca0
 
2e3aca0
-typedef enum {
2e3aca0
-  FLATPAK_HOST_COMMAND_FLAGS_CLEAR_ENV = 1 << 0,
2e3aca0
-  FLATPAK_HOST_COMMAND_FLAGS_WATCH_BUS = 1 << 1,
2e3aca0
-} FlatpakHostCommandFlags;
2e3aca0
-
2e3aca0
 #define FLATPAK_ANSI_ALT_SCREEN_ON "\x1b[?1049h"
2e3aca0
 #define FLATPAK_ANSI_ALT_SCREEN_OFF "\x1b[?1049l"
2e3aca0
 #define FLATPAK_ANSI_HIDE_CURSOR "\x1b[?25l"
2e3aca0
diff --git a/session-helper/flatpak-session-helper.c b/session-helper/flatpak-session-helper.c
2e3aca0
index 5dd7629e7f88..0fbac666775c 100644
2e3aca0
--- a/session-helper/flatpak-session-helper.c
2e3aca0
+++ b/session-helper/flatpak-session-helper.c
2e3aca0
@@ -30,6 +30,11 @@
2e3aca0
 #include "flatpak-dbus-generated.h"
2e3aca0
 #include "flatpak-utils-private.h"
2e3aca0
 
2e3aca0
+typedef enum {
2e3aca0
+  FLATPAK_HOST_COMMAND_FLAGS_CLEAR_ENV = 1 << 0,
2e3aca0
+  FLATPAK_HOST_COMMAND_FLAGS_WATCH_BUS = 1 << 1,
2e3aca0
+} FlatpakHostCommandFlags;
2e3aca0
+
2e3aca0
 static char *monitor_dir;
2e3aca0
 static char *p11_kit_server_socket_path;
2e3aca0
 static int p11_kit_server_pid = 0;
2e3aca0
-- 
2e3aca0
2.20.1
2e3aca0
2e3aca0
2e3aca0
From dd07d16a28782c5090ae5a2d40158e8325f7b70d Mon Sep 17 00:00:00 2001
2e3aca0
From: Debarshi Ray <debarshir@gnome.org>
2e3aca0
Date: Mon, 12 Aug 2019 22:19:19 +0200
2e3aca0
Subject: [PATCH 4/4] Trim unused shared library linkages from the session
2e3aca0
 helper
2e3aca0
2e3aca0
The org.freedesktop.Flatpak user D-Bus service isn't just used by
2e3aca0
flatpak(1) or applications running as Flatpaks. It's also used by
2e3aca0
toolbox(1) for similar reasons:
2e3aca0
 * To keep various configuration files inside the container
2e3aca0
   synchronized with the host
2e3aca0
 * To let the container request certain commands to be run on the host
2e3aca0
2e3aca0
The org.freedesktop.Flatpak D-Bus service itself doesn't need much in
2e3aca0
the way of dependencies, but inherits a lot of unused shared library
2e3aca0
linkages through the libflatpak-common.la convenience library. Removing
2e3aca0
these unused shared libraries reduces the footprint of toolbox(1) for
2e3aca0
those who care about such things. eg., Fedora CoreOS.
2e3aca0
2e3aca0
This commit brings down the number of shared libraries to 19 from 62.
2e3aca0
2e3aca0
Closes: #3052
2e3aca0
Approved by: alexlarsson
2e3aca0
---
2e3aca0
 app/Makefile.am.inc                      |   3 +-
2e3aca0
 app/flatpak-builtins-build-update-repo.c |   4 +-
2e3aca0
 common/Makefile.am.inc                   |  29 ++++++-
2e3aca0
 common/flatpak-dir.c                     |   4 +-
2e3aca0
 common/flatpak-exports.c                 |   4 +-
2e3aca0
 common/flatpak-run.c                     |   4 +-
2e3aca0
 common/flatpak-utils-base-private.h      |  34 ++++++++
2e3aca0
 common/flatpak-utils-base.c              | 100 +++++++++++++++++++++++
2e3aca0
 common/flatpak-utils-private.h           |   8 --
2e3aca0
 common/flatpak-utils.c                   |  74 +----------------
2e3aca0
 session-helper/Makefile.am.inc           |   4 +-
2e3aca0
 session-helper/flatpak-session-helper.c  |   5 +-
2e3aca0
 system-helper/Makefile.am.inc            |   2 +-
2e3aca0
 tests/Makefile.am.inc                    |   7 +-
2e3aca0
 14 files changed, 181 insertions(+), 101 deletions(-)
2e3aca0
 create mode 100644 common/flatpak-utils-base-private.h
2e3aca0
 create mode 100644 common/flatpak-utils-base.c
2e3aca0
2e3aca0
diff --git a/app/Makefile.am.inc b/app/Makefile.am.inc
2e3aca0
index 558065343353..a561c1d056db 100644
2e3aca0
--- a/app/Makefile.am.inc
2e3aca0
+++ b/app/Makefile.am.inc
2e3aca0
@@ -49,8 +49,6 @@ libflatpak_app_la_LIBADD = \
2e3aca0
 	$(APPSTREAM_GLIB_LIBS) \
2e3aca0
 	$(SYSTEMD_LIBS) \
2e3aca0
 	$(POLKIT_LIBS) \
2e3aca0
-	libglnx.la \
2e3aca0
-	libflatpak-common.la \
2e3aca0
 	$(NULL)
2e3aca0
 
2e3aca0
 libflatpak_app_la_CFLAGS = \
2e3aca0
@@ -143,6 +141,7 @@ flatpak_LDADD = \
2e3aca0
 	libglnx.la \
2e3aca0
 	libflatpak-app.la \
2e3aca0
 	libflatpak-common.la \
2e3aca0
+	libflatpak-common-base.la \
2e3aca0
 	$(NULL)
2e3aca0
 
2e3aca0
 flatpak_CFLAGS = \
2e3aca0
diff --git a/app/flatpak-builtins-build-update-repo.c b/app/flatpak-builtins-build-update-repo.c
2e3aca0
index f106436df698..6442da4e40ba 100644
2e3aca0
--- a/app/flatpak-builtins-build-update-repo.c
2e3aca0
+++ b/app/flatpak-builtins-build-update-repo.c
2e3aca0
@@ -1,5 +1,5 @@
2e3aca0
 /*
2e3aca0
- * Copyright © 2014 Red Hat, Inc
2e3aca0
+ * Copyright © 2014-2019 Red Hat, Inc
2e3aca0
  *
2e3aca0
  * This program is free software; you can redistribute it and/or
2e3aca0
  * modify it under the terms of the GNU Lesser General Public
2e3aca0
@@ -30,7 +30,7 @@
2e3aca0
 #include "libglnx/libglnx.h"
2e3aca0
 
2e3aca0
 #include "flatpak-builtins.h"
2e3aca0
-#include "flatpak-utils-private.h"
2e3aca0
+#include "flatpak-utils-base-private.h"
2e3aca0
 #include "flatpak-builtins-utils.h"
2e3aca0
 
2e3aca0
 static char *opt_title;
2e3aca0
diff --git a/common/Makefile.am.inc b/common/Makefile.am.inc
2e3aca0
index 3019802f2ae9..867c9c052935 100644
2e3aca0
--- a/common/Makefile.am.inc
2e3aca0
+++ b/common/Makefile.am.inc
2e3aca0
@@ -1,5 +1,5 @@
2e3aca0
 lib_LTLIBRARIES += libflatpak.la
2e3aca0
-noinst_LTLIBRARIES += libflatpak-common.la
2e3aca0
+noinst_LTLIBRARIES += libflatpak-common-base.la libflatpak-common.la
2e3aca0
 noinst_PROGRAMS += test-libflatpak
2e3aca0
 
2e3aca0
 flatpakincludedir = $(includedir)/flatpak
2e3aca0
@@ -67,9 +67,30 @@ common/flatpak-systemd-dbus-generated.c: data/org.freedesktop.systemd1.xml Makef
2e3aca0
 common/%-dbus-generated.h: common/%-dbus-generated.c
2e3aca0
 	@true # Built as a side-effect of the rules for the .c
2e3aca0
 
2e3aca0
+nodist_libflatpak_common_base_la_SOURCES = \
2e3aca0
+	$(dbus_built_sources)		\
2e3aca0
+	$(NULL)
2e3aca0
+
2e3aca0
+BUILT_SOURCES += $(nodist_libflatpak_common_base_la_SOURCES)
2e3aca0
+CLEANFILES += $(nodist_libflatpak_common_base_la_SOURCES)
2e3aca0
+
2e3aca0
+libflatpak_common_base_la_SOURCES = \
2e3aca0
+	common/flatpak-utils-base.c \
2e3aca0
+	common/flatpak-utils-base-private.h \
2e3aca0
+	$(NULL)
2e3aca0
+
2e3aca0
+libflatpak_common_base_la_CFLAGS = \
2e3aca0
+	-DFLATPAK_COMPILATION \
2e3aca0
+	$(AM_CFLAGS) \
2e3aca0
+	$(BASE_CFLAGS) \
2e3aca0
+	$(HIDDEN_VISIBILITY_CFLAGS) \
2e3aca0
+	-DLIBEXECDIR=\"$(libexecdir)\" \
2e3aca0
+	$(NULL)
2e3aca0
+
2e3aca0
+libflatpak_common_base_la_LIBADD = $(AM_LIBADD) $(BASE_LIBS)
2e3aca0
+
2e3aca0
 nodist_libflatpak_common_la_SOURCES = \
2e3aca0
 	$(nodist_flatpakinclude_HEADERS)    \
2e3aca0
-	$(dbus_built_sources)		\
2e3aca0
 	$(systemd_dbus_built_sources)	\
2e3aca0
 	$(xdp_dbus_built_sources) \
2e3aca0
 	common/flatpak-enum-types.c \
2e3aca0
@@ -146,7 +167,7 @@ libflatpak_common_la_CFLAGS = \
2e3aca0
 	-DLIBEXECDIR=\"$(libexecdir)\" \
2e3aca0
 	-I$(srcdir)/dbus-proxy \
2e3aca0
 	$(NULL)
2e3aca0
-libflatpak_common_la_LIBADD = $(AM_LIBADD) libglnx.la $(ARCHIVE_LIBS) $(BASE_LIBS) $(OSTREE_LIBS) $(SOUP_LIBS) $(JSON_LIBS) $(XAUTH_LIBS) $(XML_LIBS) $(LIBSECCOMP_LIBS) $(INTERNAL_GPGME_LIBS) $(SYSTEMD_LIBS) $(DCONF_LIBS)
2e3aca0
+libflatpak_common_la_LIBADD = $(AM_LIBADD) $(ARCHIVE_LIBS) $(BASE_LIBS) $(OSTREE_LIBS) $(SOUP_LIBS) $(JSON_LIBS) $(XAUTH_LIBS) $(XML_LIBS) $(LIBSECCOMP_LIBS) $(INTERNAL_GPGME_LIBS) $(SYSTEMD_LIBS) $(DCONF_LIBS)
2e3aca0
 
2e3aca0
 
2e3aca0
 libflatpak_la_SOURCES = \
2e3aca0
@@ -175,6 +196,8 @@ libflatpak_la_LDFLAGS = \
2e3aca0
 libflatpak_la_LIBADD = \
2e3aca0
 	$(AM_LIBADD) \
2e3aca0
 	libflatpak-common.la \
2e3aca0
+	libflatpak-common-base.la \
2e3aca0
+	libglnx.la \
2e3aca0
 	$(BASE_LIBS)	\
2e3aca0
 	$(OSTREE_LIBS)	\
2e3aca0
 	$(SOUP_LIBS)	\
2e3aca0
diff --git a/common/flatpak-dir.c b/common/flatpak-dir.c
2e3aca0
index 8f9dc66cc95b..d898d6242028 100644
2e3aca0
--- a/common/flatpak-dir.c
2e3aca0
+++ b/common/flatpak-dir.c
2e3aca0
@@ -1,5 +1,5 @@
2e3aca0
 /*
2e3aca0
- * Copyright © 2014 Red Hat, Inc
2e3aca0
+ * Copyright © 2014-2019 Red Hat, Inc
2e3aca0
  * Copyright © 2017 Endless Mobile, Inc.
2e3aca0
  *
2e3aca0
  * This program is free software; you can redistribute it and/or
2e3aca0
@@ -43,7 +43,7 @@
2e3aca0
 #include <ostree.h>
2e3aca0
 
2e3aca0
 #include "flatpak-dir-private.h"
2e3aca0
-#include "flatpak-utils-private.h"
2e3aca0
+#include "flatpak-utils-base-private.h"
2e3aca0
 #include "flatpak-oci-registry-private.h"
2e3aca0
 #include "flatpak-run-private.h"
2e3aca0
 #include "flatpak-appdata-private.h"
2e3aca0
diff --git a/common/flatpak-exports.c b/common/flatpak-exports.c
2e3aca0
index 7a5694cc37f6..8562712ba1b1 100644
2e3aca0
--- a/common/flatpak-exports.c
2e3aca0
+++ b/common/flatpak-exports.c
2e3aca0
@@ -1,5 +1,5 @@
2e3aca0
 /*
2e3aca0
- * Copyright © 2014-2018 Red Hat, Inc
2e3aca0
+ * Copyright © 2014-2019 Red Hat, Inc
2e3aca0
  *
2e3aca0
  * This program is free software; you can redistribute it and/or
2e3aca0
  * modify it under the terms of the GNU Lesser General Public
2e3aca0
@@ -43,7 +43,7 @@
2e3aca0
 #include "flatpak-exports-private.h"
2e3aca0
 #include "flatpak-run-private.h"
2e3aca0
 #include "flatpak-proxy.h"
2e3aca0
-#include "flatpak-utils-private.h"
2e3aca0
+#include "flatpak-utils-base-private.h"
2e3aca0
 #include "flatpak-dir-private.h"
2e3aca0
 #include "flatpak-systemd-dbus-generated.h"
2e3aca0
 #include "flatpak-error.h"
2e3aca0
diff --git a/common/flatpak-run.c b/common/flatpak-run.c
2e3aca0
index 8d52d3a528fa..8d0d01acba4a 100644
2e3aca0
--- a/common/flatpak-run.c
2e3aca0
+++ b/common/flatpak-run.c
2e3aca0
@@ -1,5 +1,5 @@
2e3aca0
 /*
2e3aca0
- * Copyright © 2014 Red Hat, Inc
2e3aca0
+ * Copyright © 2014-2019 Red Hat, Inc
2e3aca0
  *
2e3aca0
  * This program is free software; you can redistribute it and/or
2e3aca0
  * modify it under the terms of the GNU Lesser General Public
2e3aca0
@@ -52,7 +52,7 @@
2e3aca0
 
2e3aca0
 #include "flatpak-run-private.h"
2e3aca0
 #include "flatpak-proxy.h"
2e3aca0
-#include "flatpak-utils-private.h"
2e3aca0
+#include "flatpak-utils-base-private.h"
2e3aca0
 #include "flatpak-dir-private.h"
2e3aca0
 #include "flatpak-systemd-dbus-generated.h"
2e3aca0
 #include "flatpak-document-dbus-generated.h"
2e3aca0
diff --git a/common/flatpak-utils-base-private.h b/common/flatpak-utils-base-private.h
2e3aca0
new file mode 100644
2e3aca0
index 000000000000..d7a55273bd6b
2e3aca0
--- /dev/null
2e3aca0
+++ b/common/flatpak-utils-base-private.h
2e3aca0
@@ -0,0 +1,34 @@
2e3aca0
+/*
2e3aca0
+ * Copyright © 2019 Red Hat, Inc
2e3aca0
+ *
2e3aca0
+ * This program is free software; you can redistribute it and/or
2e3aca0
+ * modify it under the terms of the GNU Lesser General Public
2e3aca0
+ * License as published by the Free Software Foundation; either
2e3aca0
+ * version 2.1 of the License, or (at your option) any later version.
2e3aca0
+ *
2e3aca0
+ * This library is distributed in the hope that it will be useful,
2e3aca0
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
2e3aca0
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.	 See the GNU
2e3aca0
+ * Lesser General Public License for more details.
2e3aca0
+ *
2e3aca0
+ * You should have received a copy of the GNU Lesser General Public
2e3aca0
+ * License along with this library. If not, see <http://www.gnu.org/licenses/>.
2e3aca0
+ *
2e3aca0
+ * Authors:
2e3aca0
+ *       Alexander Larsson <alexl@redhat.com>
2e3aca0
+ */
2e3aca0
+
2e3aca0
+#ifndef __FLATPAK_UTILS_BASE_H__
2e3aca0
+#define __FLATPAK_UTILS_BASE_H__
2e3aca0
+
2e3aca0
+#include <glib.h>
2e3aca0
+
2e3aca0
+char *flatpak_get_timezone (void);
2e3aca0
+
2e3aca0
+char * flatpak_readlink (const char *path,
2e3aca0
+                         GError    **error);
2e3aca0
+char * flatpak_resolve_link (const char *path,
2e3aca0
+                             GError    **error);
2e3aca0
+char * flatpak_canonicalize_filename (const char *path);
2e3aca0
+
2e3aca0
+#endif /* __FLATPAK_UTILS_BASE_H__ */
2e3aca0
diff --git a/common/flatpak-utils-base.c b/common/flatpak-utils-base.c
2e3aca0
new file mode 100644
2e3aca0
index 000000000000..07d7725e1a86
2e3aca0
--- /dev/null
2e3aca0
+++ b/common/flatpak-utils-base.c
2e3aca0
@@ -0,0 +1,100 @@
2e3aca0
+/*
2e3aca0
+ * Copyright © 2019 Red Hat, Inc
2e3aca0
+ *
2e3aca0
+ * This program is free software; you can redistribute it and/or
2e3aca0
+ * modify it under the terms of the GNU Lesser General Public
2e3aca0
+ * License as published by the Free Software Foundation; either
2e3aca0
+ * version 2.1 of the License, or (at your option) any later version.
2e3aca0
+ *
2e3aca0
+ * This library is distributed in the hope that it will be useful,
2e3aca0
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
2e3aca0
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
2e3aca0
+ * Lesser General Public License for more details.
2e3aca0
+ *
2e3aca0
+ * You should have received a copy of the GNU Lesser General Public
2e3aca0
+ * License along with this library. If not, see <http://www.gnu.org/licenses/>.
2e3aca0
+ *
2e3aca0
+ * Authors:
2e3aca0
+ *       Alexander Larsson <alexl@redhat.com>
2e3aca0
+ */
2e3aca0
+
2e3aca0
+#include "config.h"
2e3aca0
+
2e3aca0
+#include "flatpak-utils-base-private.h"
2e3aca0
+
2e3aca0
+#include <stdlib.h>
2e3aca0
+#include <string.h>
2e3aca0
+
2e3aca0
+#include <gio/gio.h>
2e3aca0
+#include "libglnx/libglnx.h"
2e3aca0
+
2e3aca0
+char *
2e3aca0
+flatpak_get_timezone (void)
2e3aca0
+{
2e3aca0
+  g_autofree gchar *symlink = NULL;
2e3aca0
+  gchar *etc_timezone = NULL;
2e3aca0
+  const gchar *tzdir;
2e3aca0
+
2e3aca0
+  tzdir = getenv ("TZDIR");
2e3aca0
+  if (tzdir == NULL)
2e3aca0
+    tzdir = "/usr/share/zoneinfo";
2e3aca0
+
2e3aca0
+  symlink = flatpak_resolve_link ("/etc/localtime", NULL);
2e3aca0
+  if (symlink != NULL)
2e3aca0
+    {
2e3aca0
+      /* Resolve relative path */
2e3aca0
+      g_autofree gchar *canonical = flatpak_canonicalize_filename (symlink);
2e3aca0
+      char *canonical_suffix;
2e3aca0
+
2e3aca0
+      /* Strip the prefix and slashes if possible. */
2e3aca0
+      if (g_str_has_prefix (canonical, tzdir))
2e3aca0
+        {
2e3aca0
+          canonical_suffix = canonical + strlen (tzdir);
2e3aca0
+          while (*canonical_suffix == '/')
2e3aca0
+            canonical_suffix++;
2e3aca0
+
2e3aca0
+          return g_strdup (canonical_suffix);
2e3aca0
+        }
2e3aca0
+    }
2e3aca0
+
2e3aca0
+  if (g_file_get_contents ("/etc/timezeone", &etc_timezone,
2e3aca0
+                           NULL, NULL))
2e3aca0
+    {
2e3aca0
+      g_strchomp (etc_timezone);
2e3aca0
+      return etc_timezone;
2e3aca0
+    }
2e3aca0
+
2e3aca0
+  /* Final fall-back is UTC */
2e3aca0
+  return g_strdup ("UTC");
2e3aca0
+}
2e3aca0
+
2e3aca0
+char *
2e3aca0
+flatpak_readlink (const char *path,
2e3aca0
+                  GError    **error)
2e3aca0
+{
2e3aca0
+  return glnx_readlinkat_malloc (-1, path, NULL, error);
2e3aca0
+}
2e3aca0
+
2e3aca0
+char *
2e3aca0
+flatpak_resolve_link (const char *path,
2e3aca0
+                      GError    **error)
2e3aca0
+{
2e3aca0
+  g_autofree char *link = flatpak_readlink (path, error);
2e3aca0
+  g_autofree char *dirname = NULL;
2e3aca0
+
2e3aca0
+  if (link == NULL)
2e3aca0
+    return NULL;
2e3aca0
+
2e3aca0
+  if (g_path_is_absolute (link))
2e3aca0
+    return g_steal_pointer (&link);
2e3aca0
+
2e3aca0
+  dirname = g_path_get_dirname (path);
2e3aca0
+  return g_build_filename (dirname, link, NULL);
2e3aca0
+}
2e3aca0
+
2e3aca0
+char *
2e3aca0
+flatpak_canonicalize_filename (const char *path)
2e3aca0
+{
2e3aca0
+  g_autoptr(GFile) file = g_file_new_for_path (path);
2e3aca0
+  return g_file_get_path (file);
2e3aca0
+}
2e3aca0
diff --git a/common/flatpak-utils-private.h b/common/flatpak-utils-private.h
2e3aca0
index 0151b5253d2a..bedeffd1216c 100644
2e3aca0
--- a/common/flatpak-utils-private.h
2e3aca0
+++ b/common/flatpak-utils-private.h
2e3aca0
@@ -113,8 +113,6 @@ gboolean flatpak_extension_matches_reason (const char *extension_id,
2e3aca0
 
2e3aca0
 const char * flatpak_get_bwrap (void);
2e3aca0
 
2e3aca0
-char *flatpak_get_timezone (void);
2e3aca0
-
2e3aca0
 char **flatpak_strv_merge (char   **strv1,
2e3aca0
                            char   **strv2);
2e3aca0
 char **flatpak_subpaths_merge (char **subpaths1,
2e3aca0
@@ -603,12 +601,6 @@ gboolean flatpak_canonicalize_permissions (int         parent_dfd,
2e3aca0
                                            int         gid,
2e3aca0
                                            GError    **error);
2e3aca0
 
2e3aca0
-char * flatpak_readlink (const char *path,
2e3aca0
-                         GError    **error);
2e3aca0
-char * flatpak_resolve_link (const char *path,
2e3aca0
-                             GError    **error);
2e3aca0
-char * flatpak_canonicalize_filename (const char *path);
2e3aca0
-
2e3aca0
 gboolean flatpak_file_rename (GFile        *from,
2e3aca0
                               GFile        *to,
2e3aca0
                               GCancellable *cancellable,
2e3aca0
diff --git a/common/flatpak-utils.c b/common/flatpak-utils.c
2e3aca0
index d9912e85d6c5..2f59337e7547 100644
2e3aca0
--- a/common/flatpak-utils.c
2e3aca0
+++ b/common/flatpak-utils.c
2e3aca0
@@ -1,5 +1,5 @@
2e3aca0
 /*
2e3aca0
- * Copyright © 2014 Red Hat, Inc
2e3aca0
+ * Copyright © 2014-2019 Red Hat, Inc
2e3aca0
  *
2e3aca0
  * This program is free software; you can redistribute it and/or
2e3aca0
  * modify it under the terms of the GNU Lesser General Public
2e3aca0
@@ -25,6 +25,7 @@
2e3aca0
 #include "flatpak-dir-private.h"
2e3aca0
 #include "flatpak-oci-registry-private.h"
2e3aca0
 #include "flatpak-run-private.h"
2e3aca0
+#include "flatpak-utils-base-private.h"
2e3aca0
 #include "valgrind-private.h"
2e3aca0
 
2e3aca0
 #include <glib/gi18n-lib.h>
2e3aca0
@@ -638,46 +639,6 @@ flatpak_get_bwrap (void)
2e3aca0
   return HELPER;
2e3aca0
 }
2e3aca0
 
2e3aca0
-char *
2e3aca0
-flatpak_get_timezone (void)
2e3aca0
-{
2e3aca0
-  g_autofree gchar *symlink = NULL;
2e3aca0
-  gchar *etc_timezone = NULL;
2e3aca0
-  const gchar *tzdir;
2e3aca0
-
2e3aca0
-  tzdir = getenv ("TZDIR");
2e3aca0
-  if (tzdir == NULL)
2e3aca0
-    tzdir = "/usr/share/zoneinfo";
2e3aca0
-
2e3aca0
-  symlink = flatpak_resolve_link ("/etc/localtime", NULL);
2e3aca0
-  if (symlink != NULL)
2e3aca0
-    {
2e3aca0
-      /* Resolve relative path */
2e3aca0
-      g_autofree gchar *canonical = flatpak_canonicalize_filename (symlink);
2e3aca0
-      char *canonical_suffix;
2e3aca0
-
2e3aca0
-      /* Strip the prefix and slashes if possible. */
2e3aca0
-      if (g_str_has_prefix (canonical, tzdir))
2e3aca0
-        {
2e3aca0
-          canonical_suffix = canonical + strlen (tzdir);
2e3aca0
-          while (*canonical_suffix == '/')
2e3aca0
-            canonical_suffix++;
2e3aca0
-
2e3aca0
-          return g_strdup (canonical_suffix);
2e3aca0
-        }
2e3aca0
-    }
2e3aca0
-
2e3aca0
-  if (g_file_get_contents ("/etc/timezeone", &etc_timezone,
2e3aca0
-                           NULL, NULL))
2e3aca0
-    {
2e3aca0
-      g_strchomp (etc_timezone);
2e3aca0
-      return etc_timezone;
2e3aca0
-    }
2e3aca0
-
2e3aca0
-  /* Final fall-back is UTC */
2e3aca0
-  return g_strdup ("UTC");
2e3aca0
-}
2e3aca0
-
2e3aca0
 static gboolean
2e3aca0
 is_valid_initial_name_character (gint c, gboolean allow_dash)
2e3aca0
 {
2e3aca0
@@ -2441,37 +2402,6 @@ flatpak_rm_rf (GFile        *dir,
2e3aca0
                                cancellable, error);
2e3aca0
 }
2e3aca0
 
2e3aca0
-char *
2e3aca0
-flatpak_readlink (const char *path,
2e3aca0
-                  GError    **error)
2e3aca0
-{
2e3aca0
-  return glnx_readlinkat_malloc (-1, path, NULL, error);
2e3aca0
-}
2e3aca0
-
2e3aca0
-char *
2e3aca0
-flatpak_resolve_link (const char *path,
2e3aca0
-                      GError    **error)
2e3aca0
-{
2e3aca0
-  g_autofree char *link = flatpak_readlink (path, error);
2e3aca0
-  g_autofree char *dirname = NULL;
2e3aca0
-
2e3aca0
-  if (link == NULL)
2e3aca0
-    return NULL;
2e3aca0
-
2e3aca0
-  if (g_path_is_absolute (link))
2e3aca0
-    return g_steal_pointer (&link);
2e3aca0
-
2e3aca0
-  dirname = g_path_get_dirname (path);
2e3aca0
-  return g_build_filename (dirname, link, NULL);
2e3aca0
-}
2e3aca0
-
2e3aca0
-char *
2e3aca0
-flatpak_canonicalize_filename (const char *path)
2e3aca0
-{
2e3aca0
-  g_autoptr(GFile) file = g_file_new_for_path (path);
2e3aca0
-  return g_file_get_path (file);
2e3aca0
-}
2e3aca0
-
2e3aca0
 gboolean
2e3aca0
 flatpak_file_rename (GFile        *from,
2e3aca0
                      GFile        *to,
2e3aca0
diff --git a/session-helper/Makefile.am.inc b/session-helper/Makefile.am.inc
2e3aca0
index 7ea49bf0b652..f56c94b19274 100644
2e3aca0
--- a/session-helper/Makefile.am.inc
2e3aca0
+++ b/session-helper/Makefile.am.inc
2e3aca0
@@ -12,5 +12,5 @@ flatpak_session_helper_SOURCES = \
2e3aca0
 	session-helper/flatpak-session-helper.c	\
2e3aca0
 	$(NULL)
2e3aca0
 
2e3aca0
-flatpak_session_helper_LDADD = $(AM_LDADD) $(BASE_LIBS) libflatpak-common.la
2e3aca0
-flatpak_session_helper_CFLAGS = $(AM_CFLAGS) $(BASE_CFLAGS) $(SOUP_CFLAGS) $(OSTREE_CFLAGS) $(GSYSTEM_CFLAGS) $(JSON_CFLAGS) -DFLATPAK_COMPILATION
2e3aca0
+flatpak_session_helper_LDADD = $(AM_LDADD) $(BASE_LIBS) libflatpak-common-base.la libglnx.la
2e3aca0
+flatpak_session_helper_CFLAGS = $(AM_CFLAGS) $(BASE_CFLAGS) -DFLATPAK_COMPILATION
2e3aca0
diff --git a/session-helper/flatpak-session-helper.c b/session-helper/flatpak-session-helper.c
2e3aca0
index 0fbac666775c..26e83fc64832 100644
2e3aca0
--- a/session-helper/flatpak-session-helper.c
2e3aca0
+++ b/session-helper/flatpak-session-helper.c
2e3aca0
@@ -1,5 +1,5 @@
2e3aca0
 /*
2e3aca0
- * Copyright © 2014 Red Hat, Inc
2e3aca0
+ * Copyright © 2014-2019 Red Hat, Inc
2e3aca0
  *
2e3aca0
  * This program is free software; you can redistribute it and/or
2e3aca0
  * modify it under the terms of the GNU Lesser General Public
2e3aca0
@@ -20,6 +20,7 @@
2e3aca0
 
2e3aca0
 #include "config.h"
2e3aca0
 
2e3aca0
+#include <errno.h>
2e3aca0
 #include <locale.h>
2e3aca0
 #include <stdlib.h>
2e3aca0
 #include <string.h>
2e3aca0
@@ -28,7 +29,7 @@
2e3aca0
 #include <gio/gio.h>
2e3aca0
 #include <gio/gunixfdlist.h>
2e3aca0
 #include "flatpak-dbus-generated.h"
2e3aca0
-#include "flatpak-utils-private.h"
2e3aca0
+#include "flatpak-utils-base-private.h"
2e3aca0
 
2e3aca0
 typedef enum {
2e3aca0
   FLATPAK_HOST_COMMAND_FLAGS_CLEAR_ENV = 1 << 0,
2e3aca0
diff --git a/system-helper/Makefile.am.inc b/system-helper/Makefile.am.inc
2e3aca0
index cce749ce325e..6152ec9951fa 100644
2e3aca0
--- a/system-helper/Makefile.am.inc
2e3aca0
+++ b/system-helper/Makefile.am.inc
2e3aca0
@@ -18,7 +18,7 @@ flatpak_system_helper_SOURCES = \
2e3aca0
 	system-helper/flatpak-system-helper.c	\
2e3aca0
 	$(NULL)
2e3aca0
 
2e3aca0
-flatpak_system_helper_LDADD = $(BASE_LIBS) $(OSTREE_LIBS) $(JSON_LIBS) $(POLKIT_LIBS) libflatpak-common.la
2e3aca0
+flatpak_system_helper_LDADD = $(BASE_LIBS) $(OSTREE_LIBS) $(JSON_LIBS) $(POLKIT_LIBS) libflatpak-common.la libflatpak-common-base.la libglnx.la
2e3aca0
 flatpak_system_helper_CFLAGS = $(BASE_CFLAGS) $(OSTREE_CFLAGS) $(APPSTREAM_GLIB_CFLAGS) $(SOUP_CFLAGS) $(JSON_CFLAGS) $(POLKIT_CFLAGS) -DFLATPAK_COMPILATION -DLIBEXECDIR=\"$(libexecdir)\"
2e3aca0
 
2e3aca0
 system-helper/org.freedesktop.Flatpak.rules: system-helper/org.freedesktop.Flatpak.rules.in
2e3aca0
diff --git a/tests/Makefile.am.inc b/tests/Makefile.am.inc
2e3aca0
index 28c188377430..9039c1ed9aec 100644
2e3aca0
--- a/tests/Makefile.am.inc
2e3aca0
+++ b/tests/Makefile.am.inc
2e3aca0
@@ -53,9 +53,10 @@ testcommon_LDADD = \
2e3aca0
 	$(SOUP_LIBS) \
2e3aca0
 	$(JSON_LIBS) \
2e3aca0
 	$(APPSTREAM_GLIB_LIBS) \     
2e3aca0
-	libglnx.la \
2e3aca0
-	libflatpak-common.la \
2e3aca0
 	libflatpak-app.la \
2e3aca0
+	libflatpak-common.la \
2e3aca0
+	libflatpak-common-base.la \
2e3aca0
+	libglnx.la \
2e3aca0
 	$(NULL)
2e3aca0
 testcommon_SOURCES = tests/testcommon.c
2e3aca0
 
2e3aca0
@@ -63,7 +64,7 @@ tests_httpcache_CFLAGS = $(AM_CFLAGS) $(BASE_CFLAGS) $(OSTREE_CFLAGS) $(SOUP_CFL
2e3aca0
 	-DFLATPAK_COMPILATION \
2e3aca0
         -DLOCALEDIR=\"$(localedir)\"
2e3aca0
 tests_httpcache_LDADD = $(AM_LDADD) $(BASE_LIBS) $(OSTREE_LIBS) $(SOUP_LIBS) $(JSON_LIBS) $(APPSTREAM_GLIB_LIBS) \
2e3aca0
-	libglnx.la libflatpak-common.la
2e3aca0
+	libflatpak-common.la libflatpak-common-base.la libglnx.la
2e3aca0
 
2e3aca0
 tests/services/org.freedesktop.Flatpak.service: session-helper/org.freedesktop.Flatpak.service.in
2e3aca0
 	mkdir -p tests/services
2e3aca0
-- 
2e3aca0
2.20.1
2e3aca0