[gnome-builder/wip/chergert/flatpak-all-arches] flatpak: bring back support for alt-arches
- From: Christian Hergert <chergert src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gnome-builder/wip/chergert/flatpak-all-arches] flatpak: bring back support for alt-arches
- Date: Wed, 5 May 2021 20:46:00 +0000 (UTC)
commit 72f83aab4a26baab58fc70a900ae32172c0ff4bb
Author: Christian Hergert <chergert redhat com>
Date: Wed May 5 13:43:00 2021 -0700
flatpak: bring back support for alt-arches
This fixes the subsummary issue that crept in when Flatpak removed all
arches from the summaries.
Requires https://github.com/flatpak/flatpak/pull/4256
.../flatpak/daemon/ipc-flatpak-service-impl.c | 38 +++++++++++++++-------
src/plugins/flatpak/daemon/test-flatpak.c | 14 ++++++++
2 files changed, 40 insertions(+), 12 deletions(-)
---
diff --git a/src/plugins/flatpak/daemon/ipc-flatpak-service-impl.c
b/src/plugins/flatpak/daemon/ipc-flatpak-service-impl.c
index 8ba253d4c..40c04142c 100644
--- a/src/plugins/flatpak/daemon/ipc-flatpak-service-impl.c
+++ b/src/plugins/flatpak/daemon/ipc-flatpak-service-impl.c
@@ -462,6 +462,7 @@ is_known_worker (GTask *task,
const char *ref_branch;
gint64 download_size = 0;
gboolean found = FALSE;
+ FlatpakQueryFlags flags = 0;
g_assert (G_IS_TASK (task));
g_assert (IPC_IS_FLATPAK_SERVICE_IMPL (source_object));
@@ -475,6 +476,11 @@ is_known_worker (GTask *task,
ref_arch = flatpak_ref_get_arch (state->target);
ref_branch = flatpak_ref_get_branch (state->target);
+ if (str_equal0 (ref_arch, flatpak_get_default_arch ()))
+ flags |= FLATPAK_QUERY_FLAGS_ONLY_CACHED;
+ else
+ flags |= FLATPAK_QUERY_FLAGS_ALL_ARCHES;
+
for (guint z = 0; z < state->installs->len; z++)
{
FlatpakInstallation *install = g_ptr_array_index (state->installs, z);
@@ -488,7 +494,7 @@ is_known_worker (GTask *task,
const char *remote_name = flatpak_remote_get_name (remote);
g_autoptr(GPtrArray) refs = NULL;
- if (!(refs = flatpak_installation_list_remote_refs_sync (install, remote_name, NULL, NULL)))
+ if (!(refs = flatpak_installation_list_remote_refs_sync_full (install, remote_name, flags, NULL,
NULL)))
continue;
for (guint j = 0; j < refs->len; j++)
@@ -773,13 +779,23 @@ static char *
find_remote_for_ref (IpcFlatpakServiceImpl *self,
FlatpakRef *ref)
{
+ FlatpakQueryFlags flags = FLATPAK_QUERY_FLAGS_NONE;
+
g_assert (IPC_IS_FLATPAK_SERVICE_IMPL (self));
g_assert (FLATPAK_IS_REF (ref));
+ /* If this is not the default architecture, we need to force that we've
+ * loaded sub-summaries or we won't find any matches for the arch. Otherwise
+ * the cached form is fine (and faster).
+ */
+ if (str_equal0 (flatpak_get_default_arch (), flatpak_ref_get_arch (ref)))
+ flags |= FLATPAK_QUERY_FLAGS_ONLY_CACHED;
+ else
+ flags |= FLATPAK_QUERY_FLAGS_ALL_ARCHES;
+
/* Someday we might want to prompt the user for which remote to install from,
* but for now we'll just take the first.
*/
-
for (guint i = 0; i < self->installs_ordered->len; i++)
{
Install *install = g_ptr_array_index (self->installs_ordered, i);
@@ -792,9 +808,7 @@ find_remote_for_ref (IpcFlatpakServiceImpl *self,
{
FlatpakRemote *remote = g_ptr_array_index (remotes, j);
const char *name = flatpak_remote_get_name (remote);
- g_autoptr(GPtrArray) refs = flatpak_installation_list_remote_refs_sync_full
(install->installation, name,
-
FLATPAK_QUERY_FLAGS_ONLY_CACHED,
- NULL, NULL);
+ g_autoptr(GPtrArray) refs = flatpak_installation_list_remote_refs_sync_full
(install->installation, name, flags, NULL, NULL);
if (refs == NULL)
continue;
@@ -941,6 +955,7 @@ resolve_extension (GPtrArray *installations,
g_autoptr(GArray) maybe_extention_of = NULL;
g_autoptr(GArray) runtime_extensions = NULL;
g_autoptr(GStringChunk) strings = NULL;
+ FlatpakQueryFlags flags = FLATPAK_QUERY_FLAGS_NONE;
g_assert (installations != NULL);
g_assert (sdk != NULL);
@@ -956,6 +971,11 @@ resolve_extension (GPtrArray *installations,
if (sdk_arch == NULL)
sdk_arch = g_strdup (flatpak_get_default_arch ());
+ if (str_equal0 (sdk_arch, flatpak_get_default_arch ()))
+ flags |= FLATPAK_QUERY_FLAGS_ONLY_CACHED;
+ else
+ flags |= FLATPAK_QUERY_FLAGS_ALL_ARCHES;
+
strings = g_string_chunk_new (4096);
maybe_extention_of = g_array_new (FALSE, FALSE, sizeof (ResolveExtension));
runtime_extensions = g_array_new (FALSE, FALSE, sizeof (ResolveExtension));
@@ -974,13 +994,7 @@ resolve_extension (GPtrArray *installations,
const char *name = flatpak_remote_get_name (remote);
g_autoptr(GPtrArray) refs = NULL;
- refs = flatpak_installation_list_remote_refs_sync_full (installation,
- name,
- FLATPAK_QUERY_FLAGS_ONLY_CACHED,
- NULL,
- NULL);
-
- if (refs == NULL)
+ if (!(refs = flatpak_installation_list_remote_refs_sync_full (installation, name, flags, NULL,
NULL)))
continue;
for (guint k = 0; k < refs->len; k++)
diff --git a/src/plugins/flatpak/daemon/test-flatpak.c b/src/plugins/flatpak/daemon/test-flatpak.c
index 82a59cacf..fd5012d85 100644
--- a/src/plugins/flatpak/daemon/test-flatpak.c
+++ b/src/plugins/flatpak/daemon/test-flatpak.c
@@ -147,6 +147,20 @@ add_install_cb (GObject *object,
g_message (" Resolved to %s", resolved);
g_assert_cmpstr (resolved, ==, "org.freedesktop.Sdk.Extension.rust-stable/x86_64/20.08");
+ g_message ("Resolving org.freedesktop.Sdk.Extension.rust-stable for org.gnome.Sdk/aarch64/40");
+ ret = ipc_flatpak_service_call_resolve_extension_sync (service, "org.gnome.Sdk/aarch64/40",
"org.freedesktop.Sdk.Extension.rust-stable", &resolved, NULL, &error);
+ g_assert_no_error (error);
+ g_assert_true (ret);
+ g_message (" Resolved to %s", resolved);
+ g_assert_cmpstr (resolved, ==, "org.freedesktop.Sdk.Extension.rust-stable/aarch64/20.08");
+
+ g_message ("Resolving org.freedesktop.Sdk.Extension.rust-stable for org.gnome.Sdk/aarch64/master");
+ ret = ipc_flatpak_service_call_resolve_extension_sync (service, "org.gnome.Sdk/aarch64/master",
"org.freedesktop.Sdk.Extension.rust-stable", &resolved, NULL, &error);
+ g_assert_no_error (error);
+ g_assert_true (ret);
+ g_message (" Resolved to %s", resolved);
+ g_assert_cmpstr (resolved, ==, "org.freedesktop.Sdk.Extension.rust-stable/aarch64/20.08");
+
g_main_loop_quit (main_loop);
}
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]