[gnome-builder/wip/gtk4-port] libide/projects: add a model for template languages
- From: Christian Hergert <chergert src gnome org>
- To: commits-list gnome org
- Cc: 
- Subject: [gnome-builder/wip/gtk4-port] libide/projects: add a model for template languages
- Date: Fri, 27 May 2022 00:46:33 +0000 (UTC)
commit 2e28985eec7518e9d4d54ddc17a070887c42ecd7
Author: Christian Hergert <chergert redhat com>
Date:   Thu May 26 17:41:39 2022 -0700
    libide/projects: add a model for template languages
 src/libide/projects/ide-template-input.c | 59 ++++++++++++++++++++++++++++++++
 src/libide/projects/ide-template-input.h |  2 ++
 2 files changed, 61 insertions(+)
---
diff --git a/src/libide/projects/ide-template-input.c b/src/libide/projects/ide-template-input.c
index 084fdd5f5..4ebf96b3c 100644
--- a/src/libide/projects/ide-template-input.c
+++ b/src/libide/projects/ide-template-input.c
@@ -38,6 +38,7 @@ struct _IdeTemplateInput
   GObject parent_instance;
 
   GListStore *templates;
+  GtkStringList *languages;
 
   GFile *directory;
 
@@ -58,6 +59,7 @@ enum {
   PROP_AUTHOR,
   PROP_DIRECTORY,
   PROP_LANGUAGE,
+  PROP_LANGUAGES_MODEL,
   PROP_LICENSE_NAME,
   PROP_NAME,
   PROP_PROJECT_VERSION,
@@ -103,22 +105,44 @@ sort_by_priority (gconstpointer aptr,
   return ide_project_template_compare (a, b);
 }
 
+static int
+sort_strings (const char * const *a,
+              const char * const *b)
+{
+  return g_strcmp0 (*a, *b);
+}
+
 static void
 ide_template_input_set_templates (IdeTemplateInput *self,
                                   GPtrArray        *templates)
 {
+  g_autoptr(GHashTable) seen_languages = NULL;
+  g_autofree char **sorted_langs = NULL;
+  guint len;
+
   IDE_ENTRY;
 
   g_assert (IDE_IS_TEMPLATE_INPUT (self));
   g_assert (templates != NULL);
 
+  seen_languages = g_hash_table_new_full (g_str_hash, g_str_equal, g_free, NULL);
   g_ptr_array_sort (templates, sort_by_priority);
 
   for (guint i = 0; i < templates->len; i++)
     {
       IdeProjectTemplate *template = g_ptr_array_index (templates, i);
+      g_auto(GStrv) langs = ide_project_template_get_languages (template);
 
       g_list_store_append (self->templates, template);
+
+      if (langs == NULL)
+        continue;
+
+      for (guint j = 0; langs[j]; j++)
+        {
+          if (!g_hash_table_contains (seen_languages, langs[j]))
+            g_hash_table_insert (seen_languages, g_strdup (langs[j]), NULL);
+        }
     }
 
   if (templates->len > 0)
@@ -127,6 +151,16 @@ ide_template_input_set_templates (IdeTemplateInput *self,
       ide_template_input_set_template (self, id);
     }
 
+  sorted_langs = (char **)g_hash_table_get_keys_as_array (seen_languages, &len);
+  g_qsort_with_data (sorted_langs,
+                     len,
+                     sizeof (char *),
+                     (GCompareDataFunc) sort_strings,
+                     NULL);
+
+  gtk_string_list_splice (self->languages, 0, 0,
+                          (const char * const *)sorted_langs);
+
   IDE_EXIT;
 }
 
@@ -174,6 +208,8 @@ ide_template_input_dispose (GObject *object)
   IdeTemplateInput *self = (IdeTemplateInput *)object;
 
   g_clear_object (&self->directory);
+  g_clear_object (&self->templates);
+  g_clear_object (&self->languages);
 
   g_clear_pointer (&self->author, g_free);
   g_clear_pointer (&self->language, g_free);
@@ -235,6 +271,10 @@ ide_template_input_get_property (GObject    *object,
       g_value_set_object (value, self->templates);
       break;
 
+    case PROP_LANGUAGES_MODEL:
+      g_value_set_object (value, self->languages);
+      break;
+
     case PROP_USE_VERSION_CONTROL:
       g_value_set_boolean (value, self->use_version_control);
       break;
@@ -346,6 +386,10 @@ ide_template_input_class_init (IdeTemplateInputClass *klass)
     g_param_spec_object ("templates-model", NULL, NULL, G_TYPE_LIST_MODEL,
                          (G_PARAM_READABLE | G_PARAM_STATIC_STRINGS));
 
+  properties [PROP_LANGUAGES_MODEL] =
+    g_param_spec_object ("languages-model", NULL, NULL, G_TYPE_LIST_MODEL,
+                         (G_PARAM_READABLE | G_PARAM_STATIC_STRINGS));
+
   properties [PROP_USE_VERSION_CONTROL] =
     g_param_spec_boolean ("use-version-control", NULL, NULL, DEFAULT_USE_VERSION_CONTROL,
                           (G_PARAM_READWRITE | G_PARAM_EXPLICIT_NOTIFY | G_PARAM_STATIC_STRINGS));
@@ -365,6 +409,7 @@ ide_template_input_init (IdeTemplateInput *self)
   self->project_version = g_strdup (DEFAULT_PROJECT_VERSION);
   self->use_version_control = DEFAULT_USE_VERSION_CONTROL;
   self->templates = g_list_store_new (IDE_TYPE_PROJECT_TEMPLATE);
+  self->languages = gtk_string_list_new (NULL);
 }
 
 const char *
@@ -767,3 +812,17 @@ ide_template_input_get_templates_model (IdeTemplateInput *self)
 
   return G_LIST_MODEL (self->templates);
 }
+
+/**
+ * ide_template_input_get_languages_model:
+ * @self: a #IdeTemplateInput
+ *
+ * Returns: (transfer none): A #GListModel
+ */
+GListModel *
+ide_template_input_get_languages_model (IdeTemplateInput *self)
+{
+  g_return_val_if_fail (IDE_IS_TEMPLATE_INPUT (self), NULL);
+
+  return G_LIST_MODEL (self->languages);
+}
diff --git a/src/libide/projects/ide-template-input.h b/src/libide/projects/ide-template-input.h
index fe7ecf409..352c6ad28 100644
--- a/src/libide/projects/ide-template-input.h
+++ b/src/libide/projects/ide-template-input.h
@@ -85,6 +85,8 @@ void              ide_template_input_set_template            (IdeTemplateInput *
 IDE_AVAILABLE_IN_ALL
 GListModel       *ide_template_input_get_templates_model     (IdeTemplateInput *self);
 IDE_AVAILABLE_IN_ALL
+GListModel       *ide_template_input_get_languages_model     (IdeTemplateInput *self);
+IDE_AVAILABLE_IN_ALL
 TmplScope        *ide_template_input_to_scope                (IdeTemplateInput *self);
 
 G_END_DECLS
[
Date Prev][
Date Next]   [
Thread Prev][
Thread Next]   
[
Thread Index]
[
Date Index]
[
Author Index]