| Top | Description | Object Hierarchy | Properties | Signals |  |  |  |  | 
| GtkSourceBufferGtkSourceBuffer — Buffer object for GtkSourceView | 
#include <gtksourceview/gtksource.h>
                    GtkSourceBuffer;
enum                GtkSourceBracketMatchType;
enum                GtkSourceChangeCaseType;
GtkSourceBuffer *   gtk_source_buffer_new               (GtkTextTagTable *table);
GtkSourceBuffer *   gtk_source_buffer_new_with_language (GtkSourceLanguage *language);
void                gtk_source_buffer_set_highlight_syntax
                                                        (GtkSourceBuffer *buffer,
                                                         gboolean highlight);
gboolean            gtk_source_buffer_get_highlight_syntax
                                                        (GtkSourceBuffer *buffer);
void                gtk_source_buffer_set_language      (GtkSourceBuffer *buffer,
                                                         GtkSourceLanguage *language);
GtkSourceLanguage * gtk_source_buffer_get_language      (GtkSourceBuffer *buffer);
void                gtk_source_buffer_set_highlight_matching_brackets
                                                        (GtkSourceBuffer *buffer,
                                                         gboolean highlight);
gboolean            gtk_source_buffer_get_highlight_matching_brackets
                                                        (GtkSourceBuffer *buffer);
void                gtk_source_buffer_set_style_scheme  (GtkSourceBuffer *buffer,
                                                         GtkSourceStyleScheme *scheme);
GtkSourceStyleScheme * gtk_source_buffer_get_style_scheme
                                                        (GtkSourceBuffer *buffer);
void                gtk_source_buffer_ensure_highlight  (GtkSourceBuffer *buffer,
                                                         const GtkTextIter *start,
                                                         const GtkTextIter *end);
GtkSourceMark *     gtk_source_buffer_create_source_mark
                                                        (GtkSourceBuffer *buffer,
                                                         const gchar *name,
                                                         const gchar *category,
                                                         const GtkTextIter *where);
gboolean            gtk_source_buffer_forward_iter_to_source_mark
                                                        (GtkSourceBuffer *buffer,
                                                         GtkTextIter *iter,
                                                         const gchar *category);
gboolean            gtk_source_buffer_backward_iter_to_source_mark
                                                        (GtkSourceBuffer *buffer,
                                                         GtkTextIter *iter,
                                                         const gchar *category);
GSList *            gtk_source_buffer_get_source_marks_at_line
                                                        (GtkSourceBuffer *buffer,
                                                         gint line,
                                                         const gchar *category);
GSList *            gtk_source_buffer_get_source_marks_at_iter
                                                        (GtkSourceBuffer *buffer,
                                                         GtkTextIter *iter,
                                                         const gchar *category);
void                gtk_source_buffer_remove_source_marks
                                                        (GtkSourceBuffer *buffer,
                                                         const GtkTextIter *start,
                                                         const GtkTextIter *end,
                                                         const gchar *category);
gboolean            gtk_source_buffer_iter_has_context_class
                                                        (GtkSourceBuffer *buffer,
                                                         const GtkTextIter *iter,
                                                         const gchar *context_class);
gchar **            gtk_source_buffer_get_context_classes_at_iter
                                                        (GtkSourceBuffer *buffer,
                                                         const GtkTextIter *iter);
gboolean            gtk_source_buffer_iter_forward_to_context_class_toggle
                                                        (GtkSourceBuffer *buffer,
                                                         GtkTextIter *iter,
                                                         const gchar *context_class);
gboolean            gtk_source_buffer_iter_backward_to_context_class_toggle
                                                        (GtkSourceBuffer *buffer,
                                                         GtkTextIter *iter,
                                                         const gchar *context_class);
void                gtk_source_buffer_change_case       (GtkSourceBuffer *buffer,
                                                         GtkSourceChangeCaseType case_type,
                                                         GtkTextIter *start,
                                                         GtkTextIter *end);
gint                gtk_source_buffer_get_max_undo_levels
                                                        (GtkSourceBuffer *buffer);
void                gtk_source_buffer_set_max_undo_levels
                                                        (GtkSourceBuffer *buffer,
                                                         gint max_undo_levels);
