[gnome-builder/gnome-builder-41] flatpak: ensure deploydir of extensions
- From: Christian Hergert <chergert src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gnome-builder/gnome-builder-41] flatpak: ensure deploydir of extensions
- Date: Mon, 11 Oct 2021 17:41:48 +0000 (UTC)
commit 06a9847ec9d67b0b4d6f07f3672159559f0d5373
Author: Günther Wagner <info gunibert de>
Date: Mon Oct 11 07:15:11 2021 +0200
flatpak: ensure deploydir of extensions
This ensures that extensions always use their deploy directory instead of the Sdk in order to correctly
find executables in paths.
src/plugins/flatpak/daemon/ipc-flatpak-service-impl.c | 2 +-
src/plugins/flatpak/gbp-flatpak-runtime.c | 19 +++++++++++--------
2 files changed, 12 insertions(+), 9 deletions(-)
---
diff --git a/src/plugins/flatpak/daemon/ipc-flatpak-service-impl.c
b/src/plugins/flatpak/daemon/ipc-flatpak-service-impl.c
index dcdc16776..2daf9d141 100644
--- a/src/plugins/flatpak/daemon/ipc-flatpak-service-impl.c
+++ b/src/plugins/flatpak/daemon/ipc-flatpak-service-impl.c
@@ -372,7 +372,7 @@ install_reload (IpcFlatpakServiceImpl *self,
* directory instead of the runtime (or the application will not
* be able to locate includes/pkg-config/etc when building).
*/
- if ((installed_sdk = find_sdk (refs, sdk_ref)))
+ if ((installed_sdk = find_sdk (refs, sdk_ref)) && exten_of == NULL)
deploy_dir = flatpak_installed_ref_get_deploy_dir (installed_sdk);
else
deploy_dir = flatpak_installed_ref_get_deploy_dir (ref);
diff --git a/src/plugins/flatpak/gbp-flatpak-runtime.c b/src/plugins/flatpak/gbp-flatpak-runtime.c
index f98c02da5..154a18d54 100644
--- a/src/plugins/flatpak/gbp-flatpak-runtime.c
+++ b/src/plugins/flatpak/gbp-flatpak-runtime.c
@@ -124,14 +124,17 @@ gbp_flatpak_runtime_contains_program_in_path (IdeRuntime *runtime,
self->sdk != NULL &&
!ide_str_equal0 (self->platform, self->sdk))
{
- g_autoptr(IdeContext) context = ide_object_ref_context (IDE_OBJECT (self));
- g_autoptr(IdeRuntimeManager) manager = ide_object_ensure_child_typed (IDE_OBJECT (context),
IDE_TYPE_RUNTIME_MANAGER);
- g_autofree char *arch = ide_runtime_get_arch (runtime);
- g_autofree char *sdk_id = g_strdup_printf ("flatpak:%s/%s/%s", self->sdk, arch, self->branch);
- IdeRuntime *sdk = ide_runtime_manager_get_runtime (manager, sdk_id);
-
- if (sdk != NULL && sdk != runtime)
- ret = ide_runtime_contains_program_in_path (sdk, program, cancellable);
+ IdeContext* context = ide_object_get_context (IDE_OBJECT (self));
+ if (context)
+ {
+ g_autoptr(IdeRuntimeManager) manager = ide_object_ensure_child_typed (IDE_OBJECT (context),
IDE_TYPE_RUNTIME_MANAGER);
+ g_autofree char *arch = ide_runtime_get_arch (runtime);
+ g_autofree char *sdk_id = g_strdup_printf ("flatpak:%s/%s/%s", self->sdk, arch, self->branch);
+ IdeRuntime *sdk = ide_runtime_manager_get_runtime (manager, sdk_id);
+
+ if (sdk != NULL && sdk != runtime)
+ ret = ide_runtime_contains_program_in_path (sdk, program, cancellable);
+ }
}
/* Cache both positive and negative lookups */
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]