1 /* GTK - The GIMP Toolkit
2 * gtktextbtree.h Copyright (C) 2000 Red Hat, Inc.
4 * This library is free software; you can redistribute it and/or
5 * modify it under the terms of the GNU Lesser General Public
6 * License as published by the Free Software Foundation; either
7 * version 2 of the License, or (at your option) any later version.
9 * This library is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12 * Lesser General Public License for more details.
14 * You should have received a copy of the GNU Lesser General Public
15 * License along with this library; if not, write to the
16 * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
17 * Boston, MA 02111-1307, USA.
21 * Modified by the GTK+ Team and others 1997-2000. See the AUTHORS
22 * file for a list of people on the GTK+ Team. See the ChangeLog
23 * files for a list of changes. These files are distributed with
24 * GTK+ at ftp://ftp.gtk.org/pub/gtk/.
27 #ifndef __GTK_TEXT_BTREE_H__
28 #define __GTK_TEXT_BTREE_H__
31 #define DEBUG_VALIDATION_AND_SCROLLING
34 #ifdef DEBUG_VALIDATION_AND_SCROLLING
40 #include <gtk/gtktextbuffer.h>
41 #include <gtk/gtktexttag.h>
42 #include <gtk/gtktextmark.h>
43 #include <gtk/gtktextchild.h>
44 #include <gtk/gtktextsegment.h>
45 #include <gtk/gtktextiter.h>
49 GtkTextBTree *_gtk_text_btree_new (GtkTextTagTable *table,
50 GtkTextBuffer *buffer);
51 void _gtk_text_btree_ref (GtkTextBTree *tree);
52 void _gtk_text_btree_unref (GtkTextBTree *tree);
53 GtkTextBuffer *_gtk_text_btree_get_buffer (GtkTextBTree *tree);
56 guint _gtk_text_btree_get_chars_changed_stamp (GtkTextBTree *tree);
57 guint _gtk_text_btree_get_segments_changed_stamp (GtkTextBTree *tree);
58 void _gtk_text_btree_segments_changed (GtkTextBTree *tree);
60 gboolean _gtk_text_btree_is_end (GtkTextBTree *tree,
62 GtkTextLineSegment *seg,
66 /* Indexable segment mutation */
68 void _gtk_text_btree_delete (GtkTextIter *start,
70 void _gtk_text_btree_insert (GtkTextIter *iter,
73 void _gtk_text_btree_insert_pixbuf (GtkTextIter *iter,
76 void _gtk_text_btree_insert_child_anchor (GtkTextIter *iter,
77 GtkTextChildAnchor *anchor);
79 void _gtk_text_btree_unregister_child_anchor (GtkTextChildAnchor *anchor);
82 GtkTextLine *_gtk_text_btree_find_line_by_y (GtkTextBTree *tree,
86 gint _gtk_text_btree_find_line_top (GtkTextBTree *tree,
89 void _gtk_text_btree_add_view (GtkTextBTree *tree,
90 GtkTextLayout *layout);
91 void _gtk_text_btree_remove_view (GtkTextBTree *tree,
93 void _gtk_text_btree_invalidate_region (GtkTextBTree *tree,
94 const GtkTextIter *start,
95 const GtkTextIter *end);
96 void _gtk_text_btree_get_view_size (GtkTextBTree *tree,
100 gboolean _gtk_text_btree_is_valid (GtkTextBTree *tree,
102 gboolean _gtk_text_btree_validate (GtkTextBTree *tree,
108 void _gtk_text_btree_validate_line (GtkTextBTree *tree,
114 void _gtk_text_btree_tag (const GtkTextIter *start,
115 const GtkTextIter *end,
121 GtkTextLine * _gtk_text_btree_get_line (GtkTextBTree *tree,
123 gint *real_line_number);
124 GtkTextLine * _gtk_text_btree_get_line_no_last (GtkTextBTree *tree,
126 gint *real_line_number);
127 GtkTextLine * _gtk_text_btree_get_end_iter_line (GtkTextBTree *tree);
128 GtkTextLine * _gtk_text_btree_get_line_at_char (GtkTextBTree *tree,
130 gint *line_start_index,
131 gint *real_char_index);
132 GtkTextTag** _gtk_text_btree_get_tags (const GtkTextIter *iter,
134 gchar *_gtk_text_btree_get_text (const GtkTextIter *start,
135 const GtkTextIter *end,
136 gboolean include_hidden,
137 gboolean include_nonchars);
138 gint _gtk_text_btree_line_count (GtkTextBTree *tree);
139 gint _gtk_text_btree_char_count (GtkTextBTree *tree);
140 gboolean _gtk_text_btree_char_is_invisible (const GtkTextIter *iter);
144 /* Get iterators (these are implemented in gtktextiter.c) */
145 void _gtk_text_btree_get_iter_at_char (GtkTextBTree *tree,
148 void _gtk_text_btree_get_iter_at_line_char (GtkTextBTree *tree,
152 void _gtk_text_btree_get_iter_at_line_byte (GtkTextBTree *tree,
156 gboolean _gtk_text_btree_get_iter_from_string (GtkTextBTree *tree,
158 const gchar *string);
159 gboolean _gtk_text_btree_get_iter_at_mark_name (GtkTextBTree *tree,
161 const gchar *mark_name);
162 void _gtk_text_btree_get_iter_at_mark (GtkTextBTree *tree,
165 void _gtk_text_btree_get_end_iter (GtkTextBTree *tree,
167 void _gtk_text_btree_get_iter_at_line (GtkTextBTree *tree,
171 gboolean _gtk_text_btree_get_iter_at_first_toggle (GtkTextBTree *tree,
174 gboolean _gtk_text_btree_get_iter_at_last_toggle (GtkTextBTree *tree,
178 void _gtk_text_btree_get_iter_at_child_anchor (GtkTextBTree *tree,
180 GtkTextChildAnchor *anchor);
184 /* Manipulate marks */
185 GtkTextMark *_gtk_text_btree_set_mark (GtkTextBTree *tree,
186 GtkTextMark *existing_mark,
188 gboolean left_gravity,
189 const GtkTextIter *index,
190 gboolean should_exist);
191 void _gtk_text_btree_remove_mark_by_name (GtkTextBTree *tree,
193 void _gtk_text_btree_remove_mark (GtkTextBTree *tree,
194 GtkTextMark *segment);
195 gboolean _gtk_text_btree_get_selection_bounds (GtkTextBTree *tree,
198 void _gtk_text_btree_place_cursor (GtkTextBTree *tree,
199 const GtkTextIter *where);
200 void _gtk_text_btree_select_range (GtkTextBTree *tree,
201 const GtkTextIter *ins,
204 gboolean _gtk_text_btree_mark_is_insert (GtkTextBTree *tree,
205 GtkTextMark *segment);
206 gboolean _gtk_text_btree_mark_is_selection_bound (GtkTextBTree *tree,
207 GtkTextMark *segment);
208 GtkTextMark *_gtk_text_btree_get_mark_by_name (GtkTextBTree *tree,
210 GtkTextLine * _gtk_text_btree_first_could_contain_tag (GtkTextBTree *tree,
212 GtkTextLine * _gtk_text_btree_last_could_contain_tag (GtkTextBTree *tree,
217 /* Chunk of data associated with a line; views can use this to store
218 info at the line. They should "subclass" the header struct here. */
219 struct _GtkTextLineData {
221 GtkTextLineData *next;
223 signed int width : 24;
224 guint valid : 8; /* Actually a boolean */
228 * The data structure below defines a single line of text (from newline
229 * to newline, not necessarily what appears on one line of the screen).
231 * You can consider this line a "paragraph" also
234 struct _GtkTextLine {
235 GtkTextBTreeNode *parent; /* Pointer to parent node containing
237 GtkTextLine *next; /* Next in linked list of lines with
238 * same parent node in B-tree. NULL
239 * means end of list. */
240 GtkTextLineSegment *segments; /* First in ordered list of segments
241 * that make up the line. */
242 GtkTextLineData *views; /* data stored here by views */
243 guchar dir_strong; /* BiDi algo dir of line */
244 guchar dir_propagated_back; /* BiDi algo dir of next line */
245 guchar dir_propagated_forward; /* BiDi algo dir of prev line */
249 gint _gtk_text_line_get_number (GtkTextLine *line);
250 gboolean _gtk_text_line_char_has_tag (GtkTextLine *line,
254 gboolean _gtk_text_line_byte_has_tag (GtkTextLine *line,
258 gboolean _gtk_text_line_is_last (GtkTextLine *line,
260 gboolean _gtk_text_line_contains_end_iter (GtkTextLine *line,
262 GtkTextLine * _gtk_text_line_next (GtkTextLine *line);
263 GtkTextLine * _gtk_text_line_next_excluding_last (GtkTextLine *line);
264 GtkTextLine * _gtk_text_line_previous (GtkTextLine *line);
265 void _gtk_text_line_add_data (GtkTextLine *line,
266 GtkTextLineData *data);
267 gpointer _gtk_text_line_remove_data (GtkTextLine *line,
269 gpointer _gtk_text_line_get_data (GtkTextLine *line,
271 void _gtk_text_line_invalidate_wrap (GtkTextLine *line,
272 GtkTextLineData *ld);
273 gint _gtk_text_line_char_count (GtkTextLine *line);
274 gint _gtk_text_line_byte_count (GtkTextLine *line);
275 gint _gtk_text_line_char_index (GtkTextLine *line);
276 GtkTextLineSegment *_gtk_text_line_byte_to_segment (GtkTextLine *line,
279 GtkTextLineSegment *_gtk_text_line_char_to_segment (GtkTextLine *line,
282 gboolean _gtk_text_line_byte_locate (GtkTextLine *line,
284 GtkTextLineSegment **segment,
285 GtkTextLineSegment **any_segment,
286 gint *seg_byte_offset,
287 gint *line_byte_offset);
288 gboolean _gtk_text_line_char_locate (GtkTextLine *line,
290 GtkTextLineSegment **segment,
291 GtkTextLineSegment **any_segment,
292 gint *seg_char_offset,
293 gint *line_char_offset);
294 void _gtk_text_line_byte_to_char_offsets (GtkTextLine *line,
296 gint *line_char_offset,
297 gint *seg_char_offset);
298 void _gtk_text_line_char_to_byte_offsets (GtkTextLine *line,
300 gint *line_byte_offset,
301 gint *seg_byte_offset);
302 GtkTextLineSegment *_gtk_text_line_byte_to_any_segment (GtkTextLine *line,
305 GtkTextLineSegment *_gtk_text_line_char_to_any_segment (GtkTextLine *line,
308 gint _gtk_text_line_byte_to_char (GtkTextLine *line,
310 gint _gtk_text_line_char_to_byte (GtkTextLine *line,
312 GtkTextLine * _gtk_text_line_next_could_contain_tag (GtkTextLine *line,
315 GtkTextLine * _gtk_text_line_previous_could_contain_tag (GtkTextLine *line,
319 GtkTextLineData *_gtk_text_line_data_new (GtkTextLayout *layout,
323 void _gtk_text_btree_check (GtkTextBTree *tree);
324 void _gtk_text_btree_spew (GtkTextBTree *tree);
325 extern gboolean _gtk_text_view_debug_btree;
327 /* ignore, exported only for gtktextsegment.c */
328 void _gtk_toggle_segment_check_func (GtkTextLineSegment *segPtr,
330 void _gtk_change_node_toggle_count (GtkTextBTreeNode *node,
331 GtkTextTagInfo *info,
334 /* for gtktextmark.c */
335 void _gtk_text_btree_release_mark_segment (GtkTextBTree *tree,
336 GtkTextLineSegment *segment);
338 /* for coordination with the tag table */
339 void _gtk_text_btree_notify_will_remove_tag (GtkTextBTree *tree,