|  |  |  | Anjuta Developers Reference Manual |  | 
|---|---|---|---|---|
| Top | Description | Object Hierarchy | ||||
#include <libanjuta/interfaces/ianjuta-editor.h> #define IANJUTA_EDITOR_INDENT_WIDTH_KEY #define IANJUTA_EDITOR_PREF_SCHEMA #define IANJUTA_EDITOR_TAB_WIDTH_KEY #define IANJUTA_EDITOR_USE_TABS_KEY enum IAnjutaEditorAttribute; enum IAnjutaEditorError; struct IAnjutaEditorIface; void ianjuta_editor_append (IAnjutaEditor *obj,const gchar *text,gint length,GError **err); void ianjuta_editor_erase (IAnjutaEditor *obj,IAnjutaIterable *position_start,IAnjutaIterable *position_end,GError **err); void ianjuta_editor_erase_all (IAnjutaEditor *obj,GError **err); GQuark ianjuta_editor_error_quark (void); gint ianjuta_editor_get_column (IAnjutaEditor *obj,GError **err); gchar * ianjuta_editor_get_current_word (IAnjutaEditor *obj,GError **err); IAnjutaIterable * ianjuta_editor_get_end_position (IAnjutaEditor *obj,GError **err); gint ianjuta_editor_get_indentsize (IAnjutaEditor *obj,GError **err); gint ianjuta_editor_get_length (IAnjutaEditor *obj,GError **err); IAnjutaIterable * ianjuta_editor_get_line_begin_position (IAnjutaEditor *obj,gint line,GError **err); IAnjutaIterable * ianjuta_editor_get_line_end_position (IAnjutaEditor *obj,gint line,GError **err); int ianjuta_editor_get_line_from_position (IAnjutaEditor *obj,IAnjutaIterable *position,GError **err); gint ianjuta_editor_get_lineno (IAnjutaEditor *obj,GError **err); gint ianjuta_editor_get_offset (IAnjutaEditor *obj,GError **err); gboolean ianjuta_editor_get_overwrite (IAnjutaEditor *obj,GError **err); IAnjutaIterable * ianjuta_editor_get_position (IAnjutaEditor *obj,GError **err); IAnjutaIterable * ianjuta_editor_get_position_from_offset (IAnjutaEditor *obj,gint offset,GError **err); IAnjutaIterable * ianjuta_editor_get_start_position (IAnjutaEditor *obj,GError **err); gint ianjuta_editor_get_tabsize (IAnjutaEditor *obj,GError **err); gchar * ianjuta_editor_get_text (IAnjutaEditor *obj,IAnjutaIterable *begin,IAnjutaIterable *end,GError **err); gchar * ianjuta_editor_get_text_all (IAnjutaEditor *obj,GError **err); gboolean ianjuta_editor_get_use_spaces (IAnjutaEditor *obj,GError **err); void ianjuta_editor_goto_end (IAnjutaEditor *obj,GError **err); void ianjuta_editor_goto_line (IAnjutaEditor *obj,gint lineno,GError **err); void ianjuta_editor_goto_position (IAnjutaEditor *obj,IAnjutaIterable *position,GError **err); void ianjuta_editor_goto_start (IAnjutaEditor *obj,GError **err); void ianjuta_editor_insert (IAnjutaEditor *obj,IAnjutaIterable *position,const gchar *text,gint length,GError **err); void ianjuta_editor_set_auto_indent (IAnjutaEditor *obj,gboolean auto_indent,GError **err); void ianjuta_editor_set_indentsize (IAnjutaEditor *obj,gint indentsize,GError **err); void ianjuta_editor_set_popup_menu (IAnjutaEditor *obj,GtkWidget *menu,GError **err); void ianjuta_editor_set_tabsize (IAnjutaEditor *obj,gint tabsize,GError **err); void ianjuta_editor_set_use_spaces (IAnjutaEditor *obj,gboolean use_spaces,GError **err);
#define IANJUTA_EDITOR_INDENT_WIDTH_KEY "indent-width"
Integer key, defines the number a space for one indentation step.
#define IANJUTA_EDITOR_PREF_SCHEMA "editor"
Schema id used to store common editor settings.
#define IANJUTA_EDITOR_TAB_WIDTH_KEY "tab-width"
Integer key, defines the size of a tabulation in spaces.
#define IANJUTA_EDITOR_USE_TABS_KEY "use-tabs"
Boolean key, true is tabs has to be used for indenting.
typedef enum {
	IANJUTA_EDITOR_TEXT,
	IANJUTA_EDITOR_KEYWORD,
	IANJUTA_EDITOR_COMMENT,
	IANJUTA_EDITOR_STRING
} IAnjutaEditorAttribute;
This enumeration is used to specify the type of text. Note that not all editors implement this.
struct IAnjutaEditorIface {
	GTypeInterface g_iface;
	
