[gnome-builder/wip/libide: 85/153] libide: add getters for IdeLanguage



commit f48694f40630062cbd28c732c91db4980bc43dfb
Author: Christian Hergert <christian hergert me>
Date:   Wed Feb 11 18:12:15 2015 -0800

    libide: add getters for IdeLanguage

 libide/ide-language.c |  133 ++++++++++++++++++++++++++++++++++++++++++++++++-
 1 files changed, 132 insertions(+), 1 deletions(-)
---
diff --git a/libide/ide-language.c b/libide/ide-language.c
index 7ae6164..3118d6a 100644
--- a/libide/ide-language.c
+++ b/libide/ide-language.c
@@ -46,6 +46,119 @@ enum {
 
 static GParamSpec *gParamSpecs [LAST_PROP];
 
+/**
+ * ide_language_get_diagnostician:
+ *
+ * Returns the #IdeDiagnostician for the #IdeLanguage.
+ *
+ * The diagnostician is responsible for querying the proper language tools to
+ * diagnose issues with a particular #IdeFile.
+ *
+ * See ide_diagnostician_diagnose_async() for more information.
+ *
+ * If the #IdeLanguage does not have an #IdeDiagnostician, then %NULL is
+ * returned.
+ *
+ * Returns: (transfer none) (nullable): An #IdeDiagnostician or %NULL.
+ */
+IdeDiagnostician *
+ide_language_get_diagnostician (IdeLanguage *self)
+{
+  g_return_val_if_fail (IDE_IS_LANGUAGE (self), NULL);
+
+  if (IDE_LANGUAGE_GET_CLASS (self)->get_diagnostician)
+   return IDE_LANGUAGE_GET_CLASS (self)->get_diagnostician (self);
+
+  return NULL;
+}
+
+/**
+ * ide_language_get_highlighter:
+ *
+ * Fetches the #IdeHighlighter for the #IdeLanguage.
+ *
+ * If @language does not provide a semantic highlighter, %NULL is returned.
+ *
+ * Returns: (transfer none) (nullable): An #IdeHighlighter or %NULL.
+ */
+IdeHighlighter *
+ide_language_get_highlighter (IdeLanguage *self)
+{
+  g_return_val_if_fail (IDE_IS_LANGUAGE (self), NULL);
+
+  if (IDE_LANGUAGE_GET_CLASS (self)->get_highlighter)
+   return IDE_LANGUAGE_GET_CLASS (self)->get_highlighter (self);
+
+  return NULL;
+}
+
+/**
+ * ide_language_get_indenter:
+ *
+ * Fetches the #IdeIndenter for @language.
+ *
+ * If @language does not provide an #IdeIndenter, then %NULL is returned.
+ *
+ * Returns: (transfer none) (nullable): An #IdeIndenter or %NULL.
+ */
+IdeIndenter *
+ide_language_get_indenter (IdeLanguage *self)
+{
+  g_return_val_if_fail (IDE_IS_LANGUAGE (self), NULL);
+
+  if (IDE_LANGUAGE_GET_CLASS (self)->get_indenter)
+   return IDE_LANGUAGE_GET_CLASS (self)->get_indenter (self);
+
+  return NULL;
+}
+
+/**
+ * ide_language_get_refactory:
+ *
+ * Fetches the refactory for @language.
+ *
+ * If @language does not provide an #IdeRefactory, then %NULL is returned.
+ *
+ * Returns: (transfer none) (nullable): An #IdeRefactory or %NULL.
+ */
+IdeRefactory *
+ide_language_get_refactory (IdeLanguage *self)
+{
+  g_return_val_if_fail (IDE_IS_LANGUAGE (self), NULL);
+
+  if (IDE_LANGUAGE_GET_CLASS (self)->get_refactory)
+   return IDE_LANGUAGE_GET_CLASS (self)->get_refactory (self);
+
+  return NULL;
+}
+
+/**
+ * ide_language_get_symbol_resolver:
+ *
+ * Fetches the #IdeSymbolResolver for @language.
+ *
+ * If @language does not provide an #IdeSymbolResolver, then %NULL is returned.
+ *
+ * Returns: (transfer none) (nullable): An #IdeSymbolResolver or %NULL.
+ */
+IdeSymbolResolver *
+ide_language_get_symbol_resolver (IdeLanguage *self)
+{
+  g_return_val_if_fail (IDE_IS_LANGUAGE (self), NULL);
+
+  if (IDE_LANGUAGE_GET_CLASS (self)->get_symbol_resolver)
+   return IDE_LANGUAGE_GET_CLASS (self)->get_symbol_resolver (self);
+
+  return NULL;
+}
+
+/**
+ * ide_language_get_id:
+ *
+ * Fetches the unique identifier for the language.
+ *
+ * Returns: A string such as "c" or "python".
+ */
 const gchar *
 ide_language_get_id (IdeLanguage *self)
 {
@@ -56,7 +169,7 @@ ide_language_get_id (IdeLanguage *self)
   return priv->id;
 }
 
-void
+static void
 ide_language_set_id (IdeLanguage *self,
                      const gchar *id)
 {
@@ -68,6 +181,24 @@ ide_language_set_id (IdeLanguage *self,
   priv->id = g_intern_string (id);
 }
 
+/**
+ * ide_language_get_name:
+ *
+ * Fetches the display name for the language.
+ *
+ * Returns: A string containing the display name.
+ */
+const gchar *
+ide_language_get_name (IdeLanguage *self)
+{
+  g_return_val_if_fail (IDE_IS_LANGUAGE (self), NULL);
+
+  if (IDE_LANGUAGE_GET_CLASS (self)->get_name)
+    return IDE_LANGUAGE_GET_CLASS (self)->get_name (self);
+
+  return ide_language_get_id (self);
+}
+
 static void
 ide_language_get_property (GObject    *object,
                            guint       prop_id,


[Date Prev][Date Next]   [Thread Prev][Thread Next]   [Thread Index] [Date Index] [Author Index]