void                gtk_source_buffer_redo              (GtkSourceBuffer *buffer);
void                gtk_source_buffer_undo              (GtkSourceBuffer *buffer);
gboolean            gtk_source_buffer_can_redo          (GtkSourceBuffer *buffer);
gboolean            gtk_source_buffer_can_undo          (GtkSourceBuffer *buffer);
void                gtk_source_buffer_begin_not_undoable_action
                                                        (GtkSourceBuffer *buffer);
void                gtk_source_buffer_end_not_undoable_action
                                                        (GtkSourceBuffer *buffer);
GtkSourceUndoManager * gtk_source_buffer_get_undo_manager
                                                        (GtkSourceBuffer *buffer);
void                gtk_source_buffer_set_undo_manager  (GtkSourceBuffer *buffer,
                                                         GtkSourceUndoManager *manager);
"can-redo" gboolean : Read "can-undo" gboolean : Read "highlight-matching-brackets" gboolean : Read / Write "highlight-syntax" gboolean : Read / Write "language" GtkSourceLanguage* : Read / Write "max-undo-levels" gint : Read / Write "style-scheme" GtkSourceStyleScheme* : Read / Write "undo-manager" GtkSourceUndoManager* : Read / Write / Construct
"bracket-matched" :Run Last"highlight-updated" :Run Last"redo" :Run Last"source-mark-updated" :Run Last"undo" :Run Last
The GtkSourceBuffer object is the model for GtkSourceView widgets. It extends the GtkTextBuffer object by adding features useful to display and edit source code such as syntax highlighting and bracket matching. It also implements support for undo/redo operations, and for the search and replace.
  To create a GtkSourceBuffer use gtk_source_buffer_new() or
  gtk_source_buffer_new_with_language(). The second form is just a convenience
  function which allows you to initially set a GtkSourceLanguage.
  By default highlighting is enabled, but you can disable it with
  gtk_source_buffer_set_highlight_syntax().
    A custom GtkSourceUndoManager can be implemented and set with
    gtk_source_buffer_set_undo_manager(). However the default implementation
    should be suitable for most uses. By default, actions that can be undone or
    redone are defined as groups of operations between a call to
    gtk_text_buffer_begin_user_action() and gtk_text_buffer_end_user_action(). In
    general, this happens whenever the user presses any key which modifies the
    buffer. But the default undo manager will try to merge similar consecutive
    actions, such as multiple character insertions on the same line, into one
    action. But, inserting a newline starts a new action.
  
    The default undo manager remembers the "modified" state of the buffer, and
    restore it when an action is undone or redone. It can be useful in a text
    editor to know whether the file is saved. See gtk_text_buffer_get_modified()
    and gtk_text_buffer_set_modified().
  
It is possible to retrieve some information from the syntax highlighting engine. There are currently three default context classes that are applied to regions of a GtkSourceBuffer:
comment: the region delimits a comment;
string: the region delimits a string;
no-spell-check: the region should not be spell checked.
    Custom language definition files can create their own context classes,
    since the functions like gtk_source_buffer_iter_has_context_class() take
    a string parameter as the context class.
  
typedef enum {
	GTK_SOURCE_BRACKET_MATCH_NONE,
	GTK_SOURCE_BRACKET_MATCH_OUT_OF_RANGE,
	GTK_SOURCE_BRACKET_MATCH_NOT_FOUND,
	GTK_SOURCE_BRACKET_MATCH_FOUND
} GtkSourceBracketMatchType;
typedef enum {
	GTK_SOURCE_CHANGE_CASE_LOWER,
	GTK_SOURCE_CHANGE_CASE_UPPER,
	GTK_SOURCE_CHANGE_CASE_TOGGLE,
	GTK_SOURCE_CHANGE_CASE_TITLE
} GtkSourceChangeCaseType;
| change case to lowercase. | |
| change case to uppercase. | |
| toggle case of each character. | |
| capitalize each word. | 
Since 3.12
GtkSourceBuffer *   gtk_source_buffer_new               (GtkTextTagTable *table);
Creates a new source buffer.
| 
 | a GtkTextTagTable, or NULLto create a new one. [allow-none] | 
