Top | ![]() |
![]() |
![]() |
![]() |
const gchar * | inf_text_buffer_get_encoding () |
guint | inf_text_buffer_get_length () |
InfTextChunk * | inf_text_buffer_get_slice () |
void | inf_text_buffer_insert_text () |
void | inf_text_buffer_insert_chunk () |
void | inf_text_buffer_erase_text () |
InfTextBufferIter * | inf_text_buffer_create_iter () |
void | inf_text_buffer_destroy_iter () |
gboolean | inf_text_buffer_iter_next () |
gboolean | inf_text_buffer_iter_prev () |
gpointer | inf_text_buffer_iter_get_text () |
guint | inf_text_buffer_iter_get_length () |
gsize | inf_text_buffer_iter_get_bytes () |
guint | inf_text_buffer_iter_get_author () |
void | inf_text_buffer_text_inserted () |
void | inf_text_buffer_text_erased () |
const gchar *
inf_text_buffer_get_encoding (InfTextBuffer *buffer
);
Returns the character encoding that the buffer uses. This means that all InfTextChunk return values are encoded in this encoding and all InfTextChunk parameters are expected to be encoded in that encoding.
guint
inf_text_buffer_get_length (InfTextBuffer *buffer
);
Returns the number of characters in buffer
.
InfTextChunk * inf_text_buffer_get_slice (InfTextBuffer *buffer
,guint pos
,guint len
);
Reads len
characters, starting at pos
, from the buffer, and returns them
as a InfTextChunk.
void inf_text_buffer_insert_text (InfTextBuffer *buffer
,guint pos
,gconstpointer text
,gsize bytes
,guint len
,InfUser *user
);
Inserts text
into buffer
as written by author
. text
must be encoded in
the character encoding of the buffer, see inf_text_buffer_get_encoding()
.
buffer |
||
pos |
A character offset into |
|
text |
A pointer to the text to insert. |
|
bytes |
The length (in bytes) of |
|
len |
The length (in characters) of |
|
user |
A InfUser that has inserted the new text, or |
void inf_text_buffer_insert_chunk (InfTextBuffer *buffer
,guint pos
,InfTextChunk *chunk
,InfUser *user
);
Inserts a InfTextChunk into buffer
. user
must not necessarily be the
author of chunk
(chunk
may even consist of multiple segments). This
happens when undoing a delete operation that erased another user's text.
buffer |
||
pos |
A character offset into |
|
chunk |
A InfTextChunk. |
|
user |
A InfUser inserting |
void inf_text_buffer_erase_text (InfTextBuffer *buffer
,guint pos
,guint len
,InfUser *user
);
Erases characters from the text buffer.
buffer |
||
pos |
The position to begin deleting characters from. |
|
len |
The amount of characters to delete. |
|
user |
A InfUser that erases the text, or |
InfTextBufferIter *
inf_text_buffer_create_iter (InfTextBuffer *buffer
);
Creates a InfTextBufferIter pointing to the first segment of buffer
.
A InfTextBufferIter is used to traverse the buffer contents in steps of
so-called segments each of which is written by the same user. The function
returns NULL
if there are no segments (i.e. the buffer is empty).
The iterator stays valid as long as the buffer remains unmodified and
must be freed with inf_text_buffer_destroy_iter()
before.
A InfTextBufferIter to be freed by
inf_text_buffer_destroy_iter()
when done using it, or NULL
.
void inf_text_buffer_destroy_iter (InfTextBuffer *buffer
,InfTextBufferIter *iter
);
Destroys a InfTextBufferIter created by inf_text_buffer_create_iter()
.
gboolean inf_text_buffer_iter_next (InfTextBuffer *buffer
,InfTextBufferIter *iter
);
Moves iter
to point to the next segment in the buffer. If iter
already
points to the last segment, iter
is left unmodified and the function
returns FALSE
.
gboolean inf_text_buffer_iter_prev (InfTextBuffer *buffer
,InfTextBufferIter *iter
);
Moves iter
to point to the previous segment in the buffer. If iter
already points to the first segment, iter
is left unmodified and the
function returns FALSE
.
gpointer inf_text_buffer_iter_get_text (InfTextBuffer *buffer
,InfTextBufferIter *iter
);
Returns the text of the segment iter
points to. It is encoded in
buffer
's encoding (see inf_text_buffer_get_encoding()
).
guint inf_text_buffer_iter_get_length (InfTextBuffer *buffer
,InfTextBufferIter *iter
);
Returns the length of the segment iter
points to, in characters.
gsize inf_text_buffer_iter_get_bytes (InfTextBuffer *buffer
,InfTextBufferIter *iter
);
Returns the length of the segment iter
points to, in bytes.
guint inf_text_buffer_iter_get_author (InfTextBuffer *buffer
,InfTextBufferIter *iter
);
Returns the user ID of the user that has written the segment iter
points
to.
void inf_text_buffer_text_inserted (InfTextBuffer *buffer
,guint pos
,InfTextChunk *chunk
,InfUser *user
);
Emits the “text-inserted” signal. This is meant to be used
by interface implementations in their insert_text
function, or when text
was inserted by other means.
buffer |
||
pos |
A character offset into |
|
chunk |
A InfTextChunk. |
|
user |
A InfUser inserting |
void inf_text_buffer_text_erased (InfTextBuffer *buffer
,guint pos
,InfTextChunk *chunk
,InfUser *user
);
Emits the “text-erased” signal. This is meant to be used
by interface implementations in their erase_text
function, or when text
was erased by other means.
buffer |
||
pos |
The position to begin deleting characters from. |
|
chunk |
A InfTextChunk containing the erased text. |
|
user |
A InfUser that erases the text, or |
struct InfTextBufferIface { GTypeInterface parent; /* Virtual table */ const gchar* (*get_encoding)(InfTextBuffer* buffer); guint(*get_length)(InfTextBuffer* buffer); InfTextChunk*(*get_slice)(InfTextBuffer* buffer, guint pos, guint len); void(*insert_text)(InfTextBuffer* buffer, guint pos, InfTextChunk* chunk, InfUser* user); void(*erase_text)(InfTextBuffer* buffer, guint pos, guint len, InfUser* user); InfTextBufferIter*(*create_iter)(InfTextBuffer* buffer); void(*destroy_iter)(InfTextBuffer* buffer, InfTextBufferIter* iter); gboolean(*iter_next)(InfTextBuffer* buffer, InfTextBufferIter* iter); gboolean(*iter_prev)(InfTextBuffer* buffer, InfTextBufferIter* iter); gpointer(*iter_get_text)(InfTextBuffer* buffer, InfTextBufferIter* iter); guint(*iter_get_length)(InfTextBuffer* buffer, InfTextBufferIter* iter); gsize(*iter_get_bytes)(InfTextBuffer* buffer, InfTextBufferIter* iter); guint(*iter_get_author)(InfTextBuffer* buffer, InfTextBufferIter* iter); /* Signals */ void(*text_inserted)(InfTextBuffer* buffer, guint pos, InfTextChunk* chunk, InfUser* user); void(*text_erased)(InfTextBuffer* buffer, guint pos, InfTextChunk* chunk, InfUser* user); };
“text-erased”
signalvoid user_function (InfTextBuffer *inftextbuffer, guint arg1, InfTextChunk *arg2, InfUser *arg3, gpointer user_data)
inftextbuffer |
the object which received the signal. |
|
user_data |
user data set when the signal handler was connected. |
Flags: Run First
“text-inserted”
signalvoid user_function (InfTextBuffer *inftextbuffer, guint arg1, InfTextChunk *arg2, InfUser *arg3, gpointer user_data)
inftextbuffer |
the object which received the signal. |
|
user_data |
user data set when the signal handler was connected. |
Flags: Run First