docs: let go of *

Since we are no longer using sgml mode, using /* */ to
escape block comments inside examples does not work anymore.
Switch to using line comments with //
This commit is contained in:
Matthias Clasen 2014-02-14 21:33:36 -05:00
parent 450e7b1036
commit bc6ee788b4
31 changed files with 162 additions and 175 deletions

View File

@ -71,7 +71,7 @@
* *
* if (g_file_has_uri_scheme (file, "cdda")) * if (g_file_has_uri_scheme (file, "cdda"))
* { * {
* /* do something special with uri */ * // do something special with uri
* } * }
* g_object_unref (file); * g_object_unref (file);
* ]| * ]|

View File

@ -165,10 +165,10 @@
* { * {
* GApplicationCommandLine *cmdline = data; * GApplicationCommandLine *cmdline = data;
* *
* /* do the heavy lifting in an idle */ * // do the heavy lifting in an idle
* *
* g_application_command_line_set_exit_status (cmdline, 0); * g_application_command_line_set_exit_status (cmdline, 0);
* g_object_unref (cmdline); /* this releases the application */ * g_object_unref (cmdline); // this releases the application
* *
* return G_SOURCE_REMOVE; * return G_SOURCE_REMOVE;
* } * }
@ -177,7 +177,7 @@
* command_line (GApplication *application, * command_line (GApplication *application,
* GApplicationCommandLine *cmdline) * GApplicationCommandLine *cmdline)
* { * {
* /* keep the application running until we are done with this commandline */ * // keep the application running until we are done with this commandline
* g_application_hold (application); * g_application_hold (application);
* *
* g_object_set_data_full (G_OBJECT (cmdline), * g_object_set_data_full (G_OBJECT (cmdline),

View File

@ -106,13 +106,12 @@ g_cancellable_class_init (GCancellableClass *klass)
* *
* An example of how to us this: * An example of how to us this:
* |[<!-- language="C" --> * |[<!-- language="C" -->
* /&ast; Make sure we don't do unnecessary work if already cancelled &ast;/ * // Make sure we don't do unnecessary work if already cancelled
* if (g_cancellable_set_error_if_cancelled (cancellable, error)) * if (g_cancellable_set_error_if_cancelled (cancellable, error))
* return; * return;
* *
* /&ast; Set up all the data needed to be able to * // Set up all the data needed to be able to handle cancellation
* &ast; handle cancellation of the operation * // of the operation
* &ast;/
* my_data = my_data_new (...); * my_data = my_data_new (...);
* *
* id = 0; * id = 0;
@ -121,13 +120,12 @@ g_cancellable_class_init (GCancellableClass *klass)
* G_CALLBACK (cancelled_handler) * G_CALLBACK (cancelled_handler)
* data, NULL); * data, NULL);
* *
* /&ast; cancellable operation here... &ast;/ * // cancellable operation here...
* *
* g_cancellable_disconnect (cancellable, id); * g_cancellable_disconnect (cancellable, id);
* *
* /&ast; cancelled_handler is never called after this, * // cancelled_handler is never called after this, it is now safe
* &ast; it is now safe to free the data * // to free the data
* &ast;/
* my_data_free (my_data); * my_data_free (my_data);
* ]| * ]|
* *

View File

@ -56,7 +56,7 @@
* is typically done in the function returning the #GQuark for the * is typically done in the function returning the #GQuark for the
* error domain: * error domain:
* |[<!-- language="C" --> * |[<!-- language="C" -->
* /&ast; foo-bar-error.h: &ast;/ * // foo-bar-error.h:
* *
* #define FOO_BAR_ERROR (foo_bar_error_quark ()) * #define FOO_BAR_ERROR (foo_bar_error_quark ())
* GQuark foo_bar_error_quark (void); * GQuark foo_bar_error_quark (void);
@ -66,10 +66,10 @@
* FOO_BAR_ERROR_FAILED, * FOO_BAR_ERROR_FAILED,
* FOO_BAR_ERROR_ANOTHER_ERROR, * FOO_BAR_ERROR_ANOTHER_ERROR,
* FOO_BAR_ERROR_SOME_THIRD_ERROR, * FOO_BAR_ERROR_SOME_THIRD_ERROR,
* FOO_BAR_N_ERRORS /&ast;< skip >&ast;/ * FOO_BAR_N_ERRORS / *< skip >* /
* } FooBarError; * } FooBarError;
* *
* /&ast; foo-bar-error.c: &ast;/ * // foo-bar-error.c:
* *
* static const GDBusErrorEntry foo_bar_error_entries[] = * static const GDBusErrorEntry foo_bar_error_entries[] =
* { * {
@ -78,7 +78,7 @@
* {FOO_BAR_ERROR_SOME_THIRD_ERROR, "org.project.Foo.Bar.Error.SomeThirdError"}, * {FOO_BAR_ERROR_SOME_THIRD_ERROR, "org.project.Foo.Bar.Error.SomeThirdError"},
* }; * };
* *
* /&ast; Ensure that every error code has an associated D-Bus error name &ast;/ * // Ensure that every error code has an associated D-Bus error name
* G_STATIC_ASSERT (G_N_ELEMENTS (foo_bar_error_entries) == FOO_BAR_N_ERRORS); * G_STATIC_ASSERT (G_N_ELEMENTS (foo_bar_error_entries) == FOO_BAR_N_ERRORS);
* *
* GQuark * GQuark

View File

@ -80,13 +80,13 @@
* |[<!-- language="C" --> * |[<!-- language="C" -->
* GIOExtensionPoint *ep; * GIOExtensionPoint *ep;
* *
* /&ast; Register an extension point &ast;/ * // Register an extension point
* ep = g_io_extension_point_register ("my-extension-point"); * ep = g_io_extension_point_register ("my-extension-point");
* g_io_extension_point_set_required_type (ep, MY_TYPE_EXAMPLE); * g_io_extension_point_set_required_type (ep, MY_TYPE_EXAMPLE);
* ]| * ]|
* *
* |[<!-- language="C" --> * |[<!-- language="C" -->
* /&ast; Implement an extension point &ast;/ * // Implement an extension point
* G_DEFINE_TYPE (MyExampleImpl, my_example_impl, MY_TYPE_EXAMPLE); * G_DEFINE_TYPE (MyExampleImpl, my_example_impl, MY_TYPE_EXAMPLE);
* g_io_extension_point_implement ("my-extension-point", * g_io_extension_point_implement ("my-extension-point",
* my_example_impl_get_type (), * my_example_impl_get_type (),

View File

@ -368,13 +368,13 @@ g_memory_output_stream_init (GMemoryOutputStream *stream)
* allocation for itself). * allocation for itself).
* *
* |[<!-- language="C" --> * |[<!-- language="C" -->
* /&ast; a stream that can grow &ast;/ * // a stream that can grow
* stream = g_memory_output_stream_new (NULL, 0, realloc, free); * stream = g_memory_output_stream_new (NULL, 0, realloc, free);
* *
* /&ast; another stream that can grow &ast;/ * // another stream that can grow
* stream2 = g_memory_output_stream_new (NULL, 0, g_realloc, g_free); * stream2 = g_memory_output_stream_new (NULL, 0, g_realloc, g_free);
* *
* /&ast; a fixed-size stream &ast;/ * // a fixed-size stream
* data = malloc (200); * data = malloc (200);
* stream3 = g_memory_output_stream_new (data, 200, NULL, free); * stream3 = g_memory_output_stream_new (data, 200, NULL, free);
* ]| * ]|

View File

@ -409,7 +409,7 @@ g_simple_action_class_init (GSimpleActionClass *class)
* *
* requested = g_variant_get_int32 (value); * requested = g_variant_get_int32 (value);
* *
* /&ast; Volume only goes from 0 to 10 &ast;/ * // Volume only goes from 0 to 10
* if (0 <= requested && requested <= 10) * if (0 <= requested && requested <= 10)
* g_simple_action_set_state (action, value); * g_simple_action_set_state (action, value);
* } * }

View File

@ -111,9 +111,8 @@
* baked_cb (Cake *cake, * baked_cb (Cake *cake,
* gpointer user_data) * gpointer user_data)
* { * {
* /&ast; In this example, this callback is not given a reference to the cake, so * // In this example, this callback is not given a reference to the cake,
* &ast; the GSimpleAsyncResult has to take a reference to it. * // so the GSimpleAsyncResult has to take a reference to it.
* &ast;/
* GSimpleAsyncResult *result = user_data; * GSimpleAsyncResult *result = user_data;
* *
* if (cake == NULL) * if (cake == NULL)
@ -127,12 +126,11 @@
* g_object_unref); * g_object_unref);
* *
* *
* /&ast; In this example, we assume that baked_cb is called as a callback from * // In this example, we assume that baked_cb is called as a callback from
* &ast; the mainloop, so it's safe to complete the operation synchronously here. * // the mainloop, so it's safe to complete the operation synchronously here.
* &ast; If, however, _baker_prepare_cake () might call its callback without * // If, however, _baker_prepare_cake () might call its callback without
* &ast; first returning to the mainloop inadvisable, but some APIs do so * // first returning to the mainloop — inadvisable, but some APIs do so —
* &ast; we would need to use g_simple_async_result_complete_in_idle(). * // we would need to use g_simple_async_result_complete_in_idle().
* &ast;/
* g_simple_async_result_complete (result); * g_simple_async_result_complete (result);
* g_object_unref (result); * g_object_unref (result);
* } * }
@ -171,9 +169,8 @@
* g_object_unref); * g_object_unref);
* g_simple_async_result_complete_in_idle (simple); * g_simple_async_result_complete_in_idle (simple);
* g_object_unref (simple); * g_object_unref (simple);
* /&ast; Drop the reference returned by _baker_get_cached_cake(); the * // Drop the reference returned by _baker_get_cached_cake();
* &ast; GSimpleAsyncResult has taken its own reference. * // the GSimpleAsyncResult has taken its own reference.
* &ast;/
* g_object_unref (cake); * g_object_unref (cake);
* return; * return;
* } * }