| Returns : | a new source buffer. | 
GtkSourceBuffer *   gtk_source_buffer_new_with_language (GtkSourceLanguage *language);
Creates a new source buffer using the highlighting patterns in
language.  This is equivalent to creating a new source buffer with
a new tag table and then calling gtk_source_buffer_set_language().
| 
 | a GtkSourceLanguage. | 
| Returns : | a new source buffer which will highlight text
according to the highlighting patterns in language. | 
void gtk_source_buffer_set_highlight_syntax (GtkSourceBuffer *buffer,gboolean highlight);
Controls whether syntax is highlighted in the buffer. If highlight
is TRUE, the text will be highlighted according to the syntax
patterns specified in the language set with
gtk_source_buffer_set_language(). If highlight is FALSE, syntax highlighting
is disabled and all the GtkTextTag objects that have been added by the
syntax highlighting engine are removed from the buffer.
| 
 | a GtkSourceBuffer. | 
| 
 | TRUEto enable syntax highlighting,FALSEto disable it. | 
gboolean            gtk_source_buffer_get_highlight_syntax
                                                        (GtkSourceBuffer *buffer);
Determines whether syntax highlighting is activated in the source buffer.
| 
 | a GtkSourceBuffer. | 
| Returns : | TRUEif syntax highlighting is enabled,FALSEotherwise. | 
void gtk_source_buffer_set_language (GtkSourceBuffer *buffer,GtkSourceLanguage *language);
Associate a GtkSourceLanguage with the buffer. If language is
not-NULL and syntax highlighting is enabled (see gtk_source_buffer_set_highlight_syntax()),
the syntax patterns defined in language will be used to highlight the text
contained in the buffer. If language is NULL, the text contained in the
buffer is not highlighted.
The buffer holds a reference to language.
| 
 | a GtkSourceBuffer. | 
| 
 | a GtkSourceLanguage to set, or NULL. [allow-none] | 
GtkSourceLanguage * gtk_source_buffer_get_language      (GtkSourceBuffer *buffer);
Returns the GtkSourceLanguage associated with the buffer,
see gtk_source_buffer_set_language().  The returned object should not be
unreferenced by the user.
| 
 | a GtkSourceBuffer. | 
| Returns : | the GtkSourceLanguage associated with the buffer, or NULL. [transfer none] | 
void gtk_source_buffer_set_highlight_matching_brackets (GtkSourceBuffer *buffer,gboolean highlight);
Controls the bracket match highlighting function in the buffer. If activated, when you position your cursor over a bracket character (a parenthesis, a square bracket, etc.) the matching opening or closing bracket character will be highlighted.
| 
 | a GtkSourceBuffer. | 
| 
 | TRUEif you want matching brackets highlighted. | 
gboolean            gtk_source_buffer_get_highlight_matching_brackets
                                                        (GtkSourceBuffer *buffer);
Determines whether bracket match highlighting is activated for the source buffer.
| 
 | a GtkSourceBuffer. | 
| Returns : | TRUEif the source buffer will highlight matching
brackets. | 
void gtk_source_buffer_set_style_scheme (GtkSourceBuffer *buffer,GtkSourceStyleScheme *scheme);
Sets style scheme used by the buffer. If scheme is NULL no
style scheme is used.
| 
 | a GtkSourceBuffer. | 
| 
 | a GtkSourceStyleScheme or NULL. [allow-none] | 
GtkSourceStyleScheme * gtk_source_buffer_get_style_scheme
                                                        (GtkSourceBuffer *buffer);
Returns the GtkSourceStyleScheme associated with the buffer,
see gtk_source_buffer_set_style_scheme().
The returned object should not be unreferenced by the user.
| 
 | a GtkSourceBuffer. | 
| Returns : | the GtkSourceStyleScheme associated
with the buffer, or NULL. [transfer none] | 
void gtk_source_buffer_ensure_highlight (GtkSourceBuffer *buffer,const GtkTextIter *start,const GtkTextIter *end);
Forces buffer to analyze and highlight the given area synchronously.
This is a potentially slow operation and should be used only when you need to make sure that some text not currently visible is highlighted, for instance before printing.
| 
 | a GtkSourceBuffer. | 
| 
 | start of the area to highlight. | 
| 
 | end of the area to highlight. | 
