|  |  |  | IBus Reference Manual |  | 
|---|---|---|---|---|
| Top | Description | ||||
#define IBUS_TYPE_OBJECT_PATH #define IBUS_TYPE_ARRAY #define IBUS_TYPE_STRUCT #define IBUS_TYPE_DICT_ENTRY #define IBUS_TYPE_VARIANT typedef IBusMessage; typedef IBusMessageIter; GType ibus_type_get_object_path (void); GType ibus_type_get_array (void); GType ibus_type_get_struct (void); GType ibus_type_get_dict_entry (void); GType ibus_type_get_variant (void); IBusMessage * ibus_message_new (gint message_type); IBusMessage * ibus_message_ref (IBusMessage *message); void ibus_message_unref (IBusMessage *message); IBusMessage * ibus_message_new_method_call (const gchar *destination,const gchar *path,const gchar *interface,const gchar *method); IBusMessage * ibus_message_new_method_return (IBusMessage *reply_to); IBusMessage * ibus_message_new_error (IBusMessage *reply_to,const gchar *error_name,const gchar *error_message); IBusMessage * ibus_message_new_error_printf (IBusMessage *reply_to,const gchar *error_name,const gchar *error_format,...); IBusMessage * ibus_message_new_signal (const gchar *path,const gchar *interface,const gchar *method); gboolean ibus_message_is_method_call (IBusMessage *message,const gchar *interface,const gchar *method); gboolean ibus_message_is_error (IBusMessage *message,const gchar *error_name); gboolean ibus_message_is_signal (IBusMessage *message,const gchar *interface,const gchar *signal_name); gboolean ibus_message_set_destination (IBusMessage *message,const gchar *destination); gboolean ibus_message_set_sender (IBusMessage *message,const gchar *sender); gboolean ibus_message_set_error_name (IBusMessage *message,const gchar *error_name); gboolean ibus_message_set_interface (IBusMessage *message,const gchar *interface); gboolean ibus_message_set_member (IBusMessage *message,const gchar *member); gboolean ibus_message_set_path (IBusMessage *message,const gchar *path); void ibus_message_set_no_reply (IBusMessage *message,gboolean no_reply); gboolean ibus_message_set_reply_serial (IBusMessage *message,guint32 reply_serial); gint ibus_message_get_type (IBusMessage *message); const gchar * ibus_message_get_destination (IBusMessage *message); const gchar * ibus_message_get_sender (IBusMessage *message); const gchar * ibus_message_get_error_name (IBusMessage *message); const gchar * ibus_message_get_error_message (IBusMessage *message); const gchar * ibus_message_get_interface (IBusMessage *message); const gchar * ibus_message_get_member (IBusMessage *message); const gchar * ibus_message_get_path (IBusMessage *message); gboolean ibus_message_get_no_reply (IBusMessage *message); guint32 ibus_message_get_reply_serial (IBusMessage *message); guint32 ibus_message_get_serial (IBusMessage *message); gboolean ibus_message_append_args (IBusMessage *message,GType first_arg_type,...); gboolean ibus_message_append_args_valist (IBusMessage *message,GType first_arg_type,va_list va_args); gboolean ibus_message_get_args (IBusMessage *message,IBusError **error,GType first_arg_type,...); gboolean ibus_message_get_args_valist (IBusMessage *message,IBusError **error,GType first_arg_type,va_list va_args); void ibus_message_iter_init_append (IBusMessage *message,IBusMessageIter *iter); gboolean ibus_message_iter_append (IBusMessageIter *iter,GType type,gconstpointer value); gboolean ibus_message_iter_copy_data (IBusMessageIter *dst,IBusMessageIter *src); gboolean ibus_message_iter_init (IBusMessage *message,IBusMessageIter *iter); void ibus_message_iter_get_basic (IBusMessageIter *iter,gpointer value); gboolean ibus_message_iter_get (IBusMessageIter *iter,GType type,gpointer value); gboolean ibus_message_iter_next (IBusMessageIter *iter); gboolean ibus_message_iter_has_next (IBusMessageIter *iter); gboolean ibus_message_iter_open_container (IBusMessageIter *iter,GType type,const gchar *contained_signature,IBusMessageIter *sub); gboolean ibus_message_iter_close_container (IBusMessageIter *iter,IBusMessageIter *sub); gboolean ibus_message_iter_recurse (IBusMessageIter *iter,GType type,IBusMessageIter *sub); GType ibus_message_iter_get_arg_type (IBusMessageIter *iter); GType ibus_message_iter_get_element_type (IBusMessageIter *iter); gchar * ibus_message_to_string (IBusMessage *message);
An IBusMessage is essentially a DBusMessage, which representing a message received from or to be sent to another application.
Besides DBusMessage functions, An IBusMessage can be manipulated with its own specific functions, which are defined in this section.
#define IBUS_TYPE_OBJECT_PATH (ibus_type_get_object_path ())
Type of object path.
#define IBUS_TYPE_DICT_ENTRY (ibus_type_get_dict_entry ())
Type of IBusDictEntry.
GType               ibus_type_get_object_path           (void);
Gets the type of object path.
| Returns : | Type of object path. | 
GType               ibus_type_get_array                 (void);
Gets the type of IBusArray.
| Returns : | Type of IBusArray. | 
GType               ibus_type_get_struct                (void);
Gets the type of IBusStruct.
| Returns : | Type of IBusStruct. | 
GType               ibus_type_get_dict_entry            (void);
Gets the type of IBusDictEntry.
| Returns : | Type of IBusDictEntry. | 
GType               ibus_type_get_variant               (void);
Gets the type of IBusVariant.
| Returns : | Type of IBusVariant. | 
IBusMessage *       ibus_message_new                    (gint message_type);
New an IBusMessage. Valid D-Bus message types include:
DBUS_MESSAGE_TYPE_METHOD_CALL
DBUS_MESSAGE_TYPE_METHOD_RETURN
DBUS_MESSAGE_TYPE_ERROR
DBUS_MESSAGE_TYPE_SIGNAL
These are defined in dbus-protocol.h in D-Bus.
| 
 | Type of the message. | 