View File

@ -49,10 +49,9 @@
* enumerator = g_socket_connectable_enumerate (addr); * enumerator = g_socket_connectable_enumerate (addr);
* g_object_unref (addr); * g_object_unref (addr);
* *
* /&ast; Try each sockaddr until we succeed. Record the first * // Try each sockaddr until we succeed. Record the first connection error,
* &ast; connection error, but not any further ones (since they'll probably * // but not any further ones (since they'll probably be basically the same
* &ast; be basically the same as the first). * // as the first).
* &ast;/
* while (!conn && (sockaddr = g_socket_address_enumerator_next (enumerator, cancellable, error)) * while (!conn && (sockaddr = g_socket_address_enumerator_next (enumerator, cancellable, error))
* { * {
* conn = connect_to_sockaddr (sockaddr, conn_error ? NULL : &conn_error); * conn = connect_to_sockaddr (sockaddr, conn_error ? NULL : &conn_error);
@ -64,18 +63,15 @@
* { * {
* if (conn_error) * if (conn_error)
* { * {
* /&ast; We couldn't connect to the first address, but we succeeded * // We couldn't connect to the first address, but we succeeded
* &ast; in connecting to a later address. * // in connecting to a later address.
* &ast;/
* g_error_free (conn_error); * g_error_free (conn_error);
* } * }
* return conn; * return conn;
* } * }
* else if (error) * else if (error)
* { * {
* /&ast; Either the initial lookup failed, or else the caller * /// Either initial lookup failed, or else the caller cancelled us.
* &ast; cancelled us.
* &ast;/
* if (conn_error) * if (conn_error)
* g_error_free (conn_error); * g_error_free (conn_error);
* return NULL; * return NULL;

View File

@ -82,7 +82,7 @@
* if (!cake_decorate (cake, decoration->frosting, decoration->message, &error)) * if (!cake_decorate (cake, decoration->frosting, decoration->message, &error))
* { * {
* g_object_unref (cake); * g_object_unref (cake);
* /&ast; g_task_return_error() takes ownership of error &ast;/ * // g_task_return_error() takes ownership of error
* g_task_return_error (task, error); * g_task_return_error (task, error);
* g_object_unref (task); * g_object_unref (task);
* return; * return;
@ -119,7 +119,7 @@
* cake = _baker_get_cached_cake (self, radius, flavor, frosting, message); * cake = _baker_get_cached_cake (self, radius, flavor, frosting, message);
* if (cake != NULL) * if (cake != NULL)
* { * {
* /&ast; _baker_get_cached_cake() returns a reffed cake &ast;/ * // _baker_get_cached_cake() returns a reffed cake
* g_task_return_pointer (task, cake, g_object_unref); * g_task_return_pointer (task, cake, g_object_unref);
* g_object_unref (task); * g_object_unref (task);
* return; * return;
@ -189,9 +189,8 @@
* return; * return;
* } * }
* *
* /&ast; baking_data_free() will drop its ref on the cake, so * // baking_data_free() will drop its ref on the cake, so we have to
* &ast; we have to take another here to give to the caller. * // take another here to give to the caller.
* &ast;/
* g_task_return_pointer (result, g_object_ref (cake), g_object_unref); * g_task_return_pointer (result, g_object_ref (cake), g_object_unref);
* g_object_unref (task); * g_object_unref (task);
* } * }
@ -225,7 +224,7 @@
* *
* bd->cake = cake; * bd->cake = cake;
* *
* /&ast; Bail out now if the user has already cancelled &ast;/ * // Bail out now if the user has already cancelled
* if (g_task_return_error_if_cancelled (task)) * if (g_task_return_error_if_cancelled (task))
* { * {
* g_object_unref (task); * g_object_unref (task);
@ -239,9 +238,8 @@
* GSource *source; * GSource *source;
* *
* source = cake_decorator_wait_source_new (cake); * source = cake_decorator_wait_source_new (cake);
* /&ast; Attach @source to @task's GMainContext and have it call * // Attach @source to @task's GMainContext and have it call
* &ast; decorator_ready() when it is ready. * // decorator_ready() when it is ready.
* &ast;/
* g_task_attach_source (task, source, * g_task_attach_source (task, source,
* G_CALLBACK (decorator_ready)); * G_CALLBACK (decorator_ready));
* g_source_unref (source); * g_source_unref (source);
@ -397,22 +395,20 @@
* return; * return;
* } * }
* *
* /&ast; If the task has already been cancelled, then we don't * // If the task has already been cancelled, then we don't want to add
* &ast; want to add the cake to the cake cache. Likewise, we don't * // the cake to the cake cache. Likewise, we don't want to have the
* &ast; want to have the task get cancelled in the middle of * // task get cancelled in the middle of updating the cache.
* &ast; updating the cache. g_task_set_return_on_cancel() will * // g_task_set_return_on_cancel() will return %TRUE here if it managed
* &ast; return %TRUE here if it managed to disable return-on-cancel, * // to disable return-on-cancel, or %FALSE if the task was cancelled
* &ast; or %FALSE if the task was cancelled before it could. * // before it could.
* &ast;/
* if (g_task_set_return_on_cancel (task, FALSE)) * if (g_task_set_return_on_cancel (task, FALSE))
* { * {
* /&ast; If the caller cancels at this point, their * // If the caller cancels at this point, their
* &ast; GAsyncReadyCallback won't be invoked until we return, * // GAsyncReadyCallback won't be invoked until we return,
* &ast; so we don't have to worry that this code will run at * // so we don't have to worry that this code will run at
* &ast; the same time as that code does. But if there were * // the same time as that code does. But if there were
* &ast; other functions that might look at the cake cache, * // other functions that might look at the cake cache,
* &ast; then we'd probably need a GMutex here as well. * // then we'd probably need a GMutex here as well.
* &ast;/
* baker_add_cake_to_cache (baker, cake); * baker_add_cake_to_cache (baker, cake);
* g_task_return_pointer (task, cake, g_object_unref); * g_task_return_pointer (task, cake, g_object_unref);
* } * }
@ -432,7 +428,8 @@
* GTask *task; * GTask *task;
* *
* cake_data = g_slice_new (CakeData); * cake_data = g_slice_new (CakeData);
* /&ast; ... &ast;/ *
* ...
* *
* task = g_task_new (self, cancellable, callback, user_data); * task = g_task_new (self, cancellable, callback, user_data);
* g_task_set_task_data (task, cake_data, (GDestroyNotify) cake_data_free); * g_task_set_task_data (task, cake_data, (GDestroyNotify) cake_data_free);
@ -454,7 +451,8 @@
* Cake *cake; * Cake *cake;
* *
* cake_data = g_slice_new (CakeData); * cake_data = g_slice_new (CakeData);
* /&ast; ... &ast;/ *
* ...
* *
* task = g_task_new (self, cancellable, NULL, NULL); * task = g_task_new (self, cancellable, NULL, NULL);
* g_task_set_task_data (task, cake_data, (GDestroyNotify) cake_data_free); * g_task_set_task_data (task, cake_data, (GDestroyNotify) cake_data_free);

View File

@ -626,9 +626,9 @@ g_volume_enumerate_identifiers (GVolume *volume)
* GFile *mount_root * GFile *mount_root
* GFile *volume_activation_root; * GFile *volume_activation_root;
* *
* mount = g_volume_get_mount (volume); /&ast; mounted, so never NULL &ast;/ * mount = g_volume_get_mount (volume); // mounted, so never NULL
* mount_root = g_mount_get_root (mount); * mount_root = g_mount_get_root (mount);
* volume_activation_root = g_volume_get_activation_root (volume); /&ast; assume not NULL &ast;/ * volume_activation_root = g_volume_get_activation_root (volume); // assume not NULL
* ]| * ]|
* then the expression * then the expression
* |[<!-- language="C" --> * |[<!-- language="C" -->

View File

@ -71,9 +71,8 @@
* |[<!-- language="C" --> * |[<!-- language="C" -->
* GArray *garray; * GArray *garray;
* gint i; * gint i;
* /&ast; We create a new array to store gint values. * // We create a new array to store gint values.
* &ast; We don't want it zero-terminated or cleared to 0's. * // We don't want it zero-terminated or cleared to 0's.
* &ast;/
* garray = g_array_new (FALSE, FALSE, sizeof (gint)); * garray = g_array_new (FALSE, FALSE, sizeof (gint));
* for (i = 0; i < 10000; i++) * for (i = 0; i < 10000; i++)
* g_array_append_val (garray, i); * g_array_append_val (garray, i);
@ -122,9 +121,8 @@ struct _GRealArray
* This example gets a pointer to an element in a #GArray: * This example gets a pointer to an element in a #GArray:
* |[<!-- language="C" --> * |[<!-- language="C" -->
* EDayViewEvent *event; * EDayViewEvent *event;
* /&ast; This gets a pointer to the 4th element * // This gets a pointer to the 4th element in the array of
* &ast; in the array of EDayViewEvent structs. * // EDayViewEvent structs.
* &ast;/
* event = &g_array_index (events, EDayViewEvent, 3); * event = &g_array_index (events, EDayViewEvent, 3);
* ]| * ]|
* *

View File

@ -69,14 +69,14 @@
* g_assert ((contents == NULL && err != NULL) || (contents != NULL && err == NULL)); * g_assert ((contents == NULL && err != NULL) || (contents != NULL && err == NULL));
* if (err != NULL) * if (err != NULL)
* { * {
* /&ast; Report error to user, and free error &ast;/ * // Report error to user, and free error
* g_assert (contents == NULL); * g_assert (contents == NULL);
* fprintf (stderr, "Unable to read file: %s\n", err->message); * fprintf (stderr, "Unable to read file: %s\n", err->message);
* g_error_free (err); * g_error_free (err);
* } * }
* else * else
* { * {
* /&ast; Use file contents &ast;/ * // Use file contents
* g_assert (contents != NULL); * g_assert (contents != NULL);
* } * }
* ]| * ]|
@ -89,10 +89,12 @@
* are only interested in whether it failed and don't need to display * are only interested in whether it failed and don't need to display
* an error message, you can pass %NULL for the @error argument: * an error message, you can pass %NULL for the @error argument:
* |[<!-- language="C" --> * |[<!-- language="C" -->
* if (g_file_get_contents ("foo.txt", &contents, NULL, NULL)) /&ast; ignore errors &ast;/ * if (g_file_get_contents ("foo.txt", &contents, NULL, NULL)) // ignore errors
* /&ast; no error occurred &ast;/ ; * // no error occurred
* ;
* else * else
* /&ast; error &ast;/ ; * // error
* ;
* ]| * ]|
* *
* The #GError object contains three fields: @domain indicates the module * The #GError object contains three fields: @domain indicates the module
@ -125,9 +127,9 @@
* if (fd < 0) * if (fd < 0)
* { * {
* g_set_error (error, * g_set_error (error,
* FOO_ERROR, /&ast; error domain &ast;/ * FOO_ERROR, // error domain
* FOO_ERROR_BLAH, /&ast; error code &ast;/ * FOO_ERROR_BLAH, // error code
* "Failed to open file: %s", /&ast; error message format string &ast;/ * "Failed to open file: %s", // error message format string
* g_strerror (errno)); * g_strerror (errno));
* return -1; * return -1;
* } * }
@ -148,12 +150,12 @@
* *
* if (!sub_function_that_can_fail (err)) * if (!sub_function_that_can_fail (err))
* { * {
* /&ast; assert that error was set by the sub-function &ast;/ * // assert that error was set by the sub-function
* g_assert (err == NULL || *err != NULL); * g_assert (err == NULL || *err != NULL);
* return FALSE; * return FALSE;
* } * }
* *
* /&ast; otherwise continue, no error occurred &ast;/ * // otherwise continue, no error occurred
* g_assert (err == NULL || *err == NULL); * g_assert (err == NULL || *err == NULL);
* } * }
* ]| * ]|
@ -175,14 +177,13 @@
* *
* if (tmp_error != NULL) * if (tmp_error != NULL)
* { * {
* /&ast; store tmp_error in err, if err != NULL, * // store tmp_error in err, if err != NULL,
* &ast; otherwise call g_error_free() on tmp_error * // otherwise call g_error_free() on tmp_error
* &ast;/
* g_propagate_error (err, tmp_error); * g_propagate_error (err, tmp_error);
* return FALSE; * return FALSE;
* } * }
* *
* /&ast; otherwise continue, no error occurred &ast;/ * // otherwise continue, no error occurred
* } * }
* ]| * ]|
* *
@ -222,7 +223,7 @@
* *
* g_return_val_if_fail (err == NULL || *err == NULL, FALSE); * g_return_val_if_fail (err == NULL || *err == NULL, FALSE);
* *
* sub_function_that_can_fail (NULL); /&ast; ignore errors &ast;/ * sub_function_that_can_fail (NULL); // ignore errors
* *
* tmp_error = NULL; * tmp_error = NULL;
* other_function_that_can_fail (&tmp_error); * other_function_that_can_fail (&tmp_error);

