diff --git a/ChangeLog b/ChangeLog index ba7bdd37c6..ef9abd0d30 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,23 @@ +2000-11-03 Havoc Pennington + + * gtk/gtktexttagtable.c: Docs + (gtk_text_tag_table_size): return a signed int + + * gtk/gtktexttag.c: s/tkxt/text/g; write documentation + (gtk_text_tag_event): make the event_object a GObject + + * gtk/gtktextview.c: Write API docs for all functions. + + * gtk/gtktextview.h: add GTK_TEXT_WINDOW_PRIVATE as return value + for gtk_text_view_get_window_type() called on one of the private + windows. + + * gtk/gtktextview.c: Instead of accessing text_view->buffer + directly, call get_buffer() which demand-creates a default + buffer. So gtk_text_view_new() can be used to create a view with a + default buffer in it, if you just want an empty text box users can + put data in. Useful for GUI builders also. + 2000-11-03 Pablo Saratxaga * gtk/gtkrc.zh_TW.*: moved gtkrc.zh_TW.Big5 to gtkrc.zh_TW.big5; diff --git a/ChangeLog.pre-2-0 b/ChangeLog.pre-2-0 index ba7bdd37c6..ef9abd0d30 100644 --- a/ChangeLog.pre-2-0 +++ b/ChangeLog.pre-2-0 @@ -1,3 +1,23 @@ +2000-11-03 Havoc Pennington + + * gtk/gtktexttagtable.c: Docs + (gtk_text_tag_table_size): return a signed int + + * gtk/gtktexttag.c: s/tkxt/text/g; write documentation + (gtk_text_tag_event): make the event_object a GObject + + * gtk/gtktextview.c: Write API docs for all functions. + + * gtk/gtktextview.h: add GTK_TEXT_WINDOW_PRIVATE as return value + for gtk_text_view_get_window_type() called on one of the private + windows. + + * gtk/gtktextview.c: Instead of accessing text_view->buffer + directly, call get_buffer() which demand-creates a default + buffer. So gtk_text_view_new() can be used to create a view with a + default buffer in it, if you just want an empty text box users can + put data in. Useful for GUI builders also. + 2000-11-03 Pablo Saratxaga * gtk/gtkrc.zh_TW.*: moved gtkrc.zh_TW.Big5 to gtkrc.zh_TW.big5; diff --git a/ChangeLog.pre-2-10 b/ChangeLog.pre-2-10 index ba7bdd37c6..ef9abd0d30 100644 --- a/ChangeLog.pre-2-10 +++ b/ChangeLog.pre-2-10 @@ -1,3 +1,23 @@ +2000-11-03 Havoc Pennington + + * gtk/gtktexttagtable.c: Docs + (gtk_text_tag_table_size): return a signed int + + * gtk/gtktexttag.c: s/tkxt/text/g; write documentation + (gtk_text_tag_event): make the event_object a GObject + + * gtk/gtktextview.c: Write API docs for all functions. + + * gtk/gtktextview.h: add GTK_TEXT_WINDOW_PRIVATE as return value + for gtk_text_view_get_window_type() called on one of the private + windows. + + * gtk/gtktextview.c: Instead of accessing text_view->buffer + directly, call get_buffer() which demand-creates a default + buffer. So gtk_text_view_new() can be used to create a view with a + default buffer in it, if you just want an empty text box users can + put data in. Useful for GUI builders also. + 2000-11-03 Pablo Saratxaga * gtk/gtkrc.zh_TW.*: moved gtkrc.zh_TW.Big5 to gtkrc.zh_TW.big5; diff --git a/ChangeLog.pre-2-2 b/ChangeLog.pre-2-2 index ba7bdd37c6..ef9abd0d30 100644 --- a/ChangeLog.pre-2-2 +++ b/ChangeLog.pre-2-2 @@ -1,3 +1,23 @@ +2000-11-03 Havoc Pennington + + * gtk/gtktexttagtable.c: Docs + (gtk_text_tag_table_size): return a signed int + + * gtk/gtktexttag.c: s/tkxt/text/g; write documentation + (gtk_text_tag_event): make the event_object a GObject + + * gtk/gtktextview.c: Write API docs for all functions. + + * gtk/gtktextview.h: add GTK_TEXT_WINDOW_PRIVATE as return value + for gtk_text_view_get_window_type() called on one of the private + windows. + + * gtk/gtktextview.c: Instead of accessing text_view->buffer + directly, call get_buffer() which demand-creates a default + buffer. So gtk_text_view_new() can be used to create a view with a + default buffer in it, if you just want an empty text box users can + put data in. Useful for GUI builders also. + 2000-11-03 Pablo Saratxaga * gtk/gtkrc.zh_TW.*: moved gtkrc.zh_TW.Big5 to gtkrc.zh_TW.big5; diff --git a/ChangeLog.pre-2-4 b/ChangeLog.pre-2-4 index ba7bdd37c6..ef9abd0d30 100644 --- a/ChangeLog.pre-2-4 +++ b/ChangeLog.pre-2-4 @@ -1,3 +1,23 @@ +2000-11-03 Havoc Pennington + + * gtk/gtktexttagtable.c: Docs + (gtk_text_tag_table_size): return a signed int + + * gtk/gtktexttag.c: s/tkxt/text/g; write documentation + (gtk_text_tag_event): make the event_object a GObject + + * gtk/gtktextview.c: Write API docs for all functions. + + * gtk/gtktextview.h: add GTK_TEXT_WINDOW_PRIVATE as return value + for gtk_text_view_get_window_type() called on one of the private + windows. + + * gtk/gtktextview.c: Instead of accessing text_view->buffer + directly, call get_buffer() which demand-creates a default + buffer. So gtk_text_view_new() can be used to create a view with a + default buffer in it, if you just want an empty text box users can + put data in. Useful for GUI builders also. + 2000-11-03 Pablo Saratxaga * gtk/gtkrc.zh_TW.*: moved gtkrc.zh_TW.Big5 to gtkrc.zh_TW.big5; diff --git a/ChangeLog.pre-2-6 b/ChangeLog.pre-2-6 index ba7bdd37c6..ef9abd0d30 100644 --- a/ChangeLog.pre-2-6 +++ b/ChangeLog.pre-2-6 @@ -1,3 +1,23 @@ +2000-11-03 Havoc Pennington + + * gtk/gtktexttagtable.c: Docs + (gtk_text_tag_table_size): return a signed int + + * gtk/gtktexttag.c: s/tkxt/text/g; write documentation + (gtk_text_tag_event): make the event_object a GObject + + * gtk/gtktextview.c: Write API docs for all functions. + + * gtk/gtktextview.h: add GTK_TEXT_WINDOW_PRIVATE as return value + for gtk_text_view_get_window_type() called on one of the private + windows. + + * gtk/gtktextview.c: Instead of accessing text_view->buffer + directly, call get_buffer() which demand-creates a default + buffer. So gtk_text_view_new() can be used to create a view with a + default buffer in it, if you just want an empty text box users can + put data in. Useful for GUI builders also. + 2000-11-03 Pablo Saratxaga * gtk/gtkrc.zh_TW.*: moved gtkrc.zh_TW.Big5 to gtkrc.zh_TW.big5; diff --git a/ChangeLog.pre-2-8 b/ChangeLog.pre-2-8 index ba7bdd37c6..ef9abd0d30 100644 --- a/ChangeLog.pre-2-8 +++ b/ChangeLog.pre-2-8 @@ -1,3 +1,23 @@ +2000-11-03 Havoc Pennington + + * gtk/gtktexttagtable.c: Docs + (gtk_text_tag_table_size): return a signed int + + * gtk/gtktexttag.c: s/tkxt/text/g; write documentation + (gtk_text_tag_event): make the event_object a GObject + + * gtk/gtktextview.c: Write API docs for all functions. + + * gtk/gtktextview.h: add GTK_TEXT_WINDOW_PRIVATE as return value + for gtk_text_view_get_window_type() called on one of the private + windows. + + * gtk/gtktextview.c: Instead of accessing text_view->buffer + directly, call get_buffer() which demand-creates a default + buffer. So gtk_text_view_new() can be used to create a view with a + default buffer in it, if you just want an empty text box users can + put data in. Useful for GUI builders also. + 2000-11-03 Pablo Saratxaga * gtk/gtkrc.zh_TW.*: moved gtkrc.zh_TW.Big5 to gtkrc.zh_TW.big5; diff --git a/gtk/gtktextmark.c b/gtk/gtktextmark.c index bf2d1f2a07..13587007bc 100644 --- a/gtk/gtktextmark.c +++ b/gtk/gtktextmark.c @@ -127,6 +127,15 @@ gtk_text_mark_finalize (GObject *obj) } } +/** + * gtk_text_mark_is_visible: + * @mark: a #GtkTextMark + * + * Returns %TRUE if the mark is visible (i.e. a cursor is displayed + * for it) + * + * Return value: %TRUE if visible + **/ gboolean gtk_text_mark_is_visible (GtkTextMark *mark) { @@ -137,6 +146,14 @@ gtk_text_mark_is_visible (GtkTextMark *mark) return seg->body.mark.visible; } +/** + * gtk_text_mark_get_name: + * @mark: a #GtkTextMark + * + * Returns the mark name; returns NULL for anonymous marks. + * + * Return value: mark name + **/ const char * gtk_text_mark_get_name (GtkTextMark *mark) { @@ -147,6 +164,16 @@ gtk_text_mark_get_name (GtkTextMark *mark) return seg->body.mark.name; } +/** + * gtk_text_mark_get_deleted: + * @mark: a #GtkTextMark + * + * Returns %TRUE if the mark has been removed from its buffer + * with gtk_text_buffer_delete_mark(). Marks can't be used + * once deleted. + * + * Return value: whether the mark is deleted + **/ gboolean gtk_text_mark_get_deleted (GtkTextMark *mark) { diff --git a/gtk/gtktexttag.c b/gtk/gtktexttag.c index 8f5ca5a5c3..03d8aa9eac 100644 --- a/gtk/gtktexttag.c +++ b/gtk/gtktexttag.c @@ -120,7 +120,7 @@ enum { LAST_ARG }; -static void gtk_text_tag_init (GtkTextTag *tkxt_tag); +static void gtk_text_tag_init (GtkTextTag *text_tag); static void gtk_text_tag_class_init (GtkTextTagClass *klass); static void gtk_text_tag_destroy (GtkObject *object); static void gtk_text_tag_finalize (GObject *object); @@ -293,13 +293,22 @@ gtk_text_tag_class_init (GtkTextTagClass *klass) } void -gtk_text_tag_init (GtkTextTag *tkxt_tag) +gtk_text_tag_init (GtkTextTag *text_tag) { /* 0 is basically a fine way to initialize everything in the entire struct */ } +/** + * gtk_text_tag_new: + * @name: tag name, or %NULL + * + * Creates a #GtkTextTag. Configure the tag using object arguments, + * i.e. using g_object_set(). + * + * Return value: a new #GtkTextTag + **/ GtkTextTag* gtk_text_tag_new (const gchar *name) { @@ -317,19 +326,19 @@ gtk_text_tag_new (const gchar *name) static void gtk_text_tag_destroy (GtkObject *object) { - GtkTextTag *tkxt_tag; + GtkTextTag *text_tag; - tkxt_tag = GTK_TEXT_TAG (object); + text_tag = GTK_TEXT_TAG (object); - g_assert (!tkxt_tag->values->realized); + g_assert (!text_tag->values->realized); - if (tkxt_tag->table) - gtk_text_tag_table_remove (tkxt_tag->table, tkxt_tag); + if (text_tag->table) + gtk_text_tag_table_remove (text_tag->table, text_tag); - g_assert (tkxt_tag->table == NULL); + g_assert (text_tag->table == NULL); - gtk_text_attributes_unref (tkxt_tag->values); - tkxt_tag->values = NULL; + gtk_text_attributes_unref (text_tag->values); + text_tag->values = NULL; (* GTK_OBJECT_CLASS (parent_class)->destroy) (object); } @@ -337,12 +346,12 @@ gtk_text_tag_destroy (GtkObject *object) static void gtk_text_tag_finalize (GObject *object) { - GtkTextTag *tkxt_tag; + GtkTextTag *text_tag; - tkxt_tag = GTK_TEXT_TAG (object); + text_tag = GTK_TEXT_TAG (object); - g_free (tkxt_tag->name); - tkxt_tag->name = NULL; + g_free (text_tag->name); + text_tag->name = NULL; (* G_OBJECT_CLASS (parent_class)->finalize) (object); } @@ -378,18 +387,18 @@ set_fg_color (GtkTextTag *tag, GdkColor *color) static void gtk_text_tag_set_arg (GtkObject *object, GtkArg *arg, guint arg_id) { - GtkTextTag *tkxt_tag; + GtkTextTag *text_tag; gboolean size_changed = FALSE; - tkxt_tag = GTK_TEXT_TAG (object); + text_tag = GTK_TEXT_TAG (object); - g_return_if_fail (!tkxt_tag->values->realized); + g_return_if_fail (!text_tag->values->realized); switch (arg_id) { case ARG_NAME: - g_return_if_fail (tkxt_tag->name == NULL); - tkxt_tag->name = g_strdup (GTK_VALUE_STRING (*arg)); + g_return_if_fail (text_tag->name == NULL); + text_tag->name = g_strdup (GTK_VALUE_STRING (*arg)); break; case ARG_BACKGROUND: @@ -397,7 +406,7 @@ gtk_text_tag_set_arg (GtkObject *object, GtkArg *arg, guint arg_id) GdkColor color; if (gdk_color_parse (GTK_VALUE_STRING (*arg), &color)) - set_bg_color (tkxt_tag, &color); + set_bg_color (text_tag, &color); else g_warning ("Don't know color `%s'", GTK_VALUE_STRING (*arg)); } @@ -408,7 +417,7 @@ gtk_text_tag_set_arg (GtkObject *object, GtkArg *arg, guint arg_id) GdkColor color; if (gdk_color_parse (GTK_VALUE_STRING (*arg), &color)) - set_fg_color (tkxt_tag, &color); + set_fg_color (text_tag, &color); else g_warning ("Don't know color `%s'", GTK_VALUE_STRING (*arg)); } @@ -417,14 +426,14 @@ gtk_text_tag_set_arg (GtkObject *object, GtkArg *arg, guint arg_id) case ARG_BACKGROUND_GDK: { GdkColor *color = GTK_VALUE_POINTER (*arg); - set_bg_color (tkxt_tag, color); + set_bg_color (text_tag, color); } break; case ARG_FOREGROUND_GDK: { GdkColor *color = GTK_VALUE_POINTER (*arg); - set_fg_color (tkxt_tag, color); + set_fg_color (text_tag, color); } break; @@ -432,17 +441,17 @@ gtk_text_tag_set_arg (GtkObject *object, GtkArg *arg, guint arg_id) { GdkBitmap *bitmap = GTK_VALUE_POINTER (*arg); - tkxt_tag->bg_stipple_set = TRUE; + text_tag->bg_stipple_set = TRUE; - if (tkxt_tag->values->appearance.bg_stipple != bitmap) + if (text_tag->values->appearance.bg_stipple != bitmap) { if (bitmap != NULL) gdk_bitmap_ref (bitmap); - if (tkxt_tag->values->appearance.bg_stipple) - gdk_bitmap_unref (tkxt_tag->values->appearance.bg_stipple); + if (text_tag->values->appearance.bg_stipple) + gdk_bitmap_unref (text_tag->values->appearance.bg_stipple); - tkxt_tag->values->appearance.bg_stipple = bitmap; + text_tag->values->appearance.bg_stipple = bitmap; } } break; @@ -451,17 +460,17 @@ gtk_text_tag_set_arg (GtkObject *object, GtkArg *arg, guint arg_id) { GdkBitmap *bitmap = GTK_VALUE_POINTER (*arg); - tkxt_tag->fg_stipple_set = TRUE; + text_tag->fg_stipple_set = TRUE; - if (tkxt_tag->values->appearance.fg_stipple != bitmap) + if (text_tag->values->appearance.fg_stipple != bitmap) { if (bitmap != NULL) gdk_bitmap_ref (bitmap); - if (tkxt_tag->values->appearance.fg_stipple) - gdk_bitmap_unref (tkxt_tag->values->appearance.fg_stipple); + if (text_tag->values->appearance.fg_stipple) + gdk_bitmap_unref (text_tag->values->appearance.fg_stipple); - tkxt_tag->values->appearance.fg_stipple = bitmap; + text_tag->values->appearance.fg_stipple = bitmap; } } break; @@ -476,11 +485,11 @@ gtk_text_tag_set_arg (GtkObject *object, GtkArg *arg, guint arg_id) if (name) font_desc = pango_font_description_from_string (name); - if (tkxt_tag->values->font_desc) - pango_font_description_free (tkxt_tag->values->font_desc); + if (text_tag->values->font_desc) + pango_font_description_free (text_tag->values->font_desc); - tkxt_tag->font_set = (font_desc != NULL); - tkxt_tag->values->font_desc = font_desc; + text_tag->font_set = (font_desc != NULL); + text_tag->values->font_desc = font_desc; size_changed = TRUE; } @@ -492,110 +501,110 @@ gtk_text_tag_set_arg (GtkObject *object, GtkArg *arg, guint arg_id) font_desc = GTK_VALUE_BOXED (*arg); - if (tkxt_tag->values->font_desc) - pango_font_description_free (tkxt_tag->values->font_desc); + if (text_tag->values->font_desc) + pango_font_description_free (text_tag->values->font_desc); if (font_desc) - tkxt_tag->values->font_desc = pango_font_description_copy (font_desc); + text_tag->values->font_desc = pango_font_description_copy (font_desc); else - tkxt_tag->values->font_desc = NULL; + text_tag->values->font_desc = NULL; - tkxt_tag->font_set = (font_desc != NULL); + text_tag->font_set = (font_desc != NULL); size_changed = TRUE; } break; case ARG_PIXELS_ABOVE_LINES: - tkxt_tag->pixels_above_lines_set = TRUE; - tkxt_tag->values->pixels_above_lines = GTK_VALUE_INT (*arg); + text_tag->pixels_above_lines_set = TRUE; + text_tag->values->pixels_above_lines = GTK_VALUE_INT (*arg); size_changed = TRUE; break; case ARG_PIXELS_BELOW_LINES: - tkxt_tag->pixels_below_lines_set = TRUE; - tkxt_tag->values->pixels_below_lines = GTK_VALUE_INT (*arg); + text_tag->pixels_below_lines_set = TRUE; + text_tag->values->pixels_below_lines = GTK_VALUE_INT (*arg); size_changed = TRUE; break; case ARG_PIXELS_INSIDE_WRAP: - tkxt_tag->pixels_inside_wrap_set = TRUE; - tkxt_tag->values->pixels_inside_wrap = GTK_VALUE_INT (*arg); + text_tag->pixels_inside_wrap_set = TRUE; + text_tag->values->pixels_inside_wrap = GTK_VALUE_INT (*arg); size_changed = TRUE; break; case ARG_EDITABLE: - tkxt_tag->editable_set = TRUE; - tkxt_tag->values->editable = GTK_VALUE_BOOL (*arg); + text_tag->editable_set = TRUE; + text_tag->values->editable = GTK_VALUE_BOOL (*arg); break; case ARG_WRAP_MODE: - tkxt_tag->wrap_mode_set = TRUE; - tkxt_tag->values->wrap_mode = GTK_VALUE_ENUM (*arg); + text_tag->wrap_mode_set = TRUE; + text_tag->values->wrap_mode = GTK_VALUE_ENUM (*arg); size_changed = TRUE; break; case ARG_JUSTIFY: - tkxt_tag->justify_set = TRUE; - tkxt_tag->values->justify = GTK_VALUE_ENUM (*arg); + text_tag->justify_set = TRUE; + text_tag->values->justify = GTK_VALUE_ENUM (*arg); size_changed = TRUE; break; case ARG_DIRECTION: - tkxt_tag->values->direction = GTK_VALUE_ENUM (*arg); + text_tag->values->direction = GTK_VALUE_ENUM (*arg); break; case ARG_LEFT_MARGIN: - tkxt_tag->left_margin_set = TRUE; - tkxt_tag->values->left_margin = GTK_VALUE_INT (*arg); + text_tag->left_margin_set = TRUE; + text_tag->values->left_margin = GTK_VALUE_INT (*arg); size_changed = TRUE; break; case ARG_LEFT_WRAPPED_LINE_MARGIN: - tkxt_tag->left_wrapped_line_margin_set = TRUE; - tkxt_tag->values->left_wrapped_line_margin = GTK_VALUE_INT (*arg); + text_tag->left_wrapped_line_margin_set = TRUE; + text_tag->values->left_wrapped_line_margin = GTK_VALUE_INT (*arg); size_changed = TRUE; break; case ARG_STRIKETHROUGH: - tkxt_tag->strikethrough_set = TRUE; - tkxt_tag->values->appearance.strikethrough = GTK_VALUE_BOOL (*arg); + text_tag->strikethrough_set = TRUE; + text_tag->values->appearance.strikethrough = GTK_VALUE_BOOL (*arg); break; case ARG_RIGHT_MARGIN: - tkxt_tag->right_margin_set = TRUE; - tkxt_tag->values->right_margin = GTK_VALUE_INT (*arg); + text_tag->right_margin_set = TRUE; + text_tag->values->right_margin = GTK_VALUE_INT (*arg); size_changed = TRUE; break; case ARG_UNDERLINE: - tkxt_tag->underline_set = TRUE; - tkxt_tag->values->appearance.underline = GTK_VALUE_ENUM (*arg); + text_tag->underline_set = TRUE; + text_tag->values->appearance.underline = GTK_VALUE_ENUM (*arg); break; case ARG_OFFSET: - tkxt_tag->offset_set = TRUE; - tkxt_tag->values->offset = GTK_VALUE_INT (*arg); + text_tag->offset_set = TRUE; + text_tag->values->offset = GTK_VALUE_INT (*arg); size_changed = TRUE; break; case ARG_BG_FULL_HEIGHT: - tkxt_tag->bg_full_height_set = TRUE; - tkxt_tag->values->bg_full_height = GTK_VALUE_BOOL (*arg); + text_tag->bg_full_height_set = TRUE; + text_tag->values->bg_full_height = GTK_VALUE_BOOL (*arg); break; case ARG_LANGUAGE: - tkxt_tag->language_set = TRUE; - tkxt_tag->values->language = g_strdup (GTK_VALUE_STRING (*arg)); + text_tag->language_set = TRUE; + text_tag->values->language = g_strdup (GTK_VALUE_STRING (*arg)); break; case ARG_TABS: - tkxt_tag->tabs_set = TRUE; + text_tag->tabs_set = TRUE; - if (tkxt_tag->values->tabs) - pango_tab_array_free (tkxt_tag->values->tabs); + if (text_tag->values->tabs) + pango_tab_array_free (text_tag->values->tabs); - tkxt_tag->values->tabs = + text_tag->values->tabs = pango_tab_array_copy (GTK_VALUE_POINTER (*arg)); size_changed = TRUE; @@ -605,95 +614,95 @@ gtk_text_tag_set_arg (GtkObject *object, GtkArg *arg, guint arg_id) case ARG_BACKGROUND_SET: case ARG_BACKGROUND_GDK_SET: - tkxt_tag->bg_color_set = GTK_VALUE_BOOL (*arg); + text_tag->bg_color_set = GTK_VALUE_BOOL (*arg); break; case ARG_FOREGROUND_SET: case ARG_FOREGROUND_GDK_SET: - tkxt_tag->fg_color_set = GTK_VALUE_BOOL (*arg); + text_tag->fg_color_set = GTK_VALUE_BOOL (*arg); break; case ARG_BACKGROUND_STIPPLE_SET: - tkxt_tag->bg_stipple_set = GTK_VALUE_BOOL (*arg); + text_tag->bg_stipple_set = GTK_VALUE_BOOL (*arg); break; case ARG_FOREGROUND_STIPPLE_SET: - tkxt_tag->fg_stipple_set = GTK_VALUE_BOOL (*arg); + text_tag->fg_stipple_set = GTK_VALUE_BOOL (*arg); break; case ARG_FONT_SET: - tkxt_tag->font_set = GTK_VALUE_BOOL (*arg); + text_tag->font_set = GTK_VALUE_BOOL (*arg); size_changed = TRUE; break; case ARG_PIXELS_ABOVE_LINES_SET: - tkxt_tag->pixels_above_lines_set = GTK_VALUE_BOOL (*arg); + text_tag->pixels_above_lines_set = GTK_VALUE_BOOL (*arg); size_changed = TRUE; break; case ARG_PIXELS_BELOW_LINES_SET: - tkxt_tag->pixels_below_lines_set = GTK_VALUE_BOOL (*arg); + text_tag->pixels_below_lines_set = GTK_VALUE_BOOL (*arg); size_changed = TRUE; break; case ARG_PIXELS_INSIDE_WRAP_SET: - tkxt_tag->pixels_inside_wrap_set = GTK_VALUE_BOOL (*arg); + text_tag->pixels_inside_wrap_set = GTK_VALUE_BOOL (*arg); size_changed = TRUE; break; case ARG_EDITABLE_SET: - tkxt_tag->editable_set = GTK_VALUE_BOOL (*arg); + text_tag->editable_set = GTK_VALUE_BOOL (*arg); break; case ARG_WRAP_MODE_SET: - tkxt_tag->wrap_mode_set = GTK_VALUE_BOOL (*arg); + text_tag->wrap_mode_set = GTK_VALUE_BOOL (*arg); size_changed = TRUE; break; case ARG_JUSTIFY_SET: - tkxt_tag->justify_set = GTK_VALUE_BOOL (*arg); + text_tag->justify_set = GTK_VALUE_BOOL (*arg); size_changed = TRUE; break; case ARG_LEFT_MARGIN_SET: - tkxt_tag->left_margin_set = GTK_VALUE_BOOL (*arg); + text_tag->left_margin_set = GTK_VALUE_BOOL (*arg); size_changed = TRUE; break; case ARG_LEFT_WRAPPED_LINE_MARGIN_SET: - tkxt_tag->left_wrapped_line_margin_set = GTK_VALUE_BOOL (*arg); + text_tag->left_wrapped_line_margin_set = GTK_VALUE_BOOL (*arg); size_changed = TRUE; break; case ARG_STRIKETHROUGH_SET: - tkxt_tag->strikethrough_set = GTK_VALUE_BOOL (*arg); + text_tag->strikethrough_set = GTK_VALUE_BOOL (*arg); break; case ARG_RIGHT_MARGIN_SET: - tkxt_tag->right_margin_set = GTK_VALUE_BOOL (*arg); + text_tag->right_margin_set = GTK_VALUE_BOOL (*arg); size_changed = TRUE; break; case ARG_UNDERLINE_SET: - tkxt_tag->underline_set = GTK_VALUE_BOOL (*arg); + text_tag->underline_set = GTK_VALUE_BOOL (*arg); break; case ARG_OFFSET_SET: - tkxt_tag->offset_set = GTK_VALUE_BOOL (*arg); + text_tag->offset_set = GTK_VALUE_BOOL (*arg); size_changed = TRUE; break; case ARG_BG_FULL_HEIGHT_SET: - tkxt_tag->bg_full_height_set = GTK_VALUE_BOOL (*arg); + text_tag->bg_full_height_set = GTK_VALUE_BOOL (*arg); break; case ARG_LANGUAGE_SET: - tkxt_tag->language_set = GTK_VALUE_BOOL (*arg); + text_tag->language_set = GTK_VALUE_BOOL (*arg); size_changed = TRUE; break; case ARG_TABS_SET: - tkxt_tag->tabs_set = GTK_VALUE_BOOL (*arg); + text_tag->tabs_set = GTK_VALUE_BOOL (*arg); size_changed = TRUE; break; @@ -711,10 +720,10 @@ gtk_text_tag_set_arg (GtkObject *object, GtkArg *arg, guint arg_id) /* This is also somewhat weird since we emit another object's signal here, but the two objects are already tightly bound. */ - if (tkxt_tag->table) - gtk_signal_emit_by_name (GTK_OBJECT (tkxt_tag->table), + if (text_tag->table) + gtk_signal_emit_by_name (GTK_OBJECT (text_tag->table), "tag_changed", - tkxt_tag, size_changed); + text_tag, size_changed); } static void @@ -942,6 +951,14 @@ delta_priority_foreach (GtkTextTag *tag, gpointer user_data) tag->priority += dd->delta; } +/** + * gtk_text_tag_get_priority: + * @tag: a #GtkTextTag + * + * Get the tag priority. + * + * Return value: The tag's priority. + **/ gint gtk_text_tag_get_priority (GtkTextTag *tag) { @@ -950,6 +967,23 @@ gtk_text_tag_get_priority (GtkTextTag *tag) return tag->priority; } +/** + * gtk_text_tag_set_priority: + * @tag: a #GtkTextTag + * @priority: the new priority + * + * Sets the priority of a #GtkTextTag. Valid priorities are + * start at 0 and go to one less than gtk_text_tag_table_size(). + * Each tag in a table has a unique priority; setting the priority + * of one tag shifts the priorities of all the other tags in the + * table to maintain a unique priority for each tag. Higher priority + * tags "win" if two tags both set the same text attribute. When adding + * a tag to a tag table, it will be assigned the highest priority in + * the table by default; so normally the precedence of a set of tags + * is the order in which they were added to the table, or created with + * gtk_text_buffer_create_tag(), which adds the tag to the buffer's table + * automatically. + **/ void gtk_text_tag_set_priority (GtkTextTag *tag, gint priority) @@ -984,10 +1018,21 @@ gtk_text_tag_set_priority (GtkTextTag *tag, tag->priority = priority; } +/** + * gtk_text_tag_event: + * @tag: a #GtkTextTag + * @event_object: object that received the event, such as a widget + * @event: the event + * @iter: location where the event was received + * + * Emits the "event" signal on the #GtkTextTag. + * + * Return value: result of signal emission (whether the event was handled) + **/ gint -gtk_text_tag_event (GtkTextTag *tag, - GtkObject *event_object, - GdkEvent *event, +gtk_text_tag_event (GtkTextTag *tag, + GObject *event_object, + GdkEvent *event, const GtkTextIter *iter) { gint retval = FALSE; @@ -1070,6 +1115,14 @@ gtk_text_tag_array_sort (GtkTextTag** tag_array_p, * Attributes */ +/** + * gtk_text_attributes_new: + * + * Creates a #GtkTextAttributes, which describes + * a set of properties on some text. + * + * Return value: a new #GtkTextAttributes + **/ GtkTextAttributes* gtk_text_attributes_new (void) { @@ -1086,6 +1139,7 @@ gtk_text_attributes_new (void) return values; } +/* FIXME change the signature of this to be correct */ void gtk_text_attributes_copy (GtkTextAttributes *src, GtkTextAttributes *dest) diff --git a/gtk/gtktexttag.h b/gtk/gtktexttag.h index f0d6d68604..5527ea7b06 100644 --- a/gtk/gtktexttag.h +++ b/gtk/gtktexttag.h @@ -88,7 +88,7 @@ struct _GtkTextTagClass { GtkObjectClass parent_class; gint (* event) (GtkTextTag *tag, - GtkObject *event_object, /* widget, canvas item, whatever */ + GObject *event_object, /* widget, canvas item, whatever */ GdkEvent *event, /* the event itself */ const GtkTextIter *iter); /* location of event in buffer */ }; @@ -99,7 +99,7 @@ gint gtk_text_tag_get_priority (GtkTextTag *tag); void gtk_text_tag_set_priority (GtkTextTag *tag, gint priority); gint gtk_text_tag_event (GtkTextTag *tag, - GtkObject *event_object, + GObject *event_object, GdkEvent *event, const GtkTextIter *iter); @@ -190,6 +190,7 @@ struct _GtkTextAttributes guint pad4 : 1; }; +/* FIXME _copy() has the wrong signature */ GtkTextAttributes *gtk_text_attributes_new (void); void gtk_text_attributes_copy (GtkTextAttributes *src, GtkTextAttributes *dest); diff --git a/gtk/gtktexttagtable.c b/gtk/gtktexttagtable.c index 8122bd4885..1e60c2f861 100644 --- a/gtk/gtktexttagtable.c +++ b/gtk/gtktexttagtable.c @@ -105,6 +105,13 @@ gtk_text_tag_table_init (GtkTextTagTable *table) table->hash = g_hash_table_new (g_str_hash, g_str_equal); } +/** + * gtk_text_tag_table_new: + * Creates a new #GtkTextTagTable. The table contains no tags by + * default. + * + * Return value: a new #GtkTextTagTable + **/ GtkTextTagTable* gtk_text_tag_table_new (void) { @@ -183,8 +190,18 @@ gtk_text_tag_table_get_arg (GtkObject *object, GtkArg *arg, guint arg_id) } } +/** + * gtk_text_tag_table_add: + * @table: a #GtkTextTagTable + * @tag: a #GtkTextTag + * + * Add a tag to the table. The tag is assigned the highest priority + * in the table. + * + **/ void -gtk_text_tag_table_add (GtkTextTagTable *table, GtkTextTag *tag) +gtk_text_tag_table_add (GtkTextTagTable *table, + GtkTextTag *tag) { guint size; @@ -217,8 +234,18 @@ gtk_text_tag_table_add (GtkTextTagTable *table, GtkTextTag *tag) gtk_signal_emit (GTK_OBJECT (table), signals[TAG_ADDED], tag); } +/** + * gtk_text_tag_table_lookup: + * @table: a #GtkTextTagTable + * @name: name of a tag + * + * Look up a named tag. + * + * Return value: The tag, or %NULL if none by that name is in the table. + **/ GtkTextTag* -gtk_text_tag_table_lookup (GtkTextTagTable *table, const gchar *name) +gtk_text_tag_table_lookup (GtkTextTagTable *table, + const gchar *name) { g_return_val_if_fail (GTK_IS_TEXT_TAG_TABLE (table), NULL); g_return_val_if_fail (name != NULL, NULL); @@ -226,8 +253,18 @@ gtk_text_tag_table_lookup (GtkTextTagTable *table, const gchar *name) return g_hash_table_lookup (table->hash, name); } +/** + * gtk_text_tag_table_remove: + * @table: a #GtkTextTagTable + * @tag: a #GtkTextTag + * + * Remove a tag from the table. This will remove the table's + * reference to the tag, so be careful - the tag will end + * up destroyed if you don't have a reference to it. + **/ void -gtk_text_tag_table_remove (GtkTextTagTable *table, GtkTextTag *tag) +gtk_text_tag_table_remove (GtkTextTagTable *table, + GtkTextTag *tag) { g_return_if_fail (GTK_IS_TEXT_TAG_TABLE (table)); g_return_if_fail (GTK_IS_TEXT_TAG (tag)); @@ -279,6 +316,15 @@ list_foreach (gpointer data, gpointer user_data) (* fd->func) (data, fd->data); } +/** + * gtk_text_tag_table_foreach: + * @table: a #GtkTextTagTable + * @func: a function to call on each tag + * @data: user data + * + * Calls @func on each tag in @table, with user data @data. + * + **/ void gtk_text_tag_table_foreach (GtkTextTagTable *table, GtkTextTagTableForeach func, @@ -296,7 +342,15 @@ gtk_text_tag_table_foreach (GtkTextTagTable *table, g_slist_foreach (table->anonymous, list_foreach, &d); } -guint +/** + * gtk_text_tag_table_size: + * @table: a #GtkTextTagTable + * + * Returns the size of the table (number of tags) + * + * Return value: number of tags in @table + **/ +gint gtk_text_tag_table_size (GtkTextTagTable *table) { g_return_val_if_fail (GTK_IS_TEXT_TAG_TABLE (table), 0); diff --git a/gtk/gtktexttagtable.h b/gtk/gtktexttagtable.h index d9f60a37a9..3ab529faff 100644 --- a/gtk/gtktexttagtable.h +++ b/gtk/gtktexttagtable.h @@ -48,7 +48,7 @@ GtkTextTag *gtk_text_tag_table_lookup (GtkTextTagTable *table, void gtk_text_tag_table_foreach (GtkTextTagTable *table, GtkTextTagTableForeach func, gpointer data); -guint gtk_text_tag_table_size (GtkTextTagTable *table); +gint gtk_text_tag_table_size (GtkTextTagTable *table); #ifdef __cplusplus diff --git a/gtk/gtktextview.c b/gtk/gtktextview.c index db43d8d36b..11ecf86d26 100644 --- a/gtk/gtktextview.c +++ b/gtk/gtktextview.c @@ -21,7 +21,7 @@ * Modified by the GTK+ Team and others 1997-2000. See the AUTHORS * file for a list of people on the GTK+ Team. See the ChangeLog * files for a list of changes. These files are distributed with - * GTK+ at ftp://ftp.gtk.org/pub/gtk/. + * GTK+ at ftp://ftp.gtk.org/pub/gtk/. */ #include @@ -689,12 +689,34 @@ gtk_text_view_init (GtkTextView *text_view) text_view->drag_start_y = -1; } +/** + * gtk_text_view_new: + * Creates a new #GtkTextView. If you don't call gtk_text_view_set_buffer() + * before using the text view, an empty default buffer will be created + * for you. Get the buffer with gtk_text_view_get_buffer(). If you want + * to specify your own buffer, consider gtk_text_view_new_with_buffer(). + * + * Return value: a new #GtkTextView + **/ GtkWidget* gtk_text_view_new (void) { return GTK_WIDGET (gtk_type_new (gtk_text_view_get_type ())); } +/** + * gtk_text_view_new_with_buffer: + * @buffer: a #GtkTextBuffer + * + * Creates a new #GtkTextView widget displaying the buffer + * @buffer. One buffer can be shared among many widgets. + * @buffer may be NULL to create a default buffer, in which case + * this function is equivalent to gtk_text_view_new(). The + * text view adds its own reference count to the buffer; it does not + * take over an existing reference. + * + * Return value: a new #GtkTextView. + **/ GtkWidget* gtk_text_view_new_with_buffer (GtkTextBuffer *buffer) { @@ -707,6 +729,18 @@ gtk_text_view_new_with_buffer (GtkTextBuffer *buffer) return GTK_WIDGET (text_view); } +/** + * gtk_text_view_set_buffer: + * @text_view: a #GtkTextView + * @buffer: a #GtkTextBuffer + * + * Sets @buffer as the buffer being displayed by @text_view. The previous + * buffer displayed by the text view is unreferenced, and a reference is + * added to @buffer. If you owned a reference to @buffer before passing it + * to this function, you must remove that reference yourself; #GtkTextView + * will not "adopt" it. + * + **/ void gtk_text_view_set_buffer (GtkTextView *text_view, GtkTextBuffer *buffer) @@ -778,18 +812,57 @@ gtk_text_view_set_buffer (GtkTextView *text_view, gtk_widget_queue_draw (GTK_WIDGET (text_view)); } +static GtkTextBuffer* +get_buffer (GtkTextView *text_view) +{ + if (text_view->buffer == NULL) + { + GtkTextBuffer *b; + b = gtk_text_buffer_new (NULL); + gtk_text_view_set_buffer (text_view, b); + g_object_unref (G_OBJECT (b)); + } + + return text_view->buffer; +} + +/** + * gtk_text_view_get_buffer: + * @text_view: a #GtkTextView + * + * Returns the #GtkTextBuffer being displayed by this text view. + * The reference count on the buffer is not incremented; the caller + * of this function won't own a new reference. + * + * Return value: a #GtkTextBuffer + **/ GtkTextBuffer* gtk_text_view_get_buffer (GtkTextView *text_view) { g_return_val_if_fail (GTK_IS_TEXT_VIEW (text_view), NULL); - return text_view->buffer; + return get_buffer (text_view); } +/** + * gtk_text_view_get_iter_at_location: + * @text_view: a #GtkTextView + * @iter: a #GtkTextIter + * @x: x position, in buffer coordinates + * @y: y position, in buffer coordinates + * + * Retrieves the iterator at buffer coordinates @x and @y. Buffer + * coordinates are coordinates for the entire buffer, not just the + * currently-displayed portion. If you have coordinates from an + * event, you have to convert those to buffer coordinates with + * gtk_text_view_window_to_buffer_coords(). + * + **/ void gtk_text_view_get_iter_at_location (GtkTextView *text_view, GtkTextIter *iter, - gint x, gint y) + gint x, + gint y) { g_return_if_fail (GTK_IS_TEXT_VIEW (text_view)); g_return_if_fail (iter != NULL); @@ -801,17 +874,41 @@ gtk_text_view_get_iter_at_location (GtkTextView *text_view, y); } +/** + * gtk_text_view_get_iter_location: + * @text_view: a #GtkTextView + * @iter: a #GtkTextIter + * @location: bounds of the character at @iter + * + * Returns a rectangle which roughly contains the character at @iter. + * The rectangle position is in buffer coordinates; use + * gtk_text_view_buffer_to_window_coords() to convert these + * coordinates to coordinates for one of the windows in the text view. + * + **/ void gtk_text_view_get_iter_location (GtkTextView *text_view, const GtkTextIter *iter, GdkRectangle *location) { g_return_if_fail (GTK_IS_TEXT_VIEW (text_view)); - g_return_if_fail (gtk_text_iter_get_buffer (iter) == text_view->buffer); + g_return_if_fail (gtk_text_iter_get_buffer (iter) == get_buffer (text_view)); gtk_text_layout_get_iter_location (text_view->layout, iter, location); } +/** + * gtk_text_view_get_line_yrange: + * @text_view: a #GtkTextView + * @iter: a #GtkTextIter + * @y: return location for a y coordinate + * @height: return location for a height + * + * Returns the y coordinate of the top of the line containing @iter, + * and the height of the line. The coordinate is a buffer coordinate; + * convert to window coordinates with gtk_text_view_buffer_to_window_coords(). + * + **/ void gtk_text_view_get_line_yrange (GtkTextView *text_view, const GtkTextIter *iter, @@ -819,7 +916,7 @@ gtk_text_view_get_line_yrange (GtkTextView *text_view, gint *height) { g_return_if_fail (GTK_IS_TEXT_VIEW (text_view)); - g_return_if_fail (gtk_text_iter_get_buffer (iter) == text_view->buffer); + g_return_if_fail (gtk_text_iter_get_buffer (iter) == get_buffer (text_view)); gtk_text_layout_get_line_yrange (text_view->layout, iter, @@ -827,6 +924,19 @@ gtk_text_view_get_line_yrange (GtkTextView *text_view, height); } +/** + * gtk_text_view_get_line_at_y: + * @text_view: a #GtkTextView + * @target_iter: a #GtkTextIter + * @y: a y coordinate + * @line_top: return location for top coordinate of the line + * + * Returns the #GtkTextIter at the start of the line containing + * the coordinate @y. @y is in buffer coordinates, convert from + * window coordinates with gtk_text_view_window_to_buffer_coords(). + * If non-%NULL, @line_top will be filled with the coordinate of the top + * edge of the line. + **/ void gtk_text_view_get_line_at_y (GtkTextView *text_view, GtkTextIter *target_iter, @@ -884,7 +994,7 @@ gtk_text_view_scroll_to_mark_adjusted (GtkTextView *text_view, return FALSE; } - gtk_text_buffer_get_iter_at_mark (text_view->buffer, &iter, mark); + gtk_text_buffer_get_iter_at_mark (get_buffer (text_view), &iter, mark); gtk_text_layout_get_iter_location (text_view->layout, &iter, @@ -979,6 +1089,20 @@ gtk_text_view_scroll_to_mark_adjusted (GtkTextView *text_view, return retval; } +/** + * gtk_text_view_scroll_to_mark: + * @text_view: a #GtkTextView + * @mark: a #GtkTextMark + * @mark_within_margin: a margin + * + * Scrolls @text_view so that @mark is on the screen. If + * @mark_within_margin is nonzero, the mark will be moved onscreen by + * that many pixels. For example, if @mark_within_margin is 5, the + * mark will be at least 5 pixels away from the edge of the screen, + * if possible. + * + * Return value: TRUE if scrolling occurred + **/ gboolean gtk_text_view_scroll_to_mark (GtkTextView *text_view, GtkTextMark *mark, @@ -1001,6 +1125,16 @@ clamp_iter_onscreen (GtkTextView *text_view, GtkTextIter *iter) visible_rect.y + visible_rect.height); } +/** + * gtk_text_view_move_mark_onscreen: + * @text_view: a #GtkTextView + * @mark: a #GtkTextMark + * + * Moves a mark within the buffer so that it's + * located within the currently-visible text area. + * + * Return value: %TRUE if scrolling occurred + **/ gboolean gtk_text_view_move_mark_onscreen (GtkTextView *text_view, GtkTextMark *mark) @@ -1010,17 +1144,26 @@ gtk_text_view_move_mark_onscreen (GtkTextView *text_view, g_return_val_if_fail (GTK_IS_TEXT_VIEW (text_view), FALSE); g_return_val_if_fail (mark != NULL, FALSE); - gtk_text_buffer_get_iter_at_mark (text_view->buffer, &iter, mark); + gtk_text_buffer_get_iter_at_mark (get_buffer (text_view), &iter, mark); if (clamp_iter_onscreen (text_view, &iter)) { - gtk_text_buffer_move_mark (text_view->buffer, mark, &iter); + gtk_text_buffer_move_mark (get_buffer (text_view), mark, &iter); return TRUE; } else return FALSE; } +/** + * gtk_text_view_get_visible_rect: + * @text_view: a #GtkTextView + * @visible_rect: rectangle to fill + * + * Fills @visible_rect with the currently-visible + * region of the buffer, in buffer coordinates. Convert to window coordinates + * with gtk_text_view_buffer_to_window_coords(). + **/ void gtk_text_view_get_visible_rect (GtkTextView *text_view, GdkRectangle *visible_rect) @@ -1041,6 +1184,13 @@ gtk_text_view_get_visible_rect (GtkTextView *text_view, } } +/** + * gtk_text_view_set_wrap_mode: + * @text_view: a #GtkTextView + * @wrap_mode: a #GtkWrapMode + * + * Sets the line wrapping for the view. + **/ void gtk_text_view_set_wrap_mode (GtkTextView *text_view, GtkWrapMode wrap_mode) @@ -1060,6 +1210,14 @@ gtk_text_view_set_wrap_mode (GtkTextView *text_view, } } +/** + * gtk_text_view_get_wrap_mode: + * @text_view: a #GtkTextView + * + * Gets the line wrapping for the view. + * + * Return value: the line wrap setting + **/ GtkWrapMode gtk_text_view_get_wrap_mode (GtkTextView *text_view) { @@ -1069,6 +1227,15 @@ gtk_text_view_get_wrap_mode (GtkTextView *text_view) return text_view->wrap_mode; } +/** + * gtk_text_view_set_editable: + * @text_view: a #GtkTextView + * @setting: whether it's editable + * + * Sets the default editability of the #GtkTextView. You can override + * this default setting with tags in the buffer, using the "editable" + * attribute of tags. + **/ void gtk_text_view_set_editable (GtkTextView *text_view, gboolean setting) @@ -1087,6 +1254,15 @@ gtk_text_view_set_editable (GtkTextView *text_view, } } +/** + * gtk_text_view_get_editable: + * @text_view: a #GtkTextView + * + * Returns the default editability of the #GtkTextView. Tags in the + * buffer may override this setting for some ranges of text. + * + * Return value: whether text is editable by default + **/ gboolean gtk_text_view_get_editable (GtkTextView *text_view) { @@ -1095,6 +1271,15 @@ gtk_text_view_get_editable (GtkTextView *text_view) return text_view->editable; } +/** + * gtk_text_view_set_cursor_visible: + * @text_view: a #GtkTextView + * @setting: whether to show the insertion cursor + * + * Toggles whether the insertion point is displayed. A buffer with no editable + * text probably shouldn't have a visible cursor, so you may want to turn + * the cursor off. + **/ void gtk_text_view_set_cursor_visible (GtkTextView *text_view, gboolean setting) @@ -1122,6 +1307,14 @@ gtk_text_view_set_cursor_visible (GtkTextView *text_view, } } +/** + * gtk_text_view_get_cursor_visible: + * @text_view: a #GtkTextView + * + * Find out whether the cursor is being displayed. + * + * Return value: whether the insertion mark is visible + **/ gboolean gtk_text_view_get_cursor_visible (GtkTextView *text_view) { @@ -1131,6 +1324,15 @@ gtk_text_view_get_cursor_visible (GtkTextView *text_view) } +/** + * gtk_text_view_place_cursor_onscreen: + * @text_view: a #GtkTextView + * + * Moves the cursor to the currently visible region of the + * buffer, it it isn't there already. + * + * Return value: TRUE if the cursor had to be moved. + **/ gboolean gtk_text_view_place_cursor_onscreen (GtkTextView *text_view) { @@ -1138,13 +1340,13 @@ gtk_text_view_place_cursor_onscreen (GtkTextView *text_view) g_return_val_if_fail (GTK_IS_TEXT_VIEW (text_view), FALSE); - gtk_text_buffer_get_iter_at_mark (text_view->buffer, &insert, - gtk_text_buffer_get_mark (text_view->buffer, + gtk_text_buffer_get_iter_at_mark (get_buffer (text_view), &insert, + gtk_text_buffer_get_mark (get_buffer (text_view), "insert")); if (clamp_iter_onscreen (text_view, &insert)) { - gtk_text_buffer_place_cursor (text_view->buffer, &insert); + gtk_text_buffer_place_cursor (get_buffer (text_view), &insert); return TRUE; } else @@ -1171,6 +1373,8 @@ gtk_text_view_finalize (GObject *object) text_view = GTK_TEXT_VIEW (object); + g_return_if_fail (text_view->buffer == NULL); + if (text_view->hadjustment) gtk_object_unref (GTK_OBJECT (text_view->hadjustment)); if (text_view->vadjustment) @@ -1338,7 +1542,7 @@ gtk_text_view_allocate_children (GtkTextView *text_view) * children. */ GtkTextIter child_loc; - gtk_text_buffer_get_iter_at_child_anchor (text_view->buffer, + gtk_text_buffer_get_iter_at_child_anchor (get_buffer (text_view), &child_loc, child->anchor); @@ -1518,7 +1722,7 @@ static void gtk_text_view_get_first_para_iter (GtkTextView *text_view, GtkTextIter *iter) { - gtk_text_buffer_get_iter_at_mark (text_view->buffer, iter, + gtk_text_buffer_get_iter_at_mark (get_buffer (text_view), iter, text_view->first_para_mark); } @@ -1835,7 +2039,7 @@ emit_event_on_tags (GtkWidget *widget, text_view = GTK_TEXT_VIEW (widget); - tags = gtk_text_buffer_get_tags (text_view->buffer, iter); + tags = gtk_text_buffer_get_tags (get_buffer (text_view), iter); tmp = tags; while (tmp != NULL) @@ -1865,7 +2069,7 @@ gtk_text_view_event (GtkWidget *widget, GdkEvent *event) text_view = GTK_TEXT_VIEW (widget); if (text_view->layout == NULL || - text_view->buffer == NULL) + get_buffer (text_view) == NULL) return FALSE; if (event->any.window != text_view->text_window->bin_window) @@ -1893,10 +2097,10 @@ gtk_text_view_event (GtkWidget *widget, GdkEvent *event) GtkTextMark *insert; GtkTextIter iter; - insert = gtk_text_buffer_get_mark (text_view->buffer, + insert = gtk_text_buffer_get_mark (get_buffer (text_view), "insert"); - gtk_text_buffer_get_iter_at_mark (text_view->buffer, &iter, insert); + gtk_text_buffer_get_iter_at_mark (get_buffer (text_view), &iter, insert); return emit_event_on_tags (widget, event, &iter); } @@ -1912,7 +2116,7 @@ gtk_text_view_key_press_event (GtkWidget *widget, GdkEventKey *event) text_view = GTK_TEXT_VIEW (widget); if (text_view->layout == NULL || - text_view->buffer == NULL) + get_buffer (text_view) == NULL) return FALSE; if (GTK_WIDGET_CLASS (parent_class)->key_press_event && @@ -1926,10 +2130,10 @@ gtk_text_view_key_press_event (GtkWidget *widget, GdkEventKey *event) return TRUE; else if (event->keyval == GDK_Return) { - gtk_text_buffer_insert_interactive_at_cursor (text_view->buffer, "\n", 1, + gtk_text_buffer_insert_interactive_at_cursor (get_buffer (text_view), "\n", 1, text_view->editable); gtk_text_view_scroll_to_mark (text_view, - gtk_text_buffer_get_mark (text_view->buffer, + gtk_text_buffer_get_mark (get_buffer (text_view), "insert"), 0); return TRUE; @@ -1937,10 +2141,10 @@ gtk_text_view_key_press_event (GtkWidget *widget, GdkEventKey *event) /* Pass through Tab as literal tab, unless Control is held down */ else if (event->keyval == GDK_Tab && !(event->state & GDK_CONTROL_MASK)) { - gtk_text_buffer_insert_interactive_at_cursor (text_view->buffer, "\t", 1, + gtk_text_buffer_insert_interactive_at_cursor (get_buffer (text_view), "\t", 1, text_view->editable); gtk_text_view_scroll_to_mark (text_view, - gtk_text_buffer_get_mark (text_view->buffer, + gtk_text_buffer_get_mark (get_buffer (text_view), "insert"), 0); return TRUE; @@ -1992,7 +2196,7 @@ gtk_text_view_button_press_event (GtkWidget *widget, GdkEventButton *event) event->x + text_view->xoffset, event->y + text_view->yoffset); - if (gtk_text_buffer_get_selection_bounds (text_view->buffer, + if (gtk_text_buffer_get_selection_bounds (get_buffer (text_view), &start, &end) && gtk_text_iter_in_range (&iter, &start, &end)) { @@ -2015,7 +2219,7 @@ gtk_text_view_button_press_event (GtkWidget *widget, GdkEventButton *event) event->x + text_view->xoffset, event->y + text_view->yoffset); - gtk_text_buffer_paste_primary (text_view->buffer, + gtk_text_buffer_paste_primary (get_buffer (text_view), &iter, text_view->editable); return TRUE; @@ -2440,8 +2644,8 @@ gtk_text_view_move_cursor (GtkTextView *text_view, return; } - gtk_text_buffer_get_iter_at_mark (text_view->buffer, &insert, - gtk_text_buffer_get_mark (text_view->buffer, + gtk_text_buffer_get_iter_at_mark (get_buffer (text_view), &insert, + gtk_text_buffer_get_mark (get_buffer (text_view), "insert")); newplace = insert; @@ -2496,9 +2700,9 @@ gtk_text_view_move_cursor (GtkTextView *text_view, case GTK_MOVEMENT_BUFFER_ENDS: if (count > 0) - gtk_text_buffer_get_last_iter (text_view->buffer, &newplace); + gtk_text_buffer_get_last_iter (get_buffer (text_view), &newplace); else if (count < 0) - gtk_text_buffer_get_iter_at_offset (text_view->buffer, &newplace, 0); + gtk_text_buffer_get_iter_at_offset (get_buffer (text_view), &newplace, 0); break; default: @@ -2508,15 +2712,15 @@ gtk_text_view_move_cursor (GtkTextView *text_view, if (!gtk_text_iter_equal (&insert, &newplace)) { if (extend_selection) - gtk_text_buffer_move_mark (text_view->buffer, - gtk_text_buffer_get_mark (text_view->buffer, + gtk_text_buffer_move_mark (get_buffer (text_view), + gtk_text_buffer_get_mark (get_buffer (text_view), "insert"), &newplace); else - gtk_text_buffer_place_cursor (text_view->buffer, &newplace); + gtk_text_buffer_place_cursor (get_buffer (text_view), &newplace); gtk_text_view_scroll_to_mark (text_view, - gtk_text_buffer_get_mark (text_view->buffer, + gtk_text_buffer_get_mark (get_buffer (text_view), "insert"), 0); if (step == GTK_MOVEMENT_DISPLAY_LINES) @@ -2531,11 +2735,11 @@ gtk_text_view_set_anchor (GtkTextView *text_view) { GtkTextIter insert; - gtk_text_buffer_get_iter_at_mark (text_view->buffer, &insert, - gtk_text_buffer_get_mark (text_view->buffer, + gtk_text_buffer_get_iter_at_mark (get_buffer (text_view), &insert, + gtk_text_buffer_get_mark (get_buffer (text_view), "insert")); - gtk_text_buffer_create_mark (text_view->buffer, "anchor", &insert, TRUE); + gtk_text_buffer_create_mark (get_buffer (text_view), "anchor", &insert, TRUE); } static void @@ -2581,7 +2785,7 @@ gtk_text_view_scroll_pages (GtkTextView *text_view, gtk_text_layout_get_iter_at_pixel (text_view->layout, &new_insert, cursor_x_pos, cursor_y_pos); clamp_iter_onscreen (text_view, &new_insert); - gtk_text_buffer_place_cursor (text_view->buffer, &new_insert); + gtk_text_buffer_place_cursor (get_buffer (text_view), &new_insert); gtk_text_view_set_virtual_cursor_pos (text_view, cursor_x_pos, cursor_y_pos); @@ -2589,7 +2793,7 @@ gtk_text_view_scroll_pages (GtkTextView *text_view, * only guarantees 1 pixel onscreen. */ gtk_text_view_scroll_to_mark (text_view, - gtk_text_buffer_get_mark (text_view->buffer, + gtk_text_buffer_get_mark (get_buffer (text_view), "insert"), 0); } @@ -2625,7 +2829,7 @@ static void gtk_text_view_insert_at_cursor (GtkTextView *text_view, const gchar *str) { - gtk_text_buffer_insert_interactive_at_cursor (text_view->buffer, str, -1, + gtk_text_buffer_insert_interactive_at_cursor (get_buffer (text_view), str, -1, text_view->editable); } @@ -2642,14 +2846,14 @@ gtk_text_view_delete_from_cursor (GtkTextView *text_view, if (type == GTK_DELETE_CHARS) { /* Char delete deletes the selection, if one exists */ - if (gtk_text_buffer_delete_selection (text_view->buffer, TRUE, + if (gtk_text_buffer_delete_selection (get_buffer (text_view), TRUE, text_view->editable)) return; } - gtk_text_buffer_get_iter_at_mark (text_view->buffer, + gtk_text_buffer_get_iter_at_mark (get_buffer (text_view), &insert, - gtk_text_buffer_get_mark (text_view->buffer, + gtk_text_buffer_get_mark (get_buffer (text_view), "insert")); start = insert; @@ -2731,17 +2935,17 @@ gtk_text_view_delete_from_cursor (GtkTextView *text_view, if (!gtk_text_iter_equal (&start, &end)) { - if (gtk_text_buffer_delete_interactive (text_view->buffer, &start, &end, + if (gtk_text_buffer_delete_interactive (get_buffer (text_view), &start, &end, text_view->editable)) { if (leave_one) - gtk_text_buffer_insert_interactive_at_cursor (text_view->buffer, + gtk_text_buffer_insert_interactive_at_cursor (get_buffer (text_view), " ", 1, text_view->editable); } gtk_text_view_scroll_to_mark (text_view, - gtk_text_buffer_get_mark (text_view->buffer, "insert"), + gtk_text_buffer_get_mark (get_buffer (text_view), "insert"), 0); } } @@ -2749,9 +2953,9 @@ gtk_text_view_delete_from_cursor (GtkTextView *text_view, static void gtk_text_view_cut_clipboard (GtkTextView *text_view) { - gtk_text_buffer_cut_clipboard (text_view->buffer, text_view->editable); + gtk_text_buffer_cut_clipboard (get_buffer (text_view), text_view->editable); gtk_text_view_scroll_to_mark (text_view, - gtk_text_buffer_get_mark (text_view->buffer, + gtk_text_buffer_get_mark (get_buffer (text_view), "insert"), 0); } @@ -2759,9 +2963,9 @@ gtk_text_view_cut_clipboard (GtkTextView *text_view) static void gtk_text_view_copy_clipboard (GtkTextView *text_view) { - gtk_text_buffer_copy_clipboard (text_view->buffer); + gtk_text_buffer_copy_clipboard (get_buffer (text_view)); gtk_text_view_scroll_to_mark (text_view, - gtk_text_buffer_get_mark (text_view->buffer, + gtk_text_buffer_get_mark (get_buffer (text_view), "insert"), 0); } @@ -2769,9 +2973,9 @@ gtk_text_view_copy_clipboard (GtkTextView *text_view) static void gtk_text_view_paste_clipboard (GtkTextView *text_view) { - gtk_text_buffer_paste_clipboard (text_view->buffer, text_view->editable); + gtk_text_buffer_paste_clipboard (get_buffer (text_view), text_view->editable); gtk_text_view_scroll_to_mark (text_view, - gtk_text_buffer_get_mark (text_view->buffer, + gtk_text_buffer_get_mark (get_buffer (text_view), "insert"), 0); } @@ -2791,13 +2995,13 @@ gtk_text_view_unselect (GtkTextView *text_view) { GtkTextIter insert; - gtk_text_buffer_get_iter_at_mark (text_view->buffer, + gtk_text_buffer_get_iter_at_mark (get_buffer (text_view), &insert, - gtk_text_buffer_get_mark (text_view->buffer, + gtk_text_buffer_get_mark (get_buffer (text_view), "insert")); - gtk_text_buffer_move_mark (text_view->buffer, - gtk_text_buffer_get_mark (text_view->buffer, + gtk_text_buffer_move_mark (get_buffer (text_view), + gtk_text_buffer_get_mark (get_buffer (text_view), "selection_bound"), &insert); } @@ -2848,9 +3052,9 @@ move_insert_to_pointer_and_scroll (GtkTextView *text_view, gboolean partial_scro { gboolean scrolled = FALSE; GtkTextMark *insert_mark = - gtk_text_buffer_get_mark (text_view->buffer, "insert"); + gtk_text_buffer_get_mark (get_buffer (text_view), "insert"); - gtk_text_buffer_move_mark (text_view->buffer, + gtk_text_buffer_move_mark (get_buffer (text_view), insert_mark, &newplace); @@ -2940,7 +3144,7 @@ gtk_text_view_start_selection_drag (GtkTextView *text_view, newplace = *iter; - gtk_text_buffer_place_cursor (text_view->buffer, &newplace); + gtk_text_buffer_place_cursor (get_buffer (text_view), &newplace); text_view->selection_drag_handler = gtk_signal_connect (GTK_OBJECT (text_view), "motion_notify_event", @@ -3095,8 +3299,8 @@ gtk_text_view_ensure_layout (GtkTextView *text_view) GTK_SIGNAL_FUNC (changed_handler), text_view); - if (text_view->buffer) - gtk_text_layout_set_buffer (text_view->layout, text_view->buffer); + if (get_buffer (text_view)) + gtk_text_layout_set_buffer (text_view->layout, get_buffer (text_view)); if ((GTK_WIDGET_HAS_FOCUS (text_view) && text_view->cursor_visible)) gtk_text_view_start_cursor_blink (text_view); @@ -3219,7 +3423,7 @@ gtk_text_view_drag_data_get (GtkWidget *widget, str = NULL; length = 0; - if (gtk_text_buffer_get_selection_bounds (text_view->buffer, &start, &end)) + if (gtk_text_buffer_get_selection_bounds (get_buffer (text_view), &start, &end)) { /* Extract the selected text */ str = gtk_text_iter_get_visible_text (&start, &end); @@ -3288,7 +3492,7 @@ gtk_text_view_drag_motion (GtkWidget *widget, &newplace, bx, by); - if (gtk_text_buffer_get_selection_bounds (text_view->buffer, + if (gtk_text_buffer_get_selection_bounds (get_buffer (text_view), &start, &end) && gtk_text_iter_in_range (&newplace, &start, &end)) { @@ -3313,8 +3517,8 @@ gtk_text_view_drag_motion (GtkWidget *widget, } } - gtk_text_buffer_move_mark (text_view->buffer, - gtk_text_buffer_get_mark (text_view->buffer, + gtk_text_buffer_move_mark (get_buffer (text_view), + gtk_text_buffer_get_mark (get_buffer (text_view), "gtk_drag_target"), &newplace); @@ -3328,7 +3532,7 @@ gtk_text_view_drag_motion (GtkWidget *widget, margin /= 5; gtk_text_view_scroll_to_mark_adjusted (text_view, - gtk_text_buffer_get_mark (text_view->buffer, + gtk_text_buffer_get_mark (get_buffer (text_view), "gtk_drag_target"), margin, 1.0); } @@ -3374,13 +3578,13 @@ gtk_text_view_drag_data_received (GtkWidget *widget, text_view = GTK_TEXT_VIEW (widget); - drag_target_mark = gtk_text_buffer_get_mark (text_view->buffer, + drag_target_mark = gtk_text_buffer_get_mark (get_buffer (text_view), "gtk_drag_target"); if (drag_target_mark == NULL) return; - gtk_text_buffer_get_iter_at_mark (text_view->buffer, + gtk_text_buffer_get_iter_at_mark (get_buffer (text_view), &drop_point, drag_target_mark); @@ -3388,7 +3592,7 @@ gtk_text_view_drag_data_received (GtkWidget *widget, if (str) { - gtk_text_buffer_insert_interactive (text_view->buffer, + gtk_text_buffer_insert_interactive (get_buffer (text_view), &drop_point, str, -1, text_view->editable); g_free (str); @@ -3504,7 +3708,7 @@ gtk_text_view_value_changed (GtkAdjustment *adj, { gtk_text_layout_get_line_at_y (text_view->layout, &iter, adj->value, &line_top); - gtk_text_buffer_move_mark (text_view->buffer, text_view->first_para_mark, &iter); + gtk_text_buffer_move_mark (get_buffer (text_view), text_view->first_para_mark, &iter); text_view->first_para_pixels = adj->value - line_top; } @@ -3542,24 +3746,24 @@ gtk_text_view_commit_handler (GtkIMContext *context, const gchar *str, GtkTextView *text_view) { - gtk_text_buffer_delete_selection (text_view->buffer, TRUE, + gtk_text_buffer_delete_selection (get_buffer (text_view), TRUE, text_view->editable); if (!strcmp (str, "\n")) { - gtk_text_buffer_insert_interactive_at_cursor (text_view->buffer, "\n", 1, + gtk_text_buffer_insert_interactive_at_cursor (get_buffer (text_view), "\n", 1, text_view->editable); } else { if (text_view->overwrite_mode) gtk_text_view_delete_from_cursor (text_view, GTK_DELETE_CHARS, 1); - gtk_text_buffer_insert_interactive_at_cursor (text_view->buffer, str, -1, + gtk_text_buffer_insert_interactive_at_cursor (get_buffer (text_view), str, -1, text_view->editable); } gtk_text_view_scroll_to_mark (text_view, - gtk_text_buffer_get_mark (text_view->buffer, + gtk_text_buffer_get_mark (get_buffer (text_view), "insert"), 0); } @@ -3587,8 +3791,8 @@ gtk_text_view_get_virtual_cursor_pos (GtkTextView *text_view, GdkRectangle strong_pos; GtkTextIter insert; - gtk_text_buffer_get_iter_at_mark (text_view->buffer, &insert, - gtk_text_buffer_get_mark (text_view->buffer, + gtk_text_buffer_get_iter_at_mark (get_buffer (text_view), &insert, + gtk_text_buffer_get_mark (get_buffer (text_view), "insert")); if ((x && text_view->virtual_cursor_x == -1) || @@ -3620,8 +3824,8 @@ gtk_text_view_set_virtual_cursor_pos (GtkTextView *text_view, GdkRectangle strong_pos; GtkTextIter insert; - gtk_text_buffer_get_iter_at_mark (text_view->buffer, &insert, - gtk_text_buffer_get_mark (text_view->buffer, + gtk_text_buffer_get_iter_at_mark (get_buffer (text_view), &insert, + gtk_text_buffer_get_mark (get_buffer (text_view), "insert")); if (x == -1 || y == -1) @@ -3820,6 +4024,20 @@ text_window_get_allocation (GtkTextWindow *win, /* Windows */ +/** + * gtk_text_view_get_window: + * @text_view: a #GtkTextView + * @win: window to get + * + * Retrieves the #GdkWindow corresponding to an area of the text view; + * possible windows include the overall widget window, child windows + * on the left, right, top, bottom, and the window that displays the + * text buffer. Windows are %NULL and nonexistent if their width or + * height is 0, and are nonexistent before the widget has been + * realized. + * + * Return value: a #GdkWindow, or %NULL + **/ GdkWindow* gtk_text_view_get_window (GtkTextView *text_view, GtkTextWindowType win) @@ -3871,6 +4089,18 @@ gtk_text_view_get_window (GtkTextView *text_view, } } +/** + * gtk_text_view_get_window_type: + * @text_view: a #GtkTextView + * @window: a window type + * + * Usually used to find out which window an event corresponds to. + * If you connect to an event signal on @text_view, this function + * should be called on event->window to + * see which window it was. + * + * Return value: the window type. + **/ GtkTextWindowType gtk_text_view_get_window_type (GtkTextView *text_view, GdkWindow *window) @@ -3890,9 +4120,7 @@ gtk_text_view_get_window_type (GtkTextView *text_view, return win->type; else { - g_warning ("%s: Window is not a text view window", - G_STRLOC); - return 0; + return GTK_TEXT_WINDOW_PRIVATE; } } @@ -3943,7 +4171,7 @@ buffer_to_text_window (GtkTextView *text_view, if (win == NULL) { g_warning ("Attempt to convert text buffer coordinates to coordinates " - "for a nonexistent child window of GtkTextView"); + "for a nonexistent or private child window of GtkTextView"); return; } @@ -3958,6 +4186,18 @@ buffer_to_text_window (GtkTextView *text_view, window_y); } +/** + * gtk_text_view_buffer_to_window_coords: + * @text_view: a #GtkTextView + * @win: a #GtkTextWindowType + * @buffer_x: buffer x coordinate + * @buffer_y: buffer y coordinate + * @window_x: window x coordinate return location + * @window_y: window y coordinate return location + * + * Converts coordinate (@buffer_x, @buffer_y) to coordinates for the window + * @win, and stores the result in (@window_x, @window_y). + **/ void gtk_text_view_buffer_to_window_coords (GtkTextView *text_view, GtkTextWindowType win, @@ -4011,6 +4251,10 @@ gtk_text_view_buffer_to_window_coords (GtkTextView *text_view, window_x, window_y); break; + case GTK_TEXT_WINDOW_PRIVATE: + g_warning ("%s: can't get coords for private windows", G_STRLOC); + break; + default: g_warning ("%s: Unknown GtkTextWindowType", G_STRLOC); break; @@ -4081,6 +4325,18 @@ text_window_to_buffer (GtkTextView *text_view, buffer_y); } +/** + * gtk_text_view_window_to_buffer_coords: + * @text_view: a #GtkTextView + * @win: a #GtkTextWindowType + * @window_x: window x coordinate + * @window_y: window y coordinate + * @buffer_x: buffer x coordinate return location + * @buffer_y: buffer y coordinate return location + * + * Converts coordinates on the window identified by @win to buffer + * coordinates, storing the result in (@buffer_x,@buffer_y). + **/ void gtk_text_view_window_to_buffer_coords (GtkTextView *text_view, GtkTextWindowType win, @@ -4134,6 +4390,10 @@ gtk_text_view_window_to_buffer_coords (GtkTextView *text_view, buffer_x, buffer_y); break; + case GTK_TEXT_WINDOW_PRIVATE: + g_warning ("%s: can't get coords for private windows", G_STRLOC); + break; + default: g_warning ("%s: Unknown GtkTextWindowType", G_STRLOC); break; @@ -4207,6 +4467,17 @@ set_window_height (GtkTextView *text_view, } } +/** + * gtk_text_view_set_border_window_size: + * @text_view: a #GtkTextView + * @type: window to affect + * @size: width or height of the window + * + * Sets the width of %GTK_TEXT_WINDOW_LEFT or %GTK_TEXT_WINDOW_RIGHT, + * or the height of %GTK_TEXT_WINDOW_TOP or %GTK_TEXT_WINDOW_BOTTOM. + * Automatically destroys the corresponding window if the size is set to 0, + * and creates the window if the size is set to non-zero. + **/ void gtk_text_view_set_border_window_size (GtkTextView *text_view, GtkTextWindowType type, @@ -4241,11 +4512,22 @@ gtk_text_view_set_border_window_size (GtkTextView *text_view, break; default: - g_warning ("Unknown GtkTextWindowType in %s", G_STRLOC); + g_warning ("Can't set size of center or widget or private GtkTextWindowType in %s", G_STRLOC); break; } } +/** + * gtk_text_view_set_text_window_size: + * @text_view: a #GtkTextView + * @width: a width in pixels + * @height: a height in pixels + * + * Sets the size request for the main text window (%GTK_TEXT_WINDOW_TEXT). + * If the widget gets more space than it requested, the main text window + * will be larger than this. + * + **/ void gtk_text_view_set_text_window_size (GtkTextView *text_view, gint width, diff --git a/gtk/gtktextview.h b/gtk/gtktextview.h index f2a7cdfa5d..f2c539df61 100644 --- a/gtk/gtktextview.h +++ b/gtk/gtktextview.h @@ -44,6 +44,7 @@ extern "C" { typedef enum { + GTK_TEXT_WINDOW_PRIVATE, GTK_TEXT_WINDOW_WIDGET, GTK_TEXT_WINDOW_TEXT, GTK_TEXT_WINDOW_LEFT,