GtkSourceMark * gtk_source_buffer_create_source_mark (GtkSourceBuffer *buffer,const gchar *name,const gchar *category,const GtkTextIter *where);
Creates a source mark in the buffer of category category.  A source mark is
a GtkTextMark but organised into categories. Depending on the category
a pixbuf can be specified that will be displayed along the line of the mark.
Like a GtkTextMark, a GtkSourceMark can be anonymous if the
passed name is NULL.  Also, the buffer owns the marks so you
shouldn't unreference it.
Marks always have left gravity and are moved to the beginning of the line when the user deletes the line they were in.
Typical uses for a source mark are bookmarks, breakpoints, current executing instruction indication in a source file, etc..
| 
 | a GtkSourceBuffer. | 
| 
 | the name of the mark, or NULL. [allow-none] | 
| 
 | a string defining the mark category. | 
| 
 | location to place the mark. | 
| Returns : | a new GtkSourceMark, owned by the buffer. [transfer none] | 
Since 2.2
gboolean gtk_source_buffer_forward_iter_to_source_mark (GtkSourceBuffer *buffer,GtkTextIter *iter,const gchar *category);
Moves iter to the position of the next GtkSourceMark of the given
category. Returns TRUE if iter was moved. If category is NULL, the
next source mark can be of any category.
| 
 | a GtkSourceBuffer. | 
| 
 | an iterator. | 
| 
 | category to search for, or NULL. [allow-none] | 
| Returns : | whether iterwas moved. | 
Since 2.2
gboolean gtk_source_buffer_backward_iter_to_source_mark (GtkSourceBuffer *buffer,GtkTextIter *iter,const gchar *category);
Moves iter to the position of the previous GtkSourceMark of the given
category. Returns TRUE if iter was moved. If category is NULL, the
previous source mark can be of any category.
| 
 | a GtkSourceBuffer. | 
| 
 | an iterator. | 
| 
 | category to search for, or NULL. [allow-none] | 
| Returns : | whether iterwas moved. | 
Since 2.2
GSList * gtk_source_buffer_get_source_marks_at_line (GtkSourceBuffer *buffer,gint line,const gchar *category);
Returns the list of marks of the given category at line.
If category is NULL, all marks at line are returned.
| 
 | a GtkSourceBuffer. | 
| 
 | a line number. | 
| 
 | category to search for, or NULL. [allow-none] | 
| Returns : | a newly allocated GSList. [element-type GtkSource.Mark][transfer container] | 
Since 2.2
GSList * gtk_source_buffer_get_source_marks_at_iter (GtkSourceBuffer *buffer,GtkTextIter *iter,const gchar *category);
Returns the list of marks of the given category at iter. If category
is NULL it returns all marks at iter.
| 
 | a GtkSourceBuffer. | 
| 
 | an iterator. | 
| 
 | category to search for, or NULL. [allow-none] | 
| Returns : | a newly allocated GSList. [element-type GtkSource.Mark][transfer container] | 
Since 2.2
void gtk_source_buffer_remove_source_marks (GtkSourceBuffer *buffer,const GtkTextIter *start,const GtkTextIter *end,const gchar *category);
Remove all marks of category between start and end from the buffer.
If category is NULL, all marks in the range will be removed.
| 
 | a GtkSourceBuffer. | 
| 
 | a GtkTextIter. | 
| 
 | a GtkTextIter. | 
| 
 | category to search for, or NULL. [allow-none] | 
Since 2.2
gboolean gtk_source_buffer_iter_has_context_class (GtkSourceBuffer *buffer,const GtkTextIter *iter,const gchar *context_class);
Check if the class context_class is set on iter.
See the GtkSourceBuffer description for the list of default context classes.
| 
 | a GtkSourceBuffer. | 
| 
 | a GtkTextIter. | 
| 
 | class to search for. | 
| Returns : | whether iterhas the context class. | 
Since 2.10
gchar ** gtk_source_buffer_get_context_classes_at_iter (GtkSourceBuffer *buffer,const GtkTextIter *iter);
Get all defined context classes at iter.
See the GtkSourceBuffer description for the list of default context classes.
| 
 | a GtkSourceBuffer. | 
| 
 | a GtkTextIter. | 