View File

@ -290,11 +290,11 @@ g_mkdir_with_parents (const gchar *pathname,
* to know whether it is safe to write to a file without being * to know whether it is safe to write to a file without being
* tricked into writing into a different location. It doesn't work! * tricked into writing into a different location. It doesn't work!
* |[<!-- language="C" --> * |[<!-- language="C" -->
* /&ast; DON'T DO THIS &ast;/ * // DON'T DO THIS
* if (!g_file_test (filename, G_FILE_TEST_IS_SYMLINK)) * if (!g_file_test (filename, G_FILE_TEST_IS_SYMLINK))
* { * {
* fd = g_open (filename, O_WRONLY); * fd = g_open (filename, O_WRONLY);
* /&ast; write to fd &ast;/ * // write to fd
* } * }
* ]| * ]|
* *

View File

@ -687,7 +687,7 @@ g_hash_table_new_full (GHashFunc hash_func,
* g_hash_table_iter_init (&iter, hash_table); * g_hash_table_iter_init (&iter, hash_table);
* while (g_hash_table_iter_next (&iter, &key, &value)) * while (g_hash_table_iter_next (&iter, &key, &value))
* { * {
* /&ast; do something with key and value &ast;/ * // do something with key and value
* } * }
* ]| * ]|
* *

View File