	/* Signal */
	void (*backspace) (IAnjutaEditor *obj);
	/* Signal */
	void (*changed) (IAnjutaEditor *obj, IAnjutaIterable *position,  gboolean added,  gint length,  gint lines,  const gchar *text);
	/* Signal */
	void (*char_added) (IAnjutaEditor *obj, IAnjutaIterable *position,  gchar ch);
	/* Signal */
	void (*code_added) (IAnjutaEditor *obj, IAnjutaIterable *position,  gchar *code);
	/* Signal */
	void (*cursor_moved) (IAnjutaEditor *obj);
	/* Signal */
	void (*glade_callback_add) (IAnjutaEditor *obj, gchar *widget_typename,  gchar *signal_name,  gchar *handler_name,  gchar *object,  gboolean swap,  gboolean after,  gchar *filename);
	/* Signal */
	void (*glade_member_add) (IAnjutaEditor *obj, gchar *widget_typename,  gchar *widget_name,  gchar *filename);
	/* Signal */
	void (*line_marks_gutter_clicked) (IAnjutaEditor *obj, gint location);
	void (*append) (IAnjutaEditor *obj, const gchar *text,  gint length, GError **err);
	void (*erase) (IAnjutaEditor *obj, IAnjutaIterable *position_start,  IAnjutaIterable *position_end, GError **err);
	void (*erase_all) (IAnjutaEditor *obj, GError **err);
	gint (*get_column) (IAnjutaEditor *obj, GError **err);
	gchar* (*get_current_word) (IAnjutaEditor *obj, GError **err);
	IAnjutaIterable* (*get_end_position) (IAnjutaEditor *obj, GError **err);
	gint (*get_indentsize) (IAnjutaEditor *obj, GError **err);
	gint (*get_length) (IAnjutaEditor *obj, GError **err);
	IAnjutaIterable* (*get_line_begin_position) (IAnjutaEditor *obj, gint line, GError **err);
	IAnjutaIterable * (*get_line_end_position) (IAnjutaEditor *obj, gint line, GError **err);
	int (*get_line_from_position) (IAnjutaEditor *obj, IAnjutaIterable *position, GError **err);
	gint (*get_lineno) (IAnjutaEditor *obj, GError **err);
	gint (*get_offset) (IAnjutaEditor *obj, GError **err);
	gboolean (*get_overwrite) (IAnjutaEditor *obj, GError **err);
	IAnjutaIterable* (*get_position) (IAnjutaEditor *obj, GError **err);
	IAnjutaIterable* (*get_position_from_offset) (IAnjutaEditor *obj, gint offset, GError **err);
	IAnjutaIterable* (*get_start_position) (IAnjutaEditor *obj, GError **err);
	gint (*get_tabsize) (IAnjutaEditor *obj, GError **err);
	gchar* (*get_text) (IAnjutaEditor *obj, IAnjutaIterable *begin,  IAnjutaIterable *end, GError **err);
	gchar* (*get_text_all) (IAnjutaEditor *obj, GError **err);
	gboolean (*get_use_spaces) (IAnjutaEditor *obj, GError **err);
	void (*goto_end) (IAnjutaEditor *obj, GError **err);
	void (*goto_line) (IAnjutaEditor *obj, gint lineno, GError **err);
	void (*goto_position) (IAnjutaEditor *obj, IAnjutaIterable *position, GError **err);
	void (*goto_start) (IAnjutaEditor *obj, GError **err);
	void (*insert) (IAnjutaEditor *obj, IAnjutaIterable *position,  const gchar *text,  gint length, GError **err);
	void (*set_auto_indent) (IAnjutaEditor *obj, gboolean auto_indent, GError **err);
	void (*set_indentsize) (IAnjutaEditor *obj, gint indentsize, GError **err);
	void (*set_popup_menu) (IAnjutaEditor *obj, GtkWidget *menu, GError **err);
	void (*set_tabsize) (IAnjutaEditor *obj, gint tabsize, GError **err);
	void (*set_use_spaces) (IAnjutaEditor *obj, gboolean use_spaces, GError **err);
};
void ianjuta_editor_append (IAnjutaEditor *obj,const gchar *text,gint length,GError **err);
Appends length characters from text buffer at the end of editor
buffer. If length is -1, the whole text is used. length is in bytes.
| 
 | Self | 
