[gnome-builder/wip/chergert/gutter] plumb some properties
- From: Christian Hergert <chergert src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gnome-builder/wip/chergert/gutter] plumb some properties
- Date: Mon, 18 Sep 2017 06:28:16 +0000 (UTC)
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]