@ -77,7 +77,7 @@
* GList *l; * GList *l;
* for (l = list; l != NULL; l = l->next) * for (l = list; l != NULL; l = l->next)
* { * {
* /&ast; do something with l->data &ast;/ * // do something with l->data
* } * }
* ]| * ]|
* *
@ -92,7 +92,7 @@
* GList *next = l->next; * GList *next = l->next;
* if (should_be_removed (l)) * if (should_be_removed (l))
* { * {
* /&ast; possibly free l->data &ast;/ * // possibly free l->data
* list = g_list_delete_link (list, l); * list = g_list_delete_link (list, l);
* } * }
* l = next; * l = next;
@ -234,14 +234,14 @@ g_list_free_full (GList *list,
* the list with g_list_reverse() when all elements have been added. * the list with g_list_reverse() when all elements have been added.
* *
* |[<!-- language="C" --> * |[<!-- language="C" -->
* /&ast; Notice that these are initialized to the empty list. &ast;/ * // Notice that these are initialized to the empty list.
* GList *string_list = NULL, *number_list = NULL; * GList *string_list = NULL, *number_list = NULL;
* *
* /&ast; This is a list of strings. &ast;/ * // This is a list of strings.
* string_list = g_list_append (string_list, "first"); * string_list = g_list_append (string_list, "first");
* string_list = g_list_append (string_list, "second"); * string_list = g_list_append (string_list, "second");
* *
* /&ast; This is a list of integers. &ast;/ * // This is a list of integers.
* number_list = g_list_append (number_list, GINT_TO_POINTER (27)); * number_list = g_list_append (number_list, GINT_TO_POINTER (27));
* number_list = g_list_append (number_list, GINT_TO_POINTER (14)); * number_list = g_list_append (number_list, GINT_TO_POINTER (14));
* ]| * ]|
@ -286,7 +286,7 @@ g_list_append (GList *list,
* which will have changed, so make sure you store the new value. * which will have changed, so make sure you store the new value.
* *
* |[<!-- language="C" --> * |[<!-- language="C" -->
* /&ast; Notice that it is initialized to the empty list. &ast;/ * // Notice that it is initialized to the empty list.
* GList *list = NULL; * GList *list = NULL;
* *
* list = g_list_prepend (list, "last"); * list = g_list_prepend (list, "last");

View File

@ -2879,7 +2879,7 @@ g_main_current_source (void)
* SomeWidget *self = data; * SomeWidget *self = data;
* *
* GDK_THREADS_ENTER (); * GDK_THREADS_ENTER ();
* /&ast; do stuff with self &ast;/ * // do stuff with self
* self->idle_id = 0; * self->idle_id = 0;
* GDK_THREADS_LEAVE (); * GDK_THREADS_LEAVE ();
* *
@ -2919,7 +2919,7 @@ g_main_current_source (void)
* GDK_THREADS_ENTER (); * GDK_THREADS_ENTER ();
* if (!g_source_is_destroyed (g_main_current_source ())) * if (!g_source_is_destroyed (g_main_current_source ()))
* { * {
* /&ast; do stuff with self &ast;/ * // do stuff with self
* } * }
* GDK_THREADS_LEAVE (); * GDK_THREADS_LEAVE ();
* *

View File

@ -2069,7 +2069,7 @@ g_markup_parse_context_get_user_data (GMarkupParseContext *context)
* if (strcmp (element_name, "count-these") == 0) * if (strcmp (element_name, "count-these") == 0)
* start_counting (context); * start_counting (context);
* *
* /&ast; else, handle other tags... &ast;/ * // else, handle other tags...
* } * }
* *
* static void end_element (context, element_name, ...) * static void end_element (context, element_name, ...)
@ -2077,7 +2077,7 @@ g_markup_parse_context_get_user_data (GMarkupParseContext *context)
* if (strcmp (element_name, "count-these") == 0) * if (strcmp (element_name, "count-these") == 0)
* g_print ("Counted %d tags\n", end_counting (context)); * g_print ("Counted %d tags\n", end_counting (context));
* *
* /&ast; else, handle other tags... &ast;/ * // else, handle other tags...
* } * }
* ]| * ]|
* *