| Returns : | A newly allocated IBusMessage according to message_type. | 
IBusMessage *       ibus_message_ref                    (IBusMessage *message);
Increments the reference count of an IBusMessage.
| 
 | An IBusMessage. | 
| Returns : | The IBusMessage. | 
void                ibus_message_unref                  (IBusMessage *message);
Decrements the reference count of a DBusMessage, freeing the message if the count reaches 0.
| 
 | An IBusMessage. | 
IBusMessage * ibus_message_new_method_call (const gchar *destination,const gchar *path,const gchar *interface,const gchar *method);
Constructs a new message to invoke a method on a remote object.
The destination may be NULL in which case no destination is set;
this is appropriate when using IBus/D-Bus in a peer-to-peer context (no message bus).
The interface may be NULL, which means that if multiple methods with the given name
exist it is undefined which one will be invoked.
The path and method names may not be NULL.
Destination, path, interface, and method name can't contain any invalid characters (see the D-Bus specification).
IBusMessage *       ibus_message_new_method_return      (IBusMessage *reply_to);
Constructs a message that is a reply to a method call.
| 
 | The IBusMessage being replied to. | 
| Returns : | A newly allocate IBusMessage; or NULLif memory cannot be allocated. | 
IBusMessage * ibus_message_new_error (IBusMessage *reply_to,const gchar *error_name,const gchar *error_message);
Creates a new message that is an error reply to another message.
Error replies are most common in response to method calls, but can be returned in reply to any message.
The error name must be a valid error name according to the syntax given in the D-Bus specification.
If you don't want to make up an error name just use DBUS_ERROR_FAILED.
Use ibus_message_unref() to free the produced IBusMessage.
IBusMessage * ibus_message_new_error_printf (IBusMessage *reply_to,const gchar *error_name,const gchar *error_format,...);
Creates a new message that is an error reply to another message.
Error replies are most common in response to method calls, but can be returned in reply to any message.
The error name must be a valid error name according to the syntax given in the D-Bus specification.
If you don't want to make up an error name just use DBUS_ERROR_FAILED.
| 
 | The IBusMessage being replied to. | 
| 
 | Name of the error. | 
| 
 | Error format string as in printf()format. | 
| 
 | Format arguments, as in printf(). | 