| 
 | Text to append. | 
| 
 | Length of textto use. | 
| 
 | Error propagation and reporting | 
void ianjuta_editor_erase (IAnjutaEditor *obj,IAnjutaIterable *position_start,IAnjutaIterable *position_end,GError **err);
void ianjuta_editor_erase_all (IAnjutaEditor *obj,GError **err);
Empties the whole editor buffer. There will be zero characters. After the erase operation, none of the active iters are guranteed to be valid.
| 
 | Self | 
| 
 | Error propagation and reporting | 
gchar * ianjuta_editor_get_current_word (IAnjutaEditor *obj,GError **err);
Obtains the word on which carat is currently on.
| 
 | Self | 
| 
 | Error propagation and reporting | 
| Returns : | Current word. | 
IAnjutaIterable * ianjuta_editor_get_end_position (IAnjutaEditor *obj,GError **err);
Gets the iter positioned at the end of the editor buffer. The returned iter is the end-iter which does not point to any valid character in the buffer (it is pointed one step beyond the last valid character).
| 
 | Self | 
| 
 | Error propagation and reporting | 
| Returns : | Cell iter set to the end of the editor (end-iter). [transfer none] | 
gint ianjuta_editor_get_indentsize (IAnjutaEditor *obj,GError **err);
Returns the indentation size in spaces currently used by the editor.
| 
 | Self | 
| 
 | Error propagation and reporting | 
| Returns : | indentation size in number of spaces | 
gint ianjuta_editor_get_length (IAnjutaEditor *obj,GError **err);
Get length of complete text in editor. This will be the total number of bytes in the file or buffer.
| 
 | Self | 
| 
 | Error propagation and reporting | 
| Returns : | Text length. | 
IAnjutaIterable * ianjuta_editor_get_line_begin_position (IAnjutaEditor *obj,gint line,GError **err);
fixme
| 
 | Self | 
| 
 | fixme | 
| 
 | Error propagation and reporting. | 
| Returns : | fixme. [transfer full] | 
IAnjutaIterable * ianjuta_editor_get_line_end_position (IAnjutaEditor *obj,gint line,GError **err);
fixme
| 
 | Self | 
| 
 | fixme | 
| 
 | Error propagation and reporting. | 
| Returns : | fixme. [transfer full] | 
int ianjuta_editor_get_line_from_position (IAnjutaEditor *obj,IAnjutaIterable *position,GError **err);
gint ianjuta_editor_get_lineno (IAnjutaEditor *obj,GError **err);
Obtains current line number on which carat is.
| 
 | Self | 
| 
 | Error propagation and reporting | 
| Returns : | Line number. | 
gboolean ianjuta_editor_get_overwrite (IAnjutaEditor *obj,GError **err);
Obtains editor overwirte mode: TRUE = Override, FALSE = Insert.
| 
 | Self | 
| 
 | Error propagation and reporting | 
| Returns : | editor mode. | 
IAnjutaIterable * ianjuta_editor_get_position (IAnjutaEditor *obj,GError **err);
Get current caret position.
| 
 | Self | 
| 
 | Error propagation and reporting | 
| Returns : | Iterator that points to the current position. [transfer full] | 
IAnjutaIterable * ianjuta_editor_get_position_from_offset (IAnjutaEditor *obj,gint offset,GError **err);
Creates and returns an iter for editor cells. The iter is
placed at the unicode character position where the given offset
offset happens to fall. The returned iter is cell (character)
iter and not byte iter, so all iter operations
on it are character (not byte) iteration, including all position
and index references in the iter.
The iter must be unreferrenced by the caller when done. The iter navigates (next/previous) in step of unicode characters (one unicode character == one cell).
Retrun value: a newly created iter of IAnjutaEditorCell placed at the
given offset position.
| 
 | Self | 
| 
 | Character offset position where the iter will be set | 
| 
 | Error propagation and reporting | 