View File

@ -1146,9 +1146,8 @@ g_assert_warning (const char *log_domain,
* For example: * For example:
* *
* |[<!-- language="C" --> * |[<!-- language="C" -->
* /&ast; g_main_context_push_thread_default() should fail if the * // g_main_context_push_thread_default() should fail if the
* &ast; context is already owned by another thread. * // context is already owned by another thread.
* &ast;/
* g_test_expect_message (G_LOG_DOMAIN, * g_test_expect_message (G_LOG_DOMAIN,
* G_LOG_LEVEL_CRITICAL, * G_LOG_LEVEL_CRITICAL,
* "assertion*acquired_context*failed"); * "assertion*acquired_context*failed");

View File

@ -120,7 +120,7 @@
* exit (1); * exit (1);
* } * }
* *
* /&ast; ... &ast;/ * ...
* *
* } * }
* ]| * ]|
@ -161,18 +161,18 @@
* args = g_strdupv (argv); * args = g_strdupv (argv);
* #endif * #endif
* *
* /&ast; ... setup context ... &ast;/ * // set up context
* *
* if (!g_option_context_parse_strv (context, &args, &error)) * if (!g_option_context_parse_strv (context, &args, &error))
* { * {
* /&ast; ... error ... &ast;/ * // error happened
* } * }
* *
* /&ast; ... &ast;/ * ...
* *
* g_strfreev (args); * g_strfreev (args);
* *
* /&ast; ... &ast;/ * ...
* } * }
* ]| * ]|
*/ */

View File