| Returns : | A newly allocate IBusMessage with the error information; or NULLif memory cannot be allocated. | 
IBusMessage * ibus_message_new_signal (const gchar *path,const gchar *interface,const gchar *method);
Constructs a new message representing a signal emission. Returns NULL if memory can't be allocated for the message. A signal is identified by its originating object path, interface, and the name of the signal. Path, interface, and signal name must all be valid (the D-Bus specification defines the syntax of these fields).
gboolean ibus_message_is_method_call (IBusMessage *message,const gchar *interface,const gchar *method);
Checks whether the message is a method call with the given interface and member fields.
If the message is not DBUS_MESSAGE_TYPE_METHOD_CALL, or has a different interface or member field, returns FALSE. If the interface field is missing, then it will be assumed equal to the provided interface. The D-Bus protocol allows method callers to leave out the interface name.
gboolean ibus_message_is_error (IBusMessage *message,const gchar *error_name);
Checks whether the message is an error reply with the given error name. If the message is not DBUS_MESSAGE_TYPE_ERROR, or has a different name, returns FALSE.
gboolean ibus_message_is_signal (IBusMessage *message,const gchar *interface,const gchar *signal_name);
Checks whether the message is a signal with the given interface and member fields.
If the message is not DBUS_MESSAGE_TYPE_SIGNAL, or has a different interface or member field, returns FALSE.
gboolean ibus_message_set_destination (IBusMessage *message,const gchar *destination);
Sets the message's destination.
The destination is the name of another connection on the bus and may be either the unique name assigned by the bus to each connection, or a well-known name specified in advance.
The destination name must contain only valid characters as defined in the D-Bus specification.
gboolean ibus_message_set_sender (IBusMessage *message,const gchar *sender);
Sets the message sender.
The sender must be a valid bus name as defined in the D-Bus specification.
Usually you don't want to call this. The message bus daemon will call it to set the origin of each message. If you aren't implementing a message bus daemon you shouldn't need to set the sender.
gboolean ibus_message_set_error_name (IBusMessage *message,const gchar *error_name);
Sets the name of the error (DBUS_MESSAGE_TYPE_ERROR).
The name is fully-qualified (namespaced).
The error name must contain only valid characters as defined in the D-Bus specification.
gboolean ibus_message_set_interface (IBusMessage *message,const gchar *interface);
Sets the interface this message is being sent to
(for DBUS_MESSAGE_TYPE_METHOD_CALL) or the interface
a signal is being emitted from (for DBUS_MESSAGE_TYPE_SIGNAL).
The interface name must contain only valid characters as defined in the D-Bus specification.
gboolean ibus_message_set_member (IBusMessage *message,const gchar *member);
Sets the interface member being invoked (DBUS_MESSAGE_TYPE_METHOD_CALL)
or emitted (DBUS_MESSAGE_TYPE_SIGNAL).
The member name must contain only valid characters as defined in the D-Bus specification.
gboolean ibus_message_set_path (IBusMessage *message,const gchar *path);
Sets the object path this message is being sent to (for $DBUS_MESSAGE_TYPE_METHOD_CALL)
or the one a signal is being emitted from (for DBUS_MESSAGE_TYPE_SIGNAL).
The path must contain only valid characters as defined in the D-Bus specification.
void ibus_message_set_no_reply (IBusMessage *message,gboolean no_reply);
Sets a flag indicating that the message does not want a reply; if this flag is set, the other end of the connection may (but is not required to) optimize by not sending method return or error replies.
If this flag is set, there is no way to know whether the message successfully arrived at the remote end. Normally you know a message was received when you receive the reply to it.
The flag is FALSE by default, that is by default the other end is required to reply.
On the protocol level this toggles DBUS_HEADER_FLAG_NO_REPLY_EXPECTED.
| 
 | An IBusMessage. | 
| 
 | TRUEif no reply is desired. | 
gboolean ibus_message_set_reply_serial (IBusMessage *message,guint32 reply_serial);
Sets the reply serial of a message (the serial of the message this is a reply to).
gint                ibus_message_get_type               (IBusMessage *message);
Gets the type of an IBusMessage.
| 
 | An IBusMessage. | 
| Returns : | Type of the IBusMessage. | 
const gchar *       ibus_message_get_destination        (IBusMessage *message);
Gets the destination of a message or NULL if there is none set.
The returned string becomes invalid if the message is modified, since it points into the wire-marshaled message data.
| 
 | An IBusMessage. | 
