|  |  |  | IBus Reference Manual |  | 
|---|---|---|---|---|
| Top | Description | Object Hierarchy | ||||
struct IBusText; struct IBusTextClass; void ibus_text_append_attribute (IBusText *text,guint type,guint value,guint start_index,gint end_index); IBusAttrList * ibus_text_get_attributes (IBusText *text); gboolean ibus_text_get_is_static (IBusText *text); guint ibus_text_get_length (IBusText *text); const gchar * ibus_text_get_text (IBusText *text); IBusText * ibus_text_new_from_printf (const gchar *fmt,...); IBusText * ibus_text_new_from_static_string (const gchar *str); IBusText * ibus_text_new_from_string (const gchar *str); IBusText * ibus_text_new_from_ucs4 (const gunichar *str); IBusText * ibus_text_new_from_unichar (gunichar c); void ibus_text_set_attributes (IBusText *text,IBusAttrList *attrs);
An IBusText is the main text object in IBus. The text is decorated according to associated IBusAttribute, e.g. the foreground/background color, underline, and applied scope.
struct IBusText {
    gboolean is_static;
    gchar  *text;
    IBusAttrList *attrs;
};
A text object in IBus.
| gboolean  | Whether textis static, i.e., no need and will not be freed. Only TRUE if IBusText is newed fromibus_text_new_from_static_string(). | 
| gchar * | The string content of IBusText in UTF-8. | 
| IBusAttrList * | Associated IBusAttributes. | 
void ibus_text_append_attribute (IBusText *text,guint type,guint value,guint start_index,gint end_index);
Append an IBusAttribute for IBusText.
| 
 | an IBusText | 
| 
 | IBusAttributeType for text. | 
| 
 | Value for the type. | 
| 
 | The starting index, inclusive. | 
| 
 | The ending index, exclusive. | 
IBusAttrList *      ibus_text_get_attributes            (IBusText *text);
Return the attributes in an IBusText. Should not be freed.
| 
 | An IBusText. | 
| Returns : | the attrs in text. [transfer none] | 
gboolean            ibus_text_get_is_static             (IBusText *text);
Return the is_static in an IBusText.
| 
 | An IBusText. | 
| Returns : | the is_static in text. | 
guint               ibus_text_get_length                (IBusText *text);
Return number of characters in an IBusText.
This function is based on g_utf8_strlen(), so unlike strlen(),
it does not count by bytes but characters instead.
| 
 | An IBusText. | 
| Returns : | Number of character in text, not counted by bytes. | 
const gchar *       ibus_text_get_text                  (IBusText *text);
Return the text in an IBusText. Should not be freed.
| 
 | An IBusText. | 
| Returns : | the text in text. | 
IBusText * ibus_text_new_from_printf (const gchar *fmt,...);
New an IBusText from a printf expression.
The result of printf expression is stored in the new IBusText instance.
| 
 | printf format string. | 
| 
 | arguments for fmt. | 
| Returns : | A newly allocated IBusText. | 
IBusText *          ibus_text_new_from_static_string    (const gchar *str);
New an IBusText from a static string.
Since str is a static string which won't be freed.
This function will NOT duplicate str.
| 
 | An text string to be set. | 
| Returns : | A newly allocated IBusText. | 
IBusText *          ibus_text_new_from_string           (const gchar *str);
New an IBusText from a string.
str will be duplicated in IBusText, so feel free to free str after this function.
| 
 | An text string to be set. | 
| Returns : | A newly allocated IBusText. | 
IBusText *          ibus_text_new_from_ucs4             (const gunichar *str);
New an IBusText from an UCS-4 encoded string.
str will be duplicated in IBusText, so feel free to free str after this function.
| 
 | An text string to be set. | 
| Returns : | A newly allocated IBusText. | 
IBusText *          ibus_text_new_from_unichar          (gunichar c);
New an IBusText from a single UCS4-encoded character.
| 
 | A single UCS4-encoded character. | 
| Returns : | A newly allocated IBusText. | 
void ibus_text_set_attributes (IBusText *text,IBusAttrList *attrs);
| 
 | An IBusText. | 
| 
 | An IBusAttrList |