[gnome-builder/wip/mwleeds/ide-config-provider: 10/14] flatpak: Make the flatpak manifest search recursive
- From: Matthew Leeds <mwleeds src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gnome-builder/wip/mwleeds/ide-config-provider: 10/14] flatpak: Make the flatpak manifest search recursive
- Date: Mon, 30 Jan 2017 20:57:35 +0000 (UTC)
commit a88adc20695856e320bdf744cc8885568528888b
Author: Matthew Leeds <mleeds redhat com>
Date: Fri Dec 23 19:18:56 2016 -0600
flatpak: Make the flatpak manifest search recursive
Some projects might want to put their flatpak manifest in a subdirectory
rather than the project's root directory, and the performance hit seems
negligible.
.../flatpak/gbp-flatpak-configuration-provider.c | 55 ++++++++++++++------
1 files changed, 39 insertions(+), 16 deletions(-)
---
diff --git a/plugins/flatpak/gbp-flatpak-configuration-provider.c
b/plugins/flatpak/gbp-flatpak-configuration-provider.c
index 939c940..00edc4a 100644
--- a/plugins/flatpak/gbp-flatpak-configuration-provider.c
+++ b/plugins/flatpak/gbp-flatpak-configuration-provider.c
@@ -142,22 +142,14 @@ guess_primary_module (JsonNode *modules_node,
return NULL;
}
-static GPtrArray *
-gbp_flatpak_configuration_provider_find_flatpak_manifests (GbpFlatpakConfigurationProvider *self,
- GCancellable *cancellable,
- GFile *directory,
- GError **error)
+static gboolean
+check_dir_for_manifests (GFile *directory,
+ GPtrArray *manifests,
+ GCancellable *cancellable,
+ GError **error)
{
g_autoptr(GFileEnumerator) enumerator = NULL;
GFileInfo *file_info = NULL;
- GPtrArray *ar;
-
- g_assert (GBP_IS_FLATPAK_CONFIGURATION_PROVIDER (self));
- g_assert (!cancellable || G_IS_CANCELLABLE (cancellable));
- g_assert (G_IS_FILE (directory));
-
- ar = g_ptr_array_new ();
- g_ptr_array_set_free_func (ar, flatpak_manifest_free);
enumerator = g_file_enumerate_children (directory,
G_FILE_ATTRIBUTE_STANDARD_NAME,
@@ -165,7 +157,7 @@ gbp_flatpak_configuration_provider_find_flatpak_manifests (GbpFlatpakConfigurati
cancellable,
error);
if (!enumerator)
- return NULL;
+ return FALSE;
while ((file_info = g_file_enumerator_next_file (enumerator, cancellable, NULL)))
{
@@ -195,11 +187,18 @@ gbp_flatpak_configuration_provider_find_flatpak_manifests (GbpFlatpakConfigurati
name = g_strdup (g_file_info_get_name (file_info));
g_clear_object (&file_info);
- if (name == NULL || file_type == G_FILE_TYPE_DIRECTORY)
+ if (name == NULL)
continue;
file = g_file_get_child (directory, name);
+ if (file_type == G_FILE_TYPE_DIRECTORY)
+ {
+ if (!check_dir_for_manifests (file, manifests, cancellable, error))
+ return FALSE;
+ continue;
+ }
+
/* This regex is based on https://wiki.gnome.org/HowDoI/ChooseApplicationID */
filename_regex = g_regex_new ("^[[:alnum:]-_]+\\.[[:alnum:]-_]+(\\.[[:alnum:]-_]+)*\\.json$",
0, 0, NULL);
@@ -337,7 +336,31 @@ gbp_flatpak_configuration_provider_find_flatpak_manifests (GbpFlatpakConfigurati
}
}
- g_ptr_array_add (ar, manifest);
+ g_ptr_array_add (manifests, manifest);
+ }
+
+ return TRUE;
+}
+
+static GPtrArray *
+gbp_flatpak_configuration_provider_find_flatpak_manifests (GbpFlatpakConfigurationProvider *self,
+ GCancellable *cancellable,
+ GFile *directory,
+ GError **error)
+{
+ GPtrArray *ar;
+
+ g_assert (GBP_IS_FLATPAK_CONFIGURATION_PROVIDER (self));
+ g_assert (!cancellable || G_IS_CANCELLABLE (cancellable));
+ g_assert (G_IS_FILE (directory));
+
+ ar = g_ptr_array_new ();
+ g_ptr_array_set_free_func (ar, flatpak_manifest_free);
+
+ if (!check_dir_for_manifests (directory, ar, cancellable, error))
+ {
+ g_ptr_array_free (ar, TRUE);
+ return NULL;
}
return ar;
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]