| Returns : | Destination of the IBusMessage; NULL if there is none set. | 
const gchar *       ibus_message_get_sender             (IBusMessage *message);
Gets the unique name of the connection which originated this message,
or NULL if unknown or inapplicable.
The sender is filled in by the message bus.
Note, the returned sender is always the unique bus name. Connections may own multiple other bus names, but those are not found in the sender field.
The returned string becomes invalid if the message is modified, since it points into the wire-marshaled message data.
| 
 | An IBusMessage. | 
| Returns : | Sender of the IBusMessage; NULLif unknown or inapplicable. | 
const gchar *       ibus_message_get_error_name         (IBusMessage *message);
Gets the error name (DBUS_MESSAGE_TYPE_ERROR only) or NULL if none.
The returned string becomes invalid if the message is modified, since it points into the wire-marshaled message data.
| 
 | An IBusMessage. | 
| Returns : | Error name of the IBusMessage; NULLif none. | 
const gchar *       ibus_message_get_error_message      (IBusMessage *message);
Gets the error message (DBUS_MESSAGE_TYPE_ERROR only) or NULL if none.
The returned string becomes invalid if the message is modified, since it points into the wire-marshaled message data.
| 
 | An IBusMessage. | 
| Returns : | Error message of the IBusMessage; NULLif none. | 
const gchar *       ibus_message_get_interface          (IBusMessage *message);
Gets the interface this message is being sent to (for DBUS_MESSAGE_TYPE_METHOD_CALL)
or being emitted from (for DBUS_MESSAGE_TYPE_SIGNAL).
The interface name is fully-qualified (namespaced). Returns NULL if none.
The returned string becomes invalid if the message is modified, since it points into the wire-marshaled message data.
| 
 | An IBusMessage. | 
| Returns : | Interface name of the IBusMessage; NULLif none. | 
const gchar *       ibus_message_get_member             (IBusMessage *message);
Gets the interface member being invoked (DBUS_MESSAGE_TYPE_METHOD_CALL)
or emitted (DBUS_MESSAGE_TYPE_SIGNAL).
Returns NULL if none.
The returned string becomes invalid if the message is modified, since it points into the wire-marshaled message data.
| 
 | An IBusMessage. | 
| Returns : | Member name of the IBusMessage; NULLif none. | 
const gchar *       ibus_message_get_path               (IBusMessage *message);
Gets the object path this message is being sent to (for DBUS_MESSAGE_TYPE_METHOD_CALL)
or being emitted from (for DBUS_MESSAGE_TYPE_SIGNAL).
Returns NULL if none.
See also dbus_message_get_path_decomposed().
The returned string becomes invalid if the message is modified, since it points into the wire-marshaled message data.
| 
 | An IBusMessage. | 
| Returns : | Object path of the IBusMessage; NULLif none. | 
gboolean            ibus_message_get_no_reply           (IBusMessage *message);
Returns TRUE if the message does not expect a reply.
guint32             ibus_message_get_reply_serial       (IBusMessage *message);
Returns the serial that the message is a reply to or 0 if none.
| 
 | An IBusMessage. | 
| Returns : | The serial that the message is a reply to or 0 if none. | 
guint32             ibus_message_get_serial             (IBusMessage *message);
Returns the serial of a message or 0 if none has been specified.
The message's serial number is provided by the application sending the message and is used to identify replies to this message.
All messages received on a connection will have a serial provided by the remote application.
For messages you're sending, dbus_connection_send() will assign a serial and return it to you.
| 
 | An IBusMessage. | 
| Returns : | The serial of a message or 0 if none has been specified. | 
gboolean ibus_message_append_args (IBusMessage *message,GType first_arg_type,...);
Appends fields to a message given a variable argument list.
The variable argument list should contain the type of each argument followed by the value to append. Appendable types are basic types, and arrays of fixed-length basic types. To append variable-length basic types, or any more complex value, you have to use an iterator rather than this function.
To append a basic type, specify its type code followed by the address of the value. For example:
    dbus_int32_t v_INT32 = 42;
    const char *v_STRING = "Hello World";
    dbus_message_append_args (message,
    DBUS_TYPE_INT32, &v_INT32,
    DBUS_TYPE_STRING, &v_STRING,
    DBUS_TYPE_INVALID);
   