| Returns : | a new NULLterminated array of context class names.
Useg_strfreev()to free the array if it is no longer needed. [array zero-terminated=1][transfer full] | 
Since 2.10
gboolean gtk_source_buffer_iter_forward_to_context_class_toggle (GtkSourceBuffer *buffer,GtkTextIter *iter,const gchar *context_class);
Moves forward to the next toggle (on or off) of the context class. If no
matching context class toggles are found, returns FALSE, otherwise TRUE.
Does not return toggles located at iter, only toggles after iter. Sets
iter to the location of the toggle, or to the end of the buffer if no
toggle is found.
See the GtkSourceBuffer description for the list of default context classes.
| 
 | a GtkSourceBuffer. | 
| 
 | a GtkTextIter. | 
| 
 | the context class. | 
| Returns : | whether we found a context class toggle after iter | 
Since 2.10
gboolean gtk_source_buffer_iter_backward_to_context_class_toggle (GtkSourceBuffer *buffer,GtkTextIter *iter,const gchar *context_class);
Moves backward to the next toggle (on or off) of the context class. If no
matching context class toggles are found, returns FALSE, otherwise TRUE.
Does not return toggles located at iter, only toggles after iter. Sets
iter to the location of the toggle, or to the end of the buffer if no
toggle is found.
See the GtkSourceBuffer description for the list of default context classes.
| 
 | a GtkSourceBuffer. | 
| 
 | a GtkTextIter. | 
| 
 | the context class. | 
| Returns : | whether we found a context class toggle before iter | 
Since 2.10
void gtk_source_buffer_change_case (GtkSourceBuffer *buffer,GtkSourceChangeCaseType case_type,GtkTextIter *start,GtkTextIter *end);
Changes the case of the text between the specified iterators.
| 
 | a GtkSourceBuffer. | 
| 
 | how to change the case. | 
| 
 | a GtkTextIter. | 
| 
 | a GtkTextIter. | 
Since 3.12
gint                gtk_source_buffer_get_max_undo_levels
                                                        (GtkSourceBuffer *buffer);
Determines the number of undo levels the buffer will track for buffer edits.
| 
 | a GtkSourceBuffer. | 
| Returns : | the maximum number of possible undo levels or -1 if no limit is set. | 
void gtk_source_buffer_set_max_undo_levels (GtkSourceBuffer *buffer,gint max_undo_levels);
Sets the number of undo levels for user actions the buffer will track. If the number of user actions exceeds the limit set by this function, older actions will be discarded.
If max_undo_levels is -1, no limit is set.
| 
 | a GtkSourceBuffer. | 
| 
 | the desired maximum number of undo levels. | 
void                gtk_source_buffer_redo              (GtkSourceBuffer *buffer);
Redoes the last undo operation.  Use gtk_source_buffer_can_redo()
to check whether a call to this function will have any effect.
This function emits the "redo" signal.
| 
 | a GtkSourceBuffer. | 
void                gtk_source_buffer_undo              (GtkSourceBuffer *buffer);
Undoes the last user action which modified the buffer.  Use
gtk_source_buffer_can_undo() to check whether a call to this
function will have any effect.
This function emits the "undo" signal.
| 
 | a GtkSourceBuffer. | 
gboolean            gtk_source_buffer_can_redo          (GtkSourceBuffer *buffer);
Determines whether a source buffer can redo the last action (i.e. if the last operation was an undo).
| 
 | a GtkSourceBuffer. | 
| Returns : | TRUEif a redo is possible. | 
gboolean            gtk_source_buffer_can_undo          (GtkSourceBuffer *buffer);
Determines whether a source buffer can undo the last action.
| 
 | a GtkSourceBuffer. | 
| Returns : | TRUEif it's possible to undo the last action. | 
void                gtk_source_buffer_begin_not_undoable_action
                                                        (GtkSourceBuffer *buffer);
Marks the beginning of a not undoable action on the buffer, disabling the undo manager. Typically you would call this function before initially setting the contents of the buffer (e.g. when loading a file in a text editor).
You may nest gtk_source_buffer_begin_not_undoable_action() /
gtk_source_buffer_end_not_undoable_action() blocks.
| 
 | a GtkSourceBuffer. | 
void                gtk_source_buffer_end_not_undoable_action
                                                        (GtkSourceBuffer *buffer);