@ -1643,7 +1643,7 @@ g_regex_match_simple (const gchar *pattern,
* static void * static void
* print_uppercase_words (const gchar *string) * print_uppercase_words (const gchar *string)
* { * {
* /&ast; Print all uppercase-only words. &ast;/ * // Print all uppercase-only words.
* GRegex *regex; * GRegex *regex;
* GMatchInfo *match_info; * GMatchInfo *match_info;
* *
@ -1716,7 +1716,7 @@ g_regex_match (const GRegex *regex,
* static void * static void
* print_uppercase_words (const gchar *string) * print_uppercase_words (const gchar *string)
* { * {
* /&ast; Print all uppercase-only words. &ast;/ * // Print all uppercase-only words.
* GRegex *regex; * GRegex *regex;
* GMatchInfo *match_info; * GMatchInfo *match_info;
* GError *error = NULL; * GError *error = NULL;
@ -2853,7 +2853,7 @@ g_regex_replace_literal (const GRegex *regex,
* return FALSE; * return FALSE;
* } * }
* *
* /&ast; ... &ast;/ * ...
* *
* GRegex *reg; * GRegex *reg;
* GHashTable *h; * GHashTable *h;
@ -2870,7 +2870,7 @@ g_regex_replace_literal (const GRegex *regex,
* res = g_regex_replace_eval (reg, text, -1, 0, 0, eval_cb, h, NULL); * res = g_regex_replace_eval (reg, text, -1, 0, 0, eval_cb, h, NULL);
* g_hash_table_destroy (h); * g_hash_table_destroy (h);
* *
* /&ast; ... &ast;/ * ...
* ]| * ]|
* *
* Returns: a newly allocated string containing the replacements * Returns: a newly allocated string containing the replacements

View File

@ -96,17 +96,17 @@
* gchar *mem[10000]; * gchar *mem[10000];
* gint i; * gint i;
* *
* /&ast; Allocate 10000 blocks. &ast;/ * // Allocate 10000 blocks.
* for (i = 0; i < 10000; i++) * for (i = 0; i < 10000; i++)
* { * {
* mem[i] = g_slice_alloc (50); * mem[i] = g_slice_alloc (50);
* *
* /&ast; Fill in the memory with some junk. &ast;/ * // Fill in the memory with some junk.
* for (j = 0; j < 50; j++) * for (j = 0; j < 50; j++)
* mem[i][j] = i * j; * mem[i][j] = i * j;
* } * }
* *
* /&ast; Now free all of the blocks. &ast;/ * // Now free all of the blocks.
* for (i = 0; i < 10000; i++) * for (i = 0; i < 10000; i++)
* g_slice_free1 (50, mem[i]); * g_slice_free1 (50, mem[i]);
* ]| * ]|
@ -116,10 +116,10 @@
* |[<!-- language="C" --> * |[<!-- language="C" -->
* GRealArray *array; * GRealArray *array;
* *
* /&ast; Allocate one block, using the g_slice_new() macro. &ast;/ * // Allocate one block, using the g_slice_new() macro.
* array = g_slice_new (GRealArray); * array = g_slice_new (GRealArray);
* /&ast; We can now use array just like a normal pointer to a structure. &ast;/ * // We can now use array just like a normal pointer to a structure.
* array->data = NULL; * array->data = NULL;
* array->len = 0; * array->len = 0;
* array->alloc = 0; * array->alloc = 0;
@ -127,7 +127,7 @@
* array->clear = (clear ? 1 : 0); * array->clear = (clear ? 1 : 0);
* array->elt_size = elt_size; * array->elt_size = elt_size;
* *
* /&ast; We can free the block, so it can be reused. &ast;/ * // We can free the block, so it can be reused.
* g_slice_free (GRealArray, array); * g_slice_free (GRealArray, array);
* ]| * ]|
*/ */

View File

@ -189,14 +189,14 @@ g_slist_free_full (GSList *list,
* the elements and reverse the list when all elements have been added. * the elements and reverse the list when all elements have been added.
* *
* |[<!-- language="C" --> * |[<!-- language="C" -->
* /&ast; Notice that these are initialized to the empty list. &ast;/ * // Notice that these are initialized to the empty list.
* GSList *list = NULL, *number_list = NULL; * GSList *list = NULL, *number_list = NULL;
* *
* /&ast; This is a list of strings. &ast;/ * // This is a list of strings.
* list = g_slist_append (list, "first"); * list = g_slist_append (list, "first");
* list = g_slist_append (list, "second"); * list = g_slist_append (list, "second");
* *
* /&ast; This is a list of integers. &ast;/ * // This is a list of integers.
* number_list = g_slist_append (number_list, GINT_TO_POINTER (27)); * number_list = g_slist_append (number_list, GINT_TO_POINTER (27));
* number_list = g_slist_append (number_list, GINT_TO_POINTER (14)); * number_list = g_slist_append (number_list, GINT_TO_POINTER (14));
* ]| * ]|
@ -237,7 +237,7 @@ g_slist_append (GSList *list,
* may have changed, so make sure you store the new value. * may have changed, so make sure you store the new value.
* *
* |[<!-- language="C" --> * |[<!-- language="C" -->
* /&ast; Notice that it is initialized to the empty list. &ast;/ * // Notice that it is initialized to the empty list.
* GSList *list = NULL; * GSList *list = NULL;
* list = g_slist_prepend (list, "last"); * list = g_slist_prepend (list, "last");
* list = g_slist_prepend (list, "first"); * list = g_slist_prepend (list, "first");

View File

@ -2644,7 +2644,7 @@ wait_for_child (GPid pid,
* { * {
* g_print ("some stdout text: somagic17\n"); * g_print ("some stdout text: somagic17\n");
* g_printerr ("some stderr text: semagic43\n"); * g_printerr ("some stderr text: semagic43\n");
* exit (0); /&ast; successful test run &ast;/ * exit (0); // successful test run
* } * }
* g_test_trap_assert_passed (); * g_test_trap_assert_passed ();
* g_test_trap_assert_stdout ("*somagic17*"); * g_test_trap_assert_stdout ("*somagic17*");
@ -2761,7 +2761,7 @@ g_test_trap_fork (guint64 usec_timeout,
* return; * return;
* } * }
* *
* /&ast; Reruns this same test in a subprocess &ast;/ * // Reruns this same test in a subprocess
* g_test_trap_subprocess (NULL, 0, 0); * g_test_trap_subprocess (NULL, 0, 0);
* g_test_trap_assert_failed (); * g_test_trap_assert_failed ();
* g_test_trap_assert_stderr ("*ERROR*too large*"); * g_test_trap_assert_stderr ("*ERROR*too large*");

View File

@ -820,12 +820,12 @@ g_cond_broadcast (GCond *cond)
* while (!current_data) * while (!current_data)
* if (!g_cond_wait_until (&data_cond, &data_mutex, end_time)) * if (!g_cond_wait_until (&data_cond, &data_mutex, end_time))
* { * {
* /&ast; timeout has passed. &ast;/ * // timeout has passed.
* g_mutex_unlock (&data_mutex); * g_mutex_unlock (&data_mutex);
* return NULL; * return NULL;
* } * }
* *
* /&ast; there is data for us &ast;/ * // there is data for us
* data = current_data; * data = current_data;
* current_data = NULL; * current_data = NULL;
* *
@ -920,7 +920,7 @@ g_cond_wait_until (GCond *cond,
* |[<!-- language="C" --> * |[<!-- language="C" -->
* static GPrivate name_key = G_PRIVATE_INIT (g_free); * static GPrivate name_key = G_PRIVATE_INIT (g_free);
* *
* /&ast; return value should not be freed &ast;/ * // return value should not be freed
* const gchar * * const gchar *
* get_local_name (void) * get_local_name (void)
* { * {
@ -934,7 +934,7 @@ g_cond_wait_until (GCond *cond,
* } * }
* *
* *
* static GPrivate count_key; /&ast; no free function &ast;/ * static GPrivate count_key; // no free function
* *
* gint * gint
* get_local_count (void) * get_local_count (void)

View File

@ -106,31 +106,31 @@
* there are thread-safe variants with a _r suffix, or you can * there are thread-safe variants with a _r suffix, or you can
* look at corresponding GLib APIs (like g_strsplit() or g_strerror()). * look at corresponding GLib APIs (like g_strsplit() or g_strerror()).
* *
* - setenv() and unsetenv() manipulate the process environment in * - The functions setenv() and unsetenv() manipulate the process
* a not thread-safe way, and may interfere with getenv() calls * environment in a not thread-safe way, and may interfere with getenv()
* in other threads. Note that getenv() calls may be hidden behind * calls in other threads. Note that getenv() calls may be hidden behind
* other APIs. For example, GNU gettext() calls getenv() under the * other APIs. For example, GNU gettext() calls getenv() under the
* covers. In general, it is best to treat the environment as readonly. * covers. In general, it is best to treat the environment as readonly.
* If you absolutely have to modify the environment, do it early in * If you absolutely have to modify the environment, do it early in
* main(), when no other threads are around yet. * main(), when no other threads are around yet.
* *
* - setlocale() changes the locale for the entire process, affecting * - The setlocale() function changes the locale for the entire process,
* all threads. Temporary changes to the locale are often made to * affecting all threads. Temporary changes to the locale are often made
* change the behavior of string scanning or formatting functions * to change the behavior of string scanning or formatting functions
* like scanf() or printf(). GLib offers a number of string APIs * like scanf() or printf(). GLib offers a number of string APIs
* (like g_ascii_formatd() or g_ascii_strtod()) that can often be * (like g_ascii_formatd() or g_ascii_strtod()) that can often be
* used as an alternative. Or you can use the uselocale() function * used as an alternative. Or you can use the uselocale() function
* to change the locale only for the current thread. * to change the locale only for the current thread.
* *
* - fork() only takes the calling thread into the child's copy of the * - The fork() function only takes the calling thread into the child's
* process image. If other threads were executing in critical * copy of the process image. If other threads were executing in critical
* sections they could have left mutexes locked which could easily * sections they could have left mutexes locked which could easily
* cause deadlocks in the new child. For this reason, you should * cause deadlocks in the new child. For this reason, you should
* call exit() or exec() as soon as possible in the child and only * call exit() or exec() as soon as possible in the child and only
* make signal-safe library calls before that. * make signal-safe library calls before that.
* *
* - daemon() uses fork() in a way contrary to what is described * - The daemon() function uses fork() in a way contrary to what is
* above. It should not be used with GLib programs. * described above. It should not be used with GLib programs.
* *
* GLib itself is internally completely thread-safe (all global data is * GLib itself is internally completely thread-safe (all global data is
* automatically locked), but individual data structure instances are * automatically locked), but individual data structure instances are
@ -233,9 +233,8 @@
* { * {
* static int current_number = 0; * static int current_number = 0;
* *
* /&ast; now do a very complicated calculation to calculate the new * // now do a very complicated calculation to calculate the new
* &ast; number, this might for example be a random number generator * // number, this might for example be a random number generator
* &ast;/
* current_number = calc_next_number (current_number); * current_number = calc_next_number (current_number);
* *
* return current_number; * return current_number;
@ -619,12 +618,12 @@ g_once_impl (GOnce *once,
* *
* if (g_once_init_enter (&initialization_value)) * if (g_once_init_enter (&initialization_value))
* { * {
* gsize setup_value = 42; /&ast; initialization code here &ast;/ * gsize setup_value = 42; // initialization code here
* *
* g_once_init_leave (&initialization_value, setup_value); * g_once_init_leave (&initialization_value, setup_value);
* } * }
* *
* /&ast; use initialization_value here &ast;/ * // use initialization_value here
* ]| * ]|
* *
* Returns: %TRUE if the initialization section should be entered, * Returns: %TRUE if the initialization section should be entered,

View File

@ -3032,7 +3032,7 @@ g_variant_iter_free (GVariantIter *iter)
* *
* Here is an example for iterating with g_variant_iter_next_value(): * Here is an example for iterating with g_variant_iter_next_value():
* |[<!-- language="C" --> * |[<!-- language="C" -->
* /&ast; recursively iterate a container &ast;/ * // recursively iterate a container
* void * void
* iterate_container_recursive (GVariant *container) * iterate_container_recursive (GVariant *container)
* { * {
@ -5469,7 +5469,7 @@ g_variant_get_child (GVariant *value,
* *
* Here is an example for memory management with g_variant_iter_next(): * Here is an example for memory management with g_variant_iter_next():
* |[<!-- language="C" --> * |[<!-- language="C" -->
* /&ast; Iterates a dictionary of type 'a{sv}' &ast;/ * // Iterates a dictionary of type 'a{sv}'
* void * void
* iterate_dictionary (GVariant *dictionary) * iterate_dictionary (GVariant *dictionary)
* { * {
@ -5483,7 +5483,7 @@ g_variant_get_child (GVariant *value,
* g_print ("Item '%s' has type '%s'\n", key, * g_print ("Item '%s' has type '%s'\n", key,
* g_variant_get_type_string (value)); * g_variant_get_type_string (value));
* *
* /&ast; must free data for ourselves &ast;/ * // must free data for ourselves
* g_variant_unref (value); * g_variant_unref (value);
* g_free (key); * g_free (key);
* } * }
@ -5561,7 +5561,7 @@ g_variant_iter_next (GVariantIter *iter,
* *
* Here is an example for memory management with g_variant_iter_loop(): * Here is an example for memory management with g_variant_iter_loop():
* |[<!-- language="C" --> * |[<!-- language="C" -->
* /&ast; Iterates a dictionary of type 'a{sv}' &ast;/ * // Iterates a dictionary of type 'a{sv}'
* void * void
* iterate_dictionary (GVariant *dictionary) * iterate_dictionary (GVariant *dictionary)
* { * {
@ -5575,9 +5575,8 @@ g_variant_iter_next (GVariantIter *iter,
* g_print ("Item '%s' has type '%s'\n", key, * g_print ("Item '%s' has type '%s'\n", key,
* g_variant_get_type_string (value)); * g_variant_get_type_string (value));
* *
* /&ast; no need to free 'key' and 'value' here * // no need to free 'key' and 'value' here
* &ast; unless breaking out of this loop * // unless breaking out of this loop
* &ast;/
* } * }
* } * }
* ]| * ]|

View File

@ -80,7 +80,7 @@
* *
* Example: Calling a function defined in a GModule * Example: Calling a function defined in a GModule
* |[<!-- language="C" --> * |[<!-- language="C" -->
* /&ast; the function signature for 'say_hello' &ast;/ * // the function signature for 'say_hello'
* typedef void (* SayHelloFunc) (const char *message); * typedef void (* SayHelloFunc) (const char *message);
* *
* gboolean * gboolean
@ -115,7 +115,7 @@
* return FALSE; * return FALSE;
* } * }
* *
* /&ast; call our function in the module &ast;/ * // call our function in the module
* say_hello ("Hello world!"); * say_hello ("Hello world!");
* *
* if (!g_module_close (module)) * if (!g_module_close (module))

View File

@ -155,7 +155,7 @@ enum {
* struct _MyClosure * struct _MyClosure
* { * {
* GClosure closure; * GClosure closure;
* /&ast; extra data goes here &ast;/ * // extra data goes here
* }; * };
* *
* static void * static void
@ -164,7 +164,7 @@ enum {
* { * {
* MyClosure *my_closure = (MyClosure *)closure; * MyClosure *my_closure = (MyClosure *)closure;
* *
* /&ast; free extra data here &ast;/ * // free extra data here
* } * }
* *
* MyClosure *my_closure_new (gpointer data) * MyClosure *my_closure_new (gpointer data)
@ -175,7 +175,7 @@ enum {
* closure = g_closure_new_simple (sizeof (MyClosure), data); * closure = g_closure_new_simple (sizeof (MyClosure), data);
* my_closure = (MyClosure *) closure; * my_closure = (MyClosure *) closure;
* *
* /&ast; initialize extra data here &ast;/ * // initialize extra data here
* *
* g_closure_add_finalize_notifier (closure, notify_data, * g_closure_add_finalize_notifier (closure, notify_data,
* my_closure_finalize); * my_closure_finalize);
@ -609,7 +609,7 @@ g_closure_unref (GClosure *closure)
* |[<!-- language="C" --> * |[<!-- language="C" -->
* closure = g_cclosure_new (cb_func, cb_data); * closure = g_cclosure_new (cb_func, cb_data);
* g_source_set_closure (source, closure); * g_source_set_closure (source, closure);
* g_closure_unref (closure); /&ast; GObject doesn't really need this &ast;/ * g_closure_unref (closure); // GObject doesn't really need this
* ]| * ]|
* Because g_source_set_closure() (and similar functions) take ownership of the * Because g_source_set_closure() (and similar functions) take ownership of the
* initial reference count, if it is unowned, we instead can write: * initial reference count, if it is unowned, we instead can write:

View File

@ -84,16 +84,18 @@
* the following sequence can be used: * the following sequence can be used:
* *
* |[<!-- language="C" --> * |[<!-- language="C" -->
* /&ast; save floating state &ast;/ * // save floating state
* gboolean was_floating = g_object_is_floating (object); * gboolean was_floating = g_object_is_floating (object);
* g_object_ref_sink (object); * g_object_ref_sink (object);
* /&ast; protected code portion &ast;/ * // protected code portion
* ...; *
* /&ast; restore floating state &ast;/ * ...
*
* // restore floating state
* if (was_floating) * if (was_floating)
* g_object_force_floating (object); * g_object_force_floating (object);
* else * else
* g_object_unref (object); /&ast; release previously acquired reference &ast;/ * g_object_unref (object); // release previously acquired reference
* ]| * ]|
*/ */
@ -2239,7 +2241,7 @@ g_object_set (gpointer _object,
* "obj-property", &objval, * "obj-property", &objval,
* NULL); * NULL);
* *
* /&ast; Do something with intval, strval, objval &ast;/ * // Do something with intval, strval, objval
* *
* g_free (strval); * g_free (strval);
* g_object_unref (objval); * g_object_unref (objval);

View File

@ -72,37 +72,37 @@
* main (int argc, * main (int argc,
* char *argv[]) * char *argv[])
* { * {
* /&ast; GValues must be initialized &ast;/ * // GValues must be initialized
* GValue a = G_VALUE_INIT; * GValue a = G_VALUE_INIT;
* GValue b = G_VALUE_INIT; * GValue b = G_VALUE_INIT;
* const gchar *message; * const gchar *message;
* *
* /&ast; The GValue starts empty &ast;/ * // The GValue starts empty
* g_assert (!G_VALUE_HOLDS_STRING (&a)); * g_assert (!G_VALUE_HOLDS_STRING (&a));
* *
* /&ast; Put a string in it &ast;/ * // Put a string in it
* g_value_init (&a, G_TYPE_STRING); * g_value_init (&a, G_TYPE_STRING);
* g_assert (G_VALUE_HOLDS_STRING (&a)); * g_assert (G_VALUE_HOLDS_STRING (&a));
* g_value_set_static_string (&a, "Hello, world!"); * g_value_set_static_string (&a, "Hello, world!");
* g_printf ("%s\n", g_value_get_string (&a)); * g_printf ("%s\n", g_value_get_string (&a));
* *
* /&ast; Reset it to its pristine state &ast;/ * // Reset it to its pristine state
* g_value_unset (&a); * g_value_unset (&a);
* *
* /&ast; It can then be reused for another type &ast;/ * // It can then be reused for another type
* g_value_init (&a, G_TYPE_INT); * g_value_init (&a, G_TYPE_INT);
* g_value_set_int (&a, 42); * g_value_set_int (&a, 42);
* *
* /&ast; Attempt to transform it into a GValue of type STRING &ast;/ * // Attempt to transform it into a GValue of type STRING
* g_value_init (&b, G_TYPE_STRING); * g_value_init (&b, G_TYPE_STRING);
* *
* /&ast; An INT is transformable to a STRING &ast;/ * // An INT is transformable to a STRING
* g_assert (g_value_type_transformable (G_TYPE_INT, G_TYPE_STRING)); * g_assert (g_value_type_transformable (G_TYPE_INT, G_TYPE_STRING));
* *
* g_value_transform (&a, &b); * g_value_transform (&a, &b);
* g_printf ("%s\n", g_value_get_string (&b)); * g_printf ("%s\n", g_value_get_string (&b));
* *
* /&ast; Attempt to transform it again using a custom transform function &ast;/ * // Attempt to transform it again using a custom transform function
* g_value_register_transform_func (G_TYPE_INT, G_TYPE_STRING, int2string); * g_value_register_transform_func (G_TYPE_INT, G_TYPE_STRING, int2string);
* g_value_transform (&a, &b); * g_value_transform (&a, &b);
* g_printf ("%s\n", g_value_get_string (&b)); * g_printf ("%s\n", g_value_get_string (&b));