To append an array of fixed-length basic types, pass in the DBUS_TYPE_ARRAY typecode,
the element typecode, the address of the array pointer,
and a 32-bit integer giving the number of elements in the array. So for example:
    const dbus_int32_t array[] = { 1, 2, 3 };
    const dbus_int32_t *v_ARRAY = array;
    dbus_message_append_args (message,
    DBUS_TYPE_ARRAY, DBUS_TYPE_INT32, &v_ARRAY, 3,
    DBUS_TYPE_INVALID);
   
in C, given "int array[]", "&array == array" (the comp.lang.c FAQ says otherwise, but gcc and the FAQ don't agree). So if you're using an array instead of a pointer you have to create a pointer variable, assign the array to it, then take the address of the pointer variable. For strings it works to write const char *array = "Hello" and then use &array though.
The last argument to this function must be DBUS_TYPE_INVALID, marking the end of the argument list.
If you don't do this then libdbus won't know to stop and will read invalid memory.
String/signature/path arrays should be passed in as "const char*** address_of_array" and "int n_elements"
see_also: ibus_message_append_args_valist().
gboolean ibus_message_append_args_valist (IBusMessage *message,GType first_arg_type,va_list va_args);
Like ibus_message_append_args() but takes a va_list for use by language bindings.
see_also: ibus_message_append_args().
gboolean ibus_message_get_args (IBusMessage *message,IBusError **error,GType first_arg_type,...);
Gets arguments from a message given a variable argument list.
The supported types include those supported by ibus_message_append_args();
that is, basic types and arrays of fixed-length basic types.
The arguments are the same as they would be for ibus_message_iter_get_basic()
or ibus_message_iter_get_fixed_array().
In addition to those types, arrays of string, object path, and signature are supported;
but these are returned as allocated memory and must be freed with dbus_free_string_array(),
while the other types are returned as const references.
To get a string array pass in "char ***array_location" and "int *n_elements".
The variable argument list should contain the type of the argument followed by a pointer to
where the value should be stored. The list is terminated with DBUS_TYPE_INVALID.
Except for string arrays, the returned values are constant; do not free them. They point into the IBusMessage.
If the requested arguments are not present, or do not have the requested types, then an error will be set.
If more arguments than requested are present, the requested arguments are returned and the extra arguments are ignored.
see_also: ibus_message_append_args(), ibus_message_get_args_valist().
| 
 | An IBusMessage. | 
| 
 | Error to be filled in on failure. | 
| 
 | Type of the first argument. | 
| 
 | Rest of arguments. | 
| Returns : | TRUEif succeed; FALSEotherwise. | 
gboolean ibus_message_get_args_valist (IBusMessage *message,IBusError **error,GType first_arg_type,va_list va_args);
Like ibus_message_get_args but takes a va_list for use by language bindings.
see_also: ibus_message_append_args_valist(), ibus_message_get_args().
void ibus_message_iter_init_append (IBusMessage *message,IBusMessageIter *iter);
Initializes a IBusMessageIter for appending arguments to the end of a message.
| 
 | An IBusMessage. | 
| 
 | An IBusMessageIter to to initialize. | 
gboolean ibus_message_iter_append (IBusMessageIter *iter,GType type,gconstpointer value);
Appends a basic-typed value to the message.
The basic types are the non-container types such as integer and string.
The "value" argument should be the address of a basic-typed value. So for string, const char**. For integer, dbus_int32_t*.
gboolean ibus_message_iter_copy_data (IBusMessageIter *dst,IBusMessageIter *src);
Deep copy an IBusMessageIter to another IBusMessageIter.
| 
 | Destination to be copy to. | 
| 
 | Source to be copy from. | 
| Returns : | TRUEif succeed;FALSEif failed. | 
Since 1.2.0.20090719
gboolean ibus_message_iter_init (IBusMessage *message,IBusMessageIter *iter);
Initializes an IBusMessageIter for reading the arguments of the message passed in.
When possible, ibus_message_get_args() is much more convenient.
Some types of argument can only be read with IBusMessageIter however.
The easiest way to iterate is like this:
    dbus_message_iter_init (&iter);
    while ((current_type = dbus_message_iter_get_arg_type (&iter)) != DBUS_TYPE_INVALID)
    dbus_message_iter_next (&iter);
   
IBusMessageIter contains no allocated memory;
it need not be freed, and can be copied by assignment or memcpy().
void ibus_message_iter_get_basic (IBusMessageIter *iter,gpointer value);
Reads a basic-typed value from the message iterator.
Basic types are the non-containers such as integer and string.
The value argument should be the address of a location to store the returned value. So for int32 it should be a "dbus_int32_t*" and for string a "const char**". The returned value is by reference and should not be freed.
Be sure you have somehow checked that dbus_message_iter_get_arg_type() matches the type you are expecting,
or you'll crash when you try to use an integer as a string or something.
To read any container type (array, struct, dict) you will need to recurse into the container with
dbus_message_iter_recurse().
If the container is an array of fixed-length values,
you can get all the array elements at once with dbus_message_iter_get_fixed_array().
Otherwise, you have to iterate over the container's contents one value at a time.
All basic-typed values are guaranteed to fit in 8 bytes. So you can write code like this:
    dbus_uint64_t value;
    int type;
    dbus_message_iter_get_basic (&read_iter, &value);
    type = dbus_message_iter_get_arg_type (&read_iter);
    dbus_message_iter_append_basic (&write_iter, type, &value);
   
On some really obscure platforms dbus_uint64_t might not exist, if you need to worry about this you will know. dbus_uint64_t is just one example of a type that's large enough to hold any possible value, you could use a struct or char[8] instead if you like.
| 
 | An IBusMessageIter. | 
| 
 | Result value stores here. Cannot be NULL. | 
gboolean ibus_message_iter_get (IBusMessageIter *iter,GType type,gpointer value);
Gets an value from an IBusMessageIter, then move on to the next element.
gboolean            ibus_message_iter_next              (IBusMessageIter *iter);
Moves the iterator to the next field, if any.
If there's no next field, returns FALSE. If the iterator moves forward, returns TRUE.
gboolean            ibus_message_iter_has_next          (IBusMessageIter *iter);
Checks if an iterator has any more fields.
gboolean ibus_message_iter_open_container (IBusMessageIter *iter,GType type,const gchar *contained_signature,IBusMessageIter *sub);
Appends a container-typed value to the message;
you are required to append the contents of the container using the returned sub-iterator,
and then call dbus_message_iter_close_container().
Container types are for example struct, variant, and array.
For variants, the contained_signature should be the type of the single value inside the variant.
For structs and dict entries, contained_signature should be NULL;
it will be set to whatever types you write into the struct.
For arrays, contained_signature should be the type of the array elements.
gboolean ibus_message_iter_close_container (IBusMessageIter *iter,IBusMessageIter *sub);
Closes a container-typed value appended to the message;
may write out more information to the message known only after the entire container is written,
and may free resources created by dbus_message_iter_open_container().
gboolean ibus_message_iter_recurse (IBusMessageIter *iter,GType type,IBusMessageIter *sub);
Recurses into a container value when reading values from a message, initializing a sub-iterator to use for traversing the child values of the container.
Note that this recurses into a value, not a type, so you can only recurse if the value exists. The main implication of this is that if you have for example an empty array of array of int32, you can recurse into the outermost array, but it will have no values, so you won't be able to recurse further. There's no array of int32 to recurse into.
If a container is an array of fixed-length types, it is much more efficient to use
 dbus_message_iter_get_fixed_array() to get the whole array in one shot,
 rather than individually walking over the array elements.
Be sure you have somehow checked that dbus_message_iter_get_arg_type()
matches the type you are expecting to recurse into.
Results of this function are undefined if there is no container to recurse into at the current iterator position.
GType               ibus_message_iter_get_arg_type      (IBusMessageIter *iter);
Returns the argument type of the argument that the message iterator points to.
If the iterator is at the end of the message, returns DBUS_TYPE_INVALID.
You can thus write a loop as follows:
    dbus_message_iter_init (&iter);
    while ((current_type = dbus_message_iter_get_arg_type (&iter)) != DBUS_TYPE_INVALID)
    dbus_message_iter_next (&iter);
   
| 
 | An IBusMessageIter. | 
| Returns : | The argument type. | 
GType               ibus_message_iter_get_element_type  (IBusMessageIter *iter);
Returns the element type of the array that the message iterator points to. Note that you need to check that the iterator points to an array prior to using this function.
| 
 | An IBusMessageIter. | 
| Returns : | The argument type. | 
gchar *             ibus_message_to_string              (IBusMessage *message);
Produces a pretty formatted string which show the information of the IBusMessage. This string is suitable for debugging information print out.
Free the string by g_free() after use.
| 
 | An IBusMessage. | 
| Returns : | A string which shows the information of the message. |