[gnome-builder/wip/chergert/gutter] plumb some properties



commit 160e1dfe1a82e79ee1557682268208ec632bc9f6
Author: Christian Hergert <chergert redhat com>
Date:   Sun Sep 17 23:26:43 2017 -0700

    plumb some properties

 libide/sourceview/ide-omni-gutter-renderer.c |  175 ++++++++++++++++++++++++--
 libide/sourceview/ide-omni-gutter-renderer.h |   11 ++-
 libide/sourceview/ide-source-view.c          |  116 +++++++----------
 libide/sourceview/ide-source-view.h          |    5 +-
 4 files changed, 228 insertions(+), 79 deletions(-)
---
diff --git a/libide/sourceview/ide-omni-gutter-renderer.c b/libide/sourceview/ide-omni-gutter-renderer.c
index 21e0012..b3f8467 100644
--- a/libide/sourceview/ide-omni-gutter-renderer.c
+++ b/libide/sourceview/ide-omni-gutter-renderer.c
@@ -78,6 +78,10 @@ struct _IdeOmniGutterRenderer
   gint  stopped_line;
   guint resize_source;
   gint  number_width;
+
+  guint show_line_changes : 1;
+  guint show_line_numbers : 1;
+  guint show_line_diagnostics : 1;
 };
 
 enum {
@@ -85,6 +89,14 @@ enum {
   BACKGROUND,
 };
 
+enum {
+  PROP_0,
+  PROP_SHOW_LINE_CHANGES,
+  PROP_SHOW_LINE_NUMBERS,
+  PROP_SHOW_LINE_DIAGNOSTICS,
+  N_PROPS
+};
+
 typedef struct
 {
   guint is_breakpoint : 1;
@@ -100,6 +112,8 @@ typedef struct
 
 G_DEFINE_TYPE (IdeOmniGutterRenderer, ide_omni_gutter_renderer, GTK_SOURCE_TYPE_GUTTER_RENDERER)
 
+static GParamSpec *properties [N_PROPS];
+
 static gboolean
 get_style_boolean (GtkSourceStyleScheme *scheme,
                    const gchar          *style_name,
@@ -349,19 +363,22 @@ count_num_digits (gint num_lines)
 }
 
 static void
-ide_omni_gutter_renderer_recalculate_size (IdeOmniGutterRenderer *self,
-                                           IdeSourceView         *view)
+ide_omni_gutter_renderer_recalculate_size (IdeOmniGutterRenderer *self)
 {
   const PangoFontDescription *font_desc;
   g_autofree gchar *numbers = NULL;
   GtkTextBuffer *buffer;
+  IdeSourceView *view;
   PangoLayout *layout;
   GtkTextIter end;
   guint line;
   int height;
 
   g_assert (IDE_IS_OMNI_GUTTER_RENDERER (self));
-  g_assert (IDE_IS_SOURCE_VIEW (view));
+
+  view = (IdeSourceView *)gtk_source_gutter_renderer_get_view (GTK_SOURCE_GUTTER_RENDERER (self));
+  if (!IDE_IS_SOURCE_VIEW (view))
+    return;
 
   /*
    * First, we need to get the size of the text for the last line of the
@@ -409,7 +426,7 @@ ide_omni_gutter_renderer_notify_font_desc (IdeOmniGutterRenderer *self,
   g_assert (IDE_IS_OMNI_GUTTER_RENDERER (self));
   g_assert (IDE_IS_SOURCE_VIEW (view));
 
-  ide_omni_gutter_renderer_recalculate_size (self, view);
+  ide_omni_gutter_renderer_recalculate_size (self);
 }
 
 static void
@@ -947,7 +964,7 @@ ide_omni_gutter_renderer_reload (IdeOmniGutterRenderer *self)
   g_set_object (&self->breakpoints, breakpoints);
 
   ide_omni_gutter_renderer_reload_icons (self);
-  ide_omni_gutter_renderer_recalculate_size (self, IDE_SOURCE_VIEW (view));
+  ide_omni_gutter_renderer_recalculate_size (self);
 }
 
 static void
@@ -1016,15 +1033,12 @@ static gboolean
 ide_omni_gutter_renderer_do_recalc (gpointer data)
 {
   IdeOmniGutterRenderer *self = data;
-  GtkTextView *view;
 
   g_assert (IDE_IS_OMNI_GUTTER_RENDERER (self));
 
   self->resize_source = 0;
 
-  view = gtk_source_gutter_renderer_get_view (GTK_SOURCE_GUTTER_RENDERER (self));
-  if (IDE_IS_SOURCE_VIEW (view))
-    ide_omni_gutter_renderer_recalculate_size (self, IDE_SOURCE_VIEW (view));
+  ide_omni_gutter_renderer_recalculate_size (self);
 
   return G_SOURCE_REMOVE;
 }
@@ -1112,6 +1126,63 @@ ide_omni_gutter_renderer_dispose (GObject *object)
 }
 
 static void
+ide_omni_gutter_renderer_get_property (GObject    *object,
+                                       guint       prop_id,
+                                       GValue     *value,
+                                       GParamSpec *pspec)
+{
+  IdeOmniGutterRenderer *self = IDE_OMNI_GUTTER_RENDERER (object);
+
+  switch (prop_id)
+    {
+    case PROP_SHOW_LINE_CHANGES:
+      g_value_set_boolean (value, self->show_line_changes);
+      break;
+
+    case PROP_SHOW_LINE_DIAGNOSTICS:
+      g_value_set_boolean (value, self->show_line_diagnostics);
+      break;
+
+    case PROP_SHOW_LINE_NUMBERS:
+      g_value_set_boolean (value, self->show_line_numbers);
+      break;
+
+    default:
+      G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
+    }
+}
+
+static void
+ide_omni_gutter_renderer_set_property (GObject      *object,
+                                       guint         prop_id,
+                                       const GValue *value,
+                                       GParamSpec   *pspec)
+{
+  IdeOmniGutterRenderer *self = IDE_OMNI_GUTTER_RENDERER (object);
+
+  switch (prop_id)
+    {
+    case PROP_SHOW_LINE_CHANGES:
+      self->show_line_changes = g_value_get_boolean (value);
+      ide_omni_gutter_renderer_recalculate_size (self);
+      break;
+
+    case PROP_SHOW_LINE_DIAGNOSTICS:
+      self->show_line_diagnostics = g_value_get_boolean (value);
+      ide_omni_gutter_renderer_recalculate_size (self);
+      break;
+
+    case PROP_SHOW_LINE_NUMBERS:
+      self->show_line_numbers = g_value_get_boolean (value);
+      ide_omni_gutter_renderer_recalculate_size (self);
+      break;
+
+    default:
+      G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
+    }
+}
+
+static void
 ide_omni_gutter_renderer_class_init (IdeOmniGutterRendererClass *klass)
 {
   GObjectClass *object_class = G_OBJECT_CLASS (klass);
@@ -1119,17 +1190,37 @@ ide_omni_gutter_renderer_class_init (IdeOmniGutterRendererClass *klass)
 
   object_class->constructed = ide_omni_gutter_renderer_constructed;
   object_class->dispose = ide_omni_gutter_renderer_dispose;
+  object_class->get_property = ide_omni_gutter_renderer_get_property;
+  object_class->set_property = ide_omni_gutter_renderer_set_property;
 
   renderer_class->draw = ide_omni_gutter_renderer_draw;
   renderer_class->begin = ide_omni_gutter_renderer_begin;
   renderer_class->end = ide_omni_gutter_renderer_end;
   renderer_class->query_activatable = ide_omni_gutter_renderer_query_activatable;
   renderer_class->activate = ide_omni_gutter_renderer_activate;
+
+  properties [PROP_SHOW_LINE_CHANGES] =
+    g_param_spec_boolean ("show-line-changes", NULL, NULL, TRUE,
+                          G_PARAM_READWRITE | G_PARAM_STATIC_STRINGS);
+
+  properties [PROP_SHOW_LINE_NUMBERS] =
+    g_param_spec_boolean ("show-line-numbers", NULL, NULL, TRUE,
+                          G_PARAM_READWRITE | G_PARAM_STATIC_STRINGS);
+
+  properties [PROP_SHOW_LINE_DIAGNOSTICS] =
+    g_param_spec_boolean ("show-line-diagnostics", NULL, NULL, TRUE,
+                          G_PARAM_READWRITE | G_PARAM_STATIC_STRINGS);
+
+  g_object_class_install_properties (object_class, N_PROPS, properties);
 }
 
 static void
 ide_omni_gutter_renderer_init (IdeOmniGutterRenderer *self)
 {
+  self->show_line_changes = TRUE;
+  self->show_line_diagnostics = TRUE;
+  self->show_line_diagnostics = TRUE;
+
   self->lines = g_array_new (FALSE, FALSE, sizeof (LineInfo));
 
   g_signal_connect (self,
@@ -1185,3 +1276,69 @@ ide_omni_gutter_renderer_new (void)
 {
   return g_object_new (IDE_TYPE_OMNI_GUTTER_RENDERER, NULL);
 }
+
+gboolean
+ide_omni_gutter_renderer_get_show_line_changes (IdeOmniGutterRenderer *self)
+{
+  g_return_val_if_fail (IDE_IS_OMNI_GUTTER_RENDERER (self), FALSE);
+  return self->show_line_changes;
+}
+
+gboolean
+ide_omni_gutter_renderer_get_show_line_diagnostics (IdeOmniGutterRenderer *self)
+{
+  g_return_val_if_fail (IDE_IS_OMNI_GUTTER_RENDERER (self), FALSE);
+  return self->show_line_diagnostics;
+}
+
+gboolean
+ide_omni_gutter_renderer_get_show_line_numbers (IdeOmniGutterRenderer *self)
+{
+  g_return_val_if_fail (IDE_IS_OMNI_GUTTER_RENDERER (self), FALSE);
+  return self->show_line_numbers;
+}
+
+void
+ide_omni_gutter_renderer_set_show_line_changes (IdeOmniGutterRenderer *self,
+                                                gboolean               show_line_changes)
+{
+  g_return_if_fail (IDE_IS_OMNI_GUTTER_RENDERER (self));
+
+  show_line_changes = !!show_line_changes;
+
+  if (show_line_changes != self->show_line_changes)
+    {
+      self->show_line_changes = show_line_changes;
+      g_object_notify_by_pspec (G_OBJECT (self), properties [PROP_SHOW_LINE_CHANGES]);
+    }
+}
+
+void
+ide_omni_gutter_renderer_set_show_line_diagnostics (IdeOmniGutterRenderer *self,
+                                                    gboolean               show_line_diagnostics)
+{
+  g_return_if_fail (IDE_IS_OMNI_GUTTER_RENDERER (self));
+
+  show_line_diagnostics = !!show_line_diagnostics;
+
+  if (show_line_diagnostics != self->show_line_diagnostics)
+    {
+      self->show_line_diagnostics = show_line_diagnostics;
+      g_object_notify_by_pspec (G_OBJECT (self), properties [PROP_SHOW_LINE_DIAGNOSTICS]);
+    }
+}
+
+void
+ide_omni_gutter_renderer_set_show_line_numbers (IdeOmniGutterRenderer *self,
+                                                gboolean               show_line_numbers)
+{
+  g_return_if_fail (IDE_IS_OMNI_GUTTER_RENDERER (self));
+
+  show_line_numbers = !!show_line_numbers;
+
+  if (show_line_numbers != self->show_line_numbers)
+    {
+      self->show_line_numbers = show_line_numbers;
+      g_object_notify_by_pspec (G_OBJECT (self), properties [PROP_SHOW_LINE_NUMBERS]);
+    }
+}
diff --git a/libide/sourceview/ide-omni-gutter-renderer.h b/libide/sourceview/ide-omni-gutter-renderer.h
index b666daa..9412d6b 100644
--- a/libide/sourceview/ide-omni-gutter-renderer.h
+++ b/libide/sourceview/ide-omni-gutter-renderer.h
@@ -27,7 +27,16 @@ G_BEGIN_DECLS
 
 G_DECLARE_FINAL_TYPE (IdeOmniGutterRenderer, ide_omni_gutter_renderer, IDE, OMNI_GUTTER_RENDERER, 
GtkSourceGutterRenderer)
 
-IdeOmniGutterRenderer *ide_omni_gutter_renderer_new (void);
+IdeOmniGutterRenderer *ide_omni_gutter_renderer_new                       (void);
+gboolean               ide_omni_gutter_renderer_get_show_line_changes     (IdeOmniGutterRenderer *self);
+gboolean               ide_omni_gutter_renderer_get_show_line_diagnostics (IdeOmniGutterRenderer *self);
+gboolean               ide_omni_gutter_renderer_get_show_line_numbers     (IdeOmniGutterRenderer *self);
+void                   ide_omni_gutter_renderer_set_show_line_changes     (IdeOmniGutterRenderer *self,
+                                                                           gboolean               
show_line_changes);
+void                   ide_omni_gutter_renderer_set_show_line_diagnostics (IdeOmniGutterRenderer *self,
+                                                                           gboolean               
show_line_diagnostics);
+void                   ide_omni_gutter_renderer_set_show_line_numbers     (IdeOmniGutterRenderer *self,
+                                                                           gboolean               
show_line_numbers);
 
 G_END_DECLS
 
diff --git a/libide/sourceview/ide-source-view.c b/libide/sourceview/ide-source-view.c
index 7730d4a..3d12ce4 100644
--- a/libide/sourceview/ide-source-view.c
+++ b/libide/sourceview/ide-source-view.c
@@ -108,6 +108,7 @@ typedef struct
   GtkSourceSearchContext      *search_context;
   DzlAnimation                *hadj_animation;
   DzlAnimation                *vadj_animation;
+  IdeOmniGutterRenderer       *omni_renderer;
 
   IdeExtensionSetAdapter      *completion_providers;
   DzlSignalGroup              *completion_providers_signals;
@@ -171,8 +172,6 @@ typedef struct
   guint                        rubberband_search : 1;
   guint                        scrolling_to_scroll_mark : 1;
   guint                        show_grid_lines : 1;
-  guint                        show_line_changes : 1;
-  guint                        show_line_diagnostics : 1;
   guint                        show_search_bubbles : 1;
   guint                        show_search_shadow : 1;
   guint                        snippet_completion : 1;
@@ -235,7 +234,8 @@ enum {
   /* These are overridden */
   PROP_AUTO_INDENT,
   PROP_HIGHLIGHT_CURRENT_LINE,
-  PROP_OVERWRITE
+  PROP_OVERWRITE,
+  PROP_SHOW_LINE_NUMBERS,
 };
 
 enum {
@@ -1408,27 +1408,6 @@ ide_source_view__buffer_notify_has_selection_cb (IdeSourceView *self,
 }
 
 static void
-ide_source_view__buffer_notify_highlight_diagnostics_cb (IdeSourceView *self,
-                                                         GParamSpec    *pspec,
-                                                         IdeBuffer     *buffer)
-{
-  g_assert (IDE_IS_SOURCE_VIEW (self));
-  g_assert (IDE_IS_BUFFER (buffer));
-
-#if 0
-  if (priv->line_diagnostics_renderer != NULL)
-    {
-      gboolean visible;
-
-      visible = (priv->show_line_diagnostics && ide_buffer_get_highlight_diagnostics (buffer));
-      g_object_set (priv->line_diagnostics_renderer,
-                    "visible", visible,
-                    NULL);
-    }
-#endif
-}
-
-static void
 ide_source_view__buffer_line_flags_changed_cb (IdeSourceView *self,
                                                IdeBuffer     *buffer)
 {
@@ -1700,7 +1679,6 @@ ide_source_view_bind_buffer (IdeSourceView  *self,
 
   ide_source_view__buffer_notify_language_cb (self, NULL, buffer);
   ide_source_view__buffer_notify_file_cb (self, NULL, buffer);
-  ide_source_view__buffer_notify_highlight_diagnostics_cb (self, NULL, buffer);
   ide_source_view__buffer_notify_style_scheme_cb (self, NULL, buffer);
   ide_source_view__buffer__notify_can_redo (self, NULL, buffer);
   ide_source_view__buffer__notify_can_undo (self, NULL, buffer);
@@ -4488,6 +4466,7 @@ ide_source_view_constructed (GObject *object)
   IdeSourceView *self = (IdeSourceView *)object;
   IdeSourceViewPrivate *priv = ide_source_view_get_instance_private (self);
   GtkSourceCompletion *completion;
+  GtkSourceGutter *gutter;
 
   G_OBJECT_CLASS (ide_source_view_parent_class)->constructed (object);
 
@@ -4515,16 +4494,11 @@ ide_source_view_constructed (GObject *object)
   priv->definition_src_location = NULL;
   ide_source_view_reset_definition_highlight (self);
 
-  {
-    IdeOmniGutterRenderer *renderer;
-    GtkSourceGutter *gutter = gtk_source_view_get_gutter (GTK_SOURCE_VIEW (self), GTK_TEXT_WINDOW_LEFT);
-
-    renderer = g_object_new (IDE_TYPE_OMNI_GUTTER_RENDERER,
-                             "size", 20,
-                             "visible", TRUE,
-                             NULL);
-    gtk_source_gutter_insert (gutter, GTK_SOURCE_GUTTER_RENDERER (renderer), 1000);
-  }
+  gutter = gtk_source_view_get_gutter (GTK_SOURCE_VIEW (self), GTK_TEXT_WINDOW_LEFT);
+  priv->omni_renderer = g_object_new (IDE_TYPE_OMNI_GUTTER_RENDERER,
+                                      "visible", TRUE,
+                                      NULL);
+  gtk_source_gutter_insert (gutter, g_object_ref_sink (priv->omni_renderer), 0);
 }
 
 static void
@@ -6274,6 +6248,7 @@ ide_source_view_dispose (GObject *object)
   g_clear_object (&priv->buffer_signals);
   g_clear_object (&priv->file_setting_bindings);
   g_clear_object (&priv->word_completion_provider);
+  g_clear_object (&priv->omni_renderer);
 
   if (priv->command_str != NULL)
     {
@@ -6386,6 +6361,10 @@ ide_source_view_get_property (GObject    *object,
       g_value_set_boolean (value, ide_source_view_get_show_line_diagnostics (self));
       break;
 
+    case PROP_SHOW_LINE_NUMBERS:
+      g_value_set_boolean (value, ide_source_view_get_show_line_numbers (self));
+      break;
+
     case PROP_SHOW_SEARCH_BUBBLES:
       g_value_set_boolean (value, ide_source_view_get_show_search_bubbles (self));
       break;
@@ -6483,6 +6462,10 @@ ide_source_view_set_property (GObject      *object,
       ide_source_view_set_show_line_diagnostics (self, g_value_get_boolean (value));
       break;
 
+    case PROP_SHOW_LINE_NUMBERS:
+      ide_source_view_set_show_line_numbers (self, g_value_get_boolean (value));
+      break;
+
     case PROP_SHOW_SEARCH_BUBBLES:
       ide_source_view_set_show_search_bubbles (self, g_value_get_boolean (value));
       break;
@@ -6722,6 +6705,8 @@ ide_source_view_class_init (IdeSourceViewClass *klass)
                           TRUE,
                           (G_PARAM_READWRITE | G_PARAM_STATIC_STRINGS));
 
+  g_object_class_override_property (object_class, PROP_SHOW_LINE_NUMBERS, "show-line-numbers");
+
   properties [PROP_SHOW_SEARCH_BUBBLES] =
     g_param_spec_boolean ("show-search-bubbles",
                           "Show Search Bubbles",
@@ -7474,7 +7459,6 @@ ide_source_view_init (IdeSourceView *self)
   priv->target_line_column = 0;
   priv->snippets = g_queue_new ();
   priv->selections = g_queue_new ();
-  priv->show_line_diagnostics = TRUE;
   priv->font_scale = FONT_SCALE_NORMAL;
   priv->search_direction = GTK_DIR_DOWN;
   priv->command_str = g_string_sized_new (32);
@@ -7533,11 +7517,6 @@ ide_source_view_init (IdeSourceView *self)
                                    self,
                                    G_CONNECT_SWAPPED);
   dzl_signal_group_connect_object (priv->buffer_signals,
-                                   "notify::highlight-diagnostics",
-                                   G_CALLBACK (ide_source_view__buffer_notify_highlight_diagnostics_cb),
-                                   self,
-                                   G_CONNECT_SWAPPED);
-  dzl_signal_group_connect_object (priv->buffer_signals,
                                    "notify::file",
                                    G_CALLBACK (ide_source_view__buffer_notify_file_cb),
                                    self,
@@ -7674,7 +7653,7 @@ ide_source_view_get_show_line_changes (IdeSourceView *self)
 
   g_return_val_if_fail (IDE_IS_SOURCE_VIEW (self), FALSE);
 
-  return priv->show_line_changes;
+  return ide_omni_gutter_renderer_get_show_line_changes (priv->omni_renderer);
 }
 
 void
@@ -7685,14 +7664,8 @@ ide_source_view_set_show_line_changes (IdeSourceView *self,
 
   g_return_if_fail (IDE_IS_SOURCE_VIEW (self));
 
-  show_line_changes = !!show_line_changes;
-
-  if (show_line_changes != priv->show_line_changes)
-    {
-      priv->show_line_changes = show_line_changes;
-      /* TODO: Update omni renderer */
-      g_object_notify_by_pspec (G_OBJECT (self), properties [PROP_SHOW_LINE_CHANGES]);
-    }
+  ide_omni_gutter_renderer_set_show_line_changes (priv->omni_renderer, show_line_changes);
+  g_object_notify_by_pspec (G_OBJECT (self), properties [PROP_SHOW_LINE_CHANGES]);
 }
 
 gboolean
@@ -7702,7 +7675,7 @@ ide_source_view_get_show_line_diagnostics (IdeSourceView *self)
 
   g_return_val_if_fail (IDE_IS_SOURCE_VIEW (self), FALSE);
 
-  return priv->show_line_diagnostics;
+  return ide_omni_gutter_renderer_get_show_line_diagnostics (priv->omni_renderer);
 }
 
 void
@@ -7713,23 +7686,8 @@ ide_source_view_set_show_line_diagnostics (IdeSourceView *self,
 
   g_return_if_fail (IDE_IS_SOURCE_VIEW (self));
 
-  show_line_diagnostics = !!show_line_diagnostics;
-
-  if (show_line_diagnostics != priv->show_line_diagnostics)
-    {
-      priv->show_line_diagnostics = show_line_diagnostics;
-
-#if 0
-      if ((priv->buffer != NULL) && (priv->line_diagnostics_renderer != NULL))
-        {
-          visible = (priv->show_line_diagnostics &&
-                     ide_buffer_get_highlight_diagnostics (priv->buffer));
-          gtk_source_gutter_renderer_set_visible (priv->line_diagnostics_renderer, visible);
-        }
-#endif
-
-      g_object_notify_by_pspec (G_OBJECT (self), properties [PROP_SHOW_LINE_CHANGES]);
-    }
+  ide_omni_gutter_renderer_set_show_line_diagnostics (priv->omni_renderer, show_line_diagnostics);
+  g_object_notify_by_pspec (G_OBJECT (self), properties [PROP_SHOW_LINE_DIAGNOSTICS]);
 }
 
 gboolean
@@ -9015,3 +8973,25 @@ ide_source_view_get_current_snippet (IdeSourceView *self)
 
   return g_queue_peek_head (priv->snippets);
 }
+
+gboolean
+ide_source_view_get_show_line_numbers (IdeSourceView *self)
+{
+  IdeSourceViewPrivate *priv = ide_source_view_get_instance_private (self);
+
+  g_return_val_if_fail (IDE_IS_SOURCE_VIEW (self), FALSE);
+
+  return ide_omni_gutter_renderer_get_show_line_numbers (priv->omni_renderer);
+}
+
+void
+ide_source_view_set_show_line_numbers (IdeSourceView *self,
+                                       gboolean       show_line_numbers)
+{
+  IdeSourceViewPrivate *priv = ide_source_view_get_instance_private (self);
+
+  g_return_if_fail (IDE_IS_SOURCE_VIEW (self));
+
+  ide_omni_gutter_renderer_set_show_line_numbers (priv->omni_renderer, show_line_numbers);
+  g_object_notify (G_OBJECT (self), "show-line-numbers");
+}
diff --git a/libide/sourceview/ide-source-view.h b/libide/sourceview/ide-source-view.h
index 59156fe..fdac57a 100644
--- a/libide/sourceview/ide-source-view.h
+++ b/libide/sourceview/ide-source-view.h
@@ -358,6 +358,7 @@ GtkDirectionType            ide_source_view_get_search_direction      (IdeSource
 gboolean                    ide_source_view_get_show_grid_lines       (IdeSourceView              *self);
 gboolean                    ide_source_view_get_show_line_changes     (IdeSourceView              *self);
 gboolean                    ide_source_view_get_show_line_diagnostics (IdeSourceView              *self);
+gboolean                    ide_source_view_get_show_line_numbers     (IdeSourceView              *self);
 gboolean                    ide_source_view_get_show_search_bubbles   (IdeSourceView              *self);
 gboolean                    ide_source_view_get_show_search_shadow    (IdeSourceView              *self);
 gboolean                    ide_source_view_get_snippet_completion    (IdeSourceView              *self);
@@ -400,7 +401,9 @@ void                        ide_source_view_set_show_grid_lines       (IdeSource
 void                        ide_source_view_set_show_line_changes     (IdeSourceView              *self,
                                                                        gboolean                    
show_line_changes);
 void                        ide_source_view_set_show_line_diagnostics (IdeSourceView              *self,
-                                                                       gboolean                    
show_line_changes);
+                                                                       gboolean                    
show_line_diagnostics);
+void                        ide_source_view_set_show_line_numbers     (IdeSourceView              *self,
+                                                                       gboolean                    
show_line_numbers);
 void                        ide_source_view_set_show_search_bubbles   (IdeSourceView              *self,
                                                                        gboolean                    
show_search_bubbles);
 void                        ide_source_view_set_show_search_shadow    (IdeSourceView              *self,


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