IAnjutaIterable * ianjuta_editor_get_start_position (IAnjutaEditor *obj,GError **err);
Gets the iter positioned at the start of the editor buffer.
| 
 | Self | 
| 
 | Error propagation and reporting | 
| Returns : | Cell iter set to the begining of the editor. [transfer none] | 
gint ianjuta_editor_get_tabsize (IAnjutaEditor *obj,GError **err);
Returns the tabsize (in spaces) currently used by the editor.
| 
 | Self | 
| 
 | Error propagation and reporting | 
| Returns : | tabsize in number of spaces | 
gchar * ianjuta_editor_get_text (IAnjutaEditor *obj,IAnjutaIterable *begin,IAnjutaIterable *end,GError **err);
Gets text characters beginning from begin (including char
pointed by begin) and ending with end (excluding character
pointed by end). The characters returned are utf-8 encoded.
The iterators begin and end could be in either order. The returned
text, however, is in right order. If both begin and end points
to the same position, NULL is returned.
| 
 | Self | 
| 
 | Begining iterator | 
| 
 | End iterator | 
| 
 | Error propagation and reporting | 
| Returns : | A buffer of utf-8 characters. The returned buffer must be freed when no longer required. | 
gchar * ianjuta_editor_get_text_all (IAnjutaEditor *obj,GError **err);
Gets all text characters in the editor. The characters returned are utf-8 encoded.
| 
 | Self | 
| 
 | Error propagation and reporting | 
| Returns : | A buffer of utf-8 characters containing all text from editor. The returned buffer must be freed when no longer required. | 
gboolean ianjuta_editor_get_use_spaces (IAnjutaEditor *obj,GError **err);
Returns if the editor uses spaces for filling up tab characters.
| 
 | Self | 
| 
 | Error propagation and reporting | 
| Returns : | TRUE if yes, FALSE if no. | 
void ianjuta_editor_goto_end (IAnjutaEditor *obj,GError **err);
Carat is moved to the end of editor and text view is scrolled to bring it in viewable area of the editor.
| 
 | Self | 
| 
 | Error propagation and reporting | 
void ianjuta_editor_goto_line (IAnjutaEditor *obj,gint lineno,GError **err);
Carat is moved to the given lineno line and text view is scrolled to
bring it in viewable area of the editor.
| 
 | Self | 
| 
 | line number where carat will be moved. | 
| 
 | Error propagation and reporting | 
void ianjuta_editor_goto_position (IAnjutaEditor *obj,IAnjutaIterable *position,GError **err);
Carat is moved to the given position and text view is scrolled to
bring position in viewable area of the editor.
| 
 | Self | 
| 
 | Character position where carat will be moved. | 
| 
 | Error propagation and reporting | 
void ianjuta_editor_goto_start (IAnjutaEditor *obj,GError **err);
Carat is moved to the begining of editor and text view is scrolled to bring it in viewable area of the editor.
| 
 | Self | 
| 
 | Error propagation and reporting | 
void ianjuta_editor_insert (IAnjutaEditor *obj,IAnjutaIterable *position,const gchar *text,gint length,GError **err);
Inserts length characters from text buffer at given position of
editor buffer. If length is -1, the whole text is used.
| 
 | Self | 
| 
 | Character position in editor where insert will take place. | 
| 
 | Text to append. | 
| 
 | Length of textto use. | 
| 
 | Error propagation and reporting | 
void ianjuta_editor_set_auto_indent (IAnjutaEditor *obj,gboolean auto_indent,GError **err);
Sets whether the editor should auto-indent itself. A plugin that does custom auto-indent can set this to false and override the preferences setting
| 
 | Self | 
| 
 | TRUE to enable auto-indent, FALSE to disable | 
void ianjuta_editor_set_indentsize (IAnjutaEditor *obj,gint indentsize,GError **err);
Sets the indentation size of the editor.
| 
 | Self | 
| 
 | Error propagation and reporting | 
void ianjuta_editor_set_popup_menu (IAnjutaEditor *obj,GtkWidget *menu,GError **err);
Set Editor popup menu. This is the menu shown in the editor when one right-clicks on it.
| 
 | Self | 
| 
 | Popupmenu | 
| 
 | Error propagation and reporting | 
void ianjuta_editor_set_tabsize (IAnjutaEditor *obj,gint tabsize,GError **err);
Sets the tabsize of the editor.
| 
 | Self | 
| 
 | Tabsize in spaces | 
| 
 | Error propagation and reporting |