Marks the end of a not undoable action on the buffer. When the last not undoable block is closed through the call to this function, the list of undo actions is cleared and the undo manager is re-enabled.
| 
 | a GtkSourceBuffer. | 
GtkSourceUndoManager * gtk_source_buffer_get_undo_manager
                                                        (GtkSourceBuffer *buffer);
Returns the GtkSourceUndoManager associated with the buffer,
see gtk_source_buffer_set_undo_manager().  The returned object should not be
unreferenced by the user.
| 
 | a GtkSourceBuffer. | 
| Returns : | the GtkSourceUndoManager associated with the buffer, or NULL. [transfer none] | 
void gtk_source_buffer_set_undo_manager (GtkSourceBuffer *buffer,GtkSourceUndoManager *manager);
Set the buffer undo manager. If manager is NULL the default undo manager
will be set.
| 
 | a GtkSourceBuffer. | 
| 
 | A GtkSourceUndoManager or NULL. [allow-none] | 
"can-redo" property  "can-redo"                 gboolean              : Read
Whether Redo operation is possible.
Default value: FALSE
"can-undo" property  "can-undo"                 gboolean              : Read
Whether Undo operation is possible.
Default value: FALSE
"highlight-matching-brackets" property  "highlight-matching-brackets" gboolean              : Read / Write
Whether to highlight matching brackets in the buffer.
Default value: TRUE
"highlight-syntax" property  "highlight-syntax"         gboolean              : Read / Write
Whether to highlight syntax in the buffer.
Default value: TRUE
"language" property"language" GtkSourceLanguage* : Read / Write
Language object to get highlighting patterns from.
"max-undo-levels" property  "max-undo-levels"          gint                  : Read / Write
Number of undo levels for the buffer. -1 means no limit. This property will only affect the default undo manager.
Allowed values: >= -1
Default value: 1000
"style-scheme" property"style-scheme" GtkSourceStyleScheme* : Read / Write
Style scheme. It contains styles for syntax highlighting, optionally foreground, background, cursor color, current line color, and matching brackets style.
"undo-manager" property"undo-manager" GtkSourceUndoManager* : Read / Write / Construct
The buffer undo manager.
"bracket-matched" signalvoid                user_function                      (GtkSourceBuffer          *buffer,
                                                        GtkTextIter              *iter,
                                                        GtkSourceBracketMatchType state,
                                                        gpointer                  user_data)      : Run Last
Sets iter to a valid iterator pointing to the matching bracket
if state is GTK_SOURCE_BRACKET_MATCH_FOUND. Otherwise iter is
meaningless.
| 
 | a GtkSourceBuffer. | 
| 
 | iterator to initialize. | 
| 
 | state of bracket matching | 
| 
 | user data set when the signal handler was connected. | 
Since 2.12
"highlight-updated" signalvoid                user_function                      (GtkSourceBuffer *buffer,
                                                        GtkTextIter     *start,
                                                        GtkTextIter     *end,
                                                        gpointer         user_data)      : Run Last
The ::highlight-updated signal is emitted when the syntax
highlighting is updated in a certain region of the buffer. This
signal is useful to be notified when a context class region is
updated (e.g. the no-spell-check context class).
| 
 | the buffer that received the signal | 
| 
 | the start of the updated region | 
| 
 | the end of the updated region | 
| 
 | user data set when the signal handler was connected. | 
"redo" signalvoid                user_function                      (GtkSourceBuffer *buffer,
                                                        gpointer         user_data)      : Run Last
The ::redo signal is emitted to redo the last undo operation.
| 
 | the buffer that received the signal | 
| 
 | user data set when the signal handler was connected. | 
"source-mark-updated" signalvoid                user_function                      (GtkSourceBuffer *buffer,
                                                        GtkTextMark     *mark,
                                                        gpointer         user_data)      : Run Last
The ::source_mark_updated signal is emitted each time
a mark is added to, moved or removed from the buffer.
| 
 | the buffer that received the signal | 
| 
 | the GtkSourceMark | 
| 
 | user data set when the signal handler was connected. | 
"undo" signalvoid                user_function                      (GtkSourceBuffer *buffer,
                                                        gpointer         user_data)      : Run Last
The ::undo signal is emitted to undo the last user action which modified the buffer.
| 
 | the buffer that received the signal | 
| 
 | user data set when the signal handler was connected. |