diff options
Diffstat (limited to 'gedit/gedit-message-type.c')
-rwxr-xr-x | gedit/gedit-message-type.c | 526 |
1 files changed, 0 insertions, 526 deletions
diff --git a/gedit/gedit-message-type.c b/gedit/gedit-message-type.c deleted file mode 100755 index 61e782b3..00000000 --- a/gedit/gedit-message-type.c +++ /dev/null @@ -1,526 +0,0 @@ -#include "gedit-message-type.h" - -/** - * SECTION:gedit-message-type - * @short_description: message type description - * @include: gedit/gedit-message-type.h - * - * A message type is a prototype description for a #GeditMessage used to - * transmit messages on a #GeditMessageBus. The message type describes - * the Object Path, Method and Arguments of the message. - * - * A message type can contain any number of required and optional arguments. - * To instantiate a #GeditMessage from a #GeditMessageType, use - * gedit_message_type_instantiate(). - * - * Registering a new message type on a #GeditMessageBus with - * gedit_message_bus_register() internally creates a new #GeditMessageType. When - * then using gedit_message_bus_send(), an actual instantiation of the - * registered type is internally created and send over the bus. - * - * <example> - * <programlisting> - * // Defining a new message type - * GeditMessageType *message_type = gedit_message_type_new ("/plugins/example", - * "method", - * 0, - * "arg1", G_TYPE_STRING, - * NULL); - * - * // Instantiating an actual message from the type - * GeditMessage *message = gedit_message_type_instantiate (message_type, - * "arg1", "Hello World", - * NULL); - * </programlisting> - * </example> - * - * Since: 2.25.3 - * - */ -typedef struct -{ - GType type; - gboolean required; -} ArgumentInfo; - -struct _GeditMessageType -{ - gint ref_count; - - gchar *object_path; - gchar *method; - - guint num_arguments; - guint num_required; - - GHashTable *arguments; // mapping of key -> ArgumentInfo -}; - -/** - * gedit_message_type_ref: - * @message_type: the #GeditMessageType - * - * Increases the reference count on @message_type. - * - * Return value: @message_type - * - */ -GeditMessageType * -gedit_message_type_ref (GeditMessageType *message_type) -{ - g_return_val_if_fail (message_type != NULL, NULL); - g_atomic_int_inc (&message_type->ref_count); - - return message_type; -} - -/** - * gedit_message_type_unref: - * @message_type: the #GeditMessageType - * - * Decreases the reference count on @message_type. When the reference count - * drops to 0, @message_type is destroyed. - * - */ -void -gedit_message_type_unref (GeditMessageType *message_type) -{ - g_return_if_fail (message_type != NULL); - - if (!g_atomic_int_dec_and_test (&message_type->ref_count)) - return; - - g_free (message_type->object_path); - g_free (message_type->method); - - g_hash_table_destroy (message_type->arguments); - g_free (message_type); -} - -/** - * gedit_message_type_get_type: - * - * Retrieves the GType object which is associated with the - * #GeditMessageType class. - * - * Return value: the GType associated with #GeditMessageType. - **/ -GType -gedit_message_type_get_type (void) -{ - static GType our_type = 0; - - if (!our_type) - our_type = g_boxed_type_register_static ( - "GeditMessageType", - (GBoxedCopyFunc) gedit_message_type_ref, - (GBoxedFreeFunc) gedit_message_type_unref); - - return our_type; -} - -/** - * gedit_message_type_identifier: - * @object_path: the object path - * @method: the method - * - * Get the string identifier for @method at @object_path. - * - * Return value: the identifier for @method at @object_path - * - */ -gchar * -gedit_message_type_identifier (const gchar *object_path, - const gchar *method) -{ - return g_strconcat (object_path, ".", method, NULL); -} - -/** - * gedit_message_type_is_valid_object_path: - * @object_path: the object path - * - * Returns whether @object_path is a valid object path - * - * Return value: %TRUE if @object_path is a valid object path - * - */ -gboolean -gedit_message_type_is_valid_object_path (const gchar *object_path) -{ - if (!object_path) - return FALSE; - - /* needs to start with / */ - if (*object_path != '/') - return FALSE; - - while (*object_path) - { - if (*object_path == '/') - { - ++object_path; - - if (!*object_path || !(g_ascii_isalpha (*object_path) || *object_path == '_')) - return FALSE; - } - else if (!(g_ascii_isalnum (*object_path) || *object_path == '_')) - { - return FALSE; - } - - ++object_path; - } - - return TRUE; -} - -/** - * gedit_message_type_is_supported: - * @type: the #GType - * - * Returns if @type is #GType supported by the message system. - * - * Return value: %TRUE if @type is a supported #GType - * - */ -gboolean -gedit_message_type_is_supported (GType type) -{ - gint i = 0; - - static const GType type_list[] = - { - G_TYPE_BOOLEAN, - G_TYPE_CHAR, - G_TYPE_UCHAR, - G_TYPE_INT, - G_TYPE_UINT, - G_TYPE_LONG, - G_TYPE_ULONG, - G_TYPE_INT64, - G_TYPE_UINT64, - G_TYPE_ENUM, - G_TYPE_FLAGS, - G_TYPE_FLOAT, - G_TYPE_DOUBLE, - G_TYPE_STRING, - G_TYPE_POINTER, - G_TYPE_BOXED, - G_TYPE_OBJECT, - G_TYPE_INVALID - }; - - if (!G_TYPE_IS_VALUE_TYPE (type)) - return FALSE; - - while (type_list[i] != G_TYPE_INVALID) - { - if (g_type_is_a (type, type_list[i])) - return TRUE; - i++; - } - - return FALSE; -} - -/** - * gedit_message_type_new_valist: - * @object_path: the object path - * @method: the method - * @num_optional: number of optional arguments - * @var_args: key/gtype pair variable argument list - * - * Create a new #GeditMessageType for @method at @object_path. Argument names - * and values are supplied by the NULL terminated variable argument list. - * The last @num_optional provided arguments are considered optional. - * - * Return value: the newly constructed #GeditMessageType - * - */ -GeditMessageType * -gedit_message_type_new_valist (const gchar *object_path, - const gchar *method, - guint num_optional, - va_list var_args) -{ - GeditMessageType *message_type; - - g_return_val_if_fail (object_path != NULL, NULL); - g_return_val_if_fail (method != NULL, NULL); - g_return_val_if_fail (gedit_message_type_is_valid_object_path (object_path), NULL); - - message_type = g_new0(GeditMessageType, 1); - - message_type->ref_count = 1; - message_type->object_path = g_strdup(object_path); - message_type->method = g_strdup(method); - message_type->num_arguments = 0; - message_type->arguments = g_hash_table_new_full (g_str_hash, - g_str_equal, - (GDestroyNotify)g_free, - (GDestroyNotify)g_free); - - gedit_message_type_set_valist (message_type, num_optional, var_args); - return message_type; -} - -/** - * gedit_message_type_new: - * @object_path: the object path - * @method: the method - * @num_optional: number of optional arguments - * @...: key/gtype pair variable argument list - * - * Create a new #GeditMessageType for @method at @object_path. Argument names - * and values are supplied by the NULL terminated variable argument list. - * The last @num_optional provided arguments are considered optional. - * - * Return value: the newly constructed #GeditMessageType - * - */ -GeditMessageType * -gedit_message_type_new (const gchar *object_path, - const gchar *method, - guint num_optional, - ...) -{ - GeditMessageType *message_type; - va_list var_args; - - va_start(var_args, num_optional); - message_type = gedit_message_type_new_valist (object_path, method, num_optional, var_args); - va_end(var_args); - - return message_type; -} - -/** - * gedit_message_type_set: - * @message_type: the #GeditMessageType - * @num_optional: number of optional arguments - * @...: key/gtype pair variable argument list - * - * Sets argument names/types supplied by the NULL terminated variable - * argument list. The last @num_optional provided arguments are considered - * optional. - * - */ -void -gedit_message_type_set (GeditMessageType *message_type, - guint num_optional, - ...) -{ - va_list va_args; - - va_start (va_args, num_optional); - gedit_message_type_set_valist (message_type, num_optional, va_args); - va_end (va_args); -} - -/** - * gedit_message_type_set_valist: - * @message_type: the #GeditMessageType - * @num_optional: number of optional arguments - * @var_args: key/gtype pair variable argument list - * - * Sets argument names/types supplied by the NULL terminated variable - * argument list @var_args. The last @num_optional provided arguments are - * considered optional. - * - */ -void -gedit_message_type_set_valist (GeditMessageType *message_type, - guint num_optional, - va_list var_args) -{ - const gchar *key; - ArgumentInfo **optional = g_new0(ArgumentInfo *, num_optional); - guint i; - guint added = 0; - - // parse key -> gtype pair arguments - while ((key = va_arg (var_args, const gchar *)) != NULL) - { - // get corresponding GType - GType gtype = va_arg (var_args, GType); - ArgumentInfo *info; - - if (!gedit_message_type_is_supported (gtype)) - { - g_error ("Message type '%s' is not supported", g_type_name (gtype)); - - gedit_message_type_unref (message_type); - g_free (optional); - - return; - } - - info = g_new(ArgumentInfo, 1); - info->type = gtype; - info->required = TRUE; - - g_hash_table_insert (message_type->arguments, g_strdup (key), info); - - ++message_type->num_arguments; - ++added; - - if (num_optional > 0) - { - for (i = num_optional - 1; i > 0; --i) - optional[i] = optional[i - 1]; - - *optional = info; - } - } - - message_type->num_required += added; - - // set required for last num_optional arguments - for (i = 0; i < num_optional; ++i) - { - if (optional[i]) - { - optional[i]->required = FALSE; - --message_type->num_required; - } - } - - g_free (optional); -} - -/** - * gedit_message_type_instantiate_valist: - * @message_type: the #GeditMessageType - * @va_args: NULL terminated variable list of key/value pairs - * - * Instantiate a new message from the message type with specific values - * for the message arguments. - * - * Return value: the newly created message - * - */ -GeditMessage * -gedit_message_type_instantiate_valist (GeditMessageType *message_type, - va_list va_args) -{ - GeditMessage *message; - - g_return_val_if_fail (message_type != NULL, NULL); - - message = GEDIT_MESSAGE (g_object_new (GEDIT_TYPE_MESSAGE, "type", message_type, NULL)); - gedit_message_set_valist (message, va_args); - - return message; -} - -/** - * gedit_message_type_instantiate: - * @message_type: the #GeditMessageType - * @...: NULL terminated variable list of key/value pairs - * - * Instantiate a new message from the message type with specific values - * for the message arguments. - * - * Return value: the newly created message - * - */ -GeditMessage * -gedit_message_type_instantiate (GeditMessageType *message_type, - ...) -{ - GeditMessage *message; - va_list va_args; - - va_start (va_args, message_type); - message = gedit_message_type_instantiate_valist (message_type, va_args); - va_end (va_args); - - return message; -} - -/** - * gedit_message_type_get_object_path: - * @message_type: the #GeditMessageType - * - * Get the message type object path. - * - * Return value: the message type object path - * - */ -const gchar * -gedit_message_type_get_object_path (GeditMessageType *message_type) -{ - return message_type->object_path; -} - -/** - * gedit_message_type_get_method: - * @message_type: the #GeditMessageType - * - * Get the message type method. - * - * Return value: the message type method - * - */ -const gchar * -gedit_message_type_get_method (GeditMessageType *message_type) -{ - return message_type->method; -} - -/** - * gedit_message_type_lookup: - * @message_type: the #GeditMessageType - * @key: the argument key - * - * Get the argument key #GType. - * - * Return value: the #GType of @key - * - */ -GType -gedit_message_type_lookup (GeditMessageType *message_type, - const gchar *key) -{ - ArgumentInfo *info = g_hash_table_lookup (message_type->arguments, key); - - if (!info) - return G_TYPE_INVALID; - - return info->type; -} - -typedef struct -{ - GeditMessageTypeForeach func; - gpointer user_data; -} ForeachInfo; - -static void -foreach_gtype (const gchar *key, - ArgumentInfo *info, - ForeachInfo *finfo) -{ - finfo->func (key, info->type, info->required, finfo->user_data); -} - -/** - * gedit_message_type_foreach: - * @message_type: the #GeditMessageType - * @func: the callback function - * @user_data: user data supplied to the callback function - * - * Calls @func for each argument in the message type. - * - */ -void -gedit_message_type_foreach (GeditMessageType *message_type, - GeditMessageTypeForeach func, - gpointer user_data) -{ - ForeachInfo info = {func, user_data}; - g_hash_table_foreach (message_type->arguments, (GHFunc)foreach_gtype, &info); -} - -// ex:ts=8:noet: |