diff options
Diffstat (limited to 'gir/glib-2.0.c')
-rw-r--r-- | gir/glib-2.0.c | 42618 |
1 files changed, 0 insertions, 42618 deletions
diff --git a/gir/glib-2.0.c b/gir/glib-2.0.c deleted file mode 100644 index 2d2810ea..00000000 --- a/gir/glib-2.0.c +++ /dev/null @@ -1,42618 +0,0 @@ -/************************************************************/ -/* THIS FILE IS GENERATED DO NOT EDIT */ -/************************************************************/ - -/** - * ABS: - * @a: a numeric value - * - * Calculates the absolute value of @a. - * The absolute value is simply the number with any negative sign taken away. - * - * For example, - * - ABS(-10) is 10. - * - ABS(10) is also 10. - * - * Returns: the absolute value of @a. - */ - - -/** - * CLAMP: - * @x: the value to clamp - * @low: the minimum value allowed - * @high: the maximum value allowed - * - * Ensures that @x is between the limits set by @low and @high. If @low is - * greater than @high the result is undefined. - * - * For example, - * - CLAMP(5, 10, 15) is 10. - * - CLAMP(15, 5, 10) is 10. - * - CLAMP(20, 15, 25) is 20. - * - * Returns: the value of @x clamped to the range between @low and @high - */ - - -/** - * C_: - * @Context: a message context, must be a string literal - * @String: a message id, must be a string literal - * - * Uses gettext to get the translation for @String. @Context is - * used as a context. This is mainly useful for short strings which - * may need different translations, depending on the context in which - * they are used. - * |[<!-- language="C" --> - * label1 = C_("Navigation", "Back"); - * label2 = C_("Body part", "Back"); - * ]| - * - * If you are using the C_() macro, you need to make sure that you pass - * `--keyword=C_:1c,2` to xgettext when extracting messages. - * Note that this only works with GNU gettext >= 0.15. - * - * Returns: the translated message - * Since: 2.16 - */ - - -/** - * FALSE: - * - * Defines the %FALSE value for the #gboolean type. - */ - - -/** - * GArray: - * @data: a pointer to the element data. The data may be moved as - * elements are added to the #GArray. - * @len: the number of elements in the #GArray not including the - * possible terminating zero element. - * - * Contains the public fields of a GArray. - */ - - -/** - * GAsyncQueue: - * - * An opaque data structure which represents an asynchronous queue. - * - * It should only be accessed through the `g_async_queue_*` functions. - */ - - -/** - * GByteArray: - * @data: a pointer to the element data. The data may be moved as - * elements are added to the #GByteArray - * @len: the number of elements in the #GByteArray - * - * Contains the public fields of a GByteArray. - */ - - -/** - * GBytes: - * - * A simple refcounted data type representing an immutable sequence of zero or - * more bytes from an unspecified origin. - * - * The purpose of a #GBytes is to keep the memory region that it holds - * alive for as long as anyone holds a reference to the bytes. When - * the last reference count is dropped, the memory is released. Multiple - * unrelated callers can use byte data in the #GBytes without coordinating - * their activities, resting assured that the byte data will not change or - * move while they hold a reference. - * - * A #GBytes can come from many different origins that may have - * different procedures for freeing the memory region. Examples are - * memory from g_malloc(), from memory slices, from a #GMappedFile or - * memory from other allocators. - * - * #GBytes work well as keys in #GHashTable. Use g_bytes_equal() and - * g_bytes_hash() as parameters to g_hash_table_new() or g_hash_table_new_full(). - * #GBytes can also be used as keys in a #GTree by passing the g_bytes_compare() - * function to g_tree_new(). - * - * The data pointed to by this bytes must not be modified. For a mutable - * array of bytes see #GByteArray. Use g_bytes_unref_to_array() to create a - * mutable array for a #GBytes sequence. To create an immutable #GBytes from - * a mutable #GByteArray, use the g_byte_array_free_to_bytes() function. - * - * Since: 2.32 - */ - - -/** - * GCompareDataFunc: - * @a: a value - * @b: a value to compare with - * @user_data: user data - * - * Specifies the type of a comparison function used to compare two - * values. The function should return a negative integer if the first - * value comes before the second, 0 if they are equal, or a positive - * integer if the first value comes after the second. - * - * Returns: negative value if @a < @b; zero if @a = @b; positive - * value if @a > @b - */ - - -/** - * GCompareFunc: - * @a: a value - * @b: a value to compare with - * - * Specifies the type of a comparison function used to compare two - * values. The function should return a negative integer if the first - * value comes before the second, 0 if they are equal, or a positive - * integer if the first value comes after the second. - * - * Returns: negative value if @a < @b; zero if @a = @b; positive - * value if @a > @b - */ - - -/** - * GCond: - * - * The #GCond struct is an opaque data structure that represents a - * condition. Threads can block on a #GCond if they find a certain - * condition to be false. If other threads change the state of this - * condition they signal the #GCond, and that causes the waiting - * threads to be woken up. - * - * Consider the following example of a shared variable. One or more - * threads can wait for data to be published to the variable and when - * another thread publishes the data, it can signal one of the waiting - * threads to wake up to collect the data. - * - * Here is an example for using GCond to block a thread until a condition - * is satisfied: - * |[<!-- language="C" --> - * gpointer current_data = NULL; - * GMutex data_mutex; - * GCond data_cond; - * - * void - * push_data (gpointer data) - * { - * g_mutex_lock (&data_mutex); - * current_data = data; - * g_cond_signal (&data_cond); - * g_mutex_unlock (&data_mutex); - * } - * - * gpointer - * pop_data (void) - * { - * gpointer data; - * - * g_mutex_lock (&data_mutex); - * while (!current_data) - * g_cond_wait (&data_cond, &data_mutex); - * data = current_data; - * current_data = NULL; - * g_mutex_unlock (&data_mutex); - * - * return data; - * } - * ]| - * Whenever a thread calls pop_data() now, it will wait until - * current_data is non-%NULL, i.e. until some other thread - * has called push_data(). - * - * The example shows that use of a condition variable must always be - * paired with a mutex. Without the use of a mutex, there would be a - * race between the check of @current_data by the while loop in - * pop_data() and waiting. Specifically, another thread could set - * @current_data after the check, and signal the cond (with nobody - * waiting on it) before the first thread goes to sleep. #GCond is - * specifically useful for its ability to release the mutex and go - * to sleep atomically. - * - * It is also important to use the g_cond_wait() and g_cond_wait_until() - * functions only inside a loop which checks for the condition to be - * true. See g_cond_wait() for an explanation of why the condition may - * not be true even after it returns. - * - * If a #GCond is allocated in static storage then it can be used - * without initialisation. Otherwise, you should call g_cond_init() - * on it and g_cond_clear() when done. - * - * A #GCond should only be accessed via the g_cond_ functions. - */ - - -/** - * GData: - * - * An opaque data structure that represents a keyed data list. - * - * See also: [Keyed data lists][glib-Keyed-Data-Lists]. - */ - - -/** - * GDataForeachFunc: - * @key_id: the #GQuark id to identifying the data element. - * @data: the data element. - * @user_data: (closure): user data passed to g_dataset_foreach(). - * - * Specifies the type of function passed to g_dataset_foreach(). It is - * called with each #GQuark id and associated data element, together - * with the @user_data parameter supplied to g_dataset_foreach(). - */ - - -/** - * GDate: - * @julian_days: the Julian representation of the date - * @julian: this bit is set if @julian_days is valid - * @dmy: this is set if @day, @month and @year are valid - * @day: the day of the day-month-year representation of the date, - * as a number between 1 and 31 - * @month: the day of the day-month-year representation of the date, - * as a number between 1 and 12 - * @year: the day of the day-month-year representation of the date - * - * Represents a day between January 1, Year 1 and a few thousand years in - * the future. None of its members should be accessed directly. - * - * If the `GDate` is obtained from g_date_new(), it will be safe - * to mutate but invalid and thus not safe for calendrical computations. - * - * If it's declared on the stack, it will contain garbage so must be - * initialized with g_date_clear(). g_date_clear() makes the date invalid - * but safe. An invalid date doesn't represent a day, it's "empty." A date - * becomes valid after you set it to a Julian day or you set a day, month, - * and year. - */ - - -/** - * GDateDMY: - * @G_DATE_DAY: a day - * @G_DATE_MONTH: a month - * @G_DATE_YEAR: a year - * - * This enumeration isn't used in the API, but may be useful if you need - * to mark a number as a day, month, or year. - */ - - -/** - * GDateDay: - * - * Integer representing a day of the month; between 1 and 31. - * - * The %G_DATE_BAD_DAY value represents an invalid day of the month. - */ - - -/** - * GDateMonth: - * @G_DATE_BAD_MONTH: invalid value - * @G_DATE_JANUARY: January - * @G_DATE_FEBRUARY: February - * @G_DATE_MARCH: March - * @G_DATE_APRIL: April - * @G_DATE_MAY: May - * @G_DATE_JUNE: June - * @G_DATE_JULY: July - * @G_DATE_AUGUST: August - * @G_DATE_SEPTEMBER: September - * @G_DATE_OCTOBER: October - * @G_DATE_NOVEMBER: November - * @G_DATE_DECEMBER: December - * - * Enumeration representing a month; values are %G_DATE_JANUARY, - * %G_DATE_FEBRUARY, etc. %G_DATE_BAD_MONTH is the invalid value. - */ - - -/** - * GDateWeekday: - * @G_DATE_BAD_WEEKDAY: invalid value - * @G_DATE_MONDAY: Monday - * @G_DATE_TUESDAY: Tuesday - * @G_DATE_WEDNESDAY: Wednesday - * @G_DATE_THURSDAY: Thursday - * @G_DATE_FRIDAY: Friday - * @G_DATE_SATURDAY: Saturday - * @G_DATE_SUNDAY: Sunday - * - * Enumeration representing a day of the week; #G_DATE_MONDAY, - * #G_DATE_TUESDAY, etc. #G_DATE_BAD_WEEKDAY is an invalid weekday. - */ - - -/** - * GDateYear: - * - * Integer type representing a year. - * - * The %G_DATE_BAD_YEAR value is the invalid value. The year - * must be 1 or higher; negative ([BCE](https://en.wikipedia.org/wiki/Common_Era)) - * years are not allowed. - * - * The year is represented with four digits. - */ - - -/** - * GDestroyNotify: - * @data: the data element. - * - * Specifies the type of function which is called when a data element - * is destroyed. It is passed the pointer to the data element and - * should free any memory and resources allocated for it. - */ - - -/** - * GDir: - * - * An opaque structure representing an opened directory. - */ - - -/** - * GDoubleIEEE754: - * @v_double: the double value - * - * The #GFloatIEEE754 and #GDoubleIEEE754 unions are used to access the sign, - * mantissa and exponent of IEEE floats and doubles. These unions are defined - * as appropriate for a given platform. IEEE floats and doubles are supported - * (used for storage) by at least Intel, PPC and Sparc. - */ - - -/** - * GDuplicateFunc: - * @data: the data to duplicate - * @user_data: (closure): user data that was specified in - * g_datalist_id_dup_data() - * - * The type of functions that are used to 'duplicate' an object. - * What this means depends on the context, it could just be - * incrementing the reference count, if @data is a ref-counted - * object. - * - * Returns: a duplicate of data - */ - - -/** - * GEqualFunc: - * @a: a value - * @b: a value to compare with - * - * Specifies the type of a function used to test two values for - * equality. The function should return %TRUE if both values are equal - * and %FALSE otherwise. - * - * Returns: %TRUE if @a = @b; %FALSE otherwise - */ - - -/** - * GErrorType: - * @G_ERR_UNKNOWN: unknown error - * @G_ERR_UNEXP_EOF: unexpected end of file - * @G_ERR_UNEXP_EOF_IN_STRING: unterminated string constant - * @G_ERR_UNEXP_EOF_IN_COMMENT: unterminated comment - * @G_ERR_NON_DIGIT_IN_CONST: non-digit character in a number - * @G_ERR_DIGIT_RADIX: digit beyond radix in a number - * @G_ERR_FLOAT_RADIX: non-decimal floating point number - * @G_ERR_FLOAT_MALFORMED: malformed floating point number - * - * The possible errors, used in the @v_error field - * of #GTokenValue, when the token is a %G_TOKEN_ERROR. - */ - - -/** - * GFileError: - * @G_FILE_ERROR_EXIST: Operation not permitted; only the owner of - * the file (or other resource) or processes with special privileges - * can perform the operation. - * @G_FILE_ERROR_ISDIR: File is a directory; you cannot open a directory - * for writing, or create or remove hard links to it. - * @G_FILE_ERROR_ACCES: Permission denied; the file permissions do not - * allow the attempted operation. - * @G_FILE_ERROR_NAMETOOLONG: Filename too long. - * @G_FILE_ERROR_NOENT: No such file or directory. This is a "file - * doesn't exist" error for ordinary files that are referenced in - * contexts where they are expected to already exist. - * @G_FILE_ERROR_NOTDIR: A file that isn't a directory was specified when - * a directory is required. - * @G_FILE_ERROR_NXIO: No such device or address. The system tried to - * use the device represented by a file you specified, and it - * couldn't find the device. This can mean that the device file was - * installed incorrectly, or that the physical device is missing or - * not correctly attached to the computer. - * @G_FILE_ERROR_NODEV: The underlying file system of the specified file - * does not support memory mapping. - * @G_FILE_ERROR_ROFS: The directory containing the new link can't be - * modified because it's on a read-only file system. - * @G_FILE_ERROR_TXTBSY: Text file busy. - * @G_FILE_ERROR_FAULT: You passed in a pointer to bad memory. - * (GLib won't reliably return this, don't pass in pointers to bad - * memory.) - * @G_FILE_ERROR_LOOP: Too many levels of symbolic links were encountered - * in looking up a file name. This often indicates a cycle of symbolic - * links. - * @G_FILE_ERROR_NOSPC: No space left on device; write operation on a - * file failed because the disk is full. - * @G_FILE_ERROR_NOMEM: No memory available. The system cannot allocate - * more virtual memory because its capacity is full. - * @G_FILE_ERROR_MFILE: The current process has too many files open and - * can't open any more. Duplicate descriptors do count toward this - * limit. - * @G_FILE_ERROR_NFILE: There are too many distinct file openings in the - * entire system. - * @G_FILE_ERROR_BADF: Bad file descriptor; for example, I/O on a - * descriptor that has been closed or reading from a descriptor open - * only for writing (or vice versa). - * @G_FILE_ERROR_INVAL: Invalid argument. This is used to indicate - * various kinds of problems with passing the wrong argument to a - * library function. - * @G_FILE_ERROR_PIPE: Broken pipe; there is no process reading from the - * other end of a pipe. Every library function that returns this - * error code also generates a 'SIGPIPE' signal; this signal - * terminates the program if not handled or blocked. Thus, your - * program will never actually see this code unless it has handled - * or blocked 'SIGPIPE'. - * @G_FILE_ERROR_AGAIN: Resource temporarily unavailable; the call might - * work if you try again later. - * @G_FILE_ERROR_INTR: Interrupted function call; an asynchronous signal - * occurred and prevented completion of the call. When this - * happens, you should try the call again. - * @G_FILE_ERROR_IO: Input/output error; usually used for physical read - * or write errors. i.e. the disk or other physical device hardware - * is returning errors. - * @G_FILE_ERROR_PERM: Operation not permitted; only the owner of the - * file (or other resource) or processes with special privileges can - * perform the operation. - * @G_FILE_ERROR_NOSYS: Function not implemented; this indicates that - * the system is missing some functionality. - * @G_FILE_ERROR_FAILED: Does not correspond to a UNIX error code; this - * is the standard "failed for unspecified reason" error code present - * in all #GError error code enumerations. Returned if no specific - * code applies. - * - * Values corresponding to @errno codes returned from file operations - * on UNIX. Unlike @errno codes, GFileError values are available on - * all systems, even Windows. The exact meaning of each code depends - * on what sort of file operation you were performing; the UNIX - * documentation gives more details. The following error code descriptions - * come from the GNU C Library manual, and are under the copyright - * of that manual. - * - * It's not very portable to make detailed assumptions about exactly - * which errors will be returned from a given operation. Some errors - * don't occur on some systems, etc., sometimes there are subtle - * differences in when a system will report a given error, etc. - */ - - -/** - * GFileTest: - * @G_FILE_TEST_IS_REGULAR: %TRUE if the file is a regular file - * (not a directory). Note that this test will also return %TRUE - * if the tested file is a symlink to a regular file. - * @G_FILE_TEST_IS_SYMLINK: %TRUE if the file is a symlink. - * @G_FILE_TEST_IS_DIR: %TRUE if the file is a directory. - * @G_FILE_TEST_IS_EXECUTABLE: %TRUE if the file is executable. - * @G_FILE_TEST_EXISTS: %TRUE if the file exists. It may or may not - * be a regular file. - * - * A test to perform on a file using g_file_test(). - */ - - -/** - * GFloatIEEE754: - * @v_float: the double value - * - * The #GFloatIEEE754 and #GDoubleIEEE754 unions are used to access the sign, - * mantissa and exponent of IEEE floats and doubles. These unions are defined - * as appropriate for a given platform. IEEE floats and doubles are supported - * (used for storage) by at least Intel, PPC and Sparc. - */ - - -/** - * GFormatSizeFlags: - * @G_FORMAT_SIZE_DEFAULT: behave the same as g_format_size() - * @G_FORMAT_SIZE_LONG_FORMAT: include the exact number of bytes as part - * of the returned string. For example, "45.6 kB (45,612 bytes)". - * @G_FORMAT_SIZE_IEC_UNITS: use IEC (base 1024) units with "KiB"-style - * suffixes. IEC units should only be used for reporting things with - * a strong "power of 2" basis, like RAM sizes or RAID stripe sizes. - * Network and storage sizes should be reported in the normal SI units. - * @G_FORMAT_SIZE_BITS: set the size as a quantity in bits, rather than - * bytes, and return units in bits. For example, ‘Mb’ rather than ‘MB’. - * - * Flags to modify the format of the string returned by g_format_size_full(). - */ - - -/** - * GFunc: - * @data: the element's data - * @user_data: user data passed to g_list_foreach() or g_slist_foreach() - * - * Specifies the type of functions passed to g_list_foreach() and - * g_slist_foreach(). - */ - - -/** - * GHFunc: - * @key: a key - * @value: the value corresponding to the key - * @user_data: user data passed to g_hash_table_foreach() - * - * Specifies the type of the function passed to g_hash_table_foreach(). - * It is called with each key/value pair, together with the @user_data - * parameter which is passed to g_hash_table_foreach(). - */ - - -/** - * GHRFunc: - * @key: a key - * @value: the value associated with the key - * @user_data: user data passed to g_hash_table_remove() - * - * Specifies the type of the function passed to - * g_hash_table_foreach_remove(). It is called with each key/value - * pair, together with the @user_data parameter passed to - * g_hash_table_foreach_remove(). It should return %TRUE if the - * key/value pair should be removed from the #GHashTable. - * - * Returns: %TRUE if the key/value pair should be removed from the - * #GHashTable - */ - - -/** - * GHashFunc: - * @key: a key - * - * Specifies the type of the hash function which is passed to - * g_hash_table_new() when a #GHashTable is created. - * - * The function is passed a key and should return a #guint hash value. - * The functions g_direct_hash(), g_int_hash() and g_str_hash() provide - * hash functions which can be used when the key is a #gpointer, #gint*, - * and #gchar* respectively. - * - * g_direct_hash() is also the appropriate hash function for keys - * of the form `GINT_TO_POINTER (n)` (or similar macros). - * - * A good hash functions should produce - * hash values that are evenly distributed over a fairly large range. - * The modulus is taken with the hash table size (a prime number) to - * find the 'bucket' to place each key into. The function should also - * be very fast, since it is called for each key lookup. - * - * Note that the hash functions provided by GLib have these qualities, - * but are not particularly robust against manufactured keys that - * cause hash collisions. Therefore, you should consider choosing - * a more secure hash function when using a GHashTable with keys - * that originate in untrusted data (such as HTTP requests). - * Using g_str_hash() in that situation might make your application - * vulnerable to - * [Algorithmic Complexity Attacks](https://lwn.net/Articles/474912/). - * - * The key to choosing a good hash is unpredictability. Even - * cryptographic hashes are very easy to find collisions for when the - * remainder is taken modulo a somewhat predictable prime number. There - * must be an element of randomness that an attacker is unable to guess. - * - * Returns: the hash value corresponding to the key - */ - - -/** - * GHashTable: - * - * The #GHashTable struct is an opaque data structure to represent a - * [Hash Table][glib-Hash-Tables]. It should only be accessed via the - * following functions. - */ - - -/** - * GHashTableIter: - * - * A GHashTableIter structure represents an iterator that can be used - * to iterate over the elements of a #GHashTable. GHashTableIter - * structures are typically allocated on the stack and then initialized - * with g_hash_table_iter_init(). - * - * The iteration order of a #GHashTableIter over the keys/values in a hash - * table is not defined. - */ - - -/** - * GHook: - * @data: data which is passed to func when this hook is invoked - * @next: pointer to the next hook in the list - * @prev: pointer to the previous hook in the list - * @ref_count: the reference count of this hook - * @hook_id: the id of this hook, which is unique within its list - * @flags: flags which are set for this hook. See #GHookFlagMask for - * predefined flags - * @func: the function to call when this hook is invoked. The possible - * signatures for this function are #GHookFunc and #GHookCheckFunc - * @destroy: the default @finalize_hook function of a #GHookList calls - * this member of the hook that is being finalized - * - * The #GHook struct represents a single hook function in a #GHookList. - */ - - -/** - * GHookCheckFunc: - * @data: the data field of the #GHook is passed to the hook function here - * - * Defines the type of a hook function that can be invoked - * by g_hook_list_invoke_check(). - * - * Returns: %FALSE if the #GHook should be destroyed - */ - - -/** - * GHookCheckMarshaller: - * @hook: a #GHook - * @marshal_data: user data - * - * Defines the type of function used by g_hook_list_marshal_check(). - * - * Returns: %FALSE if @hook should be destroyed - */ - - -/** - * GHookCompareFunc: - * @new_hook: the #GHook being inserted - * @sibling: the #GHook to compare with @new_hook - * - * Defines the type of function used to compare #GHook elements in - * g_hook_insert_sorted(). - * - * Returns: a value <= 0 if @new_hook should be before @sibling - */ - - -/** - * GHookFinalizeFunc: - * @hook_list: a #GHookList - * @hook: the hook in @hook_list that gets finalized - * - * Defines the type of function to be called when a hook in a - * list of hooks gets finalized. - */ - - -/** - * GHookFindFunc: - * @hook: a #GHook - * @data: user data passed to g_hook_find_func() - * - * Defines the type of the function passed to g_hook_find(). - * - * Returns: %TRUE if the required #GHook has been found - */ - - -/** - * GHookFlagMask: - * @G_HOOK_FLAG_ACTIVE: set if the hook has not been destroyed - * @G_HOOK_FLAG_IN_CALL: set if the hook is currently being run - * @G_HOOK_FLAG_MASK: A mask covering all bits reserved for - * hook flags; see %G_HOOK_FLAG_USER_SHIFT - * - * Flags used internally in the #GHook implementation. - */ - - -/** - * GHookFunc: - * @data: the data field of the #GHook is passed to the hook function here - * - * Defines the type of a hook function that can be invoked - * by g_hook_list_invoke(). - */ - - -/** - * GHookList: - * @seq_id: the next free #GHook id - * @hook_size: the size of the #GHookList elements, in bytes - * @is_setup: 1 if the #GHookList has been initialized - * @hooks: the first #GHook element in the list - * @dummy3: unused - * @finalize_hook: the function to call to finalize a #GHook element. - * The default behaviour is to call the hooks @destroy function - * @dummy: unused - * - * The #GHookList struct represents a list of hook functions. - */ - - -/** - * GHookMarshaller: - * @hook: a #GHook - * @marshal_data: user data - * - * Defines the type of function used by g_hook_list_marshal(). - */ - - -/** - * GINT16_FROM_BE: - * @val: a #gint16 value in big-endian byte order - * - * Converts a #gint16 value from big-endian to host byte order. - * - * Returns: @val converted to host byte order - */ - - -/** - * GINT16_FROM_LE: - * @val: a #gint16 value in little-endian byte order - * - * Converts a #gint16 value from little-endian to host byte order. - * - * Returns: @val converted to host byte order - */ - - -/** - * GINT16_TO_BE: - * @val: a #gint16 value in host byte order - * - * Converts a #gint16 value from host byte order to big-endian. - * - * Returns: @val converted to big-endian - */ - - -/** - * GINT16_TO_LE: - * @val: a #gint16 value in host byte order - * - * Converts a #gint16 value from host byte order to little-endian. - * - * Returns: @val converted to little-endian - */ - - -/** - * GINT32_FROM_BE: - * @val: a #gint32 value in big-endian byte order - * - * Converts a #gint32 value from big-endian to host byte order. - * - * Returns: @val converted to host byte order - */ - - -/** - * GINT32_FROM_LE: - * @val: a #gint32 value in little-endian byte order - * - * Converts a #gint32 value from little-endian to host byte order. - * - * Returns: @val converted to host byte order - */ - - -/** - * GINT32_TO_BE: - * @val: a #gint32 value in host byte order - * - * Converts a #gint32 value from host byte order to big-endian. - * - * Returns: @val converted to big-endian - */ - - -/** - * GINT32_TO_LE: - * @val: a #gint32 value in host byte order - * - * Converts a #gint32 value from host byte order to little-endian. - * - * Returns: @val converted to little-endian - */ - - -/** - * GINT64_FROM_BE: - * @val: a #gint64 value in big-endian byte order - * - * Converts a #gint64 value from big-endian to host byte order. - * - * Returns: @val converted to host byte order - */ - - -/** - * GINT64_FROM_LE: - * @val: a #gint64 value in little-endian byte order - * - * Converts a #gint64 value from little-endian to host byte order. - * - * Returns: @val converted to host byte order - */ - - -/** - * GINT64_TO_BE: - * @val: a #gint64 value in host byte order - * - * Converts a #gint64 value from host byte order to big-endian. - * - * Returns: @val converted to big-endian - */ - - -/** - * GINT64_TO_LE: - * @val: a #gint64 value in host byte order - * - * Converts a #gint64 value from host byte order to little-endian. - * - * Returns: @val converted to little-endian - */ - - -/** - * GINT_FROM_BE: - * @val: a #gint value in big-endian byte order - * - * Converts a #gint value from big-endian to host byte order. - * - * Returns: @val converted to host byte order - */ - - -/** - * GINT_FROM_LE: - * @val: a #gint value in little-endian byte order - * - * Converts a #gint value from little-endian to host byte order. - * - * Returns: @val converted to host byte order - */ - - -/** - * GINT_TO_BE: - * @val: a #gint value in host byte order - * - * Converts a #gint value from host byte order to big-endian. - * - * Returns: @val converted to big-endian byte order - */ - - -/** - * GINT_TO_LE: - * @val: a #gint value in host byte order - * - * Converts a #gint value from host byte order to little-endian. - * - * Returns: @val converted to little-endian byte order - */ - - -/** - * GINT_TO_POINTER: - * @i: integer to stuff into a pointer - * - * Stuffs an integer into a pointer type. - * - * Remember, you may not store pointers in integers. This is not portable - * in any way, shape or form. These macros only allow storing integers in - * pointers, and only preserve 32 bits of the integer; values outside the - * range of a 32-bit integer will be mangled. - */ - - -/** - * GIOChannel: - * - * A data structure representing an IO Channel. The fields should be - * considered private and should only be accessed with the following - * functions. - */ - - -/** - * GIOChannelError: - * @G_IO_CHANNEL_ERROR_FBIG: File too large. - * @G_IO_CHANNEL_ERROR_INVAL: Invalid argument. - * @G_IO_CHANNEL_ERROR_IO: IO error. - * @G_IO_CHANNEL_ERROR_ISDIR: File is a directory. - * @G_IO_CHANNEL_ERROR_NOSPC: No space left on device. - * @G_IO_CHANNEL_ERROR_NXIO: No such device or address. - * @G_IO_CHANNEL_ERROR_OVERFLOW: Value too large for defined datatype. - * @G_IO_CHANNEL_ERROR_PIPE: Broken pipe. - * @G_IO_CHANNEL_ERROR_FAILED: Some other error. - * - * Error codes returned by #GIOChannel operations. - */ - - -/** - * GIOCondition: - * @G_IO_IN: There is data to read. - * @G_IO_OUT: Data can be written (without blocking). - * @G_IO_PRI: There is urgent data to read. - * @G_IO_ERR: Error condition. - * @G_IO_HUP: Hung up (the connection has been broken, usually for - * pipes and sockets). - * @G_IO_NVAL: Invalid request. The file descriptor is not open. - * - * A bitwise combination representing a condition to watch for on an - * event source. - */ - - -/** - * GIOError: - * @G_IO_ERROR_NONE: no error - * @G_IO_ERROR_AGAIN: an EAGAIN error occurred - * @G_IO_ERROR_INVAL: an EINVAL error occurred - * @G_IO_ERROR_UNKNOWN: another error occurred - * - * #GIOError is only used by the deprecated functions - * g_io_channel_read(), g_io_channel_write(), and g_io_channel_seek(). - */ - - -/** - * GIOFlags: - * @G_IO_FLAG_APPEND: turns on append mode, corresponds to %O_APPEND - * (see the documentation of the UNIX open() syscall) - * @G_IO_FLAG_NONBLOCK: turns on nonblocking mode, corresponds to - * %O_NONBLOCK/%O_NDELAY (see the documentation of the UNIX open() - * syscall) - * @G_IO_FLAG_IS_READABLE: indicates that the io channel is readable. - * This flag cannot be changed. - * @G_IO_FLAG_IS_WRITABLE: indicates that the io channel is writable. - * This flag cannot be changed. - * @G_IO_FLAG_IS_WRITEABLE: a misspelled version of @G_IO_FLAG_IS_WRITABLE - * that existed before the spelling was fixed in GLib 2.30. It is kept - * here for compatibility reasons. Deprecated since 2.30 - * @G_IO_FLAG_IS_SEEKABLE: indicates that the io channel is seekable, - * i.e. that g_io_channel_seek_position() can be used on it. - * This flag cannot be changed. - * @G_IO_FLAG_MASK: the mask that specifies all the valid flags. - * @G_IO_FLAG_GET_MASK: the mask of the flags that are returned from - * g_io_channel_get_flags() - * @G_IO_FLAG_SET_MASK: the mask of the flags that the user can modify - * with g_io_channel_set_flags() - * - * Specifies properties of a #GIOChannel. Some of the flags can only be - * read with g_io_channel_get_flags(), but not changed with - * g_io_channel_set_flags(). - */ - - -/** - * GIOFunc: - * @source: the #GIOChannel event source - * @condition: the condition which has been satisfied - * @data: user data set in g_io_add_watch() or g_io_add_watch_full() - * - * Specifies the type of function passed to g_io_add_watch() or - * g_io_add_watch_full(), which is called when the requested condition - * on a #GIOChannel is satisfied. - * - * Returns: the function should return %FALSE if the event source - * should be removed - */ - - -/** - * GIOFuncs: - * @io_read: reads raw bytes from the channel. This is called from - * various functions such as g_io_channel_read_chars() to - * read raw bytes from the channel. Encoding and buffering - * issues are dealt with at a higher level. - * @io_write: writes raw bytes to the channel. This is called from - * various functions such as g_io_channel_write_chars() to - * write raw bytes to the channel. Encoding and buffering - * issues are dealt with at a higher level. - * @io_seek: (optional): seeks the channel. This is called from - * g_io_channel_seek() on channels that support it. - * @io_close: closes the channel. This is called from - * g_io_channel_close() after flushing the buffers. - * @io_create_watch: creates a watch on the channel. This call - * corresponds directly to g_io_create_watch(). - * @io_free: called from g_io_channel_unref() when the channel needs to - * be freed. This function must free the memory associated - * with the channel, including freeing the #GIOChannel - * structure itself. The channel buffers have been flushed - * and possibly @io_close has been called by the time this - * function is called. - * @io_set_flags: sets the #GIOFlags on the channel. This is called - * from g_io_channel_set_flags() with all flags except - * for %G_IO_FLAG_APPEND and %G_IO_FLAG_NONBLOCK masked - * out. - * @io_get_flags: gets the #GIOFlags for the channel. This function - * need only return the %G_IO_FLAG_APPEND and - * %G_IO_FLAG_NONBLOCK flags; g_io_channel_get_flags() - * automatically adds the others as appropriate. - * - * A table of functions used to handle different types of #GIOChannel - * in a generic way. - */ - - -/** - * GIOStatus: - * @G_IO_STATUS_ERROR: An error occurred. - * @G_IO_STATUS_NORMAL: Success. - * @G_IO_STATUS_EOF: End of file. - * @G_IO_STATUS_AGAIN: Resource temporarily unavailable. - * - * Statuses returned by most of the #GIOFuncs functions. - */ - - -/** - * GKeyFile: - * - * The GKeyFile struct contains only private data - * and should not be accessed directly. - */ - - -/** - * GKeyFileError: - * @G_KEY_FILE_ERROR_UNKNOWN_ENCODING: the text being parsed was in - * an unknown encoding - * @G_KEY_FILE_ERROR_PARSE: document was ill-formed - * @G_KEY_FILE_ERROR_NOT_FOUND: the file was not found - * @G_KEY_FILE_ERROR_KEY_NOT_FOUND: a requested key was not found - * @G_KEY_FILE_ERROR_GROUP_NOT_FOUND: a requested group was not found - * @G_KEY_FILE_ERROR_INVALID_VALUE: a value could not be parsed - * - * Error codes returned by key file parsing. - */ - - -/** - * GKeyFileFlags: - * @G_KEY_FILE_NONE: No flags, default behaviour - * @G_KEY_FILE_KEEP_COMMENTS: Use this flag if you plan to write the - * (possibly modified) contents of the key file back to a file; - * otherwise all comments will be lost when the key file is - * written back. - * @G_KEY_FILE_KEEP_TRANSLATIONS: Use this flag if you plan to write the - * (possibly modified) contents of the key file back to a file; - * otherwise only the translations for the current language will be - * written back. - * - * Flags which influence the parsing. - */ - - -/** - * GLIB_CHECK_VERSION: - * @major: the major version to check for - * @minor: the minor version to check for - * @micro: the micro version to check for - * - * Checks the version of the GLib library that is being compiled - * against. See glib_check_version() for a runtime check. - * - * Returns: %TRUE if the version of the GLib header files - * is the same as or newer than the passed-in version. - */ - - -/** - * GLIB_DISABLE_DEPRECATION_WARNINGS: - * - * A macro that should be defined before including the glib.h header. - * If it is defined, no compiler warnings will be produced for uses - * of deprecated GLib APIs. - */ - - -/** - * GLIB_MAJOR_VERSION: - * - * The major version number of the GLib library. - * - * Like #glib_major_version, but from the headers used at - * application compile time, rather than from the library - * linked against at application run time. - */ - - -/** - * GLIB_MICRO_VERSION: - * - * The micro version number of the GLib library. - * - * Like #gtk_micro_version, but from the headers used at - * application compile time, rather than from the library - * linked against at application run time. - */ - - -/** - * GLIB_MINOR_VERSION: - * - * The minor version number of the GLib library. - * - * Like #gtk_minor_version, but from the headers used at - * application compile time, rather than from the library - * linked against at application run time. - */ - - -/** - * GLONG_FROM_BE: - * @val: a #glong value in big-endian byte order - * - * Converts a #glong value from big-endian to the host byte order. - * - * Returns: @val converted to host byte order - */ - - -/** - * GLONG_FROM_LE: - * @val: a #glong value in little-endian byte order - * - * Converts a #glong value from little-endian to host byte order. - * - * Returns: @val converted to host byte order - */ - - -/** - * GLONG_TO_BE: - * @val: a #glong value in host byte order - * - * Converts a #glong value from host byte order to big-endian. - * - * Returns: @val converted to big-endian byte order - */ - - -/** - * GLONG_TO_LE: - * @val: a #glong value in host byte order - * - * Converts a #glong value from host byte order to little-endian. - * - * Returns: @val converted to little-endian - */ - - -/** - * GList: - * @data: holds the element's data, which can be a pointer to any kind - * of data, or any integer value using the - * [Type Conversion Macros][glib-Type-Conversion-Macros] - * @next: contains the link to the next element in the list - * @prev: contains the link to the previous element in the list - * - * The #GList struct is used for each element in a doubly-linked list. - */ - - -/** - * GLogFunc: - * @log_domain: the log domain of the message - * @log_level: the log level of the message (including the - * fatal and recursion flags) - * @message: the message to process - * @user_data: user data, set in g_log_set_handler() - * - * Specifies the prototype of log handler functions. - * - * The default log handler, g_log_default_handler(), automatically appends a - * new-line character to @message when printing it. It is advised that any - * custom log handler functions behave similarly, so that logging calls in user - * code do not need modifying to add a new-line character to the message if the - * log handler is changed. - * - * This is not used if structured logging is enabled; see - * [Using Structured Logging][using-structured-logging]. - */ - - -/** - * GLogLevelFlags: - * @G_LOG_FLAG_RECURSION: internal flag - * @G_LOG_FLAG_FATAL: internal flag - * @G_LOG_LEVEL_ERROR: log level for errors, see g_error(). - * This level is also used for messages produced by g_assert(). - * @G_LOG_LEVEL_CRITICAL: log level for critical warning messages, see - * g_critical(). - * This level is also used for messages produced by g_return_if_fail() - * and g_return_val_if_fail(). - * @G_LOG_LEVEL_WARNING: log level for warnings, see g_warning() - * @G_LOG_LEVEL_MESSAGE: log level for messages, see g_message() - * @G_LOG_LEVEL_INFO: log level for informational messages, see g_info() - * @G_LOG_LEVEL_DEBUG: log level for debug messages, see g_debug() - * @G_LOG_LEVEL_MASK: a mask including all log levels - * - * Flags specifying the level of log messages. - * - * It is possible to change how GLib treats messages of the various - * levels using g_log_set_handler() and g_log_set_fatal_mask(). - */ - - -/** - * GMappedFile: - * - * The #GMappedFile represents a file mapping created with - * g_mapped_file_new(). It has only private members and should - * not be accessed directly. - */ - - -/** - * GMarkupCollectType: - * @G_MARKUP_COLLECT_INVALID: used to terminate the list of attributes - * to collect - * @G_MARKUP_COLLECT_STRING: collect the string pointer directly from - * the attribute_values[] array. Expects a parameter of type (const - * char **). If %G_MARKUP_COLLECT_OPTIONAL is specified and the - * attribute isn't present then the pointer will be set to %NULL - * @G_MARKUP_COLLECT_STRDUP: as with %G_MARKUP_COLLECT_STRING, but - * expects a parameter of type (char **) and g_strdup()s the - * returned pointer. The pointer must be freed with g_free() - * @G_MARKUP_COLLECT_BOOLEAN: expects a parameter of type (gboolean *) - * and parses the attribute value as a boolean. Sets %FALSE if the - * attribute isn't present. Valid boolean values consist of - * (case-insensitive) "false", "f", "no", "n", "0" and "true", "t", - * "yes", "y", "1" - * @G_MARKUP_COLLECT_TRISTATE: as with %G_MARKUP_COLLECT_BOOLEAN, but - * in the case of a missing attribute a value is set that compares - * equal to neither %FALSE nor %TRUE G_MARKUP_COLLECT_OPTIONAL is - * implied - * @G_MARKUP_COLLECT_OPTIONAL: can be bitwise ORed with the other fields. - * If present, allows the attribute not to appear. A default value - * is set depending on what value type is used - * - * A mixed enumerated type and flags field. You must specify one type - * (string, strdup, boolean, tristate). Additionally, you may optionally - * bitwise OR the type with the flag %G_MARKUP_COLLECT_OPTIONAL. - * - * It is likely that this enum will be extended in the future to - * support other types. - */ - - -/** - * GMutex: - * - * The #GMutex struct is an opaque data structure to represent a mutex - * (mutual exclusion). It can be used to protect data against shared - * access. - * - * Take for example the following function: - * |[<!-- language="C" --> - * int - * give_me_next_number (void) - * { - * static int current_number = 0; - * - * // now do a very complicated calculation to calculate the new - * // number, this might for example be a random number generator - * current_number = calc_next_number (current_number); - * - * return current_number; - * } - * ]| - * It is easy to see that this won't work in a multi-threaded - * application. There current_number must be protected against shared - * access. A #GMutex can be used as a solution to this problem: - * |[<!-- language="C" --> - * int - * give_me_next_number (void) - * { - * static GMutex mutex; - * static int current_number = 0; - * int ret_val; - * - * g_mutex_lock (&mutex); - * ret_val = current_number = calc_next_number (current_number); - * g_mutex_unlock (&mutex); - * - * return ret_val; - * } - * ]| - * Notice that the #GMutex is not initialised to any particular value. - * Its placement in static storage ensures that it will be initialised - * to all-zeros, which is appropriate. - * - * If a #GMutex is placed in other contexts (eg: embedded in a struct) - * then it must be explicitly initialised using g_mutex_init(). - * - * A #GMutex should only be accessed via g_mutex_ functions. - */ - - -/** - * GNode: - * @data: contains the actual data of the node. - * @next: points to the node's next sibling (a sibling is another - * #GNode with the same parent). - * @prev: points to the node's previous sibling. - * @parent: points to the parent of the #GNode, or is %NULL if the - * #GNode is the root of the tree. - * @children: points to the first child of the #GNode. The other - * children are accessed by using the @next pointer of each - * child. - * - * The #GNode struct represents one node in a [n-ary tree][glib-N-ary-Trees]. - */ - - -/** - * GNodeForeachFunc: - * @node: a #GNode. - * @data: user data passed to g_node_children_foreach(). - * - * Specifies the type of function passed to g_node_children_foreach(). - * The function is called with each child node, together with the user - * data passed to g_node_children_foreach(). - */ - - -/** - * GNodeTraverseFunc: - * @node: a #GNode. - * @data: user data passed to g_node_traverse(). - * - * Specifies the type of function passed to g_node_traverse(). The - * function is called with each of the nodes visited, together with the - * user data passed to g_node_traverse(). If the function returns - * %TRUE, then the traversal is stopped. - * - * Returns: %TRUE to stop the traversal. - */ - - -/** - * GOnce: - * @status: the status of the #GOnce - * @retval: the value returned by the call to the function, if @status - * is %G_ONCE_STATUS_READY - * - * A #GOnce struct controls a one-time initialization function. Any - * one-time initialization function must have its own unique #GOnce - * struct. - * - * Since: 2.4 - */ - - -/** - * GOnceStatus: - * @G_ONCE_STATUS_NOTCALLED: the function has not been called yet. - * @G_ONCE_STATUS_PROGRESS: the function call is currently in progress. - * @G_ONCE_STATUS_READY: the function has been called. - * - * The possible statuses of a one-time initialization function - * controlled by a #GOnce struct. - * - * Since: 2.4 - */ - - -/** - * GPOINTER_TO_INT: - * @p: pointer containing an integer - * - * Extracts an integer from a pointer. The integer must have - * been stored in the pointer with GINT_TO_POINTER(). - * - * Remember, you may not store pointers in integers. This is not portable - * in any way, shape or form. These macros only allow storing integers in - * pointers, and only preserve 32 bits of the integer; values outside the - * range of a 32-bit integer will be mangled. - */ - - -/** - * GPOINTER_TO_SIZE: - * @p: pointer to extract a #gsize from - * - * Extracts a #gsize from a pointer. The #gsize must have - * been stored in the pointer with GSIZE_TO_POINTER(). - */ - - -/** - * GPOINTER_TO_UINT: - * @p: pointer to extract an unsigned integer from - * - * Extracts an unsigned integer from a pointer. The integer must have - * been stored in the pointer with GUINT_TO_POINTER(). - */ - - -/** - * GPatternSpec: - * - * A GPatternSpec struct is the 'compiled' form of a pattern. This - * structure is opaque and its fields cannot be accessed directly. - */ - - -/** - * GPrivate: - * - * The #GPrivate struct is an opaque data structure to represent a - * thread-local data key. It is approximately equivalent to the - * pthread_setspecific()/pthread_getspecific() APIs on POSIX and to - * TlsSetValue()/TlsGetValue() on Windows. - * - * If you don't already know why you might want this functionality, - * then you probably don't need it. - * - * #GPrivate is a very limited resource (as far as 128 per program, - * shared between all libraries). It is also not possible to destroy a - * #GPrivate after it has been used. As such, it is only ever acceptable - * to use #GPrivate in static scope, and even then sparingly so. - * - * See G_PRIVATE_INIT() for a couple of examples. - * - * The #GPrivate structure should be considered opaque. It should only - * be accessed via the g_private_ functions. - */ - - -/** - * GPtrArray: - * @pdata: points to the array of pointers, which may be moved when the - * array grows - * @len: number of pointers in the array - * - * Contains the public fields of a pointer array. - */ - - -/** - * GQuark: - * - * A GQuark is a non-zero integer which uniquely identifies a - * particular string. A GQuark value of zero is associated to %NULL. - */ - - -/** - * GRWLock: - * - * The GRWLock struct is an opaque data structure to represent a - * reader-writer lock. It is similar to a #GMutex in that it allows - * multiple threads to coordinate access to a shared resource. - * - * The difference to a mutex is that a reader-writer lock discriminates - * between read-only ('reader') and full ('writer') access. While only - * one thread at a time is allowed write access (by holding the 'writer' - * lock via g_rw_lock_writer_lock()), multiple threads can gain - * simultaneous read-only access (by holding the 'reader' lock via - * g_rw_lock_reader_lock()). - * - * It is unspecified whether readers or writers have priority in acquiring the - * lock when a reader already holds the lock and a writer is queued to acquire - * it. - * - * Here is an example for an array with access functions: - * |[<!-- language="C" --> - * GRWLock lock; - * GPtrArray *array; - * - * gpointer - * my_array_get (guint index) - * { - * gpointer retval = NULL; - * - * if (!array) - * return NULL; - * - * g_rw_lock_reader_lock (&lock); - * if (index < array->len) - * retval = g_ptr_array_index (array, index); - * g_rw_lock_reader_unlock (&lock); - * - * return retval; - * } - * - * void - * my_array_set (guint index, gpointer data) - * { - * g_rw_lock_writer_lock (&lock); - * - * if (!array) - * array = g_ptr_array_new (); - * - * if (index >= array->len) - * g_ptr_array_set_size (array, index+1); - * g_ptr_array_index (array, index) = data; - * - * g_rw_lock_writer_unlock (&lock); - * } - * ]| - * This example shows an array which can be accessed by many readers - * (the my_array_get() function) simultaneously, whereas the writers - * (the my_array_set() function) will only be allowed one at a time - * and only if no readers currently access the array. This is because - * of the potentially dangerous resizing of the array. Using these - * functions is fully multi-thread safe now. - * - * If a #GRWLock is allocated in static storage then it can be used - * without initialisation. Otherwise, you should call - * g_rw_lock_init() on it and g_rw_lock_clear() when done. - * - * A GRWLock should only be accessed with the g_rw_lock_ functions. - * - * Since: 2.32 - */ - - -/** - * GRand: - * - * The GRand struct is an opaque data structure. It should only be - * accessed through the g_rand_* functions. - */ - - -/** - * GRecMutex: - * - * The GRecMutex struct is an opaque data structure to represent a - * recursive mutex. It is similar to a #GMutex with the difference - * that it is possible to lock a GRecMutex multiple times in the same - * thread without deadlock. When doing so, care has to be taken to - * unlock the recursive mutex as often as it has been locked. - * - * If a #GRecMutex is allocated in static storage then it can be used - * without initialisation. Otherwise, you should call - * g_rec_mutex_init() on it and g_rec_mutex_clear() when done. - * - * A GRecMutex should only be accessed with the - * g_rec_mutex_ functions. - * - * Since: 2.32 - */ - - -/** - * GSIZE_FROM_BE: - * @val: a #gsize value in big-endian byte order - * - * Converts a #gsize value from big-endian to the host byte order. - * - * Returns: @val converted to host byte order - */ - - -/** - * GSIZE_FROM_LE: - * @val: a #gsize value in little-endian byte order - * - * Converts a #gsize value from little-endian to host byte order. - * - * Returns: @val converted to host byte order - */ - - -/** - * GSIZE_TO_BE: - * @val: a #gsize value in host byte order - * - * Converts a #gsize value from host byte order to big-endian. - * - * Returns: @val converted to big-endian byte order - */ - - -/** - * GSIZE_TO_LE: - * @val: a #gsize value in host byte order - * - * Converts a #gsize value from host byte order to little-endian. - * - * Returns: @val converted to little-endian - */ - - -/** - * GSIZE_TO_POINTER: - * @s: #gsize to stuff into the pointer - * - * Stuffs a #gsize into a pointer type. - */ - - -/** - * GSList: - * @data: holds the element's data, which can be a pointer to any kind - * of data, or any integer value using the - * [Type Conversion Macros][glib-Type-Conversion-Macros] - * @next: contains the link to the next element in the list. - * - * The #GSList struct is used for each element in the singly-linked - * list. - */ - - -/** - * GSSIZE_FROM_BE: - * @val: a #gssize value in big-endian byte order - * - * Converts a #gssize value from big-endian to host byte order. - * - * Returns: @val converted to host byte order - */ - - -/** - * GSSIZE_FROM_LE: - * @val: a #gssize value in little-endian byte order - * - * Converts a #gssize value from little-endian to host byte order. - * - * Returns: @val converted to host byte order - */ - - -/** - * GSSIZE_TO_BE: - * @val: a #gssize value in host byte order - * - * Converts a #gssize value from host byte order to big-endian. - * - * Returns: @val converted to big-endian - */ - - -/** - * GSSIZE_TO_LE: - * @val: a #gssize value in host byte order - * - * Converts a #gssize value from host byte order to little-endian. - * - * Returns: @val converted to little-endian - */ - - -/** - * GScanner: - * @user_data: unused - * @max_parse_errors: unused - * @parse_errors: g_scanner_error() increments this field - * @input_name: name of input stream, featured by the default message handler - * @qdata: quarked data - * @config: link into the scanner configuration - * @token: token parsed by the last g_scanner_get_next_token() - * @value: value of the last token from g_scanner_get_next_token() - * @line: line number of the last token from g_scanner_get_next_token() - * @position: char number of the last token from g_scanner_get_next_token() - * @next_token: token parsed by the last g_scanner_peek_next_token() - * @next_value: value of the last token from g_scanner_peek_next_token() - * @next_line: line number of the last token from g_scanner_peek_next_token() - * @next_position: char number of the last token from g_scanner_peek_next_token() - * @msg_handler: handler function for _warn and _error - * - * The data structure representing a lexical scanner. - * - * You should set @input_name after creating the scanner, since - * it is used by the default message handler when displaying - * warnings and errors. If you are scanning a file, the filename - * would be a good choice. - * - * The @user_data and @max_parse_errors fields are not used. - * If you need to associate extra data with the scanner you - * can place them here. - * - * If you want to use your own message handler you can set the - * @msg_handler field. The type of the message handler function - * is declared by #GScannerMsgFunc. - */ - - -/** - * GScannerConfig: - * @cset_skip_characters: specifies which characters should be skipped - * by the scanner (the default is the whitespace characters: space, - * tab, carriage-return and line-feed). - * @cset_identifier_first: specifies the characters which can start - * identifiers (the default is #G_CSET_a_2_z, "_", and #G_CSET_A_2_Z). - * @cset_identifier_nth: specifies the characters which can be used - * in identifiers, after the first character (the default is - * #G_CSET_a_2_z, "_0123456789", #G_CSET_A_2_Z, #G_CSET_LATINS, - * #G_CSET_LATINC). - * @cpair_comment_single: specifies the characters at the start and - * end of single-line comments. The default is "#\n" which means - * that single-line comments start with a '#' and continue until - * a '\n' (end of line). - * @case_sensitive: specifies if symbols are case sensitive (the - * default is %FALSE). - * @skip_comment_multi: specifies if multi-line comments are skipped - * and not returned as tokens (the default is %TRUE). - * @skip_comment_single: specifies if single-line comments are skipped - * and not returned as tokens (the default is %TRUE). - * @scan_comment_multi: specifies if multi-line comments are recognized - * (the default is %TRUE). - * @scan_identifier: specifies if identifiers are recognized (the - * default is %TRUE). - * @scan_identifier_1char: specifies if single-character - * identifiers are recognized (the default is %FALSE). - * @scan_identifier_NULL: specifies if %NULL is reported as - * %G_TOKEN_IDENTIFIER_NULL (the default is %FALSE). - * @scan_symbols: specifies if symbols are recognized (the default - * is %TRUE). - * @scan_binary: specifies if binary numbers are recognized (the - * default is %FALSE). - * @scan_octal: specifies if octal numbers are recognized (the - * default is %TRUE). - * @scan_float: specifies if floating point numbers are recognized - * (the default is %TRUE). - * @scan_hex: specifies if hexadecimal numbers are recognized (the - * default is %TRUE). - * @scan_hex_dollar: specifies if '$' is recognized as a prefix for - * hexadecimal numbers (the default is %FALSE). - * @scan_string_sq: specifies if strings can be enclosed in single - * quotes (the default is %TRUE). - * @scan_string_dq: specifies if strings can be enclosed in double - * quotes (the default is %TRUE). - * @numbers_2_int: specifies if binary, octal and hexadecimal numbers - * are reported as #G_TOKEN_INT (the default is %TRUE). - * @int_2_float: specifies if all numbers are reported as %G_TOKEN_FLOAT - * (the default is %FALSE). - * @identifier_2_string: specifies if identifiers are reported as strings - * (the default is %FALSE). - * @char_2_token: specifies if characters are reported by setting - * `token = ch` or as %G_TOKEN_CHAR (the default is %TRUE). - * @symbol_2_token: specifies if symbols are reported by setting - * `token = v_symbol` or as %G_TOKEN_SYMBOL (the default is %FALSE). - * @scope_0_fallback: specifies if a symbol is searched for in the - * default scope in addition to the current scope (the default is %FALSE). - * @store_int64: use value.v_int64 rather than v_int - * - * Specifies the #GScanner parser configuration. Most settings can - * be changed during the parsing phase and will affect the lexical - * parsing of the next unpeeked token. - */ - - -/** - * GScannerMsgFunc: - * @scanner: a #GScanner - * @message: the message - * @error: %TRUE if the message signals an error, - * %FALSE if it signals a warning. - * - * Specifies the type of the message handler function. - */ - - -/** - * GSeekType: - * @G_SEEK_CUR: the current position in the file. - * @G_SEEK_SET: the start of the file. - * @G_SEEK_END: the end of the file. - * - * An enumeration specifying the base position for a - * g_io_channel_seek_position() operation. - */ - - -/** - * GSequence: - * - * The #GSequence struct is an opaque data type representing a - * [sequence][glib-Sequences] data type. - */ - - -/** - * GSequenceIter: - * - * The #GSequenceIter struct is an opaque data type representing an - * iterator pointing into a #GSequence. - */ - - -/** - * GSequenceIterCompareFunc: - * @a: a #GSequenceIter - * @b: a #GSequenceIter - * @data: user data - * - * A #GSequenceIterCompareFunc is a function used to compare iterators. - * It must return zero if the iterators compare equal, a negative value - * if @a comes before @b, and a positive value if @b comes before @a. - * - * Returns: zero if the iterators are equal, a negative value if @a - * comes before @b, and a positive value if @b comes before @a. - */ - - -/** - * GShellError: - * @G_SHELL_ERROR_BAD_QUOTING: Mismatched or otherwise mangled quoting. - * @G_SHELL_ERROR_EMPTY_STRING: String to be parsed was empty. - * @G_SHELL_ERROR_FAILED: Some other error. - * - * Error codes returned by shell functions. - */ - - -/** - * GStatBuf: - * - * A type corresponding to the appropriate struct type for the stat() - * system call, depending on the platform and/or compiler being used. - * - * See g_stat() for more information. - */ - - -/** - * GString: - * @str: points to the character data. It may move as text is added. - * The @str field is null-terminated and so - * can be used as an ordinary C string. - * @len: contains the length of the string, not including the - * terminating nul byte. - * @allocated_len: the number of bytes that can be stored in the - * string before it needs to be reallocated. May be larger than @len. - * - * The GString struct contains the public fields of a GString. - */ - - -/** - * GStringChunk: - * - * An opaque data structure representing String Chunks. - * It should only be accessed by using the following functions. - */ - - -/** - * GStrv: - * - * A typedef alias for gchar**. This is mostly useful when used together with - * g_auto(). - */ - - -/** - * GTestCase: - * - * An opaque structure representing a test case. - */ - - -/** - * GTestDataFunc: - * @user_data: the data provided when registering the test - * - * The type used for test case functions that take an extra pointer - * argument. - * - * Since: 2.28 - */ - - -/** - * GTestFileType: - * @G_TEST_DIST: a file that was included in the distribution tarball - * @G_TEST_BUILT: a file that was built on the compiling machine - * - * The type of file to return the filename for, when used with - * g_test_build_filename(). - * - * These two options correspond rather directly to the 'dist' and - * 'built' terminology that automake uses and are explicitly used to - * distinguish between the 'srcdir' and 'builddir' being separate. All - * files in your project should either be dist (in the - * `EXTRA_DIST` or `dist_schema_DATA` - * sense, in which case they will always be in the srcdir) or built (in - * the `BUILT_SOURCES` sense, in which case they will - * always be in the builddir). - * - * Note: as a general rule of automake, files that are generated only as - * part of the build-from-git process (but then are distributed with the - * tarball) always go in srcdir (even if doing a srcdir != builddir - * build from git) and are considered as distributed files. - * - * Since: 2.38 - */ - - -/** - * GTestFixtureFunc: - * @fixture: (not nullable): the test fixture - * @user_data: the data provided when registering the test - * - * The type used for functions that operate on test fixtures. This is - * used for the fixture setup and teardown functions as well as for the - * testcases themselves. - * - * @user_data is a pointer to the data that was given when registering - * the test case. - * - * @fixture will be a pointer to the area of memory allocated by the - * test framework, of the size requested. If the requested size was - * zero then @fixture will be equal to @user_data. - * - * Since: 2.28 - */ - - -/** - * GTestFunc: - * - * The type used for test case functions. - * - * Since: 2.28 - */ - - -/** - * GTestSubprocessFlags: - * @G_TEST_SUBPROCESS_INHERIT_STDIN: If this flag is given, the child - * process will inherit the parent's stdin. Otherwise, the child's - * stdin is redirected to `/dev/null`. - * @G_TEST_SUBPROCESS_INHERIT_STDOUT: If this flag is given, the child - * process will inherit the parent's stdout. Otherwise, the child's - * stdout will not be visible, but it will be captured to allow - * later tests with g_test_trap_assert_stdout(). - * @G_TEST_SUBPROCESS_INHERIT_STDERR: If this flag is given, the child - * process will inherit the parent's stderr. Otherwise, the child's - * stderr will not be visible, but it will be captured to allow - * later tests with g_test_trap_assert_stderr(). - * - * Flags to pass to g_test_trap_subprocess() to control input and output. - * - * Note that in contrast with g_test_trap_fork(), the default is to - * not show stdout and stderr. - */ - - -/** - * GTestSuite: - * - * An opaque structure representing a test suite. - */ - - -/** - * GThread: - * - * The #GThread struct represents a running thread. This struct - * is returned by g_thread_new() or g_thread_try_new(). You can - * obtain the #GThread struct representing the current thread by - * calling g_thread_self(). - * - * GThread is refcounted, see g_thread_ref() and g_thread_unref(). - * The thread represented by it holds a reference while it is running, - * and g_thread_join() consumes the reference that it is given, so - * it is normally not necessary to manage GThread references - * explicitly. - * - * The structure is opaque -- none of its fields may be directly - * accessed. - */ - - -/** - * GThreadError: - * @G_THREAD_ERROR_AGAIN: a thread couldn't be created due to resource - * shortage. Try again later. - * - * Possible errors of thread related functions. - */ - - -/** - * GThreadFunc: - * @data: data passed to the thread - * - * Specifies the type of the @func functions passed to g_thread_new() - * or g_thread_try_new(). - * - * Returns: the return value of the thread - */ - - -/** - * GThreadPool: - * @func: the function to execute in the threads of this pool - * @user_data: the user data for the threads of this pool - * @exclusive: are all threads exclusive to this pool - * - * The #GThreadPool struct represents a thread pool. It has three - * public read-only members, but the underlying struct is bigger, - * so you must not copy this struct. - */ - - -/** - * GTime: - * - * Simply a replacement for `time_t`. It has been deprecated - * since it is not equivalent to `time_t` on 64-bit platforms - * with a 64-bit `time_t`. - * - * Unrelated to #GTimer. - * - * Note that #GTime is defined to always be a 32-bit integer, - * unlike `time_t` which may be 64-bit on some systems. Therefore, - * #GTime will overflow in the year 2038, and you cannot use the - * address of a #GTime variable as argument to the UNIX time() - * function. - * - * Instead, do the following: - * - * |[<!-- language="C" --> - * time_t ttime; - * GTime gtime; - * - * time (&ttime); - * gtime = (GTime)ttime; - * ]| - * - * Deprecated: 2.62: This is not [Y2038-safe](https://en.wikipedia.org/wiki/Year_2038_problem). - * Use #GDateTime or #time_t instead. - */ - - -/** - * GTimeVal: - * @tv_sec: seconds - * @tv_usec: microseconds - * - * Represents a precise time, with seconds and microseconds. - * - * Similar to the struct timeval returned by the `gettimeofday()` - * UNIX system call. - * - * GLib is attempting to unify around the use of 64-bit integers to - * represent microsecond-precision time. As such, this type will be - * removed from a future version of GLib. A consequence of using `glong` for - * `tv_sec` is that on 32-bit systems `GTimeVal` is subject to the year 2038 - * problem. - * - * Deprecated: 2.62: Use #GDateTime or #guint64 instead. - */ - - -/** - * GTimeZone: - * - * #GTimeZone is an opaque structure whose members cannot be accessed - * directly. - * - * Since: 2.26 - */ - - -/** - * GTimer: - * - * Opaque datatype that records a start time. - */ - - -/** - * GTokenType: - * @G_TOKEN_EOF: the end of the file - * @G_TOKEN_LEFT_PAREN: a '(' character - * @G_TOKEN_LEFT_CURLY: a '{' character - * @G_TOKEN_LEFT_BRACE: a '[' character - * @G_TOKEN_RIGHT_CURLY: a '}' character - * @G_TOKEN_RIGHT_PAREN: a ')' character - * @G_TOKEN_RIGHT_BRACE: a ']' character - * @G_TOKEN_EQUAL_SIGN: a '=' character - * @G_TOKEN_COMMA: a ',' character - * @G_TOKEN_NONE: not a token - * @G_TOKEN_ERROR: an error occurred - * @G_TOKEN_CHAR: a character - * @G_TOKEN_BINARY: a binary integer - * @G_TOKEN_OCTAL: an octal integer - * @G_TOKEN_INT: an integer - * @G_TOKEN_HEX: a hex integer - * @G_TOKEN_FLOAT: a floating point number - * @G_TOKEN_STRING: a string - * @G_TOKEN_SYMBOL: a symbol - * @G_TOKEN_IDENTIFIER: an identifier - * @G_TOKEN_IDENTIFIER_NULL: a null identifier - * @G_TOKEN_COMMENT_SINGLE: one line comment - * @G_TOKEN_COMMENT_MULTI: multi line comment - * - * The possible types of token returned from each - * g_scanner_get_next_token() call. - */ - - -/** - * GTokenValue: - * @v_symbol: token symbol value - * @v_identifier: token identifier value - * @v_binary: token binary integer value - * @v_octal: octal integer value - * @v_int: integer value - * @v_int64: 64-bit integer value - * @v_float: floating point value - * @v_hex: hex integer value - * @v_string: string value - * @v_comment: comment value - * @v_char: character value - * @v_error: error value - * - * A union holding the value of the token. - */ - - -/** - * GTrashStack: - * @next: pointer to the previous element of the stack, - * gets stored in the first `sizeof (gpointer)` - * bytes of the element - * - * Each piece of memory that is pushed onto the stack - * is cast to a GTrashStack*. - * - * Deprecated: 2.48: #GTrashStack is deprecated without replacement - */ - - -/** - * GTraverseFlags: - * @G_TRAVERSE_LEAVES: only leaf nodes should be visited. This name has - * been introduced in 2.6, for older version use - * %G_TRAVERSE_LEAFS. - * @G_TRAVERSE_NON_LEAVES: only non-leaf nodes should be visited. This - * name has been introduced in 2.6, for older - * version use %G_TRAVERSE_NON_LEAFS. - * @G_TRAVERSE_ALL: all nodes should be visited. - * @G_TRAVERSE_MASK: a mask of all traverse flags. - * @G_TRAVERSE_LEAFS: identical to %G_TRAVERSE_LEAVES. - * @G_TRAVERSE_NON_LEAFS: identical to %G_TRAVERSE_NON_LEAVES. - * - * Specifies which nodes are visited during several of the tree - * functions, including g_node_traverse() and g_node_find(). - */ - - -/** - * GTraverseFunc: - * @key: a key of a #GTree node - * @value: the value corresponding to the key - * @data: user data passed to g_tree_traverse() - * - * Specifies the type of function passed to g_tree_traverse(). It is - * passed the key and value of each node, together with the @user_data - * parameter passed to g_tree_traverse(). If the function returns - * %TRUE, the traversal is stopped. - * - * Returns: %TRUE to stop the traversal - */ - - -/** - * GTraverseType: - * @G_IN_ORDER: vists a node's left child first, then the node itself, - * then its right child. This is the one to use if you - * want the output sorted according to the compare - * function. - * @G_PRE_ORDER: visits a node, then its children. - * @G_POST_ORDER: visits the node's children, then the node itself. - * @G_LEVEL_ORDER: is not implemented for - * [balanced binary trees][glib-Balanced-Binary-Trees]. - * For [n-ary trees][glib-N-ary-Trees], it - * vists the root node first, then its children, then - * its grandchildren, and so on. Note that this is less - * efficient than the other orders. - * - * Specifies the type of traversal performed by g_tree_traverse(), - * g_node_traverse() and g_node_find(). The different orders are - * illustrated here: - * - In order: A, B, C, D, E, F, G, H, I - * ![](Sorted_binary_tree_inorder.svg) - * - Pre order: F, B, A, D, C, E, G, I, H - * ![](Sorted_binary_tree_preorder.svg) - * - Post order: A, C, E, D, B, H, I, G, F - * ![](Sorted_binary_tree_postorder.svg) - * - Level order: F, B, G, A, D, I, C, E, H - * ![](Sorted_binary_tree_breadth-first_traversal.svg) - */ - - -/** - * GTree: - * - * The GTree struct is an opaque data structure representing a - * [balanced binary tree][glib-Balanced-Binary-Trees]. It should be - * accessed only by using the following functions. - */ - - -/** - * GUINT16_FROM_BE: - * @val: a #guint16 value in big-endian byte order - * - * Converts a #guint16 value from big-endian to host byte order. - * - * Returns: @val converted to host byte order - */ - - -/** - * GUINT16_FROM_LE: - * @val: a #guint16 value in little-endian byte order - * - * Converts a #guint16 value from little-endian to host byte order. - * - * Returns: @val converted to host byte order - */ - - -/** - * GUINT16_SWAP_BE_PDP: - * @val: a #guint16 value in big-endian or pdp-endian byte order - * - * Converts a #guint16 value between big-endian and pdp-endian byte order. - * The conversion is symmetric so it can be used both ways. - * - * Returns: @val converted to the opposite byte order - */ - - -/** - * GUINT16_SWAP_LE_BE: - * @val: a #guint16 value in little-endian or big-endian byte order - * - * Converts a #guint16 value between little-endian and big-endian byte order. - * The conversion is symmetric so it can be used both ways. - * - * Returns: @val converted to the opposite byte order - */ - - -/** - * GUINT16_SWAP_LE_PDP: - * @val: a #guint16 value in little-endian or pdp-endian byte order - * - * Converts a #guint16 value between little-endian and pdp-endian byte order. - * The conversion is symmetric so it can be used both ways. - * - * Returns: @val converted to the opposite byte order - */ - - -/** - * GUINT16_TO_BE: - * @val: a #guint16 value in host byte order - * - * Converts a #guint16 value from host byte order to big-endian. - * - * Returns: @val converted to big-endian - */ - - -/** - * GUINT16_TO_LE: - * @val: a #guint16 value in host byte order - * - * Converts a #guint16 value from host byte order to little-endian. - * - * Returns: @val converted to little-endian - */ - - -/** - * GUINT32_FROM_BE: - * @val: a #guint32 value in big-endian byte order - * - * Converts a #guint32 value from big-endian to host byte order. - * - * Returns: @val converted to host byte order - */ - - -/** - * GUINT32_FROM_LE: - * @val: a #guint32 value in little-endian byte order - * - * Converts a #guint32 value from little-endian to host byte order. - * - * Returns: @val converted to host byte order - */ - - -/** - * GUINT32_SWAP_BE_PDP: - * @val: a #guint32 value in big-endian or pdp-endian byte order - * - * Converts a #guint32 value between big-endian and pdp-endian byte order. - * The conversion is symmetric so it can be used both ways. - * - * Returns: @val converted to the opposite byte order - */ - - -/** - * GUINT32_SWAP_LE_BE: - * @val: a #guint32 value in little-endian or big-endian byte order - * - * Converts a #guint32 value between little-endian and big-endian byte order. - * The conversion is symmetric so it can be used both ways. - * - * Returns: @val converted to the opposite byte order - */ - - -/** - * GUINT32_SWAP_LE_PDP: - * @val: a #guint32 value in little-endian or pdp-endian byte order - * - * Converts a #guint32 value between little-endian and pdp-endian byte order. - * The conversion is symmetric so it can be used both ways. - * - * Returns: @val converted to the opposite byte order - */ - - -/** - * GUINT32_TO_BE: - * @val: a #guint32 value in host byte order - * - * Converts a #guint32 value from host byte order to big-endian. - * - * Returns: @val converted to big-endian - */ - - -/** - * GUINT32_TO_LE: - * @val: a #guint32 value in host byte order - * - * Converts a #guint32 value from host byte order to little-endian. - * - * Returns: @val converted to little-endian - */ - - -/** - * GUINT64_FROM_BE: - * @val: a #guint64 value in big-endian byte order - * - * Converts a #guint64 value from big-endian to host byte order. - * - * Returns: @val converted to host byte order - */ - - -/** - * GUINT64_FROM_LE: - * @val: a #guint64 value in little-endian byte order - * - * Converts a #guint64 value from little-endian to host byte order. - * - * Returns: @val converted to host byte order - */ - - -/** - * GUINT64_SWAP_LE_BE: - * @val: a #guint64 value in little-endian or big-endian byte order - * - * Converts a #guint64 value between little-endian and big-endian byte order. - * The conversion is symmetric so it can be used both ways. - * - * Returns: @val converted to the opposite byte order - */ - - -/** - * GUINT64_TO_BE: - * @val: a #guint64 value in host byte order - * - * Converts a #guint64 value from host byte order to big-endian. - * - * Returns: @val converted to big-endian - */ - - -/** - * GUINT64_TO_LE: - * @val: a #guint64 value in host byte order - * - * Converts a #guint64 value from host byte order to little-endian. - * - * Returns: @val converted to little-endian - */ - - -/** - * GUINT_FROM_BE: - * @val: a #guint value in big-endian byte order - * - * Converts a #guint value from big-endian to host byte order. - * - * Returns: @val converted to host byte order - */ - - -/** - * GUINT_FROM_LE: - * @val: a #guint value in little-endian byte order - * - * Converts a #guint value from little-endian to host byte order. - * - * Returns: @val converted to host byte order - */ - - -/** - * GUINT_TO_BE: - * @val: a #guint value in host byte order - * - * Converts a #guint value from host byte order to big-endian. - * - * Returns: @val converted to big-endian byte order - */ - - -/** - * GUINT_TO_LE: - * @val: a #guint value in host byte order - * - * Converts a #guint value from host byte order to little-endian. - * - * Returns: @val converted to little-endian byte order. - */ - - -/** - * GUINT_TO_POINTER: - * @u: unsigned integer to stuff into the pointer - * - * Stuffs an unsigned integer into a pointer type. - */ - - -/** - * GULONG_FROM_BE: - * @val: a #gulong value in big-endian byte order - * - * Converts a #gulong value from big-endian to host byte order. - * - * Returns: @val converted to host byte order - */ - - -/** - * GULONG_FROM_LE: - * @val: a #gulong value in little-endian byte order - * - * Converts a #gulong value from little-endian to host byte order. - * - * Returns: @val converted to host byte order - */ - - -/** - * GULONG_TO_BE: - * @val: a #gulong value in host byte order - * - * Converts a #gulong value from host byte order to big-endian. - * - * Returns: @val converted to big-endian - */ - - -/** - * GULONG_TO_LE: - * @val: a #gulong value in host byte order - * - * Converts a #gulong value from host byte order to little-endian. - * - * Returns: @val converted to little-endian - */ - - -/** - * GUri: - * - * A parsed absolute URI. - * - * Since #GUri only represents absolute URIs, all #GUris will have a - * URI scheme, so g_uri_get_scheme() will always return a non-%NULL - * answer. Likewise, by definition, all URIs have a path component, so - * g_uri_get_path() will always return a non-%NULL string (which may be empty). - * - * If the URI string has an - * [‘authority’ component](https://tools.ietf.org/html/rfc3986#section-3) (that - * is, if the scheme is followed by `://` rather than just `:`), then the - * #GUri will contain a hostname, and possibly a port and ‘userinfo’. - * Additionally, depending on how the #GUri was constructed/parsed (for example, - * using the %G_URI_FLAGS_HAS_PASSWORD and %G_URI_FLAGS_HAS_AUTH_PARAMS flags), - * the userinfo may be split out into a username, password, and - * additional authorization-related parameters. - * - * Normally, the components of a #GUri will have all `%`-encoded - * characters decoded. However, if you construct/parse a #GUri with - * %G_URI_FLAGS_ENCODED, then the `%`-encoding will be preserved instead in - * the userinfo, path, and query fields (and in the host field if also - * created with %G_URI_FLAGS_NON_DNS). In particular, this is necessary if - * the URI may contain binary data or non-UTF-8 text, or if decoding - * the components might change the interpretation of the URI. - * - * For example, with the encoded flag: - * - * |[<!-- language="C" --> - * g_autoptr(GUri) uri = g_uri_parse ("http://host/path?query=http%3A%2F%2Fhost%2Fpath%3Fparam%3Dvalue", G_URI_FLAGS_ENCODED, &err); - * g_assert_cmpstr (g_uri_get_query (uri), ==, "query=http%3A%2F%2Fhost%2Fpath%3Fparam%3Dvalue"); - * ]| - * - * While the default `%`-decoding behaviour would give: - * - * |[<!-- language="C" --> - * g_autoptr(GUri) uri = g_uri_parse ("http://host/path?query=http%3A%2F%2Fhost%2Fpath%3Fparam%3Dvalue", G_URI_FLAGS_NONE, &err); - * g_assert_cmpstr (g_uri_get_query (uri), ==, "query=http://host/path?param=value"); - * ]| - * - * During decoding, if an invalid UTF-8 string is encountered, parsing will fail - * with an error indicating the bad string location: - * - * |[<!-- language="C" --> - * g_autoptr(GUri) uri = g_uri_parse ("http://host/path?query=http%3A%2F%2Fhost%2Fpath%3Fbad%3D%00alue", G_URI_FLAGS_NONE, &err); - * g_assert_error (err, G_URI_ERROR, G_URI_ERROR_BAD_QUERY); - * ]| - * - * You should pass %G_URI_FLAGS_ENCODED or %G_URI_FLAGS_ENCODED_QUERY if you - * need to handle that case manually. In particular, if the query string - * contains `=` characters that are `%`-encoded, you should let - * g_uri_parse_params() do the decoding once of the query. - * - * #GUri is immutable once constructed, and can safely be accessed from - * multiple threads. Its reference counting is atomic. - * - * Since: 2.66 - */ - - -/** - * GUriParamsIter: - * - * Many URI schemes include one or more attribute/value pairs as part of the URI - * value. For example `scheme://server/path?query=string&is=there` has two - * attributes – `query=string` and `is=there` – in its query part. - * - * A #GUriParamsIter structure represents an iterator that can be used to - * iterate over the attribute/value pairs of a URI query string. #GUriParamsIter - * structures are typically allocated on the stack and then initialized with - * g_uri_params_iter_init(). See the documentation for g_uri_params_iter_init() - * for a usage example. - * - * Since: 2.66 - */ - - -/** - * GVariant: - * - * #GVariant is an opaque data structure and can only be accessed - * using the following functions. - * - * Since: 2.24 - */ - - -/** - * GVariantBuilder: - * - * A utility type for constructing container-type #GVariant instances. - * - * This is an opaque structure and may only be accessed using the - * following functions. - * - * #GVariantBuilder is not threadsafe in any way. Do not attempt to - * access it from more than one thread. - */ - - -/** - * GVariantClass: - * @G_VARIANT_CLASS_BOOLEAN: The #GVariant is a boolean. - * @G_VARIANT_CLASS_BYTE: The #GVariant is a byte. - * @G_VARIANT_CLASS_INT16: The #GVariant is a signed 16 bit integer. - * @G_VARIANT_CLASS_UINT16: The #GVariant is an unsigned 16 bit integer. - * @G_VARIANT_CLASS_INT32: The #GVariant is a signed 32 bit integer. - * @G_VARIANT_CLASS_UINT32: The #GVariant is an unsigned 32 bit integer. - * @G_VARIANT_CLASS_INT64: The #GVariant is a signed 64 bit integer. - * @G_VARIANT_CLASS_UINT64: The #GVariant is an unsigned 64 bit integer. - * @G_VARIANT_CLASS_HANDLE: The #GVariant is a file handle index. - * @G_VARIANT_CLASS_DOUBLE: The #GVariant is a double precision floating - * point value. - * @G_VARIANT_CLASS_STRING: The #GVariant is a normal string. - * @G_VARIANT_CLASS_OBJECT_PATH: The #GVariant is a D-Bus object path - * string. - * @G_VARIANT_CLASS_SIGNATURE: The #GVariant is a D-Bus signature string. - * @G_VARIANT_CLASS_VARIANT: The #GVariant is a variant. - * @G_VARIANT_CLASS_MAYBE: The #GVariant is a maybe-typed value. - * @G_VARIANT_CLASS_ARRAY: The #GVariant is an array. - * @G_VARIANT_CLASS_TUPLE: The #GVariant is a tuple. - * @G_VARIANT_CLASS_DICT_ENTRY: The #GVariant is a dictionary entry. - * - * The range of possible top-level types of #GVariant instances. - * - * Since: 2.24 - */ - - -/** - * GVariantDict: - * - * #GVariantDict is a mutable interface to #GVariant dictionaries. - * - * It can be used for doing a sequence of dictionary lookups in an - * efficient way on an existing #GVariant dictionary or it can be used - * to construct new dictionaries with a hashtable-like interface. It - * can also be used for taking existing dictionaries and modifying them - * in order to create new ones. - * - * #GVariantDict can only be used with %G_VARIANT_TYPE_VARDICT - * dictionaries. - * - * It is possible to use #GVariantDict allocated on the stack or on the - * heap. When using a stack-allocated #GVariantDict, you begin with a - * call to g_variant_dict_init() and free the resources with a call to - * g_variant_dict_clear(). - * - * Heap-allocated #GVariantDict follows normal refcounting rules: you - * allocate it with g_variant_dict_new() and use g_variant_dict_ref() - * and g_variant_dict_unref(). - * - * g_variant_dict_end() is used to convert the #GVariantDict back into a - * dictionary-type #GVariant. When used with stack-allocated instances, - * this also implicitly frees all associated memory, but for - * heap-allocated instances, you must still call g_variant_dict_unref() - * afterwards. - * - * You will typically want to use a heap-allocated #GVariantDict when - * you expose it as part of an API. For most other uses, the - * stack-allocated form will be more convenient. - * - * Consider the following two examples that do the same thing in each - * style: take an existing dictionary and look up the "count" uint32 - * key, adding 1 to it if it is found, or returning an error if the - * key is not found. Each returns the new dictionary as a floating - * #GVariant. - * - * ## Using a stack-allocated GVariantDict - * - * |[<!-- language="C" --> - * GVariant * - * add_to_count (GVariant *orig, - * GError **error) - * { - * GVariantDict dict; - * guint32 count; - * - * g_variant_dict_init (&dict, orig); - * if (!g_variant_dict_lookup (&dict, "count", "u", &count)) - * { - * g_set_error (...); - * g_variant_dict_clear (&dict); - * return NULL; - * } - * - * g_variant_dict_insert (&dict, "count", "u", count + 1); - * - * return g_variant_dict_end (&dict); - * } - * ]| - * - * ## Using heap-allocated GVariantDict - * - * |[<!-- language="C" --> - * GVariant * - * add_to_count (GVariant *orig, - * GError **error) - * { - * GVariantDict *dict; - * GVariant *result; - * guint32 count; - * - * dict = g_variant_dict_new (orig); - * - * if (g_variant_dict_lookup (dict, "count", "u", &count)) - * { - * g_variant_dict_insert (dict, "count", "u", count + 1); - * result = g_variant_dict_end (dict); - * } - * else - * { - * g_set_error (...); - * result = NULL; - * } - * - * g_variant_dict_unref (dict); - * - * return result; - * } - * ]| - * - * Since: 2.40 - */ - - -/** - * GVariantIter: (skip) - * - * #GVariantIter is an opaque data structure and can only be accessed - * using the following functions. - */ - - -/** - * GVariantParseError: - * @G_VARIANT_PARSE_ERROR_FAILED: generic error (unused) - * @G_VARIANT_PARSE_ERROR_BASIC_TYPE_EXPECTED: a non-basic #GVariantType was given where a basic type was expected - * @G_VARIANT_PARSE_ERROR_CANNOT_INFER_TYPE: cannot infer the #GVariantType - * @G_VARIANT_PARSE_ERROR_DEFINITE_TYPE_EXPECTED: an indefinite #GVariantType was given where a definite type was expected - * @G_VARIANT_PARSE_ERROR_INPUT_NOT_AT_END: extra data after parsing finished - * @G_VARIANT_PARSE_ERROR_INVALID_CHARACTER: invalid character in number or unicode escape - * @G_VARIANT_PARSE_ERROR_INVALID_FORMAT_STRING: not a valid #GVariant format string - * @G_VARIANT_PARSE_ERROR_INVALID_OBJECT_PATH: not a valid object path - * @G_VARIANT_PARSE_ERROR_INVALID_SIGNATURE: not a valid type signature - * @G_VARIANT_PARSE_ERROR_INVALID_TYPE_STRING: not a valid #GVariant type string - * @G_VARIANT_PARSE_ERROR_NO_COMMON_TYPE: could not find a common type for array entries - * @G_VARIANT_PARSE_ERROR_NUMBER_OUT_OF_RANGE: the numerical value is out of range of the given type - * @G_VARIANT_PARSE_ERROR_NUMBER_TOO_BIG: the numerical value is out of range for any type - * @G_VARIANT_PARSE_ERROR_TYPE_ERROR: cannot parse as variant of the specified type - * @G_VARIANT_PARSE_ERROR_UNEXPECTED_TOKEN: an unexpected token was encountered - * @G_VARIANT_PARSE_ERROR_UNKNOWN_KEYWORD: an unknown keyword was encountered - * @G_VARIANT_PARSE_ERROR_UNTERMINATED_STRING_CONSTANT: unterminated string constant - * @G_VARIANT_PARSE_ERROR_VALUE_EXPECTED: no value given - * @G_VARIANT_PARSE_ERROR_RECURSION: variant was too deeply nested; #GVariant is only guaranteed to handle nesting up to 64 levels (Since: 2.64) - * - * Error codes returned by parsing text-format GVariants. - */ - - -/** - * G_APPROX_VALUE: - * @a: a numeric value - * @b: a numeric value - * @epsilon: a numeric value that expresses the tolerance between @a and @b - * - * Evaluates to a truth value if the absolute difference between @a and @b is - * smaller than @epsilon, and to a false value otherwise. - * - * For example, - * - `G_APPROX_VALUE (5, 6, 2)` evaluates to true - * - `G_APPROX_VALUE (3.14, 3.15, 0.001)` evaluates to false - * - `G_APPROX_VALUE (n, 0.f, FLT_EPSILON)` evaluates to true if `n` is within - * the single precision floating point epsilon from zero - * - * Returns: %TRUE if the two values are within the desired range - * Since: 2.58 - */ - - -/** - * G_ASCII_DTOSTR_BUF_SIZE: - * - * A good size for a buffer to be passed into g_ascii_dtostr(). - * It is guaranteed to be enough for all output of that function - * on systems with 64bit IEEE-compatible doubles. - * - * The typical usage would be something like: - * |[<!-- language="C" --> - * char buf[G_ASCII_DTOSTR_BUF_SIZE]; - * - * fprintf (out, "value=%s\n", g_ascii_dtostr (buf, sizeof (buf), value)); - * ]| - */ - - -/** - * G_ATOMIC_LOCK_FREE: - * - * This macro is defined if the atomic operations of GLib are - * implemented using real hardware atomic operations. This means that - * the GLib atomic API can be used between processes and safely mixed - * with other (hardware) atomic APIs. - * - * If this macro is not defined, the atomic operations may be - * emulated using a mutex. In that case, the GLib atomic operations are - * only atomic relative to themselves and within a single process. - */ - - -/** - * G_BEGIN_DECLS: - * - * Used (along with #G_END_DECLS) to bracket header files. If the - * compiler in use is a C++ compiler, adds extern "C" - * around the header. - */ - - -/** - * G_BIG_ENDIAN: - * - * Specifies one of the possible types of byte order. - * See #G_BYTE_ORDER. - */ - - -/** - * G_BYTE_ORDER: - * - * The host byte order. - * This can be either #G_LITTLE_ENDIAN or #G_BIG_ENDIAN (support for - * #G_PDP_ENDIAN may be added in future.) - */ - - -/** - * G_CSET_A_2_Z: - * - * The set of uppercase ASCII alphabet characters. - * Used for specifying valid identifier characters - * in #GScannerConfig. - */ - - -/** - * G_CSET_DIGITS: - * - * The set of ASCII digits. - * Used for specifying valid identifier characters - * in #GScannerConfig. - */ - - -/** - * G_CSET_LATINC: - * - * The set of uppercase ISO 8859-1 alphabet characters - * which are not ASCII characters. - * Used for specifying valid identifier characters - * in #GScannerConfig. - */ - - -/** - * G_CSET_LATINS: - * - * The set of lowercase ISO 8859-1 alphabet characters - * which are not ASCII characters. - * Used for specifying valid identifier characters - * in #GScannerConfig. - */ - - -/** - * G_CSET_a_2_z: - * - * The set of lowercase ASCII alphabet characters. - * Used for specifying valid identifier characters - * in #GScannerConfig. - */ - - -/** - * G_DATE_BAD_DAY: - * - * Represents an invalid #GDateDay. - */ - - -/** - * G_DATE_BAD_JULIAN: - * - * Represents an invalid Julian day number. - */ - - -/** - * G_DATE_BAD_YEAR: - * - * Represents an invalid year. - */ - - -/** - * G_DEFINE_AUTOPTR_CLEANUP_FUNC: - * @TypeName: a type name to define a g_autoptr() cleanup function for - * @func: the cleanup function - * - * Defines the appropriate cleanup function for a pointer type. - * - * The function will not be called if the variable to be cleaned up - * contains %NULL. - * - * This will typically be the `_free()` or `_unref()` function for the given - * type. - * - * With this definition, it will be possible to use g_autoptr() with - * @TypeName. - * - * |[ - * G_DEFINE_AUTOPTR_CLEANUP_FUNC(GObject, g_object_unref) - * ]| - * - * This macro should be used unconditionally; it is a no-op on compilers - * where cleanup is not supported. - * - * Since: 2.44 - */ - - -/** - * G_DEFINE_AUTO_CLEANUP_CLEAR_FUNC: - * @TypeName: a type name to define a g_auto() cleanup function for - * @func: the clear function - * - * Defines the appropriate cleanup function for a type. - * - * This will typically be the `_clear()` function for the given type. - * - * With this definition, it will be possible to use g_auto() with - * @TypeName. - * - * |[ - * G_DEFINE_AUTO_CLEANUP_CLEAR_FUNC(GQueue, g_queue_clear) - * ]| - * - * This macro should be used unconditionally; it is a no-op on compilers - * where cleanup is not supported. - * - * Since: 2.44 - */ - - -/** - * G_DEFINE_AUTO_CLEANUP_FREE_FUNC: - * @TypeName: a type name to define a g_auto() cleanup function for - * @func: the free function - * @none: the "none" value for the type - * - * Defines the appropriate cleanup function for a type. - * - * With this definition, it will be possible to use g_auto() with - * @TypeName. - * - * This function will be rarely used. It is used with pointer-based - * typedefs and non-pointer types where the value of the variable - * represents a resource that must be freed. Two examples are #GStrv - * and file descriptors. - * - * @none specifies the "none" value for the type in question. It is - * probably something like %NULL or `-1`. If the variable is found to - * contain this value then the free function will not be called. - * - * |[ - * G_DEFINE_AUTO_CLEANUP_FREE_FUNC(GStrv, g_strfreev, NULL) - * ]| - * - * This macro should be used unconditionally; it is a no-op on compilers - * where cleanup is not supported. - * - * Since: 2.44 - */ - - -/** - * G_DEFINE_QUARK: - * @QN: the name to return a #GQuark for - * @q_n: prefix for the function name - * - * A convenience macro which defines a function returning the - * #GQuark for the name @QN. The function will be named - * @q_n_quark(). - * - * Note that the quark name will be stringified automatically - * in the macro, so you shouldn't use double quotes. - * - * Since: 2.34 - */ - - -/** - * G_DEPRECATED: - * - * This macro is similar to %G_GNUC_DEPRECATED, and can be used to mark - * functions declarations as deprecated. Unlike %G_GNUC_DEPRECATED, it is - * meant to be portable across different compilers and must be placed - * before the function declaration. - * - * |[<!-- language="C" -- - * G_DEPRECATED - * int my_mistake (void); - * ]| - * - * Since: 2.32 - */ - - -/** - * G_DEPRECATED_FOR: - * @f: the name of the function that this function was deprecated for - * - * This macro is similar to %G_GNUC_DEPRECATED_FOR, and can be used to mark - * functions declarations as deprecated. Unlike %G_GNUC_DEPRECATED_FOR, it - * is meant to be portable across different compilers and must be placed - * before the function declaration. - * - * |[<!-- language="C" -- - * G_DEPRECATED_FOR(my_replacement) - * int my_mistake (void); - * ]| - * - * Since: 2.32 - */ - - -/** - * G_DIR_SEPARATOR: - * - * The directory separator character. - * This is '/' on UNIX machines and '\' under Windows. - */ - - -/** - * G_DIR_SEPARATOR_S: - * - * The directory separator as a string. - * This is "/" on UNIX machines and "\" under Windows. - */ - - -/** - * G_E: - * - * The base of natural logarithms. - */ - - -/** - * G_END_DECLS: - * - * Used (along with #G_BEGIN_DECLS) to bracket header files. If the - * compiler in use is a C++ compiler, adds extern "C" - * around the header. - */ - - -/** - * G_FILE_ERROR: - * - * Error domain for file operations. Errors in this domain will - * be from the #GFileError enumeration. See #GError for information - * on error domains. - */ - - -/** - * G_GINT16_FORMAT: - * - * This is the platform dependent conversion specifier for scanning and - * printing values of type #gint16. It is a string literal, but doesn't - * include the percent-sign, such that you can add precision and length - * modifiers between percent-sign and conversion specifier. - * - * |[<!-- language="C" --> - * gint16 in; - * gint32 out; - * sscanf ("42", "%" G_GINT16_FORMAT, &in) - * out = in * 1000; - * g_print ("%" G_GINT32_FORMAT, out); - * ]| - */ - - -/** - * G_GINT16_MODIFIER: - * - * The platform dependent length modifier for conversion specifiers - * for scanning and printing values of type #gint16 or #guint16. It - * is a string literal, but doesn't include the percent-sign, such - * that you can add precision and length modifiers between percent-sign - * and conversion specifier and append a conversion specifier. - * - * The following example prints "0x7b"; - * |[<!-- language="C" --> - * gint16 value = 123; - * g_print ("%#" G_GINT16_MODIFIER "x", value); - * ]| - * - * Since: 2.4 - */ - - -/** - * G_GINT32_FORMAT: - * - * This is the platform dependent conversion specifier for scanning - * and printing values of type #gint32. See also #G_GINT16_FORMAT. - */ - - -/** - * G_GINT32_MODIFIER: - * - * The platform dependent length modifier for conversion specifiers - * for scanning and printing values of type #gint32 or #guint32. It - * is a string literal. See also #G_GINT16_MODIFIER. - * - * Since: 2.4 - */ - - -/** - * G_GINT64_CONSTANT: - * @val: a literal integer value, e.g. 0x1d636b02300a7aa7 - * - * This macro is used to insert 64-bit integer literals - * into the source code. - */ - - -/** - * G_GINT64_FORMAT: - * - * This is the platform dependent conversion specifier for scanning - * and printing values of type #gint64. See also #G_GINT16_FORMAT. - * - * Some platforms do not support scanning and printing 64-bit integers, - * even though the types are supported. On such platforms %G_GINT64_FORMAT - * is not defined. Note that scanf() may not support 64-bit integers, even - * if %G_GINT64_FORMAT is defined. Due to its weak error handling, scanf() - * is not recommended for parsing anyway; consider using g_ascii_strtoull() - * instead. - */ - - -/** - * G_GINT64_MODIFIER: - * - * The platform dependent length modifier for conversion specifiers - * for scanning and printing values of type #gint64 or #guint64. - * It is a string literal. - * - * Some platforms do not support printing 64-bit integers, even - * though the types are supported. On such platforms %G_GINT64_MODIFIER - * is not defined. - * - * Since: 2.4 - */ - - -/** - * G_GINTPTR_FORMAT: - * - * This is the platform dependent conversion specifier for scanning - * and printing values of type #gintptr. - * - * Since: 2.22 - */ - - -/** - * G_GINTPTR_MODIFIER: - * - * The platform dependent length modifier for conversion specifiers - * for scanning and printing values of type #gintptr or #guintptr. - * It is a string literal. - * - * Since: 2.22 - */ - - -/** - * G_GNUC_BEGIN_IGNORE_DEPRECATIONS: - * - * Tells gcc (if it is a new enough version) to temporarily stop emitting - * warnings when functions marked with %G_GNUC_DEPRECATED or - * %G_GNUC_DEPRECATED_FOR are called. This is useful for when you have - * one deprecated function calling another one, or when you still have - * regression tests for deprecated functions. - * - * Use %G_GNUC_END_IGNORE_DEPRECATIONS to begin warning again. (If you - * are not compiling with `-Wdeprecated-declarations` then neither macro - * has any effect.) - * - * This macro can be used either inside or outside of a function body, - * but must appear on a line by itself. Both this macro and the corresponding - * %G_GNUC_END_IGNORE_DEPRECATIONS are considered statements, so they - * should not be used around branching or loop conditions; for instance, - * this use is invalid: - * - * |[<!-- language="C" --> - * G_GNUC_BEGIN_IGNORE_DEPRECATIONS - * if (check == some_deprecated_function ()) - * G_GNUC_END_IGNORE_DEPRECATIONS - * { - * do_something (); - * } - * ]| - * - * and you should move the deprecated section outside the condition - * - * |[<!-- language="C" --> - * - * // Solution A - * some_data_t *res; - * - * G_GNUC_BEGIN_IGNORE_DEPRECATIONS - * res = some_deprecated_function (); - * G_GNUC_END_IGNORE_DEPRECATIONS - * - * if (check == res) - * { - * do_something (); - * } - * - * // Solution B - * G_GNUC_BEGIN_IGNORE_DEPRECATIONS - * if (check == some_deprecated_function ()) - * { - * do_something (); - * } - * G_GNUC_END_IGNORE_DEPRECATIONS - * ]| - * - * |[<!-- language="C" -- - * static void - * test_deprecated_function (void) - * { - * G_GNUC_BEGIN_IGNORE_DEPRECATIONS - * g_assert_cmpint (my_mistake (), ==, 42); - * G_GNUC_END_IGNORE_DEPRECATIONS - * } - * ]| - * - * Since: 2.32 - */ - - -/** - * G_GNUC_CHECK_VERSION: - * @major: major version to check against - * @minor: minor version to check against - * - * Expands to a check for a compiler with __GNUC__ defined and a version - * greater than or equal to the major and minor numbers provided. For example, - * the following would only match on compilers such as GCC 4.8 or newer. - * - * |[<!-- language="C" --> - * #if G_GNUC_CHECK_VERSION(4, 8) - * #endif - * ]| - * - * Since: 2.42 - */ - - -/** - * G_GNUC_END_IGNORE_DEPRECATIONS: - * - * Undoes the effect of %G_GNUC_BEGIN_IGNORE_DEPRECATIONS, telling - * gcc to begin outputting warnings again (assuming those warnings - * had been enabled to begin with). - * - * This macro can be used either inside or outside of a function body, - * but must appear on a line by itself. - * - * Since: 2.32 - */ - - -/** - * G_GNUC_EXTENSION: - * - * Expands to __extension__ when gcc is used as the compiler. This simply - * tells gcc not to warn about the following non-standard code when compiling - * with the `-pedantic` option. - */ - - -/** - * G_GNUC_INTERNAL: - * - * This attribute can be used for marking library functions as being used - * internally to the library only, which may allow the compiler to handle - * function calls more efficiently. Note that static functions do not need - * to be marked as internal in this way. See the GNU C documentation for - * details. - * - * When using a compiler that supports the GNU C hidden visibility attribute, - * this macro expands to __attribute__((visibility("hidden"))). - * When using the Sun Studio compiler, it expands to __hidden. - * - * Note that for portability, the attribute should be placed before the - * function declaration. While GCC allows the macro after the declaration, - * Sun Studio does not. - * - * |[<!-- language="C" --> - * G_GNUC_INTERNAL - * void _g_log_fallback_handler (const gchar *log_domain, - * GLogLevelFlags log_level, - * const gchar *message, - * gpointer unused_data); - * ]| - * - * Since: 2.6 - */ - - -/** - * G_GOFFSET_CONSTANT: - * @val: a literal integer value, e.g. 0x1d636b02300a7aa7 - * - * This macro is used to insert #goffset 64-bit integer literals - * into the source code. - * - * See also #G_GINT64_CONSTANT. - * - * Since: 2.20 - */ - - -/** - * G_GOFFSET_FORMAT: - * - * This is the platform dependent conversion specifier for scanning - * and printing values of type #goffset. See also #G_GINT64_FORMAT. - * - * Since: 2.20 - */ - - -/** - * G_GOFFSET_MODIFIER: - * - * The platform dependent length modifier for conversion specifiers - * for scanning and printing values of type #goffset. It is a string - * literal. See also #G_GINT64_MODIFIER. - * - * Since: 2.20 - */ - - -/** - * G_GSIZE_FORMAT: - * - * This is the platform dependent conversion specifier for scanning - * and printing values of type #gsize. See also #G_GINT16_FORMAT. - * - * Since: 2.6 - */ - - -/** - * G_GSIZE_MODIFIER: - * - * The platform dependent length modifier for conversion specifiers - * for scanning and printing values of type #gsize. It - * is a string literal. - * - * Since: 2.6 - */ - - -/** - * G_GSSIZE_FORMAT: - * - * This is the platform dependent conversion specifier for scanning - * and printing values of type #gssize. See also #G_GINT16_FORMAT. - * - * Since: 2.6 - */ - - -/** - * G_GSSIZE_MODIFIER: - * - * The platform dependent length modifier for conversion specifiers - * for scanning and printing values of type #gssize. It - * is a string literal. - * - * Since: 2.6 - */ - - -/** - * G_GUINT16_FORMAT: - * - * This is the platform dependent conversion specifier for scanning - * and printing values of type #guint16. See also #G_GINT16_FORMAT - */ - - -/** - * G_GUINT32_FORMAT: - * - * This is the platform dependent conversion specifier for scanning - * and printing values of type #guint32. See also #G_GINT16_FORMAT. - */ - - -/** - * G_GUINT64_CONSTANT: - * @val: a literal integer value, e.g. 0x1d636b02300a7aa7U - * - * This macro is used to insert 64-bit unsigned integer - * literals into the source code. - * - * Since: 2.10 - */ - - -/** - * G_GUINT64_FORMAT: - * - * This is the platform dependent conversion specifier for scanning - * and printing values of type #guint64. See also #G_GINT16_FORMAT. - * - * Some platforms do not support scanning and printing 64-bit integers, - * even though the types are supported. On such platforms %G_GUINT64_FORMAT - * is not defined. Note that scanf() may not support 64-bit integers, even - * if %G_GINT64_FORMAT is defined. Due to its weak error handling, scanf() - * is not recommended for parsing anyway; consider using g_ascii_strtoull() - * instead. - */ - - -/** - * G_GUINTPTR_FORMAT: - * - * This is the platform dependent conversion specifier - * for scanning and printing values of type #guintptr. - * - * Since: 2.22 - */ - - -/** - * G_HAVE_GNUC_VISIBILITY: - * - * Defined to 1 if gcc-style visibility handling is supported. - */ - - -/** - * G_HOOK: - * @hook: a pointer - * - * Casts a pointer to a `GHook*`. - */ - - -/** - * G_HOOK_ACTIVE: - * @hook: a #GHook - * - * Returns %TRUE if the #GHook is active, which is normally the case - * until the #GHook is destroyed. - * - * Returns: %TRUE if the #GHook is active - */ - - -/** - * G_HOOK_FLAGS: - * @hook: a #GHook - * - * Gets the flags of a hook. - */ - - -/** - * G_HOOK_FLAG_USER_SHIFT: - * - * The position of the first bit which is not reserved for internal - * use be the #GHook implementation, i.e. - * `1 << G_HOOK_FLAG_USER_SHIFT` is the first - * bit which can be used for application-defined flags. - */ - - -/** - * G_HOOK_IN_CALL: - * @hook: a #GHook - * - * Returns %TRUE if the #GHook function is currently executing. - * - * Returns: %TRUE if the #GHook function is currently executing - */ - - -/** - * G_HOOK_IS_UNLINKED: - * @hook: a #GHook - * - * Returns %TRUE if the #GHook is not in a #GHookList. - * - * Returns: %TRUE if the #GHook is not in a #GHookList - */ - - -/** - * G_HOOK_IS_VALID: - * @hook: a #GHook - * - * Returns %TRUE if the #GHook is valid, i.e. it is in a #GHookList, - * it is active and it has not been destroyed. - * - * Returns: %TRUE if the #GHook is valid - */ - - -/** - * G_IEEE754_DOUBLE_BIAS: - * - * The bias by which exponents in double-precision floats are offset. - */ - - -/** - * G_IEEE754_FLOAT_BIAS: - * - * The bias by which exponents in single-precision floats are offset. - */ - - -/** - * G_IO_CHANNEL_ERROR: - * - * Error domain for #GIOChannel operations. Errors in this domain will - * be from the #GIOChannelError enumeration. See #GError for - * information on error domains. - */ - - -/** - * G_IS_DIR_SEPARATOR: - * @c: a character - * - * Checks whether a character is a directory - * separator. It returns %TRUE for '/' on UNIX - * machines and for '\' or '/' under Windows. - * - * Since: 2.6 - */ - - -/** - * G_KEY_FILE_DESKTOP_GROUP: - * - * The name of the main group of a desktop entry file, as defined in the - * [Desktop Entry Specification](http://freedesktop.org/Standards/desktop-entry-spec). - * Consult the specification for more - * details about the meanings of the keys below. - * - * Since: 2.14 - */ - - -/** - * G_KEY_FILE_DESKTOP_KEY_ACTIONS: - * - * A key under %G_KEY_FILE_DESKTOP_GROUP, whose value is a string list - * giving the available application actions. - * - * Since: 2.38 - */ - - -/** - * G_KEY_FILE_DESKTOP_KEY_CATEGORIES: - * - * A key under %G_KEY_FILE_DESKTOP_GROUP, whose value is a list - * of strings giving the categories in which the desktop entry - * should be shown in a menu. - * - * Since: 2.14 - */ - - -/** - * G_KEY_FILE_DESKTOP_KEY_COMMENT: - * - * A key under %G_KEY_FILE_DESKTOP_GROUP, whose value is a localized - * string giving the tooltip for the desktop entry. - * - * Since: 2.14 - */ - - -/** - * G_KEY_FILE_DESKTOP_KEY_DBUS_ACTIVATABLE: - * - * A key under %G_KEY_FILE_DESKTOP_GROUP, whose value is a boolean - * set to true if the application is D-Bus activatable. - * - * Since: 2.38 - */ - - -/** - * G_KEY_FILE_DESKTOP_KEY_EXEC: - * - * A key under %G_KEY_FILE_DESKTOP_GROUP, whose value is a string - * giving the command line to execute. It is only valid for desktop - * entries with the `Application` type. - * - * Since: 2.14 - */ - - -/** - * G_KEY_FILE_DESKTOP_KEY_GENERIC_NAME: - * - * A key under %G_KEY_FILE_DESKTOP_GROUP, whose value is a localized - * string giving the generic name of the desktop entry. - * - * Since: 2.14 - */ - - -/** - * G_KEY_FILE_DESKTOP_KEY_HIDDEN: - * - * A key under %G_KEY_FILE_DESKTOP_GROUP, whose value is a boolean - * stating whether the desktop entry has been deleted by the user. - * - * Since: 2.14 - */ - - -/** - * G_KEY_FILE_DESKTOP_KEY_ICON: - * - * A key under %G_KEY_FILE_DESKTOP_GROUP, whose value is a localized - * string giving the name of the icon to be displayed for the desktop - * entry. - * - * Since: 2.14 - */ - - -/** - * G_KEY_FILE_DESKTOP_KEY_MIME_TYPE: - * - * A key under %G_KEY_FILE_DESKTOP_GROUP, whose value is a list - * of strings giving the MIME types supported by this desktop entry. - * - * Since: 2.14 - */ - - -/** - * G_KEY_FILE_DESKTOP_KEY_NAME: - * - * A key under %G_KEY_FILE_DESKTOP_GROUP, whose value is a localized - * string giving the specific name of the desktop entry. - * - * Since: 2.14 - */ - - -/** - * G_KEY_FILE_DESKTOP_KEY_NOT_SHOW_IN: - * - * A key under %G_KEY_FILE_DESKTOP_GROUP, whose value is a list of - * strings identifying the environments that should not display the - * desktop entry. - * - * Since: 2.14 - */ - - -/** - * G_KEY_FILE_DESKTOP_KEY_NO_DISPLAY: - * - * A key under %G_KEY_FILE_DESKTOP_GROUP, whose value is a boolean - * stating whether the desktop entry should be shown in menus. - * - * Since: 2.14 - */ - - -/** - * G_KEY_FILE_DESKTOP_KEY_ONLY_SHOW_IN: - * - * A key under %G_KEY_FILE_DESKTOP_GROUP, whose value is a list of - * strings identifying the environments that should display the - * desktop entry. - * - * Since: 2.14 - */ - - -/** - * G_KEY_FILE_DESKTOP_KEY_PATH: - * - * A key under %G_KEY_FILE_DESKTOP_GROUP, whose value is a string - * containing the working directory to run the program in. It is only - * valid for desktop entries with the `Application` type. - * - * Since: 2.14 - */ - - -/** - * G_KEY_FILE_DESKTOP_KEY_STARTUP_NOTIFY: - * - * A key under %G_KEY_FILE_DESKTOP_GROUP, whose value is a boolean - * stating whether the application supports the - * [Startup Notification Protocol Specification](http://www.freedesktop.org/Standards/startup-notification-spec). - * - * Since: 2.14 - */ - - -/** - * G_KEY_FILE_DESKTOP_KEY_STARTUP_WM_CLASS: - * - * A key under %G_KEY_FILE_DESKTOP_GROUP, whose value is string - * identifying the WM class or name hint of a window that the application - * will create, which can be used to emulate Startup Notification with - * older applications. - * - * Since: 2.14 - */ - - -/** - * G_KEY_FILE_DESKTOP_KEY_TERMINAL: - * - * A key under %G_KEY_FILE_DESKTOP_GROUP, whose value is a boolean - * stating whether the program should be run in a terminal window. - * - * It is only valid for desktop entries with the `Application` type. - * - * Since: 2.14 - */ - - -/** - * G_KEY_FILE_DESKTOP_KEY_TRY_EXEC: - * - * A key under %G_KEY_FILE_DESKTOP_GROUP, whose value is a string - * giving the file name of a binary on disk used to determine if the - * program is actually installed. It is only valid for desktop entries - * with the `Application` type. - * - * Since: 2.14 - */ - - -/** - * G_KEY_FILE_DESKTOP_KEY_TYPE: - * - * A key under %G_KEY_FILE_DESKTOP_GROUP, whose value is a string - * giving the type of the desktop entry. - * - * Usually %G_KEY_FILE_DESKTOP_TYPE_APPLICATION, - * %G_KEY_FILE_DESKTOP_TYPE_LINK, or - * %G_KEY_FILE_DESKTOP_TYPE_DIRECTORY. - * - * Since: 2.14 - */ - - -/** - * G_KEY_FILE_DESKTOP_KEY_URL: - * - * A key under %G_KEY_FILE_DESKTOP_GROUP, whose value is a string - * giving the URL to access. It is only valid for desktop entries - * with the `Link` type. - * - * Since: 2.14 - */ - - -/** - * G_KEY_FILE_DESKTOP_KEY_VERSION: - * - * A key under %G_KEY_FILE_DESKTOP_GROUP, whose value is a string - * giving the version of the Desktop Entry Specification used for - * the desktop entry file. - * - * Since: 2.14 - */ - - -/** - * G_KEY_FILE_DESKTOP_TYPE_APPLICATION: - * - * The value of the %G_KEY_FILE_DESKTOP_KEY_TYPE, key for desktop - * entries representing applications. - * - * Since: 2.14 - */ - - -/** - * G_KEY_FILE_DESKTOP_TYPE_DIRECTORY: - * - * The value of the %G_KEY_FILE_DESKTOP_KEY_TYPE, key for desktop - * entries representing directories. - * - * Since: 2.14 - */ - - -/** - * G_KEY_FILE_DESKTOP_TYPE_LINK: - * - * The value of the %G_KEY_FILE_DESKTOP_KEY_TYPE, key for desktop - * entries representing links to documents. - * - * Since: 2.14 - */ - - -/** - * G_KEY_FILE_ERROR: - * - * Error domain for key file parsing. Errors in this domain will - * be from the #GKeyFileError enumeration. - * - * See #GError for information on error domains. - */ - - -/** - * G_LIKELY: - * @expr: the expression - * - * Hints the compiler that the expression is likely to evaluate to - * a true value. The compiler may use this information for optimizations. - * - * |[<!-- language="C" --> - * if (G_LIKELY (random () != 1)) - * g_print ("not one"); - * ]| - * - * Returns: the value of @expr - * Since: 2.2 - */ - - -/** - * G_LITTLE_ENDIAN: - * - * Specifies one of the possible types of byte order. - * See #G_BYTE_ORDER. - */ - - -/** - * G_LN10: - * - * The natural logarithm of 10. - */ - - -/** - * G_LN2: - * - * The natural logarithm of 2. - */ - - -/** - * G_LOCK: - * @name: the name of the lock - * - * Works like g_mutex_lock(), but for a lock defined with - * %G_LOCK_DEFINE. - */ - - -/** - * G_LOCK_DEFINE: - * @name: the name of the lock - * - * The `G_LOCK_` macros provide a convenient interface to #GMutex. - * %G_LOCK_DEFINE defines a lock. It can appear in any place where - * variable definitions may appear in programs, i.e. in the first block - * of a function or outside of functions. The @name parameter will be - * mangled to get the name of the #GMutex. This means that you - * can use names of existing variables as the parameter - e.g. the name - * of the variable you intend to protect with the lock. Look at our - * give_me_next_number() example using the `G_LOCK` macros: - * - * Here is an example for using the `G_LOCK` convenience macros: - * - * |[<!-- language="C" --> - * G_LOCK_DEFINE (current_number); - * - * int - * give_me_next_number (void) - * { - * static int current_number = 0; - * int ret_val; - * - * G_LOCK (current_number); - * ret_val = current_number = calc_next_number (current_number); - * G_UNLOCK (current_number); - * - * return ret_val; - * } - * ]| - */ - - -/** - * G_LOCK_DEFINE_STATIC: - * @name: the name of the lock - * - * This works like %G_LOCK_DEFINE, but it creates a static object. - */ - - -/** - * G_LOCK_EXTERN: - * @name: the name of the lock - * - * This declares a lock, that is defined with %G_LOCK_DEFINE in another - * module. - */ - - -/** - * G_LOG_2_BASE_10: - * - * Multiplying the base 2 exponent by this number yields the base 10 exponent. - */ - - -/** - * G_LOG_DOMAIN: - * - * Defines the log domain. See [Log Domains](#log-domains). - * - * Libraries should define this so that any messages - * which they log can be differentiated from messages from other - * libraries and application code. But be careful not to define - * it in any public header files. - * - * Log domains must be unique, and it is recommended that they are the - * application or library name, optionally followed by a hyphen and a sub-domain - * name. For example, `bloatpad` or `bloatpad-io`. - * - * If undefined, it defaults to the default %NULL (or `""`) log domain; this is - * not advisable, as it cannot be filtered against using the `G_MESSAGES_DEBUG` - * environment variable. - * - * For example, GTK+ uses this in its `Makefile.am`: - * |[ - * AM_CPPFLAGS = -DG_LOG_DOMAIN=\"Gtk\" - * ]| - * - * Applications can choose to leave it as the default %NULL (or `""`) - * domain. However, defining the domain offers the same advantages as - * above. - */ - - -/** - * G_LOG_FATAL_MASK: - * - * GLib log levels that are considered fatal by default. - * - * This is not used if structured logging is enabled; see - * [Using Structured Logging][using-structured-logging]. - */ - - -/** - * G_LOG_LEVEL_USER_SHIFT: - * - * Log levels below 1<<G_LOG_LEVEL_USER_SHIFT are used by GLib. - * Higher bits can be used for user-defined log levels. - */ - - -/** - * G_MAXDOUBLE: - * - * The maximum value which can be held in a #gdouble. - */ - - -/** - * G_MAXFLOAT: - * - * The maximum value which can be held in a #gfloat. - */ - - -/** - * G_MAXINT: - * - * The maximum value which can be held in a #gint. - */ - - -/** - * G_MAXINT16: - * - * The maximum value which can be held in a #gint16. - * - * Since: 2.4 - */ - - -/** - * G_MAXINT32: - * - * The maximum value which can be held in a #gint32. - * - * Since: 2.4 - */ - - -/** - * G_MAXINT64: - * - * The maximum value which can be held in a #gint64. - */ - - -/** - * G_MAXINT8: - * - * The maximum value which can be held in a #gint8. - * - * Since: 2.4 - */ - - -/** - * G_MAXLONG: - * - * The maximum value which can be held in a #glong. - */ - - -/** - * G_MAXOFFSET: - * - * The maximum value which can be held in a #goffset. - */ - - -/** - * G_MAXSHORT: - * - * The maximum value which can be held in a #gshort. - */ - - -/** - * G_MAXSIZE: - * - * The maximum value which can be held in a #gsize. - * - * Since: 2.4 - */ - - -/** - * G_MAXSSIZE: - * - * The maximum value which can be held in a #gssize. - * - * Since: 2.14 - */ - - -/** - * G_MAXUINT: - * - * The maximum value which can be held in a #guint. - */ - - -/** - * G_MAXUINT16: - * - * The maximum value which can be held in a #guint16. - * - * Since: 2.4 - */ - - -/** - * G_MAXUINT32: - * - * The maximum value which can be held in a #guint32. - * - * Since: 2.4 - */ - - -/** - * G_MAXUINT64: - * - * The maximum value which can be held in a #guint64. - */ - - -/** - * G_MAXUINT8: - * - * The maximum value which can be held in a #guint8. - * - * Since: 2.4 - */ - - -/** - * G_MAXULONG: - * - * The maximum value which can be held in a #gulong. - */ - - -/** - * G_MAXUSHORT: - * - * The maximum value which can be held in a #gushort. - */ - - -/** - * G_MINDOUBLE: - * - * The minimum positive value which can be held in a #gdouble. - * - * If you are interested in the smallest value which can be held - * in a #gdouble, use -%G_MAXDOUBLE. - */ - - -/** - * G_MINFLOAT: - * - * The minimum positive value which can be held in a #gfloat. - * - * If you are interested in the smallest value which can be held - * in a #gfloat, use -%G_MAXFLOAT. - */ - - -/** - * G_MININT: - * - * The minimum value which can be held in a #gint. - */ - - -/** - * G_MINLONG: - * - * The minimum value which can be held in a #glong. - */ - - -/** - * G_MINOFFSET: - * - * The minimum value which can be held in a #goffset. - */ - - -/** - * G_MINSHORT: - * - * The minimum value which can be held in a #gshort. - */ - - -/** - * G_MINSSIZE: - * - * The minimum value which can be held in a #gssize. - * - * Since: 2.14 - */ - - -/** - * G_N_ELEMENTS: - * @arr: the array - * - * Determines the number of elements in an array. The array must be - * declared so the compiler knows its size at compile-time; this - * macro will not work on an array allocated on the heap, only static - * arrays or arrays on the stack. - */ - - -/** - * G_ONCE_INIT: - * - * A #GOnce must be initialized with this macro before it can be used. - * - * |[<!-- language="C" --> - * GOnce my_once = G_ONCE_INIT; - * ]| - * - * Since: 2.4 - */ - - -/** - * G_OS_UNIX: - * - * This macro is defined only on UNIX. So you can bracket - * UNIX-specific code in "\#ifdef G_OS_UNIX". - */ - - -/** - * G_OS_WIN32: - * - * This macro is defined only on Windows. So you can bracket - * Windows-specific code in "\#ifdef G_OS_WIN32". - */ - - -/** - * G_PASTE: - * @identifier1: an identifier - * @identifier2: an identifier - * - * Yields a new preprocessor pasted identifier - * @identifier1identifier2 from its expanded - * arguments @identifier1 and @identifier2. For example, - * the following code: - * |[<!-- language="C" --> - * #define GET(traveller,method) G_PASTE(traveller_get_, method) (traveller) - * const gchar *name = GET (traveller, name); - * const gchar *quest = GET (traveller, quest); - * GdkColor *favourite = GET (traveller, favourite_colour); - * ]| - * - * is transformed by the preprocessor into: - * |[<!-- language="C" --> - * const gchar *name = traveller_get_name (traveller); - * const gchar *quest = traveller_get_quest (traveller); - * GdkColor *favourite = traveller_get_favourite_colour (traveller); - * ]| - * - * Since: 2.20 - */ - - -/** - * G_PDP_ENDIAN: - * - * Specifies one of the possible types of byte order - * (currently unused). See #G_BYTE_ORDER. - */ - - -/** - * G_PI: - * - * The value of pi (ratio of circle's circumference to its diameter). - */ - - -/** - * G_PI_2: - * - * Pi divided by 2. - */ - - -/** - * G_PI_4: - * - * Pi divided by 4. - */ - - -/** - * G_PRIVATE_INIT: - * @notify: a #GDestroyNotify - * - * A macro to assist with the static initialisation of a #GPrivate. - * - * This macro is useful for the case that a #GDestroyNotify function - * should be associated with the key. This is needed when the key will be - * used to point at memory that should be deallocated when the thread - * exits. - * - * Additionally, the #GDestroyNotify will also be called on the previous - * value stored in the key when g_private_replace() is used. - * - * If no #GDestroyNotify is needed, then use of this macro is not - * required -- if the #GPrivate is declared in static scope then it will - * be properly initialised by default (ie: to all zeros). See the - * examples below. - * - * |[<!-- language="C" --> - * static GPrivate name_key = G_PRIVATE_INIT (g_free); - * - * // return value should not be freed - * const gchar * - * get_local_name (void) - * { - * return g_private_get (&name_key); - * } - * - * void - * set_local_name (const gchar *name) - * { - * g_private_replace (&name_key, g_strdup (name)); - * } - * - * - * static GPrivate count_key; // no free function - * - * gint - * get_local_count (void) - * { - * return GPOINTER_TO_INT (g_private_get (&count_key)); - * } - * - * void - * set_local_count (gint count) - * { - * g_private_set (&count_key, GINT_TO_POINTER (count)); - * } - * ]| - * - * Since: 2.32 - */ - - -/** - * G_SEARCHPATH_SEPARATOR: - * - * The search path separator character. - * This is ':' on UNIX machines and ';' under Windows. - */ - - -/** - * G_SEARCHPATH_SEPARATOR_S: - * - * The search path separator as a string. - * This is ":" on UNIX machines and ";" under Windows. - */ - - -/** - * G_SHELL_ERROR: - * - * Error domain for shell functions. - * - * Errors in this domain will be from the #GShellError enumeration. - * - * See #GError for information on error domains. - */ - - -/** - * G_SQRT2: - * - * The square root of two. - */ - - -/** - * G_STATIC_ASSERT: - * @expr: a constant expression - * - * The G_STATIC_ASSERT() macro lets the programmer check - * a condition at compile time, the condition needs to - * be compile time computable. The macro can be used in - * any place where a typedef is valid. - * - * A typedef is generally allowed in exactly the same places that - * a variable declaration is allowed. For this reason, you should - * not use G_STATIC_ASSERT() in the middle of blocks of code. - * - * The macro should only be used once per source code line. - * - * Since: 2.20 - */ - - -/** - * G_STATIC_ASSERT_EXPR: - * @expr: a constant expression - * - * The G_STATIC_ASSERT_EXPR() macro lets the programmer check - * a condition at compile time. The condition needs to be - * compile time computable. - * - * Unlike G_STATIC_ASSERT(), this macro evaluates to an expression - * and, as such, can be used in the middle of other expressions. - * Its value should be ignored. This can be accomplished by placing - * it as the first argument of a comma expression. - * - * |[<!-- language="C" --> - * #define ADD_ONE_TO_INT(x) \ - * (G_STATIC_ASSERT_EXPR(sizeof (x) == sizeof (int)), ((x) + 1)) - * ]| - * - * Since: 2.30 - */ - - -/** - * G_STMT_END: - * - * Used within multi-statement macros so that they can be used in places - * where only one statement is expected by the compiler. - */ - - -/** - * G_STMT_START: - * - * Used within multi-statement macros so that they can be used in places - * where only one statement is expected by the compiler. - */ - - -/** - * G_STRFUNC: - * - * Expands to a string identifying the current function. - * - * Since: 2.4 - */ - - -/** - * G_STRINGIFY: - * @macro_or_string: a macro or a string - * - * Accepts a macro or a string and converts it into a string after - * preprocessor argument expansion. For example, the following code: - * - * |[<!-- language="C" --> - * #define AGE 27 - * const gchar *greeting = G_STRINGIFY (AGE) " today!"; - * ]| - * - * is transformed by the preprocessor into (code equivalent to): - * - * |[<!-- language="C" --> - * const gchar *greeting = "27 today!"; - * ]| - */ - - -/** - * G_STRLOC: - * - * Expands to a string identifying the current code position. - */ - - -/** - * G_STRUCT_MEMBER: - * @member_type: the type of the struct field - * @struct_p: a pointer to a struct - * @struct_offset: the offset of the field from the start of the struct, - * in bytes - * - * Returns a member of a structure at a given offset, using the given type. - * - * Returns: the struct member - */ - - -/** - * G_STRUCT_MEMBER_P: - * @struct_p: a pointer to a struct - * @struct_offset: the offset from the start of the struct, in bytes - * - * Returns an untyped pointer to a given offset of a struct. - * - * Returns: an untyped pointer to @struct_p plus @struct_offset bytes - */ - - -/** - * G_STRUCT_OFFSET: - * @struct_type: a structure type, e.g. #GtkWidget - * @member: a field in the structure, e.g. @window - * - * Returns the offset, in bytes, of a member of a struct. - * - * Returns: the offset of @member from the start of @struct_type - */ - - -/** - * G_STR_DELIMITERS: - * - * The standard delimiters, used in g_strdelimit(). - */ - - -/** - * G_THREAD_ERROR: - * - * The error domain of the GLib thread subsystem. - */ - - -/** - * G_TRYLOCK: - * @name: the name of the lock - * - * Works like g_mutex_trylock(), but for a lock defined with - * %G_LOCK_DEFINE. - * - * Returns: %TRUE, if the lock could be locked. - */ - - -/** - * G_UNAVAILABLE: - * @maj: the major version that introduced the symbol - * @min: the minor version that introduced the symbol - * - * This macro can be used to mark a function declaration as unavailable. - * It must be placed before the function declaration. Use of a function - * that has been annotated with this macros will produce a compiler warning. - * - * Since: 2.32 - */ - - -/** - * G_UNLIKELY: - * @expr: the expression - * - * Hints the compiler that the expression is unlikely to evaluate to - * a true value. The compiler may use this information for optimizations. - * - * |[<!-- language="C" --> - * if (G_UNLIKELY (random () == 1)) - * g_print ("a random one"); - * ]| - * - * Returns: the value of @expr - * Since: 2.2 - */ - - -/** - * G_UNLOCK: - * @name: the name of the lock - * - * Works like g_mutex_unlock(), but for a lock defined with - * %G_LOCK_DEFINE. - */ - - -/** - * G_USEC_PER_SEC: - * - * Number of microseconds in one second (1 million). - * This macro is provided for code readability. - */ - - -/** - * G_VARIANT_PARSE_ERROR: - * - * Error domain for GVariant text format parsing. Specific error codes - * are not currently defined for this domain. See #GError for - * information on error domains. - */ - - -/** - * G_VA_COPY: - * @ap1: the va_list variable to place a copy of @ap2 in - * @ap2: a va_list - * - * Portable way to copy va_list variables. - * - * In order to use this function, you must include string.h yourself, - * because this macro may use memmove() and GLib does not include - * string.h for you. - * - * Each invocation of `G_VA_COPY (ap1, ap2)` must be matched with a - * corresponding `va_end (ap1)` call in the same function. - */ - - -/** - * G_WIN32_DLLMAIN_FOR_DLL_NAME: - * @static: empty or "static" - * @dll_name: the name of the (pointer to the) char array where - * the DLL name will be stored. If this is used, you must also - * include `windows.h`. If you need a more complex DLL entry - * point function, you cannot use this - * - * On Windows, this macro defines a DllMain() function that stores - * the actual DLL name that the code being compiled will be included in. - * - * On non-Windows platforms, expands to nothing. - */ - - -/** - * G_WIN32_HAVE_WIDECHAR_API: - * - * On Windows, this macro defines an expression which evaluates to - * %TRUE if the code is running on a version of Windows where the wide - * character versions of the Win32 API functions, and the wide character - * versions of the C library functions work. (They are always present in - * the DLLs, but don't work on Windows 9x and Me.) - * - * On non-Windows platforms, it is not defined. - * - * Since: 2.6 - */ - - -/** - * G_WIN32_IS_NT_BASED: - * - * On Windows, this macro defines an expression which evaluates to - * %TRUE if the code is running on an NT-based Windows operating system. - * - * On non-Windows platforms, it is not defined. - * - * Since: 2.6 - */ - - -/** - * MAX: - * @a: a numeric value - * @b: a numeric value - * - * Calculates the maximum of @a and @b. - * - * Returns: the maximum of @a and @b. - */ - - -/** - * MAXPATHLEN: - * - * Provided for UNIX emulation on Windows; equivalent to UNIX - * macro %MAXPATHLEN, which is the maximum length of a filename - * (including full path). - */ - - -/** - * MIN: - * @a: a numeric value - * @b: a numeric value - * - * Calculates the minimum of @a and @b. - * - * Returns: the minimum of @a and @b. - */ - - -/** - * NC_: - * @Context: a message context, must be a string literal - * @String: a message id, must be a string literal - * - * Only marks a string for translation, with context. - * This is useful in situations where the translated strings can't - * be directly used, e.g. in string array initializers. To get the - * translated string, you should call g_dpgettext2() at runtime. - * - * |[<!-- language="C" --> - * { - * static const char *messages[] = { - * NC_("some context", "some very meaningful message"), - * NC_("some context", "and another one") - * }; - * const char *string; - * ... - * string - * = index > 1 ? g_dpgettext2 (NULL, "some context", "a default message") - * : g_dpgettext2 (NULL, "some context", messages[index]); - * - * fputs (string); - * ... - * } - * ]| - * - * If you are using the NC_() macro, you need to make sure that you pass - * `--keyword=NC_:1c,2` to xgettext when extracting messages. - * Note that this only works with GNU gettext >= 0.15. Intltool has support - * for the NC_() macro since version 0.40.1. - * - * Since: 2.18 - */ - - -/** - * NULL: - * - * Defines the standard %NULL pointer. - */ - - -/** - * N_: - * @String: the string to be translated - * - * Only marks a string for translation. This is useful in situations - * where the translated strings can't be directly used, e.g. in string - * array initializers. To get the translated string, call gettext() - * at runtime. - * |[<!-- language="C" --> - * { - * static const char *messages[] = { - * N_("some very meaningful message"), - * N_("and another one") - * }; - * const char *string; - * ... - * string - * = index > 1 ? _("a default message") : gettext (messages[index]); - * - * fputs (string); - * ... - * } - * ]| - * - * Since: 2.4 - */ - - -/** - * Q_: - * @String: the string to be translated, with a '|'-separated prefix - * which must not be translated - * - * Like _(), but handles context in message ids. This has the advantage - * that the string can be adorned with a prefix to guarantee uniqueness - * and provide context to the translator. - * - * One use case given in the gettext manual is GUI translation, where one - * could e.g. disambiguate two "Open" menu entries as "File|Open" and - * "Printer|Open". Another use case is the string "Russian" which may - * have to be translated differently depending on whether it's the name - * of a character set or a language. This could be solved by using - * "charset|Russian" and "language|Russian". - * - * See the C_() macro for a different way to mark up translatable strings - * with context. - * - * If you are using the Q_() macro, you need to make sure that you pass - * `--keyword=Q_` to xgettext when extracting messages. - * If you are using GNU gettext >= 0.15, you can also use - * `--keyword=Q_:1g` to let xgettext split the context - * string off into a msgctxt line in the po file. - * - * Returns: the translated message - * Since: 2.4 - */ - - -/** - * SECTION:arcbox - * @Title: Atomically reference counted data - * @Short_description: Allocated memory with atomic reference counting semantics - * - * An "atomically reference counted box", or "ArcBox", is an opaque wrapper - * data type that is guaranteed to be as big as the size of a given data type, - * and which augments the given data type with thread safe reference counting - * semantics for its memory management. - * - * ArcBox is useful if you have a plain old data type, like a structure - * typically placed on the stack, and you wish to provide additional API - * to use it on the heap; or if you want to implement a new type to be - * passed around by reference without necessarily implementing copy/free - * semantics or your own reference counting. - * - * The typical use is: - * - * |[<!-- language="C" --> - * typedef struct { - * char *name; - * char *address; - * char *city; - * char *state; - * int age; - * } Person; - * - * Person * - * person_new (void) - * { - * return g_atomic_rc_box_new0 (Person); - * } - * ]| - * - * Every time you wish to acquire a reference on the memory, you should - * call g_atomic_rc_box_acquire(); similarly, when you wish to release a reference - * you should call g_atomic_rc_box_release(): - * - * |[<!-- language="C" --> - * // Add a Person to the Database; the Database acquires ownership - * // of the Person instance - * void - * add_person_to_database (Database *db, Person *p) - * { - * db->persons = g_list_prepend (db->persons, g_atomic_rc_box_acquire (p)); - * } - * - * // Removes a Person from the Database; the reference acquired by - * // add_person_to_database() is released here - * void - * remove_person_from_database (Database *db, Person *p) - * { - * db->persons = g_list_remove (db->persons, p); - * g_atomic_rc_box_release (p); - * } - * ]| - * - * If you have additional memory allocated inside the structure, you can - * use g_atomic_rc_box_release_full(), which takes a function pointer, which - * will be called if the reference released was the last: - * - * |[<!-- language="C" --> - * void - * person_clear (Person *p) - * { - * g_free (p->name); - * g_free (p->address); - * g_free (p->city); - * g_free (p->state); - * } - * - * void - * remove_person_from_database (Database *db, Person *p) - * { - * db->persons = g_list_remove (db->persons, p); - * g_atomic_rc_box_release_full (p, (GDestroyNotify) person_clear); - * } - * ]| - * - * If you wish to transfer the ownership of a reference counted data - * type without increasing the reference count, you can use g_steal_pointer(): - * - * |[<!-- language="C" --> - * Person *p = g_atomic_rc_box_new (Person); - * - * fill_person_details (p); - * - * add_person_to_database (db, g_steal_pointer (&p)); - * ]| - * - * ## Thread safety - * - * The reference counting operations on data allocated using g_atomic_rc_box_alloc(), - * g_atomic_rc_box_new(), and g_atomic_rc_box_dup() are guaranteed to be atomic, and thus - * can be safely be performed by different threads. It is important to note that - * only the reference acquisition and release are atomic; changes to the content - * of the data are your responsibility. - * - * ## Automatic pointer clean up - * - * If you want to add g_autoptr() support to your plain old data type through - * reference counting, you can use the G_DEFINE_AUTOPTR_CLEANUP_FUNC() and - * g_atomic_rc_box_release(): - * - * |[<!-- language="C" --> - * G_DEFINE_AUTOPTR_CLEANUP_FUNC (MyDataStruct, g_atomic_rc_box_release) - * ]| - * - * If you need to clear the contents of the data, you will need to use an - * ancillary function that calls g_rc_box_release_full(): - * - * |[<!-- language="C" --> - * static void - * my_data_struct_release (MyDataStruct *data) - * { - * // my_data_struct_clear() is defined elsewhere - * g_atomic_rc_box_release_full (data, (GDestroyNotify) my_data_struct_clear); - * } - * - * G_DEFINE_AUTOPTR_CLEANUP_FUNC (MyDataStruct, my_data_struct_release) - * ]| - * - * Since: 2.58 - */ - - -/** - * SECTION:arrays - * @title: Arrays - * @short_description: arrays of arbitrary elements which grow - * automatically as elements are added - * - * Arrays are similar to standard C arrays, except that they grow - * automatically as elements are added. - * - * Array elements can be of any size (though all elements of one array - * are the same size), and the array can be automatically cleared to - * '0's and zero-terminated. - * - * To create a new array use g_array_new(). - * - * To add elements to an array with a cost of O(n) at worst, use - * g_array_append_val(), g_array_append_vals(), g_array_prepend_val(), - * g_array_prepend_vals(), g_array_insert_val() and g_array_insert_vals(). - * - * To access an element of an array in O(1) (to read it or to write it), - * use g_array_index(). - * - * To set the size of an array, use g_array_set_size(). - * - * To free an array, use g_array_unref() or g_array_free(). - * - * All the sort functions are internally calling a quick-sort (or similar) - * function with an average cost of O(n log(n)) and a worst case - * cost of O(n^2). - * - * Here is an example that stores integers in a #GArray: - * |[<!-- language="C" --> - * GArray *garray; - * gint i; - * // We create a new array to store gint values. - * // We don't want it zero-terminated or cleared to 0's. - * garray = g_array_new (FALSE, FALSE, sizeof (gint)); - * for (i = 0; i < 10000; i++) - * g_array_append_val (garray, i); - * for (i = 0; i < 10000; i++) - * if (g_array_index (garray, gint, i) != i) - * g_print ("ERROR: got %d instead of %d\n", - * g_array_index (garray, gint, i), i); - * g_array_free (garray, TRUE); - * ]| - */ - - -/** - * SECTION:arrays_byte - * @title: Byte Arrays - * @short_description: arrays of bytes - * - * #GByteArray is a mutable array of bytes based on #GArray, to provide arrays - * of bytes which grow automatically as elements are added. - * - * To create a new #GByteArray use g_byte_array_new(). To add elements to a - * #GByteArray, use g_byte_array_append(), and g_byte_array_prepend(). - * - * To set the size of a #GByteArray, use g_byte_array_set_size(). - * - * To free a #GByteArray, use g_byte_array_free(). - * - * An example for using a #GByteArray: - * |[<!-- language="C" --> - * GByteArray *gbarray; - * gint i; - * - * gbarray = g_byte_array_new (); - * for (i = 0; i < 10000; i++) - * g_byte_array_append (gbarray, (guint8*) "abcd", 4); - * - * for (i = 0; i < 10000; i++) - * { - * g_assert (gbarray->data[4*i] == 'a'); - * g_assert (gbarray->data[4*i+1] == 'b'); - * g_assert (gbarray->data[4*i+2] == 'c'); - * g_assert (gbarray->data[4*i+3] == 'd'); - * } - * - * g_byte_array_free (gbarray, TRUE); - * ]| - * - * See #GBytes if you are interested in an immutable object representing a - * sequence of bytes. - */ - - -/** - * SECTION:arrays_pointer - * @title: Pointer Arrays - * @short_description: arrays of pointers to any type of data, which - * grow automatically as new elements are added - * - * Pointer Arrays are similar to Arrays but are used only for storing - * pointers. - * - * If you remove elements from the array, elements at the end of the - * array are moved into the space previously occupied by the removed - * element. This means that you should not rely on the index of particular - * elements remaining the same. You should also be careful when deleting - * elements while iterating over the array. - * - * To create a pointer array, use g_ptr_array_new(). - * - * To add elements to a pointer array, use g_ptr_array_add(). - * - * To remove elements from a pointer array, use g_ptr_array_remove(), - * g_ptr_array_remove_index() or g_ptr_array_remove_index_fast(). - * - * To access an element of a pointer array, use g_ptr_array_index(). - * - * To set the size of a pointer array, use g_ptr_array_set_size(). - * - * To free a pointer array, use g_ptr_array_free(). - * - * An example using a #GPtrArray: - * |[<!-- language="C" --> - * GPtrArray *array; - * gchar *string1 = "one"; - * gchar *string2 = "two"; - * gchar *string3 = "three"; - * - * array = g_ptr_array_new (); - * g_ptr_array_add (array, (gpointer) string1); - * g_ptr_array_add (array, (gpointer) string2); - * g_ptr_array_add (array, (gpointer) string3); - * - * if (g_ptr_array_index (array, 0) != (gpointer) string1) - * g_print ("ERROR: got %p instead of %p\n", - * g_ptr_array_index (array, 0), string1); - * - * g_ptr_array_free (array, TRUE); - * ]| - */ - - -/** - * SECTION:async_queues - * @title: Asynchronous Queues - * @short_description: asynchronous communication between threads - * @see_also: #GThreadPool - * - * Often you need to communicate between different threads. In general - * it's safer not to do this by shared memory, but by explicit message - * passing. These messages only make sense asynchronously for - * multi-threaded applications though, as a synchronous operation could - * as well be done in the same thread. - * - * Asynchronous queues are an exception from most other GLib data - * structures, as they can be used simultaneously from multiple threads - * without explicit locking and they bring their own builtin reference - * counting. This is because the nature of an asynchronous queue is that - * it will always be used by at least 2 concurrent threads. - * - * For using an asynchronous queue you first have to create one with - * g_async_queue_new(). #GAsyncQueue structs are reference counted, - * use g_async_queue_ref() and g_async_queue_unref() to manage your - * references. - * - * A thread which wants to send a message to that queue simply calls - * g_async_queue_push() to push the message to the queue. - * - * A thread which is expecting messages from an asynchronous queue - * simply calls g_async_queue_pop() for that queue. If no message is - * available in the queue at that point, the thread is now put to sleep - * until a message arrives. The message will be removed from the queue - * and returned. The functions g_async_queue_try_pop() and - * g_async_queue_timeout_pop() can be used to only check for the presence - * of messages or to only wait a certain time for messages respectively. - * - * For almost every function there exist two variants, one that locks - * the queue and one that doesn't. That way you can hold the queue lock - * (acquire it with g_async_queue_lock() and release it with - * g_async_queue_unlock()) over multiple queue accessing instructions. - * This can be necessary to ensure the integrity of the queue, but should - * only be used when really necessary, as it can make your life harder - * if used unwisely. Normally you should only use the locking function - * variants (those without the _unlocked suffix). - * - * In many cases, it may be more convenient to use #GThreadPool when - * you need to distribute work to a set of worker threads instead of - * using #GAsyncQueue manually. #GThreadPool uses a GAsyncQueue - * internally. - */ - - -/** - * SECTION:atomic_operations - * @title: Atomic Operations - * @short_description: basic atomic integer and pointer operations - * @see_also: #GMutex - * - * The following is a collection of compiler macros to provide atomic - * access to integer and pointer-sized values. - * - * The macros that have 'int' in the name will operate on pointers to - * #gint and #guint. The macros with 'pointer' in the name will operate - * on pointers to any pointer-sized value, including #gsize. There is - * no support for 64bit operations on platforms with 32bit pointers - * because it is not generally possible to perform these operations - * atomically. - * - * The get, set and exchange operations for integers and pointers - * nominally operate on #gint and #gpointer, respectively. Of the - * arithmetic operations, the 'add' operation operates on (and returns) - * signed integer values (#gint and #gssize) and the 'and', 'or', and - * 'xor' operations operate on (and return) unsigned integer values - * (#guint and #gsize). - * - * All of the operations act as a full compiler and (where appropriate) - * hardware memory barrier. Acquire and release or producer and - * consumer barrier semantics are not available through this API. - * - * It is very important that all accesses to a particular integer or - * pointer be performed using only this API and that different sizes of - * operation are not mixed or used on overlapping memory regions. Never - * read or assign directly from or to a value -- always use this API. - * - * For simple reference counting purposes you should use - * g_atomic_int_inc() and g_atomic_int_dec_and_test(). Other uses that - * fall outside of simple reference counting patterns are prone to - * subtle bugs and occasionally undefined behaviour. It is also worth - * noting that since all of these operations require global - * synchronisation of the entire machine, they can be quite slow. In - * the case of performing multiple atomic operations it can often be - * faster to simply acquire a mutex lock around the critical area, - * perform the operations normally and then release the lock. - */ - - -/** - * SECTION:base64 - * @title: Base64 Encoding - * @short_description: encodes and decodes data in Base64 format - * - * Base64 is an encoding that allows a sequence of arbitrary bytes to be - * encoded as a sequence of printable ASCII characters. For the definition - * of Base64, see - * [RFC 1421](http://www.ietf.org/rfc/rfc1421.txt) - * or - * [RFC 2045](http://www.ietf.org/rfc/rfc2045.txt). - * Base64 is most commonly used as a MIME transfer encoding - * for email. - * - * GLib supports incremental encoding using g_base64_encode_step() and - * g_base64_encode_close(). Incremental decoding can be done with - * g_base64_decode_step(). To encode or decode data in one go, use - * g_base64_encode() or g_base64_decode(). To avoid memory allocation when - * decoding, you can use g_base64_decode_inplace(). - * - * Support for Base64 encoding has been added in GLib 2.12. - */ - - -/** - * SECTION:bookmarkfile - * @title: Bookmark file parser - * @short_description: parses files containing bookmarks - * - * GBookmarkFile lets you parse, edit or create files containing bookmarks - * to URI, along with some meta-data about the resource pointed by the URI - * like its MIME type, the application that is registering the bookmark and - * the icon that should be used to represent the bookmark. The data is stored - * using the - * [Desktop Bookmark Specification](http://www.gnome.org/~ebassi/bookmark-spec). - * - * The syntax of the bookmark files is described in detail inside the - * Desktop Bookmark Specification, here is a quick summary: bookmark - * files use a sub-class of the XML Bookmark Exchange Language - * specification, consisting of valid UTF-8 encoded XML, under the - * <xbel> root element; each bookmark is stored inside a - * <bookmark> element, using its URI: no relative paths can - * be used inside a bookmark file. The bookmark may have a user defined - * title and description, to be used instead of the URI. Under the - * <metadata> element, with its owner attribute set to - * `http://freedesktop.org`, is stored the meta-data about a resource - * pointed by its URI. The meta-data consists of the resource's MIME - * type; the applications that have registered a bookmark; the groups - * to which a bookmark belongs to; a visibility flag, used to set the - * bookmark as "private" to the applications and groups that has it - * registered; the URI and MIME type of an icon, to be used when - * displaying the bookmark inside a GUI. - * - * Here is an example of a bookmark file: - * [bookmarks.xbel](https://gitlab.gnome.org/GNOME/glib/-/blob/HEAD/glib/tests/bookmarks.xbel) - * - * A bookmark file might contain more than one bookmark; each bookmark - * is accessed through its URI. - * - * The important caveat of bookmark files is that when you add a new - * bookmark you must also add the application that is registering it, using - * g_bookmark_file_add_application() or g_bookmark_file_set_application_info(). - * If a bookmark has no applications then it won't be dumped when creating - * the on disk representation, using g_bookmark_file_to_data() or - * g_bookmark_file_to_file(). - * - * The #GBookmarkFile parser was added in GLib 2.12. - */ - - -/** - * SECTION:byte_order - * @title: Byte Order Macros - * @short_description: a portable way to convert between different byte orders - * - * These macros provide a portable way to determine the host byte order - * and to convert values between different byte orders. - * - * The byte order is the order in which bytes are stored to create larger - * data types such as the #gint and #glong values. - * The host byte order is the byte order used on the current machine. - * - * Some processors store the most significant bytes (i.e. the bytes that - * hold the largest part of the value) first. These are known as big-endian - * processors. Other processors (notably the x86 family) store the most - * significant byte last. These are known as little-endian processors. - * - * Finally, to complicate matters, some other processors store the bytes in - * a rather curious order known as PDP-endian. For a 4-byte word, the 3rd - * most significant byte is stored first, then the 4th, then the 1st and - * finally the 2nd. - * - * Obviously there is a problem when these different processors communicate - * with each other, for example over networks or by using binary file formats. - * This is where these macros come in. They are typically used to convert - * values into a byte order which has been agreed on for use when - * communicating between different processors. The Internet uses what is - * known as 'network byte order' as the standard byte order (which is in - * fact the big-endian byte order). - * - * Note that the byte order conversion macros may evaluate their arguments - * multiple times, thus you should not use them with arguments which have - * side-effects. - */ - - -/** - * SECTION:checkedmath - * @title: Bounds-checking integer arithmetic - * @short_description: a set of helpers for performing checked integer arithmetic - * - * GLib offers a set of macros for doing additions and multiplications - * of unsigned integers, with checks for overflows. - * - * The helpers all have three arguments. A pointer to the destination - * is always the first argument and the operands to the operation are - * the other two. - * - * Following standard GLib convention, the helpers return %TRUE in case - * of success (ie: no overflow). - * - * The helpers may be macros, normal functions or inlines. They may be - * implemented with inline assembly or compiler intrinsics where - * available. - * - * Since: 2.48 - */ - - -/** - * SECTION:checksum - * @title: Data Checksums - * @short_description: computes the checksum for data - * - * GLib provides a generic API for computing checksums (or "digests") - * for a sequence of arbitrary bytes, using various hashing algorithms - * like MD5, SHA-1 and SHA-256. Checksums are commonly used in various - * environments and specifications. - * - * GLib supports incremental checksums using the GChecksum data - * structure, by calling g_checksum_update() as long as there's data - * available and then using g_checksum_get_string() or - * g_checksum_get_digest() to compute the checksum and return it either - * as a string in hexadecimal form, or as a raw sequence of bytes. To - * compute the checksum for binary blobs and NUL-terminated strings in - * one go, use the convenience functions g_compute_checksum_for_data() - * and g_compute_checksum_for_string(), respectively. - * - * Support for checksums has been added in GLib 2.16 - */ - - -/** - * SECTION:conversions - * @title: Character Set Conversion - * @short_description: convert strings between different character sets - * - * The g_convert() family of function wraps the functionality of iconv(). - * In addition to pure character set conversions, GLib has functions to - * deal with the extra complications of encodings for file names. - * - * ## File Name Encodings - * - * Historically, UNIX has not had a defined encoding for file names: - * a file name is valid as long as it does not have path separators - * in it ("/"). However, displaying file names may require conversion: - * from the character set in which they were created, to the character - * set in which the application operates. Consider the Spanish file name - * "Presentación.sxi". If the application which created it uses - * ISO-8859-1 for its encoding, - * |[ - * Character: P r e s e n t a c i ó n . s x i - * Hex code: 50 72 65 73 65 6e 74 61 63 69 f3 6e 2e 73 78 69 - * ]| - * However, if the application use UTF-8, the actual file name on - * disk would look like this: - * |[ - * Character: P r e s e n t a c i ó n . s x i - * Hex code: 50 72 65 73 65 6e 74 61 63 69 c3 b3 6e 2e 73 78 69 - * ]| - * Glib uses UTF-8 for its strings, and GUI toolkits like GTK+ that use - * GLib do the same thing. If you get a file name from the file system, - * for example, from readdir() or from g_dir_read_name(), and you wish - * to display the file name to the user, you will need to convert it - * into UTF-8. The opposite case is when the user types the name of a - * file they wish to save: the toolkit will give you that string in - * UTF-8 encoding, and you will need to convert it to the character - * set used for file names before you can create the file with open() - * or fopen(). - * - * By default, GLib assumes that file names on disk are in UTF-8 - * encoding. This is a valid assumption for file systems which - * were created relatively recently: most applications use UTF-8 - * encoding for their strings, and that is also what they use for - * the file names they create. However, older file systems may - * still contain file names created in "older" encodings, such as - * ISO-8859-1. In this case, for compatibility reasons, you may want - * to instruct GLib to use that particular encoding for file names - * rather than UTF-8. You can do this by specifying the encoding for - * file names in the [`G_FILENAME_ENCODING`][G_FILENAME_ENCODING] - * environment variable. For example, if your installation uses - * ISO-8859-1 for file names, you can put this in your `~/.profile`: - * |[ - * export G_FILENAME_ENCODING=ISO-8859-1 - * ]| - * GLib provides the functions g_filename_to_utf8() and - * g_filename_from_utf8() to perform the necessary conversions. - * These functions convert file names from the encoding specified - * in `G_FILENAME_ENCODING` to UTF-8 and vice-versa. This - * [diagram][file-name-encodings-diagram] illustrates how - * these functions are used to convert between UTF-8 and the - * encoding for file names in the file system. - * - * ## Conversion between file name encodings # {#file-name-encodings-diagram) - * - * ![](file-name-encodings.png) - * - * ## Checklist for Application Writers - * - * This section is a practical summary of the detailed - * things to do to make sure your applications process file - * name encodings correctly. - * - * 1. If you get a file name from the file system from a function - * such as readdir() or gtk_file_chooser_get_filename(), you do - * not need to do any conversion to pass that file name to - * functions like open(), rename(), or fopen() -- those are "raw" - * file names which the file system understands. - * - * 2. If you need to display a file name, convert it to UTF-8 first - * by using g_filename_to_utf8(). If conversion fails, display a - * string like "Unknown file name". Do not convert this string back - * into the encoding used for file names if you wish to pass it to - * the file system; use the original file name instead. - * - * For example, the document window of a word processor could display - * "Unknown file name" in its title bar but still let the user save - * the file, as it would keep the raw file name internally. This - * can happen if the user has not set the `G_FILENAME_ENCODING` - * environment variable even though he has files whose names are - * not encoded in UTF-8. - * - * 3. If your user interface lets the user type a file name for saving - * or renaming, convert it to the encoding used for file names in - * the file system by using g_filename_from_utf8(). Pass the converted - * file name to functions like fopen(). If conversion fails, ask the - * user to enter a different file name. This can happen if the user - * types Japanese characters when `G_FILENAME_ENCODING` is set to - * `ISO-8859-1`, for example. - */ - - -/** - * SECTION:datalist - * @title: Keyed Data Lists - * @short_description: lists of data elements which are accessible by a - * string or GQuark identifier - * - * Keyed data lists provide lists of arbitrary data elements which can - * be accessed either with a string or with a #GQuark corresponding to - * the string. - * - * The #GQuark methods are quicker, since the strings have to be - * converted to #GQuarks anyway. - * - * Data lists are used for associating arbitrary data with #GObjects, - * using g_object_set_data() and related functions. - * - * To create a datalist, use g_datalist_init(). - * - * To add data elements to a datalist use g_datalist_id_set_data(), - * g_datalist_id_set_data_full(), g_datalist_set_data() and - * g_datalist_set_data_full(). - * - * To get data elements from a datalist use g_datalist_id_get_data() - * and g_datalist_get_data(). - * - * To iterate over all data elements in a datalist use - * g_datalist_foreach() (not thread-safe). - * - * To remove data elements from a datalist use - * g_datalist_id_remove_data() and g_datalist_remove_data(). - * - * To remove all data elements from a datalist, use g_datalist_clear(). - */ - - -/** - * SECTION:datasets - * @title: Datasets - * @short_description: associate groups of data elements with - * particular memory locations - * - * Datasets associate groups of data elements with particular memory - * locations. These are useful if you need to associate data with a - * structure returned from an external library. Since you cannot modify - * the structure, you use its location in memory as the key into a - * dataset, where you can associate any number of data elements with it. - * - * There are two forms of most of the dataset functions. The first form - * uses strings to identify the data elements associated with a - * location. The second form uses #GQuark identifiers, which are - * created with a call to g_quark_from_string() or - * g_quark_from_static_string(). The second form is quicker, since it - * does not require looking up the string in the hash table of #GQuark - * identifiers. - * - * There is no function to create a dataset. It is automatically - * created as soon as you add elements to it. - * - * To add data elements to a dataset use g_dataset_id_set_data(), - * g_dataset_id_set_data_full(), g_dataset_set_data() and - * g_dataset_set_data_full(). - * - * To get data elements from a dataset use g_dataset_id_get_data() and - * g_dataset_get_data(). - * - * To iterate over all data elements in a dataset use - * g_dataset_foreach() (not thread-safe). - * - * To remove data elements from a dataset use - * g_dataset_id_remove_data() and g_dataset_remove_data(). - * - * To destroy a dataset, use g_dataset_destroy(). - */ - - -/** - * SECTION:date - * @title: Date and Time Functions - * @short_description: calendrical calculations and miscellaneous time stuff - * - * The #GDate data structure represents a day between January 1, Year 1, - * and sometime a few thousand years in the future (right now it will go - * to the year 65535 or so, but g_date_set_parse() only parses up to the - * year 8000 or so - just count on "a few thousand"). #GDate is meant to - * represent everyday dates, not astronomical dates or historical dates - * or ISO timestamps or the like. It extrapolates the current Gregorian - * calendar forward and backward in time; there is no attempt to change - * the calendar to match time periods or locations. #GDate does not store - * time information; it represents a day. - * - * The #GDate implementation has several nice features; it is only a - * 64-bit struct, so storing large numbers of dates is very efficient. It - * can keep both a Julian and day-month-year representation of the date, - * since some calculations are much easier with one representation or the - * other. A Julian representation is simply a count of days since some - * fixed day in the past; for #GDate the fixed day is January 1, 1 AD. - * ("Julian" dates in the #GDate API aren't really Julian dates in the - * technical sense; technically, Julian dates count from the start of the - * Julian period, Jan 1, 4713 BC). - * - * #GDate is simple to use. First you need a "blank" date; you can get a - * dynamically allocated date from g_date_new(), or you can declare an - * automatic variable or array and initialize it by - * calling g_date_clear(). A cleared date is safe; it's safe to call - * g_date_set_dmy() and the other mutator functions to initialize the - * value of a cleared date. However, a cleared date is initially - * invalid, meaning that it doesn't represent a day that exists. - * It is undefined to call any of the date calculation routines on an - * invalid date. If you obtain a date from a user or other - * unpredictable source, you should check its validity with the - * g_date_valid() predicate. g_date_valid() is also used to check for - * errors with g_date_set_parse() and other functions that can - * fail. Dates can be invalidated by calling g_date_clear() again. - * - * It is very important to use the API to access the #GDate - * struct. Often only the day-month-year or only the Julian - * representation is valid. Sometimes neither is valid. Use the API. - * - * GLib also features #GDateTime which represents a precise time. - */ - - -/** - * SECTION:date-time - * @title: GDateTime - * @short_description: a structure representing Date and Time - * @see_also: #GTimeZone - * - * #GDateTime is a structure that combines a Gregorian date and time - * into a single structure. It provides many conversion and methods to - * manipulate dates and times. Time precision is provided down to - * microseconds and the time can range (proleptically) from 0001-01-01 - * 00:00:00 to 9999-12-31 23:59:59.999999. #GDateTime follows POSIX - * time in the sense that it is oblivious to leap seconds. - * - * #GDateTime is an immutable object; once it has been created it cannot - * be modified further. All modifiers will create a new #GDateTime. - * Nearly all such functions can fail due to the date or time going out - * of range, in which case %NULL will be returned. - * - * #GDateTime is reference counted: the reference count is increased by calling - * g_date_time_ref() and decreased by calling g_date_time_unref(). When the - * reference count drops to 0, the resources allocated by the #GDateTime - * structure are released. - * - * Many parts of the API may produce non-obvious results. As an - * example, adding two months to January 31st will yield March 31st - * whereas adding one month and then one month again will yield either - * March 28th or March 29th. Also note that adding 24 hours is not - * always the same as adding one day (since days containing daylight - * savings time transitions are either 23 or 25 hours in length). - * - * #GDateTime is available since GLib 2.26. - */ - - -/** - * SECTION:error_reporting - * @Title: Error Reporting - * @Short_description: a system for reporting errors - * - * GLib provides a standard method of reporting errors from a called - * function to the calling code. (This is the same problem solved by - * exceptions in other languages.) It's important to understand that - * this method is both a data type (the #GError struct) and a [set of - * rules][gerror-rules]. If you use #GError incorrectly, then your code will not - * properly interoperate with other code that uses #GError, and users - * of your API will probably get confused. In most cases, [using #GError is - * preferred over numeric error codes][gerror-comparison], but there are - * situations where numeric error codes are useful for performance. - * - * First and foremost: #GError should only be used to report recoverable - * runtime errors, never to report programming errors. If the programmer - * has screwed up, then you should use g_warning(), g_return_if_fail(), - * g_assert(), g_error(), or some similar facility. (Incidentally, - * remember that the g_error() function should only be used for - * programming errors, it should not be used to print any error - * reportable via #GError.) - * - * Examples of recoverable runtime errors are "file not found" or - * "failed to parse input." Examples of programming errors are "NULL - * passed to strcmp()" or "attempted to free the same pointer twice." - * These two kinds of errors are fundamentally different: runtime errors - * should be handled or reported to the user, programming errors should - * be eliminated by fixing the bug in the program. This is why most - * functions in GLib and GTK+ do not use the #GError facility. - * - * Functions that can fail take a return location for a #GError as their - * last argument. On error, a new #GError instance will be allocated and - * returned to the caller via this argument. For example: - * |[<!-- language="C" --> - * gboolean g_file_get_contents (const gchar *filename, - * gchar **contents, - * gsize *length, - * GError **error); - * ]| - * If you pass a non-%NULL value for the `error` argument, it should - * point to a location where an error can be placed. For example: - * |[<!-- language="C" --> - * gchar *contents; - * GError *err = NULL; - * - * g_file_get_contents ("foo.txt", &contents, NULL, &err); - * g_assert ((contents == NULL && err != NULL) || (contents != NULL && err == NULL)); - * if (err != NULL) - * { - * // Report error to user, and free error - * g_assert (contents == NULL); - * fprintf (stderr, "Unable to read file: %s\n", err->message); - * g_error_free (err); - * } - * else - * { - * // Use file contents - * g_assert (contents != NULL); - * } - * ]| - * Note that `err != NULL` in this example is a reliable indicator - * of whether g_file_get_contents() failed. Additionally, - * g_file_get_contents() returns a boolean which - * indicates whether it was successful. - * - * Because g_file_get_contents() returns %FALSE on failure, if you - * are only interested in whether it failed and don't need to display - * an error message, you can pass %NULL for the @error argument: - * |[<!-- language="C" --> - * if (g_file_get_contents ("foo.txt", &contents, NULL, NULL)) // ignore errors - * // no error occurred - * ; - * else - * // error - * ; - * ]| - * - * The #GError object contains three fields: @domain indicates the module - * the error-reporting function is located in, @code indicates the specific - * error that occurred, and @message is a user-readable error message with - * as many details as possible. Several functions are provided to deal - * with an error received from a called function: g_error_matches() - * returns %TRUE if the error matches a given domain and code, - * g_propagate_error() copies an error into an error location (so the - * calling function will receive it), and g_clear_error() clears an - * error location by freeing the error and resetting the location to - * %NULL. To display an error to the user, simply display the @message, - * perhaps along with additional context known only to the calling - * function (the file being opened, or whatever - though in the - * g_file_get_contents() case, the @message already contains a filename). - * - * Since error messages may be displayed to the user, they need to be valid - * UTF-8 (all GTK widgets expect text to be UTF-8). Keep this in mind in - * particular when formatting error messages with filenames, which are in - * the 'filename encoding', and need to be turned into UTF-8 using - * g_filename_to_utf8(), g_filename_display_name() or g_utf8_make_valid(). - * - * Note, however, that many error messages are too technical to display to the - * user in an application, so prefer to use g_error_matches() to categorize errors - * from called functions, and build an appropriate error message for the context - * within your application. Error messages from a #GError are more appropriate - * to be printed in system logs or on the command line. They are typically - * translated. - * - * When implementing a function that can report errors, the basic - * tool is g_set_error(). Typically, if a fatal error occurs you - * want to g_set_error(), then return immediately. g_set_error() - * does nothing if the error location passed to it is %NULL. - * Here's an example: - * |[<!-- language="C" --> - * gint - * foo_open_file (GError **error) - * { - * gint fd; - * int saved_errno; - * - * g_return_val_if_fail (error == NULL || *error == NULL, -1); - * - * fd = open ("file.txt", O_RDONLY); - * saved_errno = errno; - * - * if (fd < 0) - * { - * g_set_error (error, - * FOO_ERROR, // error domain - * FOO_ERROR_BLAH, // error code - * "Failed to open file: %s", // error message format string - * g_strerror (saved_errno)); - * return -1; - * } - * else - * return fd; - * } - * ]| - * - * Things are somewhat more complicated if you yourself call another - * function that can report a #GError. If the sub-function indicates - * fatal errors in some way other than reporting a #GError, such as - * by returning %TRUE on success, you can simply do the following: - * |[<!-- language="C" --> - * gboolean - * my_function_that_can_fail (GError **err) - * { - * g_return_val_if_fail (err == NULL || *err == NULL, FALSE); - * - * if (!sub_function_that_can_fail (err)) - * { - * // assert that error was set by the sub-function - * g_assert (err == NULL || *err != NULL); - * return FALSE; - * } - * - * // otherwise continue, no error occurred - * g_assert (err == NULL || *err == NULL); - * } - * ]| - * - * If the sub-function does not indicate errors other than by - * reporting a #GError (or if its return value does not reliably indicate - * errors) you need to create a temporary #GError - * since the passed-in one may be %NULL. g_propagate_error() is - * intended for use in this case. - * |[<!-- language="C" --> - * gboolean - * my_function_that_can_fail (GError **err) - * { - * GError *tmp_error; - * - * g_return_val_if_fail (err == NULL || *err == NULL, FALSE); - * - * tmp_error = NULL; - * sub_function_that_can_fail (&tmp_error); - * - * if (tmp_error != NULL) - * { - * // store tmp_error in err, if err != NULL, - * // otherwise call g_error_free() on tmp_error - * g_propagate_error (err, tmp_error); - * return FALSE; - * } - * - * // otherwise continue, no error occurred - * } - * ]| - * - * Error pileups are always a bug. For example, this code is incorrect: - * |[<!-- language="C" --> - * gboolean - * my_function_that_can_fail (GError **err) - * { - * GError *tmp_error; - * - * g_return_val_if_fail (err == NULL || *err == NULL, FALSE); - * - * tmp_error = NULL; - * sub_function_that_can_fail (&tmp_error); - * other_function_that_can_fail (&tmp_error); - * - * if (tmp_error != NULL) - * { - * g_propagate_error (err, tmp_error); - * return FALSE; - * } - * } - * ]| - * @tmp_error should be checked immediately after sub_function_that_can_fail(), - * and either cleared or propagated upward. The rule is: after each error, - * you must either handle the error, or return it to the calling function. - * - * Note that passing %NULL for the error location is the equivalent - * of handling an error by always doing nothing about it. So the - * following code is fine, assuming errors in sub_function_that_can_fail() - * are not fatal to my_function_that_can_fail(): - * |[<!-- language="C" --> - * gboolean - * my_function_that_can_fail (GError **err) - * { - * GError *tmp_error; - * - * g_return_val_if_fail (err == NULL || *err == NULL, FALSE); - * - * sub_function_that_can_fail (NULL); // ignore errors - * - * tmp_error = NULL; - * other_function_that_can_fail (&tmp_error); - * - * if (tmp_error != NULL) - * { - * g_propagate_error (err, tmp_error); - * return FALSE; - * } - * } - * ]| - * - * Note that passing %NULL for the error location ignores errors; - * it's equivalent to - * `try { sub_function_that_can_fail (); } catch (...) {}` - * in C++. It does not mean to leave errors unhandled; it means - * to handle them by doing nothing. - * - * Error domains and codes are conventionally named as follows: - * - * - The error domain is called <NAMESPACE>_<MODULE>_ERROR, - * for example %G_SPAWN_ERROR or %G_THREAD_ERROR: - * |[<!-- language="C" --> - * #define G_SPAWN_ERROR g_spawn_error_quark () - * - * G_DEFINE_QUARK (g-spawn-error-quark, g_spawn_error) - * ]| - * - * - The quark function for the error domain is called - * <namespace>_<module>_error_quark, - * for example g_spawn_error_quark() or g_thread_error_quark(). - * - * - The error codes are in an enumeration called - * <Namespace><Module>Error; - * for example, #GThreadError or #GSpawnError. - * - * - Members of the error code enumeration are called - * <NAMESPACE>_<MODULE>_ERROR_<CODE>, - * for example %G_SPAWN_ERROR_FORK or %G_THREAD_ERROR_AGAIN. - * - * - If there's a "generic" or "unknown" error code for unrecoverable - * errors it doesn't make sense to distinguish with specific codes, - * it should be called <NAMESPACE>_<MODULE>_ERROR_FAILED, - * for example %G_SPAWN_ERROR_FAILED. In the case of error code - * enumerations that may be extended in future releases, you should - * generally not handle this error code explicitly, but should - * instead treat any unrecognized error code as equivalent to - * FAILED. - * - * ## Comparison of #GError and traditional error handling # {#gerror-comparison} - * - * #GError has several advantages over traditional numeric error codes: - * importantly, tools like - * [gobject-introspection](https://developer.gnome.org/gi/stable/) understand - * #GErrors and convert them to exceptions in bindings; the message includes - * more information than just a code; and use of a domain helps prevent - * misinterpretation of error codes. - * - * #GError has disadvantages though: it requires a memory allocation, and - * formatting the error message string has a performance overhead. This makes it - * unsuitable for use in retry loops where errors are a common case, rather than - * being unusual. For example, using %G_IO_ERROR_WOULD_BLOCK means hitting these - * overheads in the normal control flow. String formatting overhead can be - * eliminated by using g_set_error_literal() in some cases. - * - * These performance issues can be compounded if a function wraps the #GErrors - * returned by the functions it calls: this multiplies the number of allocations - * and string formatting operations. This can be partially mitigated by using - * g_prefix_error(). - * - * ## Rules for use of #GError # {#gerror-rules} - * - * Summary of rules for use of #GError: - * - * - Do not report programming errors via #GError. - * - * - The last argument of a function that returns an error should - * be a location where a #GError can be placed (i.e. `GError **error`). - * If #GError is used with varargs, the `GError**` should be the last - * argument before the `...`. - * - * - The caller may pass %NULL for the `GError**` if they are not interested - * in details of the exact error that occurred. - * - * - If %NULL is passed for the `GError**` argument, then errors should - * not be returned to the caller, but your function should still - * abort and return if an error occurs. That is, control flow should - * not be affected by whether the caller wants to get a #GError. - * - * - If a #GError is reported, then your function by definition had a - * fatal failure and did not complete whatever it was supposed to do. - * If the failure was not fatal, then you handled it and you should not - * report it. If it was fatal, then you must report it and discontinue - * whatever you were doing immediately. - * - * - If a #GError is reported, out parameters are not guaranteed to - * be set to any defined value. - * - * - A `GError*` must be initialized to %NULL before passing its address - * to a function that can report errors. - * - * - #GError structs must not be stack-allocated. - * - * - "Piling up" errors is always a bug. That is, if you assign a - * new #GError to a `GError*` that is non-%NULL, thus overwriting - * the previous error, it indicates that you should have aborted - * the operation instead of continuing. If you were able to continue, - * you should have cleared the previous error with g_clear_error(). - * g_set_error() will complain if you pile up errors. - * - * - By convention, if you return a boolean value indicating success - * then %TRUE means success and %FALSE means failure. Avoid creating - * functions which have a boolean return value and a #GError parameter, - * but where the boolean does something other than signal whether the - * #GError is set. Among other problems, it requires C callers to allocate - * a temporary error. Instead, provide a `gboolean *` out parameter. - * There are functions in GLib itself such as g_key_file_has_key() that - * are hard to use because of this. If %FALSE is returned, the error must - * be set to a non-%NULL value. One exception to this is that in situations - * that are already considered to be undefined behaviour (such as when a - * g_return_val_if_fail() check fails), the error need not be set. - * Instead of checking separately whether the error is set, callers - * should ensure that they do not provoke undefined behaviour, then - * assume that the error will be set on failure. - * - * - A %NULL return value is also frequently used to mean that an error - * occurred. You should make clear in your documentation whether %NULL - * is a valid return value in non-error cases; if %NULL is a valid value, - * then users must check whether an error was returned to see if the - * function succeeded. - * - * - When implementing a function that can report errors, you may want - * to add a check at the top of your function that the error return - * location is either %NULL or contains a %NULL error (e.g. - * `g_return_if_fail (error == NULL || *error == NULL);`). - * - * ## Extended #GError Domains # {#gerror-extended-domains} - * - * Since GLib 2.68 it is possible to extend the #GError type. This is - * done with the G_DEFINE_EXTENDED_ERROR() macro. To create an - * extended #GError type do something like this in the header file: - * |[<!-- language="C" --> - * typedef enum - * { - * MY_ERROR_BAD_REQUEST, - * } MyError; - * #define MY_ERROR (my_error_quark ()) - * GQuark my_error_quark (void); - * int - * my_error_get_parse_error_id (GError *error); - * const char * - * my_error_get_bad_request_details (GError *error); - * ]| - * and in implementation: - * |[<!-- language="C" --> - * typedef struct - * { - * int parse_error_id; - * char *bad_request_details; - * } MyErrorPrivate; - * - * static void - * my_error_private_init (MyErrorPrivate *priv) - * { - * priv->parse_error_id = -1; - * // No need to set priv->bad_request_details to NULL, - * // the struct is initialized with zeros. - * } - * - * static void - * my_error_private_copy (const MyErrorPrivate *src_priv, MyErrorPrivate *dest_priv) - * { - * dest_priv->parse_error_id = src_priv->parse_error_id; - * dest_priv->bad_request_details = g_strdup (src_priv->bad_request_details); - * } - * - * static void - * my_error_private_clear (MyErrorPrivate *priv) - * { - * g_free (priv->bad_request_details); - * } - * - * // This defines the my_error_get_private and my_error_quark functions. - * G_DEFINE_EXTENDED_ERROR (MyError, my_error) - * - * int - * my_error_get_parse_error_id (GError *error) - * { - * MyErrorPrivate *priv = my_error_get_private (error); - * g_return_val_if_fail (priv != NULL, -1); - * return priv->parse_error_id; - * } - * - * const char * - * my_error_get_bad_request_details (GError *error) - * { - * MyErrorPrivate *priv = my_error_get_private (error); - * g_return_val_if_fail (priv != NULL, NULL); - * g_return_val_if_fail (error->code != MY_ERROR_BAD_REQUEST, NULL); - * return priv->bad_request_details; - * } - * - * static void - * my_error_set_bad_request (GError **error, - * const char *reason, - * int error_id, - * const char *details) - * { - * MyErrorPrivate *priv; - * g_set_error (error, MY_ERROR, MY_ERROR_BAD_REQUEST, "Invalid request: %s", reason); - * if (error != NULL && *error != NULL) - * { - * priv = my_error_get_private (error); - * g_return_val_if_fail (priv != NULL, NULL); - * priv->parse_error_id = error_id; - * priv->bad_request_details = g_strdup (details); - * } - * } - * ]| - * An example of use of the error could be: - * |[<!-- language="C" --> - * gboolean - * send_request (GBytes *request, GError **error) - * { - * ParseFailedStatus *failure = validate_request (request); - * if (failure != NULL) - * { - * my_error_set_bad_request (error, failure->reason, failure->error_id, failure->details); - * parse_failed_status_free (failure); - * return FALSE; - * } - * - * return send_one (request, error); - * } - * ]| - * - * Please note that if you are a library author and your library - * exposes an existing error domain, then you can't make this error - * domain an extended one without breaking ABI. This is because - * earlier it was possible to create an error with this error domain - * on the stack and then copy it with g_error_copy(). If the new - * version of your library makes the error domain an extended one, - * then g_error_copy() called by code that allocated the error on the - * stack will try to copy more data than it used to, which will lead - * to undefined behavior. You must not stack-allocate errors with an - * extended error domain, and it is bad practice to stack-allocate any - * other #GErrors. - * - * Extended error domains in unloadable plugins/modules are not - * supported. - */ - - -/** - * SECTION:fileutils - * @title: File Utilities - * @short_description: various file-related functions - * - * Do not use these APIs unless you are porting a POSIX application to Windows. - * A more high-level file access API is provided as GIO — see the documentation - * for #GFile. - * - * There is a group of functions which wrap the common POSIX functions - * dealing with filenames (g_open(), g_rename(), g_mkdir(), g_stat(), - * g_unlink(), g_remove(), g_fopen(), g_freopen()). The point of these - * wrappers is to make it possible to handle file names with any Unicode - * characters in them on Windows without having to use ifdefs and the - * wide character API in the application code. - * - * On some Unix systems, these APIs may be defined as identical to their POSIX - * counterparts. For this reason, you must check for and include the necessary - * header files (such as `fcntl.h`) before using functions like g_creat(). You - * must also define the relevant feature test macros. - * - * The pathname argument should be in the GLib file name encoding. - * On POSIX this is the actual on-disk encoding which might correspond - * to the locale settings of the process (or the `G_FILENAME_ENCODING` - * environment variable), or not. - * - * On Windows the GLib file name encoding is UTF-8. Note that the - * Microsoft C library does not use UTF-8, but has separate APIs for - * current system code page and wide characters (UTF-16). The GLib - * wrappers call the wide character API if present (on modern Windows - * systems), otherwise convert to/from the system code page. - * - * Another group of functions allows to open and read directories - * in the GLib file name encoding. These are g_dir_open(), - * g_dir_read_name(), g_dir_rewind(), g_dir_close(). - */ - - -/** - * SECTION:ghostutils - * @short_description: Internet hostname utilities - * - * Functions for manipulating internet hostnames; in particular, for - * converting between Unicode and ASCII-encoded forms of - * Internationalized Domain Names (IDNs). - * - * The - * [Internationalized Domain Names for Applications (IDNA)](http://www.ietf.org/rfc/rfc3490.txt) - * standards allow for the use - * of Unicode domain names in applications, while providing - * backward-compatibility with the old ASCII-only DNS, by defining an - * ASCII-Compatible Encoding of any given Unicode name, which can be - * used with non-IDN-aware applications and protocols. (For example, - * "Παν語.org" maps to "xn--4wa8awb4637h.org".) - */ - - -/** - * SECTION:gregex - * @title: Perl-compatible regular expressions - * @short_description: matches strings against regular expressions - * @see_also: [Regular expression syntax][glib-regex-syntax] - * - * The g_regex_*() functions implement regular - * expression pattern matching using syntax and semantics similar to - * Perl regular expression. - * - * Some functions accept a @start_position argument, setting it differs - * from just passing over a shortened string and setting #G_REGEX_MATCH_NOTBOL - * in the case of a pattern that begins with any kind of lookbehind assertion. - * For example, consider the pattern "\Biss\B" which finds occurrences of "iss" - * in the middle of words. ("\B" matches only if the current position in the - * subject is not a word boundary.) When applied to the string "Mississipi" - * from the fourth byte, namely "issipi", it does not match, because "\B" is - * always false at the start of the subject, which is deemed to be a word - * boundary. However, if the entire string is passed , but with - * @start_position set to 4, it finds the second occurrence of "iss" because - * it is able to look behind the starting point to discover that it is - * preceded by a letter. - * - * Note that, unless you set the #G_REGEX_RAW flag, all the strings passed - * to these functions must be encoded in UTF-8. The lengths and the positions - * inside the strings are in bytes and not in characters, so, for instance, - * "\xc3\xa0" (i.e. "à") is two bytes long but it is treated as a - * single character. If you set #G_REGEX_RAW the strings can be non-valid - * UTF-8 strings and a byte is treated as a character, so "\xc3\xa0" is two - * bytes and two characters long. - * - * When matching a pattern, "\n" matches only against a "\n" character in - * the string, and "\r" matches only a "\r" character. To match any newline - * sequence use "\R". This particular group matches either the two-character - * sequence CR + LF ("\r\n"), or one of the single characters LF (linefeed, - * U+000A, "\n"), VT vertical tab, U+000B, "\v"), FF (formfeed, U+000C, "\f"), - * CR (carriage return, U+000D, "\r"), NEL (next line, U+0085), LS (line - * separator, U+2028), or PS (paragraph separator, U+2029). - * - * The behaviour of the dot, circumflex, and dollar metacharacters are - * affected by newline characters, the default is to recognize any newline - * character (the same characters recognized by "\R"). This can be changed - * with #G_REGEX_NEWLINE_CR, #G_REGEX_NEWLINE_LF and #G_REGEX_NEWLINE_CRLF - * compile options, and with #G_REGEX_MATCH_NEWLINE_ANY, - * #G_REGEX_MATCH_NEWLINE_CR, #G_REGEX_MATCH_NEWLINE_LF and - * #G_REGEX_MATCH_NEWLINE_CRLF match options. These settings are also - * relevant when compiling a pattern if #G_REGEX_EXTENDED is set, and an - * unescaped "#" outside a character class is encountered. This indicates - * a comment that lasts until after the next newline. - * - * When setting the %G_REGEX_JAVASCRIPT_COMPAT flag, pattern syntax and pattern - * matching is changed to be compatible with the way that regular expressions - * work in JavaScript. More precisely, a lonely ']' character in the pattern - * is a syntax error; the '\x' escape only allows 0 to 2 hexadecimal digits, and - * you must use the '\u' escape sequence with 4 hex digits to specify a unicode - * codepoint instead of '\x' or 'x{....}'. If '\x' or '\u' are not followed by - * the specified number of hex digits, they match 'x' and 'u' literally; also - * '\U' always matches 'U' instead of being an error in the pattern. Finally, - * pattern matching is modified so that back references to an unset subpattern - * group produces a match with the empty string instead of an error. See - * pcreapi(3) for more information. - * - * Creating and manipulating the same #GRegex structure from different - * threads is not a problem as #GRegex does not modify its internal - * state between creation and destruction, on the other hand #GMatchInfo - * is not threadsafe. - * - * The regular expressions low-level functionalities are obtained through - * the excellent - * [PCRE](http://www.pcre.org/) - * library written by Philip Hazel. - */ - - -/** - * SECTION:gstrvbuilder - * @title: GStrvBuilder - * @short_description: Helper to create NULL-terminated string arrays. - * - * #GStrvBuilder is a method of easily building dynamically sized - * NULL-terminated string arrays. - * - * The following example shows how to build a two element array: - * - * |[<!-- language="C" --> - * g_autoptr(GStrvBuilder) builder = g_strv_builder_new (); - * g_strv_builder_add (builder, "hello"); - * g_strv_builder_add (builder, "world"); - * g_auto(GStrv) array = g_strv_builder_end (builder); - * ]| - * - * Since: 2.68 - */ - - -/** - * SECTION:gunix - * @title: UNIX-specific utilities and integration - * @short_description: pipes, signal handling - * @include: glib-unix.h - * - * Most of GLib is intended to be portable; in contrast, this set of - * functions is designed for programs which explicitly target UNIX, - * or are using it to build higher level abstractions which would be - * conditionally compiled if the platform matches G_OS_UNIX. - * - * To use these functions, you must explicitly include the - * "glib-unix.h" header. - */ - - -/** - * SECTION:guri - * @short_description: URI-handling utilities - * @include: glib.h - * - * The #GUri type and related functions can be used to parse URIs into - * their components, and build valid URIs from individual components. - * - * Note that #GUri scope is to help manipulate URIs in various applications, - * following [RFC 3986](https://tools.ietf.org/html/rfc3986). In particular, - * it doesn't intend to cover web browser needs, and doesn't implement the - * [WHATWG URL](https://url.spec.whatwg.org/) standard. No APIs are provided to - * help prevent - * [homograph attacks](https://en.wikipedia.org/wiki/IDN_homograph_attack), so - * #GUri is not suitable for formatting URIs for display to the user for making - * security-sensitive decisions. - * - * ## Relative and absolute URIs # {#relative-absolute-uris} - * - * As defined in [RFC 3986](https://tools.ietf.org/html/rfc3986#section-4), the - * hierarchical nature of URIs means that they can either be ‘relative - * references’ (sometimes referred to as ‘relative URIs’) or ‘URIs’ (for - * clarity, ‘URIs’ are referred to in this documentation as - * ‘absolute URIs’ — although - * [in constrast to RFC 3986](https://tools.ietf.org/html/rfc3986#section-4.3), - * fragment identifiers are always allowed). - * - * Relative references have one or more components of the URI missing. In - * particular, they have no scheme. Any other component, such as hostname, - * query, etc. may be missing, apart from a path, which has to be specified (but - * may be empty). The path may be relative, starting with `./` rather than `/`. - * - * For example, a valid relative reference is `./path?query`, - * `/?query#fragment` or `//example.com`. - * - * Absolute URIs have a scheme specified. Any other components of the URI which - * are missing are specified as explicitly unset in the URI, rather than being - * resolved relative to a base URI using g_uri_parse_relative(). - * - * For example, a valid absolute URI is `file:///home/bob` or - * `https://search.com?query=string`. - * - * A #GUri instance is always an absolute URI. A string may be an absolute URI - * or a relative reference; see the documentation for individual functions as to - * what forms they accept. - * - * ## Parsing URIs - * - * The most minimalist APIs for parsing URIs are g_uri_split() and - * g_uri_split_with_user(). These split a URI into its component - * parts, and return the parts; the difference between the two is that - * g_uri_split() treats the ‘userinfo’ component of the URI as a - * single element, while g_uri_split_with_user() can (depending on the - * #GUriFlags you pass) treat it as containing a username, password, - * and authentication parameters. Alternatively, g_uri_split_network() - * can be used when you are only interested in the components that are - * needed to initiate a network connection to the service (scheme, - * host, and port). - * - * g_uri_parse() is similar to g_uri_split(), but instead of returning - * individual strings, it returns a #GUri structure (and it requires - * that the URI be an absolute URI). - * - * g_uri_resolve_relative() and g_uri_parse_relative() allow you to - * resolve a relative URI relative to a base URI. - * g_uri_resolve_relative() takes two strings and returns a string, - * and g_uri_parse_relative() takes a #GUri and a string and returns a - * #GUri. - * - * All of the parsing functions take a #GUriFlags argument describing - * exactly how to parse the URI; see the documentation for that type - * for more details on the specific flags that you can pass. If you - * need to choose different flags based on the type of URI, you can - * use g_uri_peek_scheme() on the URI string to check the scheme - * first, and use that to decide what flags to parse it with. - * - * For example, you might want to use %G_URI_PARAMS_WWW_FORM when parsing the - * params for a web URI, so compare the result of g_uri_peek_scheme() against - * `http` and `https`. - * - * ## Building URIs - * - * g_uri_join() and g_uri_join_with_user() can be used to construct - * valid URI strings from a set of component strings. They are the - * inverse of g_uri_split() and g_uri_split_with_user(). - * - * Similarly, g_uri_build() and g_uri_build_with_user() can be used to - * construct a #GUri from a set of component strings. - * - * As with the parsing functions, the building functions take a - * #GUriFlags argument. In particular, it is important to keep in mind - * whether the URI components you are using are already `%`-encoded. If so, - * you must pass the %G_URI_FLAGS_ENCODED flag. - * - * ## `file://` URIs - * - * Note that Windows and Unix both define special rules for parsing - * `file://` URIs (involving non-UTF-8 character sets on Unix, and the - * interpretation of path separators on Windows). #GUri does not - * implement these rules. Use g_filename_from_uri() and - * g_filename_to_uri() if you want to properly convert between - * `file://` URIs and local filenames. - * - * ## URI Equality - * - * Note that there is no `g_uri_equal ()` function, because comparing - * URIs usefully requires scheme-specific knowledge that #GUri does - * not have. #GUri can help with normalization if you use the various - * encoded #GUriFlags as well as %G_URI_FLAGS_SCHEME_NORMALIZE however - * it is not comprehensive. - * For example, `data:,foo` and `data:;base64,Zm9v` resolve to the same - * thing according to the `data:` URI specification which GLib does not - * handle. - * - * Since: 2.66 - */ - - -/** - * SECTION:gvariant - * @title: GVariant - * @short_description: strongly typed value datatype - * @see_also: GVariantType - * - * #GVariant is a variant datatype; it can contain one or more values - * along with information about the type of the values. - * - * A #GVariant may contain simple types, like an integer, or a boolean value; - * or complex types, like an array of two strings, or a dictionary of key - * value pairs. A #GVariant is also immutable: once it's been created neither - * its type nor its content can be modified further. - * - * GVariant is useful whenever data needs to be serialized, for example when - * sending method parameters in D-Bus, or when saving settings using GSettings. - * - * When creating a new #GVariant, you pass the data you want to store in it - * along with a string representing the type of data you wish to pass to it. - * - * For instance, if you want to create a #GVariant holding an integer value you - * can use: - * - * |[<!-- language="C" --> - * GVariant *v = g_variant_new ("u", 40); - * ]| - * - * The string "u" in the first argument tells #GVariant that the data passed to - * the constructor (40) is going to be an unsigned integer. - * - * More advanced examples of #GVariant in use can be found in documentation for - * [GVariant format strings][gvariant-format-strings-pointers]. - * - * The range of possible values is determined by the type. - * - * The type system used by #GVariant is #GVariantType. - * - * #GVariant instances always have a type and a value (which are given - * at construction time). The type and value of a #GVariant instance - * can never change other than by the #GVariant itself being - * destroyed. A #GVariant cannot contain a pointer. - * - * #GVariant is reference counted using g_variant_ref() and - * g_variant_unref(). #GVariant also has floating reference counts -- - * see g_variant_ref_sink(). - * - * #GVariant is completely threadsafe. A #GVariant instance can be - * concurrently accessed in any way from any number of threads without - * problems. - * - * #GVariant is heavily optimised for dealing with data in serialized - * form. It works particularly well with data located in memory-mapped - * files. It can perform nearly all deserialization operations in a - * small constant time, usually touching only a single memory page. - * Serialized #GVariant data can also be sent over the network. - * - * #GVariant is largely compatible with D-Bus. Almost all types of - * #GVariant instances can be sent over D-Bus. See #GVariantType for - * exceptions. (However, #GVariant's serialization format is not the same - * as the serialization format of a D-Bus message body: use #GDBusMessage, - * in the gio library, for those.) - * - * For space-efficiency, the #GVariant serialization format does not - * automatically include the variant's length, type or endianness, - * which must either be implied from context (such as knowledge that a - * particular file format always contains a little-endian - * %G_VARIANT_TYPE_VARIANT which occupies the whole length of the file) - * or supplied out-of-band (for instance, a length, type and/or endianness - * indicator could be placed at the beginning of a file, network message - * or network stream). - * - * A #GVariant's size is limited mainly by any lower level operating - * system constraints, such as the number of bits in #gsize. For - * example, it is reasonable to have a 2GB file mapped into memory - * with #GMappedFile, and call g_variant_new_from_data() on it. - * - * For convenience to C programmers, #GVariant features powerful - * varargs-based value construction and destruction. This feature is - * designed to be embedded in other libraries. - * - * There is a Python-inspired text language for describing #GVariant - * values. #GVariant includes a printer for this language and a parser - * with type inferencing. - * - * ## Memory Use - * - * #GVariant tries to be quite efficient with respect to memory use. - * This section gives a rough idea of how much memory is used by the - * current implementation. The information here is subject to change - * in the future. - * - * The memory allocated by #GVariant can be grouped into 4 broad - * purposes: memory for serialized data, memory for the type - * information cache, buffer management memory and memory for the - * #GVariant structure itself. - * - * ## Serialized Data Memory - * - * This is the memory that is used for storing GVariant data in - * serialized form. This is what would be sent over the network or - * what would end up on disk, not counting any indicator of the - * endianness, or of the length or type of the top-level variant. - * - * The amount of memory required to store a boolean is 1 byte. 16, - * 32 and 64 bit integers and double precision floating point numbers - * use their "natural" size. Strings (including object path and - * signature strings) are stored with a nul terminator, and as such - * use the length of the string plus 1 byte. - * - * Maybe types use no space at all to represent the null value and - * use the same amount of space (sometimes plus one byte) as the - * equivalent non-maybe-typed value to represent the non-null case. - * - * Arrays use the amount of space required to store each of their - * members, concatenated. Additionally, if the items stored in an - * array are not of a fixed-size (ie: strings, other arrays, etc) - * then an additional framing offset is stored for each item. The - * size of this offset is either 1, 2 or 4 bytes depending on the - * overall size of the container. Additionally, extra padding bytes - * are added as required for alignment of child values. - * - * Tuples (including dictionary entries) use the amount of space - * required to store each of their members, concatenated, plus one - * framing offset (as per arrays) for each non-fixed-sized item in - * the tuple, except for the last one. Additionally, extra padding - * bytes are added as required for alignment of child values. - * - * Variants use the same amount of space as the item inside of the - * variant, plus 1 byte, plus the length of the type string for the - * item inside the variant. - * - * As an example, consider a dictionary mapping strings to variants. - * In the case that the dictionary is empty, 0 bytes are required for - * the serialization. - * - * If we add an item "width" that maps to the int32 value of 500 then - * we will use 4 byte to store the int32 (so 6 for the variant - * containing it) and 6 bytes for the string. The variant must be - * aligned to 8 after the 6 bytes of the string, so that's 2 extra - * bytes. 6 (string) + 2 (padding) + 6 (variant) is 14 bytes used - * for the dictionary entry. An additional 1 byte is added to the - * array as a framing offset making a total of 15 bytes. - * - * If we add another entry, "title" that maps to a nullable string - * that happens to have a value of null, then we use 0 bytes for the - * null value (and 3 bytes for the variant to contain it along with - * its type string) plus 6 bytes for the string. Again, we need 2 - * padding bytes. That makes a total of 6 + 2 + 3 = 11 bytes. - * - * We now require extra padding between the two items in the array. - * After the 14 bytes of the first item, that's 2 bytes required. - * We now require 2 framing offsets for an extra two - * bytes. 14 + 2 + 11 + 2 = 29 bytes to encode the entire two-item - * dictionary. - * - * ## Type Information Cache - * - * For each GVariant type that currently exists in the program a type - * information structure is kept in the type information cache. The - * type information structure is required for rapid deserialization. - * - * Continuing with the above example, if a #GVariant exists with the - * type "a{sv}" then a type information struct will exist for - * "a{sv}", "{sv}", "s", and "v". Multiple uses of the same type - * will share the same type information. Additionally, all - * single-digit types are stored in read-only static memory and do - * not contribute to the writable memory footprint of a program using - * #GVariant. - * - * Aside from the type information structures stored in read-only - * memory, there are two forms of type information. One is used for - * container types where there is a single element type: arrays and - * maybe types. The other is used for container types where there - * are multiple element types: tuples and dictionary entries. - * - * Array type info structures are 6 * sizeof (void *), plus the - * memory required to store the type string itself. This means that - * on 32-bit systems, the cache entry for "a{sv}" would require 30 - * bytes of memory (plus malloc overhead). - * - * Tuple type info structures are 6 * sizeof (void *), plus 4 * - * sizeof (void *) for each item in the tuple, plus the memory - * required to store the type string itself. A 2-item tuple, for - * example, would have a type information structure that consumed - * writable memory in the size of 14 * sizeof (void *) (plus type - * string) This means that on 32-bit systems, the cache entry for - * "{sv}" would require 61 bytes of memory (plus malloc overhead). - * - * This means that in total, for our "a{sv}" example, 91 bytes of - * type information would be allocated. - * - * The type information cache, additionally, uses a #GHashTable to - * store and look up the cached items and stores a pointer to this - * hash table in static storage. The hash table is freed when there - * are zero items in the type cache. - * - * Although these sizes may seem large it is important to remember - * that a program will probably only have a very small number of - * different types of values in it and that only one type information - * structure is required for many different values of the same type. - * - * ## Buffer Management Memory - * - * #GVariant uses an internal buffer management structure to deal - * with the various different possible sources of serialized data - * that it uses. The buffer is responsible for ensuring that the - * correct call is made when the data is no longer in use by - * #GVariant. This may involve a g_free() or a g_slice_free() or - * even g_mapped_file_unref(). - * - * One buffer management structure is used for each chunk of - * serialized data. The size of the buffer management structure - * is 4 * (void *). On 32-bit systems, that's 16 bytes. - * - * ## GVariant structure - * - * The size of a #GVariant structure is 6 * (void *). On 32-bit - * systems, that's 24 bytes. - * - * #GVariant structures only exist if they are explicitly created - * with API calls. For example, if a #GVariant is constructed out of - * serialized data for the example given above (with the dictionary) - * then although there are 9 individual values that comprise the - * entire dictionary (two keys, two values, two variants containing - * the values, two dictionary entries, plus the dictionary itself), - * only 1 #GVariant instance exists -- the one referring to the - * dictionary. - * - * If calls are made to start accessing the other values then - * #GVariant instances will exist for those values only for as long - * as they are in use (ie: until you call g_variant_unref()). The - * type information is shared. The serialized data and the buffer - * management structure for that serialized data is shared by the - * child. - * - * ## Summary - * - * To put the entire example together, for our dictionary mapping - * strings to variants (with two entries, as given above), we are - * using 91 bytes of memory for type information, 29 bytes of memory - * for the serialized data, 16 bytes for buffer management and 24 - * bytes for the #GVariant instance, or a total of 160 bytes, plus - * malloc overhead. If we were to use g_variant_get_child_value() to - * access the two dictionary entries, we would use an additional 48 - * bytes. If we were to have other dictionaries of the same type, we - * would use more memory for the serialized data and buffer - * management for those dictionaries, but the type information would - * be shared. - */ - - -/** - * SECTION:gvarianttype - * @title: GVariantType - * @short_description: introduction to the GVariant type system - * @see_also: #GVariantType, #GVariant - * - * This section introduces the GVariant type system. It is based, in - * large part, on the D-Bus type system, with two major changes and - * some minor lifting of restrictions. The - * [D-Bus specification](http://dbus.freedesktop.org/doc/dbus-specification.html), - * therefore, provides a significant amount of - * information that is useful when working with GVariant. - * - * The first major change with respect to the D-Bus type system is the - * introduction of maybe (or "nullable") types. Any type in GVariant can be - * converted to a maybe type, in which case, "nothing" (or "null") becomes a - * valid value. Maybe types have been added by introducing the - * character "m" to type strings. - * - * The second major change is that the GVariant type system supports the - * concept of "indefinite types" -- types that are less specific than - * the normal types found in D-Bus. For example, it is possible to speak - * of "an array of any type" in GVariant, where the D-Bus type system - * would require you to speak of "an array of integers" or "an array of - * strings". Indefinite types have been added by introducing the - * characters "*", "?" and "r" to type strings. - * - * Finally, all arbitrary restrictions relating to the complexity of - * types are lifted along with the restriction that dictionary entries - * may only appear nested inside of arrays. - * - * Just as in D-Bus, GVariant types are described with strings ("type - * strings"). Subject to the differences mentioned above, these strings - * are of the same form as those found in D-Bus. Note, however: D-Bus - * always works in terms of messages and therefore individual type - * strings appear nowhere in its interface. Instead, "signatures" - * are a concatenation of the strings of the type of each argument in a - * message. GVariant deals with single values directly so GVariant type - * strings always describe the type of exactly one value. This means - * that a D-Bus signature string is generally not a valid GVariant type - * string -- except in the case that it is the signature of a message - * containing exactly one argument. - * - * An indefinite type is similar in spirit to what may be called an - * abstract type in other type systems. No value can exist that has an - * indefinite type as its type, but values can exist that have types - * that are subtypes of indefinite types. That is to say, - * g_variant_get_type() will never return an indefinite type, but - * calling g_variant_is_of_type() with an indefinite type may return - * %TRUE. For example, you cannot have a value that represents "an - * array of no particular type", but you can have an "array of integers" - * which certainly matches the type of "an array of no particular type", - * since "array of integers" is a subtype of "array of no particular - * type". - * - * This is similar to how instances of abstract classes may not - * directly exist in other type systems, but instances of their - * non-abstract subtypes may. For example, in GTK, no object that has - * the type of #GtkBin can exist (since #GtkBin is an abstract class), - * but a #GtkWindow can certainly be instantiated, and you would say - * that the #GtkWindow is a #GtkBin (since #GtkWindow is a subclass of - * #GtkBin). - * - * ## GVariant Type Strings - * - * A GVariant type string can be any of the following: - * - * - any basic type string (listed below) - * - * - "v", "r" or "*" - * - * - one of the characters 'a' or 'm', followed by another type string - * - * - the character '(', followed by a concatenation of zero or more other - * type strings, followed by the character ')' - * - * - the character '{', followed by a basic type string (see below), - * followed by another type string, followed by the character '}' - * - * A basic type string describes a basic type (as per - * g_variant_type_is_basic()) and is always a single character in length. - * The valid basic type strings are "b", "y", "n", "q", "i", "u", "x", "t", - * "h", "d", "s", "o", "g" and "?". - * - * The above definition is recursive to arbitrary depth. "aaaaai" and - * "(ui(nq((y)))s)" are both valid type strings, as is - * "a(aa(ui)(qna{ya(yd)}))". In order to not hit memory limits, #GVariant - * imposes a limit on recursion depth of 65 nested containers. This is the - * limit in the D-Bus specification (64) plus one to allow a #GDBusMessage to - * be nested in a top-level tuple. - * - * The meaning of each of the characters is as follows: - * - `b`: the type string of %G_VARIANT_TYPE_BOOLEAN; a boolean value. - * - `y`: the type string of %G_VARIANT_TYPE_BYTE; a byte. - * - `n`: the type string of %G_VARIANT_TYPE_INT16; a signed 16 bit integer. - * - `q`: the type string of %G_VARIANT_TYPE_UINT16; an unsigned 16 bit integer. - * - `i`: the type string of %G_VARIANT_TYPE_INT32; a signed 32 bit integer. - * - `u`: the type string of %G_VARIANT_TYPE_UINT32; an unsigned 32 bit integer. - * - `x`: the type string of %G_VARIANT_TYPE_INT64; a signed 64 bit integer. - * - `t`: the type string of %G_VARIANT_TYPE_UINT64; an unsigned 64 bit integer. - * - `h`: the type string of %G_VARIANT_TYPE_HANDLE; a signed 32 bit value - * that, by convention, is used as an index into an array of file - * descriptors that are sent alongside a D-Bus message. - * - `d`: the type string of %G_VARIANT_TYPE_DOUBLE; a double precision - * floating point value. - * - `s`: the type string of %G_VARIANT_TYPE_STRING; a string. - * - `o`: the type string of %G_VARIANT_TYPE_OBJECT_PATH; a string in the form - * of a D-Bus object path. - * - `g`: the type string of %G_VARIANT_TYPE_SIGNATURE; a string in the form of - * a D-Bus type signature. - * - `?`: the type string of %G_VARIANT_TYPE_BASIC; an indefinite type that - * is a supertype of any of the basic types. - * - `v`: the type string of %G_VARIANT_TYPE_VARIANT; a container type that - * contain any other type of value. - * - `a`: used as a prefix on another type string to mean an array of that - * type; the type string "ai", for example, is the type of an array of - * signed 32-bit integers. - * - `m`: used as a prefix on another type string to mean a "maybe", or - * "nullable", version of that type; the type string "ms", for example, - * is the type of a value that maybe contains a string, or maybe contains - * nothing. - * - `()`: used to enclose zero or more other concatenated type strings to - * create a tuple type; the type string "(is)", for example, is the type of - * a pair of an integer and a string. - * - `r`: the type string of %G_VARIANT_TYPE_TUPLE; an indefinite type that is - * a supertype of any tuple type, regardless of the number of items. - * - `{}`: used to enclose a basic type string concatenated with another type - * string to create a dictionary entry type, which usually appears inside of - * an array to form a dictionary; the type string "a{sd}", for example, is - * the type of a dictionary that maps strings to double precision floating - * point values. - * - * The first type (the basic type) is the key type and the second type is - * the value type. The reason that the first type is restricted to being a - * basic type is so that it can easily be hashed. - * - `*`: the type string of %G_VARIANT_TYPE_ANY; the indefinite type that is - * a supertype of all types. Note that, as with all type strings, this - * character represents exactly one type. It cannot be used inside of tuples - * to mean "any number of items". - * - * Any type string of a container that contains an indefinite type is, - * itself, an indefinite type. For example, the type string "a*" - * (corresponding to %G_VARIANT_TYPE_ARRAY) is an indefinite type - * that is a supertype of every array type. "(*s)" is a supertype - * of all tuples that contain exactly two items where the second - * item is a string. - * - * "a{?*}" is an indefinite type that is a supertype of all arrays - * containing dictionary entries where the key is any basic type and - * the value is any type at all. This is, by definition, a dictionary, - * so this type string corresponds to %G_VARIANT_TYPE_DICTIONARY. Note - * that, due to the restriction that the key of a dictionary entry must - * be a basic type, "{**}" is not a valid type string. - */ - - -/** - * SECTION:hash_tables - * @title: Hash Tables - * @short_description: associations between keys and values so that - * given a key the value can be found quickly - * - * A #GHashTable provides associations between keys and values which is - * optimized so that given a key, the associated value can be found, - * inserted or removed in amortized O(1). All operations going through - * each element take O(n) time (list all keys/values, table resize, etc.). - * - * Note that neither keys nor values are copied when inserted into the - * #GHashTable, so they must exist for the lifetime of the #GHashTable. - * This means that the use of static strings is OK, but temporary - * strings (i.e. those created in buffers and those returned by GTK - * widgets) should be copied with g_strdup() before being inserted. - * - * If keys or values are dynamically allocated, you must be careful to - * ensure that they are freed when they are removed from the - * #GHashTable, and also when they are overwritten by new insertions - * into the #GHashTable. It is also not advisable to mix static strings - * and dynamically-allocated strings in a #GHashTable, because it then - * becomes difficult to determine whether the string should be freed. - * - * To create a #GHashTable, use g_hash_table_new(). - * - * To insert a key and value into a #GHashTable, use - * g_hash_table_insert(). - * - * To look up a value corresponding to a given key, use - * g_hash_table_lookup() and g_hash_table_lookup_extended(). - * - * g_hash_table_lookup_extended() can also be used to simply - * check if a key is present in the hash table. - * - * To remove a key and value, use g_hash_table_remove(). - * - * To call a function for each key and value pair use - * g_hash_table_foreach() or use an iterator to iterate over the - * key/value pairs in the hash table, see #GHashTableIter. The iteration order - * of a hash table is not defined, and you must not rely on iterating over - * keys/values in the same order as they were inserted. - * - * To destroy a #GHashTable use g_hash_table_destroy(). - * - * A common use-case for hash tables is to store information about a - * set of keys, without associating any particular value with each - * key. GHashTable optimizes one way of doing so: If you store only - * key-value pairs where key == value, then GHashTable does not - * allocate memory to store the values, which can be a considerable - * space saving, if your set is large. The functions - * g_hash_table_add() and g_hash_table_contains() are designed to be - * used when using #GHashTable this way. - * - * #GHashTable is not designed to be statically initialised with keys and - * values known at compile time. To build a static hash table, use a tool such - * as [gperf](https://www.gnu.org/software/gperf/). - */ - - -/** - * SECTION:hmac - * @title: Secure HMAC Digests - * @short_description: computes the HMAC for data - * - * HMACs should be used when producing a cookie or hash based on data - * and a key. Simple mechanisms for using SHA1 and other algorithms to - * digest a key and data together are vulnerable to various security - * issues. - * [HMAC](http://en.wikipedia.org/wiki/HMAC) - * uses algorithms like SHA1 in a secure way to produce a digest of a - * key and data. - * - * Both the key and data are arbitrary byte arrays of bytes or characters. - * - * Support for HMAC Digests has been added in GLib 2.30, and support for SHA-512 - * in GLib 2.42. Support for SHA-384 was added in GLib 2.52. - */ - - -/** - * SECTION:hooks - * @title: Hook Functions - * @short_description: support for manipulating lists of hook functions - * - * The #GHookList, #GHook and their related functions provide support for - * lists of hook functions. Functions can be added and removed from the lists, - * and the list of hook functions can be invoked. - */ - - -/** - * SECTION:i18n - * @title: Internationalization - * @short_description: gettext support macros - * @see_also: the gettext manual - * - * GLib doesn't force any particular localization method upon its users. - * But since GLib itself is localized using the gettext() mechanism, it seems - * natural to offer the de-facto standard gettext() support macros in an - * easy-to-use form. - * - * In order to use these macros in an application, you must include - * `<glib/gi18n.h>`. For use in a library, you must include - * `<glib/gi18n-lib.h>` - * after defining the %GETTEXT_PACKAGE macro suitably for your library: - * |[<!-- language="C" --> - * #define GETTEXT_PACKAGE "gtk20" - * #include <glib/gi18n-lib.h> - * ]| - * For an application, note that you also have to call bindtextdomain(), - * bind_textdomain_codeset(), textdomain() and setlocale() early on in your - * main() to make gettext() work. For example: - * |[<!-- language="C" --> - * #include <glib/gi18n.h> - * #include <locale.h> - * - * int - * main (int argc, char **argv) - * { - * setlocale (LC_ALL, ""); - * bindtextdomain (GETTEXT_PACKAGE, DATADIR "/locale"); - * bind_textdomain_codeset (GETTEXT_PACKAGE, "UTF-8"); - * textdomain (GETTEXT_PACKAGE); - * - * // Rest of your application. - * } - * ]| - * where `DATADIR` is as typically provided by automake or Meson. - * - * For a library, you only have to call bindtextdomain() and - * bind_textdomain_codeset() in your initialization function. If your library - * doesn't have an initialization function, you can call the functions before - * the first translated message. - * - * The - * [gettext manual](http://www.gnu.org/software/gettext/manual/gettext.html#Maintainers) - * covers details of how to integrate gettext into a project’s build system and - * workflow. - */ - - -/** - * SECTION:iochannels - * @title: IO Channels - * @short_description: portable support for using files, pipes and sockets - * @see_also: g_io_add_watch(), g_io_add_watch_full(), g_source_remove(), - * #GMainLoop - * - * The #GIOChannel data type aims to provide a portable method for - * using file descriptors, pipes, and sockets, and integrating them - * into the [main event loop][glib-The-Main-Event-Loop]. Currently, - * full support is available on UNIX platforms, support for Windows - * is only partially complete. - * - * To create a new #GIOChannel on UNIX systems use - * g_io_channel_unix_new(). This works for plain file descriptors, - * pipes and sockets. Alternatively, a channel can be created for a - * file in a system independent manner using g_io_channel_new_file(). - * - * Once a #GIOChannel has been created, it can be used in a generic - * manner with the functions g_io_channel_read_chars(), - * g_io_channel_write_chars(), g_io_channel_seek_position(), and - * g_io_channel_shutdown(). - * - * To add a #GIOChannel to the [main event loop][glib-The-Main-Event-Loop], - * use g_io_add_watch() or g_io_add_watch_full(). Here you specify which - * events you are interested in on the #GIOChannel, and provide a - * function to be called whenever these events occur. - * - * #GIOChannel instances are created with an initial reference count of 1. - * g_io_channel_ref() and g_io_channel_unref() can be used to - * increment or decrement the reference count respectively. When the - * reference count falls to 0, the #GIOChannel is freed. (Though it - * isn't closed automatically, unless it was created using - * g_io_channel_new_file().) Using g_io_add_watch() or - * g_io_add_watch_full() increments a channel's reference count. - * - * The new functions g_io_channel_read_chars(), - * g_io_channel_read_line(), g_io_channel_read_line_string(), - * g_io_channel_read_to_end(), g_io_channel_write_chars(), - * g_io_channel_seek_position(), and g_io_channel_flush() should not be - * mixed with the deprecated functions g_io_channel_read(), - * g_io_channel_write(), and g_io_channel_seek() on the same channel. - */ - - -/** - * SECTION:keyfile - * @title: Key-value file parser - * @short_description: parses .ini-like config files - * - * #GKeyFile lets you parse, edit or create files containing groups of - * key-value pairs, which we call "key files" for lack of a better name. - * Several freedesktop.org specifications use key files now, e.g the - * [Desktop Entry Specification](http://freedesktop.org/Standards/desktop-entry-spec) - * and the - * [Icon Theme Specification](http://freedesktop.org/Standards/icon-theme-spec). - * - * The syntax of key files is described in detail in the - * [Desktop Entry Specification](http://freedesktop.org/Standards/desktop-entry-spec), - * here is a quick summary: Key files - * consists of groups of key-value pairs, interspersed with comments. - * - * |[ - * # this is just an example - * # there can be comments before the first group - * - * [First Group] - * - * Name=Key File Example\tthis value shows\nescaping - * - * # localized strings are stored in multiple key-value pairs - * Welcome=Hello - * Welcome[de]=Hallo - * Welcome[fr_FR]=Bonjour - * Welcome[it]=Ciao - * Welcome[be@latin]=Hello - * - * [Another Group] - * - * Numbers=2;20;-200;0 - * - * Booleans=true;false;true;true - * ]| - * - * Lines beginning with a '#' and blank lines are considered comments. - * - * Groups are started by a header line containing the group name enclosed - * in '[' and ']', and ended implicitly by the start of the next group or - * the end of the file. Each key-value pair must be contained in a group. - * - * Key-value pairs generally have the form `key=value`, with the - * exception of localized strings, which have the form - * `key[locale]=value`, with a locale identifier of the - * form `lang_COUNTRY@MODIFIER` where `COUNTRY` and `MODIFIER` - * are optional. - * Space before and after the '=' character are ignored. Newline, tab, - * carriage return and backslash characters in value are escaped as \n, - * \t, \r, and \\\\, respectively. To preserve leading spaces in values, - * these can also be escaped as \s. - * - * Key files can store strings (possibly with localized variants), integers, - * booleans and lists of these. Lists are separated by a separator character, - * typically ';' or ','. To use the list separator character in a value in - * a list, it has to be escaped by prefixing it with a backslash. - * - * This syntax is obviously inspired by the .ini files commonly met - * on Windows, but there are some important differences: - * - * - .ini files use the ';' character to begin comments, - * key files use the '#' character. - * - * - Key files do not allow for ungrouped keys meaning only - * comments can precede the first group. - * - * - Key files are always encoded in UTF-8. - * - * - Key and Group names are case-sensitive. For example, a group called - * [GROUP] is a different from [group]. - * - * - .ini files don't have a strongly typed boolean entry type, - * they only have GetProfileInt(). In key files, only - * true and false (in lower case) are allowed. - * - * Note that in contrast to the - * [Desktop Entry Specification](http://freedesktop.org/Standards/desktop-entry-spec), - * groups in key files may contain the same - * key multiple times; the last entry wins. Key files may also contain - * multiple groups with the same name; they are merged together. - * Another difference is that keys and group names in key files are not - * restricted to ASCII characters. - * - * Here is an example of loading a key file and reading a value: - * |[<!-- language="C" --> - * g_autoptr(GError) error = NULL; - * g_autoptr(GKeyFile) key_file = g_key_file_new (); - * - * if (!g_key_file_load_from_file (key_file, "key-file.ini", flags, &error)) - * { - * if (!g_error_matches (error, G_FILE_ERROR, G_FILE_ERROR_NOENT)) - * g_warning ("Error loading key file: %s", error->message); - * return; - * } - * - * g_autofree gchar *val = g_key_file_get_string (key_file, "Group Name", "SomeKey", &error); - * if (val == NULL && - * !g_error_matches (error, G_KEY_FILE_ERROR, G_KEY_FILE_ERROR_KEY_NOT_FOUND)) - * { - * g_warning ("Error finding key in key file: %s", error->message); - * return; - * } - * else if (val == NULL) - * { - * // Fall back to a default value. - * val = g_strdup ("default-value"); - * } - * ]| - * - * Here is an example of creating and saving a key file: - * |[<!-- language="C" --> - * g_autoptr(GKeyFile) key_file = g_key_file_new (); - * const gchar *val = …; - * g_autoptr(GError) error = NULL; - * - * g_key_file_set_string (key_file, "Group Name", "SomeKey", val); - * - * // Save as a file. - * if (!g_key_file_save_to_file (key_file, "key-file.ini", &error)) - * { - * g_warning ("Error saving key file: %s", error->message); - * return; - * } - * - * // Or store to a GBytes for use elsewhere. - * gsize data_len; - * g_autofree guint8 *data = (guint8 *) g_key_file_to_data (key_file, &data_len, &error); - * if (data == NULL) - * { - * g_warning ("Error saving key file: %s", error->message); - * return; - * } - * g_autoptr(GBytes) bytes = g_bytes_new_take (g_steal_pointer (&data), data_len); - * ]| - */ - - -/** - * SECTION:linked_lists_double - * @title: Doubly-Linked Lists - * @short_description: linked lists that can be iterated over in both directions - * - * The #GList structure and its associated functions provide a standard - * doubly-linked list data structure. The benefit of this data-structure - * is to provide insertion/deletion operations in O(1) complexity where - * access/search operations are in O(n). The benefit of #GList over - * #GSList (singly linked list) is that the worst case on access/search - * operations is divided by two which comes at a cost in space as we need - * to retain two pointers in place of one. - * - * Each element in the list contains a piece of data, together with - * pointers which link to the previous and next elements in the list. - * Using these pointers it is possible to move through the list in both - * directions (unlike the singly-linked [GSList][glib-Singly-Linked-Lists], - * which only allows movement through the list in the forward direction). - * - * The double linked list does not keep track of the number of items - * and does not keep track of both the start and end of the list. If - * you want fast access to both the start and the end of the list, - * and/or the number of items in the list, use a - * [GQueue][glib-Double-ended-Queues] instead. - * - * The data contained in each element can be either integer values, by - * using one of the [Type Conversion Macros][glib-Type-Conversion-Macros], - * or simply pointers to any type of data. - * - * List elements are allocated from the [slice allocator][glib-Memory-Slices], - * which is more efficient than allocating elements individually. - * - * Note that most of the #GList functions expect to be passed a pointer - * to the first element in the list. The functions which insert - * elements return the new start of the list, which may have changed. - * - * There is no function to create a #GList. %NULL is considered to be - * a valid, empty list so you simply set a #GList* to %NULL to initialize - * it. - * - * To add elements, use g_list_append(), g_list_prepend(), - * g_list_insert() and g_list_insert_sorted(). - * - * To visit all elements in the list, use a loop over the list: - * |[<!-- language="C" --> - * GList *l; - * for (l = list; l != NULL; l = l->next) - * { - * // do something with l->data - * } - * ]| - * - * To call a function for each element in the list, use g_list_foreach(). - * - * To loop over the list and modify it (e.g. remove a certain element) - * a while loop is more appropriate, for example: - * |[<!-- language="C" --> - * GList *l = list; - * while (l != NULL) - * { - * GList *next = l->next; - * if (should_be_removed (l)) - * { - * // possibly free l->data - * list = g_list_delete_link (list, l); - * } - * l = next; - * } - * ]| - * - * To remove elements, use g_list_remove(). - * - * To navigate in a list, use g_list_first(), g_list_last(), - * g_list_next(), g_list_previous(). - * - * To find elements in the list use g_list_nth(), g_list_nth_data(), - * g_list_find() and g_list_find_custom(). - * - * To find the index of an element use g_list_position() and - * g_list_index(). - * - * To free the entire list, use g_list_free() or g_list_free_full(). - */ - - -/** - * SECTION:linked_lists_single - * @title: Singly-Linked Lists - * @short_description: linked lists that can be iterated in one direction - * - * The #GSList structure and its associated functions provide a - * standard singly-linked list data structure. The benefit of this - * data-structure is to provide insertion/deletion operations in O(1) - * complexity where access/search operations are in O(n). The benefit - * of #GSList over #GList (doubly linked list) is that they are lighter - * in space as they only need to retain one pointer but it double the - * cost of the worst case access/search operations. - * - * Each element in the list contains a piece of data, together with a - * pointer which links to the next element in the list. Using this - * pointer it is possible to move through the list in one direction - * only (unlike the [double-linked lists][glib-Doubly-Linked-Lists], - * which allow movement in both directions). - * - * The data contained in each element can be either integer values, by - * using one of the [Type Conversion Macros][glib-Type-Conversion-Macros], - * or simply pointers to any type of data. - * - * List elements are allocated from the [slice allocator][glib-Memory-Slices], - * which is more efficient than allocating elements individually. - * - * Note that most of the #GSList functions expect to be passed a - * pointer to the first element in the list. The functions which insert - * elements return the new start of the list, which may have changed. - * - * There is no function to create a #GSList. %NULL is considered to be - * the empty list so you simply set a #GSList* to %NULL. - * - * To add elements, use g_slist_append(), g_slist_prepend(), - * g_slist_insert() and g_slist_insert_sorted(). - * - * To remove elements, use g_slist_remove(). - * - * To find elements in the list use g_slist_last(), g_slist_next(), - * g_slist_nth(), g_slist_nth_data(), g_slist_find() and - * g_slist_find_custom(). - * - * To find the index of an element use g_slist_position() and - * g_slist_index(). - * - * To call a function for each element in the list use - * g_slist_foreach(). - * - * To free the entire list, use g_slist_free(). - */ - - -/** - * SECTION:macros - * @title: Standard Macros - * @short_description: commonly-used macros - * - * These macros provide a few commonly-used features. - */ - - -/** - * SECTION:macros_misc - * @title: Miscellaneous Macros - * @short_description: specialized macros which are not used often - * - * These macros provide more specialized features which are not - * needed so often by application programmers. - */ - - -/** - * SECTION:main - * @title: The Main Event Loop - * @short_description: manages all available sources of events - * - * The main event loop manages all the available sources of events for - * GLib and GTK+ applications. These events can come from any number of - * different types of sources such as file descriptors (plain files, - * pipes or sockets) and timeouts. New types of event sources can also - * be added using g_source_attach(). - * - * To allow multiple independent sets of sources to be handled in - * different threads, each source is associated with a #GMainContext. - * A #GMainContext can only be running in a single thread, but - * sources can be added to it and removed from it from other threads. All - * functions which operate on a #GMainContext or a built-in #GSource are - * thread-safe. - * - * Each event source is assigned a priority. The default priority, - * %G_PRIORITY_DEFAULT, is 0. Values less than 0 denote higher priorities. - * Values greater than 0 denote lower priorities. Events from high priority - * sources are always processed before events from lower priority sources. - * - * Idle functions can also be added, and assigned a priority. These will - * be run whenever no events with a higher priority are ready to be processed. - * - * The #GMainLoop data type represents a main event loop. A GMainLoop is - * created with g_main_loop_new(). After adding the initial event sources, - * g_main_loop_run() is called. This continuously checks for new events from - * each of the event sources and dispatches them. Finally, the processing of - * an event from one of the sources leads to a call to g_main_loop_quit() to - * exit the main loop, and g_main_loop_run() returns. - * - * It is possible to create new instances of #GMainLoop recursively. - * This is often used in GTK+ applications when showing modal dialog - * boxes. Note that event sources are associated with a particular - * #GMainContext, and will be checked and dispatched for all main - * loops associated with that GMainContext. - * - * GTK+ contains wrappers of some of these functions, e.g. gtk_main(), - * gtk_main_quit() and gtk_events_pending(). - * - * ## Creating new source types - * - * One of the unusual features of the #GMainLoop functionality - * is that new types of event source can be created and used in - * addition to the builtin type of event source. A new event source - * type is used for handling GDK events. A new source type is created - * by "deriving" from the #GSource structure. The derived type of - * source is represented by a structure that has the #GSource structure - * as a first element, and other elements specific to the new source - * type. To create an instance of the new source type, call - * g_source_new() passing in the size of the derived structure and - * a table of functions. These #GSourceFuncs determine the behavior of - * the new source type. - * - * New source types basically interact with the main context - * in two ways. Their prepare function in #GSourceFuncs can set a timeout - * to determine the maximum amount of time that the main loop will sleep - * before checking the source again. In addition, or as well, the source - * can add file descriptors to the set that the main context checks using - * g_source_add_poll(). - * - * ## Customizing the main loop iteration - * - * Single iterations of a #GMainContext can be run with - * g_main_context_iteration(). In some cases, more detailed control - * of exactly how the details of the main loop work is desired, for - * instance, when integrating the #GMainLoop with an external main loop. - * In such cases, you can call the component functions of - * g_main_context_iteration() directly. These functions are - * g_main_context_prepare(), g_main_context_query(), - * g_main_context_check() and g_main_context_dispatch(). - * - * ## State of a Main Context # {#mainloop-states} - * - * The operation of these functions can best be seen in terms - * of a state diagram, as shown in this image. - * - * ![](mainloop-states.gif) - * - * On UNIX, the GLib mainloop is incompatible with fork(). Any program - * using the mainloop must either exec() or exit() from the child - * without returning to the mainloop. - * - * ## Memory management of sources # {#mainloop-memory-management} - * - * There are two options for memory management of the user data passed to a - * #GSource to be passed to its callback on invocation. This data is provided - * in calls to g_timeout_add(), g_timeout_add_full(), g_idle_add(), etc. and - * more generally, using g_source_set_callback(). This data is typically an - * object which ‘owns’ the timeout or idle callback, such as a widget or a - * network protocol implementation. In many cases, it is an error for the - * callback to be invoked after this owning object has been destroyed, as that - * results in use of freed memory. - * - * The first, and preferred, option is to store the source ID returned by - * functions such as g_timeout_add() or g_source_attach(), and explicitly - * remove that source from the main context using g_source_remove() when the - * owning object is finalized. This ensures that the callback can only be - * invoked while the object is still alive. - * - * The second option is to hold a strong reference to the object in the - * callback, and to release it in the callback’s #GDestroyNotify. This ensures - * that the object is kept alive until after the source is finalized, which is - * guaranteed to be after it is invoked for the final time. The #GDestroyNotify - * is another callback passed to the ‘full’ variants of #GSource functions (for - * example, g_timeout_add_full()). It is called when the source is finalized, - * and is designed for releasing references like this. - * - * One important caveat of this second approach is that it will keep the object - * alive indefinitely if the main loop is stopped before the #GSource is - * invoked, which may be undesirable. - */ - - -/** - * SECTION:markup - * @Title: Simple XML Subset Parser - * @Short_description: parses a subset of XML - * @See_also: [XML Specification](http://www.w3.org/TR/REC-xml/) - * - * The "GMarkup" parser is intended to parse a simple markup format - * that's a subset of XML. This is a small, efficient, easy-to-use - * parser. It should not be used if you expect to interoperate with - * other applications generating full-scale XML, and must not be used if you - * expect to parse untrusted input. However, it's very - * useful for application data files, config files, etc. where you - * know your application will be the only one writing the file. - * Full-scale XML parsers should be able to parse the subset used by - * GMarkup, so you can easily migrate to full-scale XML at a later - * time if the need arises. - * - * GMarkup is not guaranteed to signal an error on all invalid XML; - * the parser may accept documents that an XML parser would not. - * However, XML documents which are not well-formed (which is a - * weaker condition than being valid. See the - * [XML specification](http://www.w3.org/TR/REC-xml/) - * for definitions of these terms.) are not considered valid GMarkup - * documents. - * - * Simplifications to XML include: - * - * - Only UTF-8 encoding is allowed - * - * - No user-defined entities - * - * - Processing instructions, comments and the doctype declaration - * are "passed through" but are not interpreted in any way - * - * - No DTD or validation - * - * The markup format does support: - * - * - Elements - * - * - Attributes - * - * - 5 standard entities: & < > " ' - * - * - Character references - * - * - Sections marked as CDATA - */ - - -/** - * SECTION:memory - * @Short_Description: general memory-handling - * @Title: Memory Allocation - * - * These functions provide support for allocating and freeing memory. - * - * If any call to allocate memory using functions g_new(), g_new0(), g_renew(), - * g_malloc(), g_malloc0(), g_malloc0_n(), g_realloc(), and g_realloc_n() - * fails, the application is terminated. This also means that there is no - * need to check if the call succeeded. On the other hand, the `g_try_...()` family - * of functions returns %NULL on failure that can be used as a check - * for unsuccessful memory allocation. The application is not terminated - * in this case. - * - * As all GLib functions and data structures use `g_malloc()` internally, unless - * otherwise specified, any allocation failure will result in the application - * being terminated. - * - * It's important to match g_malloc() (and wrappers such as g_new()) with - * g_free(), g_slice_alloc() (and wrappers such as g_slice_new()) with - * g_slice_free(), plain malloc() with free(), and (if you're using C++) - * new with delete and new[] with delete[]. Otherwise bad things can happen, - * since these allocators may use different memory pools (and new/delete call - * constructors and destructors). - * - * Since GLib 2.46 g_malloc() is hardcoded to always use the system malloc - * implementation. - */ - - -/** - * SECTION:memory_slices - * @title: Memory Slices - * @short_description: efficient way to allocate groups of equal-sized - * chunks of memory - * - * Memory slices provide a space-efficient and multi-processing scalable - * way to allocate equal-sized pieces of memory, just like the original - * #GMemChunks (from GLib 2.8), while avoiding their excessive - * memory-waste, scalability and performance problems. - * - * To achieve these goals, the slice allocator uses a sophisticated, - * layered design that has been inspired by Bonwick's slab allocator - * ([Bonwick94](http://citeseer.ist.psu.edu/bonwick94slab.html) - * Jeff Bonwick, The slab allocator: An object-caching kernel - * memory allocator. USENIX 1994, and - * [Bonwick01](http://citeseer.ist.psu.edu/bonwick01magazines.html) - * Bonwick and Jonathan Adams, Magazines and vmem: Extending the - * slab allocator to many cpu's and arbitrary resources. USENIX 2001) - * - * It uses posix_memalign() to optimize allocations of many equally-sized - * chunks, and has per-thread free lists (the so-called magazine layer) - * to quickly satisfy allocation requests of already known structure sizes. - * This is accompanied by extra caching logic to keep freed memory around - * for some time before returning it to the system. Memory that is unused - * due to alignment constraints is used for cache colorization (random - * distribution of chunk addresses) to improve CPU cache utilization. The - * caching layer of the slice allocator adapts itself to high lock contention - * to improve scalability. - * - * The slice allocator can allocate blocks as small as two pointers, and - * unlike malloc(), it does not reserve extra space per block. For large block - * sizes, g_slice_new() and g_slice_alloc() will automatically delegate to the - * system malloc() implementation. For newly written code it is recommended - * to use the new `g_slice` API instead of g_malloc() and - * friends, as long as objects are not resized during their lifetime and the - * object size used at allocation time is still available when freeing. - * - * Here is an example for using the slice allocator: - * |[<!-- language="C" --> - * gchar *mem[10000]; - * gint i; - * - * // Allocate 10000 blocks. - * for (i = 0; i < 10000; i++) - * { - * mem[i] = g_slice_alloc (50); - * - * // Fill in the memory with some junk. - * for (j = 0; j < 50; j++) - * mem[i][j] = i * j; - * } - * - * // Now free all of the blocks. - * for (i = 0; i < 10000; i++) - * g_slice_free1 (50, mem[i]); - * ]| - * - * And here is an example for using the using the slice allocator - * with data structures: - * |[<!-- language="C" --> - * GRealArray *array; - * - * // Allocate one block, using the g_slice_new() macro. - * array = g_slice_new (GRealArray); - * - * // We can now use array just like a normal pointer to a structure. - * array->data = NULL; - * array->len = 0; - * array->alloc = 0; - * array->zero_terminated = (zero_terminated ? 1 : 0); - * array->clear = (clear ? 1 : 0); - * array->elt_size = elt_size; - * - * // We can free the block, so it can be reused. - * g_slice_free (GRealArray, array); - * ]| - */ - - -/** - * SECTION:messages - * @Title: Message Output and Debugging Functions - * @Short_description: functions to output messages and help debug applications - * - * These functions provide support for outputting messages. - * - * The g_return family of macros (g_return_if_fail(), - * g_return_val_if_fail(), g_return_if_reached(), - * g_return_val_if_reached()) should only be used for programming - * errors, a typical use case is checking for invalid parameters at - * the beginning of a public function. They should not be used if - * you just mean "if (error) return", they should only be used if - * you mean "if (bug in program) return". The program behavior is - * generally considered undefined after one of these checks fails. - * They are not intended for normal control flow, only to give a - * perhaps-helpful warning before giving up. - * - * Structured logging output is supported using g_log_structured(). This differs - * from the traditional g_log() API in that log messages are handled as a - * collection of key–value pairs representing individual pieces of information, - * rather than as a single string containing all the information in an arbitrary - * format. - * - * The convenience macros g_info(), g_message(), g_debug(), g_warning() and g_error() - * will use the traditional g_log() API unless you define the symbol - * %G_LOG_USE_STRUCTURED before including `glib.h`. But note that even messages - * logged through the traditional g_log() API are ultimatively passed to - * g_log_structured(), so that all log messages end up in same destination. - * If %G_LOG_USE_STRUCTURED is defined, g_test_expect_message() will become - * ineffective for the wrapper macros g_warning() and friends (see - * [Testing for Messages][testing-for-messages]). - * - * The support for structured logging was motivated by the following needs (some - * of which were supported previously; others weren’t): - * * Support for multiple logging levels. - * * Structured log support with the ability to add `MESSAGE_ID`s (see - * g_log_structured()). - * * Moving the responsibility for filtering log messages from the program to - * the log viewer — instead of libraries and programs installing log handlers - * (with g_log_set_handler()) which filter messages before output, all log - * messages are outputted, and the log viewer program (such as `journalctl`) - * must filter them. This is based on the idea that bugs are sometimes hard - * to reproduce, so it is better to log everything possible and then use - * tools to analyse the logs than it is to not be able to reproduce a bug to - * get additional log data. Code which uses logging in performance-critical - * sections should compile out the g_log_structured() calls in - * release builds, and compile them in in debugging builds. - * * A single writer function which handles all log messages in a process, from - * all libraries and program code; rather than multiple log handlers with - * poorly defined interactions between them. This allows a program to easily - * change its logging policy by changing the writer function, for example to - * log to an additional location or to change what logging output fallbacks - * are used. The log writer functions provided by GLib are exposed publicly - * so they can be used from programs’ log writers. This allows log writer - * policy and implementation to be kept separate. - * * If a library wants to add standard information to all of its log messages - * (such as library state) or to redact private data (such as passwords or - * network credentials), it should use a wrapper function around its - * g_log_structured() calls or implement that in the single log writer - * function. - * * If a program wants to pass context data from a g_log_structured() call to - * its log writer function so that, for example, it can use the correct - * server connection to submit logs to, that user data can be passed as a - * zero-length #GLogField to g_log_structured_array(). - * * Color output needed to be supported on the terminal, to make reading - * through logs easier. - * - * ## Using Structured Logging ## {#using-structured-logging} - * - * To use structured logging (rather than the old-style logging), either use - * the g_log_structured() and g_log_structured_array() functions; or define - * `G_LOG_USE_STRUCTURED` before including any GLib header, and use the - * g_message(), g_debug(), g_error() (etc.) macros. - * - * You do not need to define `G_LOG_USE_STRUCTURED` to use g_log_structured(), - * but it is a good idea to avoid confusion. - * - * ## Log Domains ## {#log-domains} - * - * Log domains may be used to broadly split up the origins of log messages. - * Typically, there are one or a few log domains per application or library. - * %G_LOG_DOMAIN should be used to define the default log domain for the current - * compilation unit — it is typically defined at the top of a source file, or in - * the preprocessor flags for a group of source files. - * - * Log domains must be unique, and it is recommended that they are the - * application or library name, optionally followed by a hyphen and a sub-domain - * name. For example, `bloatpad` or `bloatpad-io`. - * - * ## Debug Message Output ## {#debug-message-output} - * - * The default log functions (g_log_default_handler() for the old-style API and - * g_log_writer_default() for the structured API) both drop debug and - * informational messages by default, unless the log domains of those messages - * are listed in the `G_MESSAGES_DEBUG` environment variable (or it is set to - * `all`). - * - * It is recommended that custom log writer functions re-use the - * `G_MESSAGES_DEBUG` environment variable, rather than inventing a custom one, - * so that developers can re-use the same debugging techniques and tools across - * projects. Since GLib 2.68, this can be implemented by dropping messages - * for which g_log_writer_default_would_drop() returns %TRUE. - * - * ## Testing for Messages ## {#testing-for-messages} - * - * With the old g_log() API, g_test_expect_message() and - * g_test_assert_expected_messages() could be used in simple cases to check - * whether some code under test had emitted a given log message. These - * functions have been deprecated with the structured logging API, for several - * reasons: - * * They relied on an internal queue which was too inflexible for many use - * cases, where messages might be emitted in several orders, some - * messages might not be emitted deterministically, or messages might be - * emitted by unrelated log domains. - * * They do not support structured log fields. - * * Examining the log output of code is a bad approach to testing it, and - * while it might be necessary for legacy code which uses g_log(), it should - * be avoided for new code using g_log_structured(). - * - * They will continue to work as before if g_log() is in use (and - * %G_LOG_USE_STRUCTURED is not defined). They will do nothing if used with the - * structured logging API. - * - * Examining the log output of code is discouraged: libraries should not emit to - * `stderr` during defined behaviour, and hence this should not be tested. If - * the log emissions of a library during undefined behaviour need to be tested, - * they should be limited to asserting that the library aborts and prints a - * suitable error message before aborting. This should be done with - * g_test_trap_assert_stderr(). - * - * If it is really necessary to test the structured log messages emitted by a - * particular piece of code – and the code cannot be restructured to be more - * suitable to more conventional unit testing – you should write a custom log - * writer function (see g_log_set_writer_func()) which appends all log messages - * to a queue. When you want to check the log messages, examine and clear the - * queue, ignoring irrelevant log messages (for example, from log domains other - * than the one under test). - */ - - -/** - * SECTION:misc_utils - * @title: Miscellaneous Utility Functions - * @short_description: a selection of portable utility functions - * - * These are portable utility functions. - */ - - -/** - * SECTION:numerical - * @title: Numerical Definitions - * @short_description: mathematical constants, and floating point decomposition - * - * GLib offers mathematical constants such as #G_PI for the value of pi; - * many platforms have these in the C library, but some don't, the GLib - * versions always exist. - * - * The #GFloatIEEE754 and #GDoubleIEEE754 unions are used to access the - * sign, mantissa and exponent of IEEE floats and doubles. These unions are - * defined as appropriate for a given platform. IEEE floats and doubles are - * supported (used for storage) by at least Intel, PPC and Sparc. See - * [IEEE 754-2008](http://en.wikipedia.org/wiki/IEEE_float) - * for more information about IEEE number formats. - */ - - -/** - * SECTION:option - * @Short_description: parses commandline options - * @Title: Commandline option parser - * - * The GOption commandline parser is intended to be a simpler replacement - * for the popt library. It supports short and long commandline options, - * as shown in the following example: - * - * `testtreemodel -r 1 --max-size 20 --rand --display=:1.0 -vb -- file1 file2` - * - * The example demonstrates a number of features of the GOption - * commandline parser: - * - * - Options can be single letters, prefixed by a single dash. - * - * - Multiple short options can be grouped behind a single dash. - * - * - Long options are prefixed by two consecutive dashes. - * - * - Options can have an extra argument, which can be a number, a string or - * a filename. For long options, the extra argument can be appended with - * an equals sign after the option name, which is useful if the extra - * argument starts with a dash, which would otherwise cause it to be - * interpreted as another option. - * - * - Non-option arguments are returned to the application as rest arguments. - * - * - An argument consisting solely of two dashes turns off further parsing, - * any remaining arguments (even those starting with a dash) are returned - * to the application as rest arguments. - * - * Another important feature of GOption is that it can automatically - * generate nicely formatted help output. Unless it is explicitly turned - * off with g_option_context_set_help_enabled(), GOption will recognize - * the `--help`, `-?`, `--help-all` and `--help-groupname` options - * (where `groupname` is the name of a #GOptionGroup) and write a text - * similar to the one shown in the following example to stdout. - * - * |[ - * Usage: - * testtreemodel [OPTION...] - test tree model performance - * - * Help Options: - * -h, --help Show help options - * --help-all Show all help options - * --help-gtk Show GTK+ Options - * - * Application Options: - * -r, --repeats=N Average over N repetitions - * -m, --max-size=M Test up to 2^M items - * --display=DISPLAY X display to use - * -v, --verbose Be verbose - * -b, --beep Beep when done - * --rand Randomize the data - * ]| - * - * GOption groups options in #GOptionGroups, which makes it easy to - * incorporate options from multiple sources. The intended use for this is - * to let applications collect option groups from the libraries it uses, - * add them to their #GOptionContext, and parse all options by a single call - * to g_option_context_parse(). See gtk_get_option_group() for an example. - * - * If an option is declared to be of type string or filename, GOption takes - * care of converting it to the right encoding; strings are returned in - * UTF-8, filenames are returned in the GLib filename encoding. Note that - * this only works if setlocale() has been called before - * g_option_context_parse(). - * - * Here is a complete example of setting up GOption to parse the example - * commandline above and produce the example help output. - * |[<!-- language="C" --> - * static gint repeats = 2; - * static gint max_size = 8; - * static gboolean verbose = FALSE; - * static gboolean beep = FALSE; - * static gboolean randomize = FALSE; - * - * static GOptionEntry entries[] = - * { - * { "repeats", 'r', 0, G_OPTION_ARG_INT, &repeats, "Average over N repetitions", "N" }, - * { "max-size", 'm', 0, G_OPTION_ARG_INT, &max_size, "Test up to 2^M items", "M" }, - * { "verbose", 'v', 0, G_OPTION_ARG_NONE, &verbose, "Be verbose", NULL }, - * { "beep", 'b', 0, G_OPTION_ARG_NONE, &beep, "Beep when done", NULL }, - * { "rand", 0, 0, G_OPTION_ARG_NONE, &randomize, "Randomize the data", NULL }, - * G_OPTION_ENTRY_NULL - * }; - * - * int - * main (int argc, char *argv[]) - * { - * GError *error = NULL; - * GOptionContext *context; - * - * context = g_option_context_new ("- test tree model performance"); - * g_option_context_add_main_entries (context, entries, GETTEXT_PACKAGE); - * g_option_context_add_group (context, gtk_get_option_group (TRUE)); - * if (!g_option_context_parse (context, &argc, &argv, &error)) - * { - * g_print ("option parsing failed: %s\n", error->message); - * exit (1); - * } - * - * ... - * - * } - * ]| - * - * On UNIX systems, the argv that is passed to main() has no particular - * encoding, even to the extent that different parts of it may have - * different encodings. In general, normal arguments and flags will be - * in the current locale and filenames should be considered to be opaque - * byte strings. Proper use of %G_OPTION_ARG_FILENAME vs - * %G_OPTION_ARG_STRING is therefore important. - * - * Note that on Windows, filenames do have an encoding, but using - * #GOptionContext with the argv as passed to main() will result in a - * program that can only accept commandline arguments with characters - * from the system codepage. This can cause problems when attempting to - * deal with filenames containing Unicode characters that fall outside - * of the codepage. - * - * A solution to this is to use g_win32_get_command_line() and - * g_option_context_parse_strv() which will properly handle full Unicode - * filenames. If you are using #GApplication, this is done - * automatically for you. - * - * The following example shows how you can use #GOptionContext directly - * in order to correctly deal with Unicode filenames on Windows: - * - * |[<!-- language="C" --> - * int - * main (int argc, char **argv) - * { - * GError *error = NULL; - * GOptionContext *context; - * gchar **args; - * - * #ifdef G_OS_WIN32 - * args = g_win32_get_command_line (); - * #else - * args = g_strdupv (argv); - * #endif - * - * // set up context - * - * if (!g_option_context_parse_strv (context, &args, &error)) - * { - * // error happened - * } - * - * ... - * - * g_strfreev (args); - * - * ... - * } - * ]| - */ - - -/** - * SECTION:patterns - * @title: Glob-style pattern matching - * @short_description: matches strings against patterns containing '*' - * (wildcard) and '?' (joker) - * - * The g_pattern_match* functions match a string - * against a pattern containing '*' and '?' wildcards with similar - * semantics as the standard glob() function: '*' matches an arbitrary, - * possibly empty, string, '?' matches an arbitrary character. - * - * Note that in contrast to glob(), the '/' character can be matched by - * the wildcards, there are no '[...]' character ranges and '*' and '?' - * can not be escaped to include them literally in a pattern. - * - * When multiple strings must be matched against the same pattern, it - * is better to compile the pattern to a #GPatternSpec using - * g_pattern_spec_new() and use g_pattern_match_string() instead of - * g_pattern_match_simple(). This avoids the overhead of repeated - * pattern compilation. - */ - - -/** - * SECTION:quarks - * @title: Quarks - * @short_description: a 2-way association between a string and a - * unique integer identifier - * - * Quarks are associations between strings and integer identifiers. - * Given either the string or the #GQuark identifier it is possible to - * retrieve the other. - * - * Quarks are used for both [datasets][glib-Datasets] and - * [keyed data lists][glib-Keyed-Data-Lists]. - * - * To create a new quark from a string, use g_quark_from_string() or - * g_quark_from_static_string(). - * - * To find the string corresponding to a given #GQuark, use - * g_quark_to_string(). - * - * To find the #GQuark corresponding to a given string, use - * g_quark_try_string(). - * - * Another use for the string pool maintained for the quark functions - * is string interning, using g_intern_string() or - * g_intern_static_string(). An interned string is a canonical - * representation for a string. One important advantage of interned - * strings is that they can be compared for equality by a simple - * pointer comparison, rather than using strcmp(). - */ - - -/** - * SECTION:queue - * @Title: Double-ended Queues - * @Short_description: double-ended queue data structure - * - * The #GQueue structure and its associated functions provide a standard - * queue data structure. Internally, GQueue uses the same data structure - * as #GList to store elements with the same complexity over - * insertion/deletion (O(1)) and access/search (O(n)) operations. - * - * The data contained in each element can be either integer values, by - * using one of the [Type Conversion Macros][glib-Type-Conversion-Macros], - * or simply pointers to any type of data. - * - * As with all other GLib data structures, #GQueue is not thread-safe. - * For a thread-safe queue, use #GAsyncQueue. - * - * To create a new GQueue, use g_queue_new(). - * - * To initialize a statically-allocated GQueue, use #G_QUEUE_INIT or - * g_queue_init(). - * - * To add elements, use g_queue_push_head(), g_queue_push_head_link(), - * g_queue_push_tail() and g_queue_push_tail_link(). - * - * To remove elements, use g_queue_pop_head() and g_queue_pop_tail(). - * - * To free the entire queue, use g_queue_free(). - */ - - -/** - * SECTION:random_numbers - * @title: Random Numbers - * @short_description: pseudo-random number generator - * - * The following functions allow you to use a portable, fast and good - * pseudo-random number generator (PRNG). - * - * Do not use this API for cryptographic purposes such as key - * generation, nonces, salts or one-time pads. - * - * This PRNG is suitable for non-cryptographic use such as in games - * (shuffling a card deck, generating levels), generating data for - * a test suite, etc. If you need random data for cryptographic - * purposes, it is recommended to use platform-specific APIs such - * as `/dev/random` on UNIX, or CryptGenRandom() on Windows. - * - * GRand uses the Mersenne Twister PRNG, which was originally - * developed by Makoto Matsumoto and Takuji Nishimura. Further - * information can be found at - * [this page](http://www.math.sci.hiroshima-u.ac.jp/~m-mat/MT/emt.html). - * - * If you just need a random number, you simply call the g_random_* - * functions, which will create a globally used #GRand and use the - * according g_rand_* functions internally. Whenever you need a - * stream of reproducible random numbers, you better create a - * #GRand yourself and use the g_rand_* functions directly, which - * will also be slightly faster. Initializing a #GRand with a - * certain seed will produce exactly the same series of random - * numbers on all platforms. This can thus be used as a seed for - * e.g. games. - * - * The g_rand*_range functions will return high quality equally - * distributed random numbers, whereas for example the - * `(g_random_int()%max)` approach often - * doesn't yield equally distributed numbers. - * - * GLib changed the seeding algorithm for the pseudo-random number - * generator Mersenne Twister, as used by #GRand. This was necessary, - * because some seeds would yield very bad pseudo-random streams. - * Also the pseudo-random integers generated by g_rand*_int_range() - * will have a slightly better equal distribution with the new - * version of GLib. - * - * The original seeding and generation algorithms, as found in - * GLib 2.0.x, can be used instead of the new ones by setting the - * environment variable `G_RANDOM_VERSION` to the value of '2.0'. - * Use the GLib-2.0 algorithms only if you have sequences of numbers - * generated with Glib-2.0 that you need to reproduce exactly. - */ - - -/** - * SECTION:rcbox - * @Title: Reference counted data - * @Short_description: Allocated memory with reference counting semantics - * - * A "reference counted box", or "RcBox", is an opaque wrapper data type - * that is guaranteed to be as big as the size of a given data type, and - * which augments the given data type with reference counting semantics - * for its memory management. - * - * RcBox is useful if you have a plain old data type, like a structure - * typically placed on the stack, and you wish to provide additional API - * to use it on the heap; or if you want to implement a new type to be - * passed around by reference without necessarily implementing copy/free - * semantics or your own reference counting. - * - * The typical use is: - * - * |[<!-- language="C" --> - * typedef struct { - * char *name; - * char *address; - * char *city; - * char *state; - * int age; - * } Person; - * - * Person * - * person_new (void) - * { - * return g_rc_box_new0 (Person); - * } - * ]| - * - * Every time you wish to acquire a reference on the memory, you should - * call g_rc_box_acquire(); similarly, when you wish to release a reference - * you should call g_rc_box_release(): - * - * |[<!-- language="C" --> - * // Add a Person to the Database; the Database acquires ownership - * // of the Person instance - * void - * add_person_to_database (Database *db, Person *p) - * { - * db->persons = g_list_prepend (db->persons, g_rc_box_acquire (p)); - * } - * - * // Removes a Person from the Database; the reference acquired by - * // add_person_to_database() is released here - * void - * remove_person_from_database (Database *db, Person *p) - * { - * db->persons = g_list_remove (db->persons, p); - * g_rc_box_release (p); - * } - * ]| - * - * If you have additional memory allocated inside the structure, you can - * use g_rc_box_release_full(), which takes a function pointer, which - * will be called if the reference released was the last: - * - * |[<!-- language="C" --> - * void - * person_clear (Person *p) - * { - * g_free (p->name); - * g_free (p->address); - * g_free (p->city); - * g_free (p->state); - * } - * - * void - * remove_person_from_database (Database *db, Person *p) - * { - * db->persons = g_list_remove (db->persons, p); - * g_rc_box_release_full (p, (GDestroyNotify) person_clear); - * } - * ]| - * - * If you wish to transfer the ownership of a reference counted data - * type without increasing the reference count, you can use g_steal_pointer(): - * - * |[<!-- language="C" --> - * Person *p = g_rc_box_new (Person); - * - * // fill_person_details() is defined elsewhere - * fill_person_details (p); - * - * // add_person_to_database_no_ref() is defined elsewhere; it adds - * // a Person to the Database without taking a reference - * add_person_to_database_no_ref (db, g_steal_pointer (&p)); - * ]| - * - * ## Thread safety - * - * The reference counting operations on data allocated using g_rc_box_alloc(), - * g_rc_box_new(), and g_rc_box_dup() are not thread safe; it is your code's - * responsibility to ensure that references are acquired are released on the - * same thread. - * - * If you need thread safe reference counting, see the [atomic reference counted - * data][arcbox] API. - * - * ## Automatic pointer clean up - * - * If you want to add g_autoptr() support to your plain old data type through - * reference counting, you can use the G_DEFINE_AUTOPTR_CLEANUP_FUNC() and - * g_rc_box_release(): - * - * |[<!-- language="C" --> - * G_DEFINE_AUTOPTR_CLEANUP_FUNC (MyDataStruct, g_rc_box_release) - * ]| - * - * If you need to clear the contents of the data, you will need to use an - * ancillary function that calls g_rc_box_release_full(): - * - * |[<!-- language="C" --> - * static void - * my_data_struct_release (MyDataStruct *data) - * { - * // my_data_struct_clear() is defined elsewhere - * g_rc_box_release_full (data, (GDestroyNotify) my_data_struct_clear); - * } - * - * G_DEFINE_AUTOPTR_CLEANUP_FUNC (MyDataStruct, my_data_struct_release) - * ]| - * - * Since: 2.58 - */ - - -/** - * SECTION:refcount - * @Title: Reference counting - * @Short_description: Reference counting types and functions - * - * Reference counting is a garbage collection mechanism that is based on - * assigning a counter to a data type, or any memory area; the counter is - * increased whenever a new reference to that data type is acquired, and - * decreased whenever the reference is released. Once the last reference - * is released, the resources associated to that data type are freed. - * - * GLib uses reference counting in many of its data types, and provides - * the #grefcount and #gatomicrefcount types to implement safe and atomic - * reference counting semantics in new data types. - * - * It is important to note that #grefcount and #gatomicrefcount should be - * considered completely opaque types; you should always use the provided - * API to increase and decrease the counters, and you should never check - * their content directly, or compare their content with other values. - * - * Since: 2.58 - */ - - -/** - * SECTION:refstring - * @Title: Reference counted strings - * @Short_description: Strings with reference counted memory management - * - * Reference counted strings are normal C strings that have been augmented - * with a reference counter to manage their resources. You allocate a new - * reference counted string and acquire and release references as needed, - * instead of copying the string among callers; when the last reference on - * the string is released, the resources allocated for it are freed. - * - * Typically, reference counted strings can be used when parsing data from - * files and storing them into data structures that are passed to various - * callers: - * - * |[<!-- language="C" --> - * PersonDetails * - * person_details_from_data (const char *data) - * { - * // Use g_autoptr() to simplify error cases - * g_autoptr(GRefString) full_name = NULL; - * g_autoptr(GRefString) address = NULL; - * g_autoptr(GRefString) city = NULL; - * g_autoptr(GRefString) state = NULL; - * g_autoptr(GRefString) zip_code = NULL; - * - * // parse_person_details() is defined elsewhere; returns refcounted strings - * if (!parse_person_details (data, &full_name, &address, &city, &state, &zip_code)) - * return NULL; - * - * if (!validate_zip_code (zip_code)) - * return NULL; - * - * // add_address_to_cache() and add_full_name_to_cache() are defined - * // elsewhere; they add strings to various caches, using refcounted - * // strings to avoid copying data over and over again - * add_address_to_cache (address, city, state, zip_code); - * add_full_name_to_cache (full_name); - * - * // person_details_new() is defined elsewhere; it takes a reference - * // on each string - * PersonDetails *res = person_details_new (full_name, - * address, - * city, - * state, - * zip_code); - * - * return res; - * } - * ]| - * - * In the example above, we have multiple functions taking the same strings - * for different uses; with typical C strings, we'd have to copy the strings - * every time the life time rules of the data differ from the life time of - * the string parsed from the original buffer. With reference counted strings, - * each caller can take a reference on the data, and keep it as long as it - * needs to own the string. - * - * Reference counted strings can also be "interned" inside a global table - * owned by GLib; while an interned string has at least a reference, creating - * a new interned reference counted string with the same contents will return - * a reference to the existing string instead of creating a new reference - * counted string instance. Once the string loses its last reference, it will - * be automatically removed from the global interned strings table. - * - * Since: 2.58 - */ - - -/** - * SECTION:scanner - * @title: Lexical Scanner - * @short_description: a general purpose lexical scanner - * - * The #GScanner and its associated functions provide a - * general purpose lexical scanner. - */ - - -/** - * SECTION:sequence - * @title: Sequences - * @short_description: scalable lists - * - * The #GSequence data structure has the API of a list, but is - * implemented internally with a balanced binary tree. This means that - * most of the operations (access, search, insertion, deletion, ...) on - * #GSequence are O(log(n)) in average and O(n) in worst case for time - * complexity. But, note that maintaining a balanced sorted list of n - * elements is done in time O(n log(n)). - * The data contained in each element can be either integer values, by using - * of the [Type Conversion Macros][glib-Type-Conversion-Macros], or simply - * pointers to any type of data. - * - * A #GSequence is accessed through "iterators", represented by a - * #GSequenceIter. An iterator represents a position between two - * elements of the sequence. For example, the "begin" iterator - * represents the gap immediately before the first element of the - * sequence, and the "end" iterator represents the gap immediately - * after the last element. In an empty sequence, the begin and end - * iterators are the same. - * - * Some methods on #GSequence operate on ranges of items. For example - * g_sequence_foreach_range() will call a user-specified function on - * each element with the given range. The range is delimited by the - * gaps represented by the passed-in iterators, so if you pass in the - * begin and end iterators, the range in question is the entire - * sequence. - * - * The function g_sequence_get() is used with an iterator to access the - * element immediately following the gap that the iterator represents. - * The iterator is said to "point" to that element. - * - * Iterators are stable across most operations on a #GSequence. For - * example an iterator pointing to some element of a sequence will - * continue to point to that element even after the sequence is sorted. - * Even moving an element to another sequence using for example - * g_sequence_move_range() will not invalidate the iterators pointing - * to it. The only operation that will invalidate an iterator is when - * the element it points to is removed from any sequence. - * - * To sort the data, either use g_sequence_insert_sorted() or - * g_sequence_insert_sorted_iter() to add data to the #GSequence or, if - * you want to add a large amount of data, it is more efficient to call - * g_sequence_sort() or g_sequence_sort_iter() after doing unsorted - * insertions. - */ - - -/** - * SECTION:shell - * @title: Shell-related Utilities - * @short_description: shell-like commandline handling - * - * GLib provides the functions g_shell_quote() and g_shell_unquote() - * to handle shell-like quoting in strings. The function g_shell_parse_argv() - * parses a string similar to the way a POSIX shell (/bin/sh) would. - * - * Note that string handling in shells has many obscure and historical - * corner-cases which these functions do not necessarily reproduce. They - * are good enough in practice, though. - */ - - -/** - * SECTION:spawn - * @Short_description: process launching - * @Title: Spawning Processes - * - * GLib supports spawning of processes with an API that is more - * convenient than the bare UNIX fork() and exec(). - * - * The g_spawn family of functions has synchronous (g_spawn_sync()) - * and asynchronous variants (g_spawn_async(), g_spawn_async_with_pipes()), - * as well as convenience variants that take a complete shell-like - * commandline (g_spawn_command_line_sync(), g_spawn_command_line_async()). - * - * See #GSubprocess in GIO for a higher-level API that provides - * stream interfaces for communication with child processes. - * - * An example of using g_spawn_async_with_pipes(): - * |[<!-- language="C" --> - * const gchar * const argv[] = { "my-favourite-program", "--args", NULL }; - * gint child_stdout, child_stderr; - * GPid child_pid; - * g_autoptr(GError) error = NULL; - * - * // Spawn child process. - * g_spawn_async_with_pipes (NULL, argv, NULL, G_SPAWN_DO_NOT_REAP_CHILD, NULL, - * NULL, &child_pid, NULL, &child_stdout, - * &child_stderr, &error); - * if (error != NULL) - * { - * g_error ("Spawning child failed: %s", error->message); - * return; - * } - * - * // Add a child watch function which will be called when the child process - * // exits. - * g_child_watch_add (child_pid, child_watch_cb, NULL); - * - * // You could watch for output on @child_stdout and @child_stderr using - * // #GUnixInputStream or #GIOChannel here. - * - * static void - * child_watch_cb (GPid pid, - * gint status, - * gpointer user_data) - * { - * g_message ("Child %" G_PID_FORMAT " exited %s", pid, - * g_spawn_check_wait_status (status, NULL) ? "normally" : "abnormally"); - * - * // Free any resources associated with the child here, such as I/O channels - * // on its stdout and stderr FDs. If you have no code to put in the - * // child_watch_cb() callback, you can remove it and the g_child_watch_add() - * // call, but you must also remove the G_SPAWN_DO_NOT_REAP_CHILD flag, - * // otherwise the child process will stay around as a zombie until this - * // process exits. - * - * g_spawn_close_pid (pid); - * } - * ]| - */ - - -/** - * SECTION:string_chunks - * @title: String Chunks - * @short_description: efficient storage of groups of strings - * - * String chunks are used to store groups of strings. Memory is - * allocated in blocks, and as strings are added to the #GStringChunk - * they are copied into the next free position in a block. When a block - * is full a new block is allocated. - * - * When storing a large number of strings, string chunks are more - * efficient than using g_strdup() since fewer calls to malloc() are - * needed, and less memory is wasted in memory allocation overheads. - * - * By adding strings with g_string_chunk_insert_const() it is also - * possible to remove duplicates. - * - * To create a new #GStringChunk use g_string_chunk_new(). - * - * To add strings to a #GStringChunk use g_string_chunk_insert(). - * - * To add strings to a #GStringChunk, but without duplicating strings - * which are already in the #GStringChunk, use - * g_string_chunk_insert_const(). - * - * To free the entire #GStringChunk use g_string_chunk_free(). It is - * not possible to free individual strings. - */ - - -/** - * SECTION:string_utils - * @title: String Utility Functions - * @short_description: various string-related functions - * - * This section describes a number of utility functions for creating, - * duplicating, and manipulating strings. - * - * Note that the functions g_printf(), g_fprintf(), g_sprintf(), - * g_vprintf(), g_vfprintf(), g_vsprintf() and g_vasprintf() - * are declared in the header `gprintf.h` which is not included in `glib.h` - * (otherwise using `glib.h` would drag in `stdio.h`), so you'll have to - * explicitly include `<glib/gprintf.h>` in order to use the GLib - * printf() functions. - * - * ## String precision pitfalls # {#string-precision} - * - * While you may use the printf() functions to format UTF-8 strings, - * notice that the precision of a \%Ns parameter is interpreted - * as the number of bytes, not characters to print. On top of that, - * the GNU libc implementation of the printf() functions has the - * "feature" that it checks that the string given for the \%Ns - * parameter consists of a whole number of characters in the current - * encoding. So, unless you are sure you are always going to be in an - * UTF-8 locale or your know your text is restricted to ASCII, avoid - * using \%Ns. If your intention is to format strings for a - * certain number of columns, then \%Ns is not a correct solution - * anyway, since it fails to take wide characters (see g_unichar_iswide()) - * into account. - * - * Note also that there are various printf() parameters which are platform - * dependent. GLib provides platform independent macros for these parameters - * which should be used instead. A common example is %G_GUINT64_FORMAT, which - * should be used instead of `%llu` or similar parameters for formatting - * 64-bit integers. These macros are all named `G_*_FORMAT`; see - * [Basic Types][glib-Basic-Types]. - */ - - -/** - * SECTION:strings - * @title: Strings - * @short_description: text buffers which grow automatically - * as text is added - * - * A #GString is an object that handles the memory management of a C - * string for you. The emphasis of #GString is on text, typically - * UTF-8. Crucially, the "str" member of a #GString is guaranteed to - * have a trailing nul character, and it is therefore always safe to - * call functions such as strchr() or g_strdup() on it. - * - * However, a #GString can also hold arbitrary binary data, because it - * has a "len" member, which includes any possible embedded nul - * characters in the data. Conceptually then, #GString is like a - * #GByteArray with the addition of many convenience methods for text, - * and a guaranteed nul terminator. - */ - - -/** - * SECTION:testing - * @title: Testing - * @short_description: a test framework - * - * GLib provides a framework for writing and maintaining unit tests - * in parallel to the code they are testing. The API is designed according - * to established concepts found in the other test frameworks (JUnit, NUnit, - * RUnit), which in turn is based on smalltalk unit testing concepts. - * - * - Test case: Tests (test methods) are grouped together with their - * fixture into test cases. - * - * - Fixture: A test fixture consists of fixture data and setup and - * teardown methods to establish the environment for the test - * functions. We use fresh fixtures, i.e. fixtures are newly set - * up and torn down around each test invocation to avoid dependencies - * between tests. - * - * - Test suite: Test cases can be grouped into test suites, to allow - * subsets of the available tests to be run. Test suites can be - * grouped into other test suites as well. - * - * The API is designed to handle creation and registration of test suites - * and test cases implicitly. A simple call like - * |[<!-- language="C" --> - * g_test_add_func ("/misc/assertions", test_assertions); - * ]| - * creates a test suite called "misc" with a single test case named - * "assertions", which consists of running the test_assertions function. - * - * In addition to the traditional g_assert_true(), the test framework provides - * an extended set of assertions for comparisons: g_assert_cmpfloat(), - * g_assert_cmpfloat_with_epsilon(), g_assert_cmpint(), g_assert_cmpuint(), - * g_assert_cmphex(), g_assert_cmpstr(), g_assert_cmpmem() and - * g_assert_cmpvariant(). The - * advantage of these variants over plain g_assert_true() is that the assertion - * messages can be more elaborate, and include the values of the compared - * entities. - * - * Note that g_assert() should not be used in unit tests, since it is a no-op - * when compiling with `G_DISABLE_ASSERT`. Use g_assert() in production code, - * and g_assert_true() in unit tests. - * - * A full example of creating a test suite with two tests using fixtures: - * |[<!-- language="C" --> - * #include <glib.h> - * #include <locale.h> - * - * typedef struct { - * MyObject *obj; - * OtherObject *helper; - * } MyObjectFixture; - * - * static void - * my_object_fixture_set_up (MyObjectFixture *fixture, - * gconstpointer user_data) - * { - * fixture->obj = my_object_new (); - * my_object_set_prop1 (fixture->obj, "some-value"); - * my_object_do_some_complex_setup (fixture->obj, user_data); - * - * fixture->helper = other_object_new (); - * } - * - * static void - * my_object_fixture_tear_down (MyObjectFixture *fixture, - * gconstpointer user_data) - * { - * g_clear_object (&fixture->helper); - * g_clear_object (&fixture->obj); - * } - * - * static void - * test_my_object_test1 (MyObjectFixture *fixture, - * gconstpointer user_data) - * { - * g_assert_cmpstr (my_object_get_property (fixture->obj), ==, "initial-value"); - * } - * - * static void - * test_my_object_test2 (MyObjectFixture *fixture, - * gconstpointer user_data) - * { - * my_object_do_some_work_using_helper (fixture->obj, fixture->helper); - * g_assert_cmpstr (my_object_get_property (fixture->obj), ==, "updated-value"); - * } - * - * int - * main (int argc, char *argv[]) - * { - * setlocale (LC_ALL, ""); - * - * g_test_init (&argc, &argv, NULL); - * - * // Define the tests. - * g_test_add ("/my-object/test1", MyObjectFixture, "some-user-data", - * my_object_fixture_set_up, test_my_object_test1, - * my_object_fixture_tear_down); - * g_test_add ("/my-object/test2", MyObjectFixture, "some-user-data", - * my_object_fixture_set_up, test_my_object_test2, - * my_object_fixture_tear_down); - * - * return g_test_run (); - * } - * ]| - * - * ### Integrating GTest in your project - * - * If you are using the [Meson](http://mesonbuild.com) build system, you will - * typically use the provided `test()` primitive to call the test binaries, - * e.g.: - * - * |[<!-- language="plain" --> - * test( - * 'foo', - * executable('foo', 'foo.c', dependencies: deps), - * env: [ - * 'G_TEST_SRCDIR=@0@'.format(meson.current_source_dir()), - * 'G_TEST_BUILDDIR=@0@'.format(meson.current_build_dir()), - * ], - * ) - * - * test( - * 'bar', - * executable('bar', 'bar.c', dependencies: deps), - * env: [ - * 'G_TEST_SRCDIR=@0@'.format(meson.current_source_dir()), - * 'G_TEST_BUILDDIR=@0@'.format(meson.current_build_dir()), - * ], - * ) - * ]| - * - * If you are using Autotools, you're strongly encouraged to use the Automake - * [TAP](https://testanything.org/) harness; GLib provides template files for - * easily integrating with it: - * - * - [glib-tap.mk](https://gitlab.gnome.org/GNOME/glib/blob/glib-2-58/glib-tap.mk) - * - [tap-test](https://gitlab.gnome.org/GNOME/glib/blob/glib-2-58/tap-test) - * - [tap-driver.sh](https://gitlab.gnome.org/GNOME/glib/blob/glib-2-58/tap-driver.sh) - * - * You can copy these files in your own project's root directory, and then - * set up your `Makefile.am` file to reference them, for instance: - * - * |[<!-- language="plain" --> - * include $(top_srcdir)/glib-tap.mk - * - * # test binaries - * test_programs = \ - * foo \ - * bar - * - * # data distributed in the tarball - * dist_test_data = \ - * foo.data.txt \ - * bar.data.txt - * - * # data not distributed in the tarball - * test_data = \ - * blah.data.txt - * ]| - * - * Make sure to distribute the TAP files, using something like the following - * in your top-level `Makefile.am`: - * - * |[<!-- language="plain" --> - * EXTRA_DIST += \ - * tap-driver.sh \ - * tap-test - * ]| - * - * `glib-tap.mk` will be distributed implicitly due to being included in a - * `Makefile.am`. All three files should be added to version control. - * - * If you don't have access to the Autotools TAP harness, you can use the - * [gtester][gtester] and [gtester-report][gtester-report] tools, and use - * the [glib.mk](https://gitlab.gnome.org/GNOME/glib/blob/glib-2-58/glib.mk) - * Automake template provided by GLib. Note, however, that since GLib 2.62, - * [gtester][gtester] and [gtester-report][gtester-report] have been deprecated - * in favour of using TAP. The `--tap` argument to tests is enabled by default - * as of GLib 2.62. - */ - - -/** - * SECTION:thread_pools - * @title: Thread Pools - * @short_description: pools of threads to execute work concurrently - * @see_also: #GThread - * - * Sometimes you wish to asynchronously fork out the execution of work - * and continue working in your own thread. If that will happen often, - * the overhead of starting and destroying a thread each time might be - * too high. In such cases reusing already started threads seems like a - * good idea. And it indeed is, but implementing this can be tedious - * and error-prone. - * - * Therefore GLib provides thread pools for your convenience. An added - * advantage is, that the threads can be shared between the different - * subsystems of your program, when they are using GLib. - * - * To create a new thread pool, you use g_thread_pool_new(). - * It is destroyed by g_thread_pool_free(). - * - * If you want to execute a certain task within a thread pool, - * you call g_thread_pool_push(). - * - * To get the current number of running threads you call - * g_thread_pool_get_num_threads(). To get the number of still - * unprocessed tasks you call g_thread_pool_unprocessed(). To control - * the maximal number of threads for a thread pool, you use - * g_thread_pool_get_max_threads() and g_thread_pool_set_max_threads(). - * - * Finally you can control the number of unused threads, that are kept - * alive by GLib for future use. The current number can be fetched with - * g_thread_pool_get_num_unused_threads(). The maximal number can be - * controlled by g_thread_pool_get_max_unused_threads() and - * g_thread_pool_set_max_unused_threads(). All currently unused threads - * can be stopped by calling g_thread_pool_stop_unused_threads(). - */ - - -/** - * SECTION:threads - * @title: Threads - * @short_description: portable support for threads, mutexes, locks, - * conditions and thread private data - * @see_also: #GThreadPool, #GAsyncQueue - * - * Threads act almost like processes, but unlike processes all threads - * of one process share the same memory. This is good, as it provides - * easy communication between the involved threads via this shared - * memory, and it is bad, because strange things (so called - * "Heisenbugs") might happen if the program is not carefully designed. - * In particular, due to the concurrent nature of threads, no - * assumptions on the order of execution of code running in different - * threads can be made, unless order is explicitly forced by the - * programmer through synchronization primitives. - * - * The aim of the thread-related functions in GLib is to provide a - * portable means for writing multi-threaded software. There are - * primitives for mutexes to protect the access to portions of memory - * (#GMutex, #GRecMutex and #GRWLock). There is a facility to use - * individual bits for locks (g_bit_lock()). There are primitives - * for condition variables to allow synchronization of threads (#GCond). - * There are primitives for thread-private data - data that every - * thread has a private instance of (#GPrivate). There are facilities - * for one-time initialization (#GOnce, g_once_init_enter()). Finally, - * there are primitives to create and manage threads (#GThread). - * - * The GLib threading system used to be initialized with g_thread_init(). - * This is no longer necessary. Since version 2.32, the GLib threading - * system is automatically initialized at the start of your program, - * and all thread-creation functions and synchronization primitives - * are available right away. - * - * Note that it is not safe to assume that your program has no threads - * even if you don't call g_thread_new() yourself. GLib and GIO can - * and will create threads for their own purposes in some cases, such - * as when using g_unix_signal_source_new() or when using GDBus. - * - * Originally, UNIX did not have threads, and therefore some traditional - * UNIX APIs are problematic in threaded programs. Some notable examples - * are - * - * - C library functions that return data in statically allocated - * buffers, such as strtok() or strerror(). For many of these, - * there are thread-safe variants with a _r suffix, or you can - * look at corresponding GLib APIs (like g_strsplit() or g_strerror()). - * - * - The functions setenv() and unsetenv() manipulate the process - * environment in a not thread-safe way, and may interfere with getenv() - * calls in other threads. Note that getenv() calls may be hidden behind - * other APIs. For example, GNU gettext() calls getenv() under the - * covers. In general, it is best to treat the environment as readonly. - * If you absolutely have to modify the environment, do it early in - * main(), when no other threads are around yet. - * - * - The setlocale() function changes the locale for the entire process, - * affecting all threads. Temporary changes to the locale are often made - * to change the behavior of string scanning or formatting functions - * like scanf() or printf(). GLib offers a number of string APIs - * (like g_ascii_formatd() or g_ascii_strtod()) that can often be - * used as an alternative. Or you can use the uselocale() function - * to change the locale only for the current thread. - * - * - The fork() function only takes the calling thread into the child's - * copy of the process image. If other threads were executing in critical - * sections they could have left mutexes locked which could easily - * cause deadlocks in the new child. For this reason, you should - * call exit() or exec() as soon as possible in the child and only - * make signal-safe library calls before that. - * - * - The daemon() function uses fork() in a way contrary to what is - * described above. It should not be used with GLib programs. - * - * GLib itself is internally completely thread-safe (all global data is - * automatically locked), but individual data structure instances are - * not automatically locked for performance reasons. For example, - * you must coordinate accesses to the same #GHashTable from multiple - * threads. The two notable exceptions from this rule are #GMainLoop - * and #GAsyncQueue, which are thread-safe and need no further - * application-level locking to be accessed from multiple threads. - * Most refcounting functions such as g_object_ref() are also thread-safe. - * - * A common use for #GThreads is to move a long-running blocking operation out - * of the main thread and into a worker thread. For GLib functions, such as - * single GIO operations, this is not necessary, and complicates the code. - * Instead, the `…_async()` version of the function should be used from the main - * thread, eliminating the need for locking and synchronisation between multiple - * threads. If an operation does need to be moved to a worker thread, consider - * using g_task_run_in_thread(), or a #GThreadPool. #GThreadPool is often a - * better choice than #GThread, as it handles thread reuse and task queueing; - * #GTask uses this internally. - * - * However, if multiple blocking operations need to be performed in sequence, - * and it is not possible to use #GTask for them, moving them to a worker thread - * can clarify the code. - */ - - -/** - * SECTION:timers - * @title: Timers - * @short_description: keep track of elapsed time - * - * #GTimer records a start time, and counts microseconds elapsed since - * that time. This is done somewhat differently on different platforms, - * and can be tricky to get exactly right, so #GTimer provides a - * portable/convenient interface. - */ - - -/** - * SECTION:timezone - * @title: GTimeZone - * @short_description: a structure representing a time zone - * @see_also: #GDateTime - * - * #GTimeZone is a structure that represents a time zone, at no - * particular point in time. It is refcounted and immutable. - * - * Each time zone has an identifier (for example, ‘Europe/London’) which is - * platform dependent. See g_time_zone_new() for information on the identifier - * formats. The identifier of a time zone can be retrieved using - * g_time_zone_get_identifier(). - * - * A time zone contains a number of intervals. Each interval has - * an abbreviation to describe it (for example, ‘PDT’), an offset to UTC and a - * flag indicating if the daylight savings time is in effect during that - * interval. A time zone always has at least one interval — interval 0. Note - * that interval abbreviations are not the same as time zone identifiers - * (apart from ‘UTC’), and cannot be passed to g_time_zone_new(). - * - * Every UTC time is contained within exactly one interval, but a given - * local time may be contained within zero, one or two intervals (due to - * incontinuities associated with daylight savings time). - * - * An interval may refer to a specific period of time (eg: the duration - * of daylight savings time during 2010) or it may refer to many periods - * of time that share the same properties (eg: all periods of daylight - * savings time). It is also possible (usually for political reasons) - * that some properties (like the abbreviation) change between intervals - * without other properties changing. - * - * #GTimeZone is available since GLib 2.26. - */ - - -/** - * SECTION:trash_stack - * @title: Trash Stacks - * @short_description: maintain a stack of unused allocated memory chunks - * - * A #GTrashStack is an efficient way to keep a stack of unused allocated - * memory chunks. Each memory chunk is required to be large enough to hold - * a #gpointer. This allows the stack to be maintained without any space - * overhead, since the stack pointers can be stored inside the memory chunks. - * - * There is no function to create a #GTrashStack. A %NULL #GTrashStack* - * is a perfectly valid empty stack. - * - * There is no longer any good reason to use #GTrashStack. If you have - * extra pieces of memory, free() them and allocate them again later. - * - * Deprecated: 2.48: #GTrashStack is deprecated without replacement - */ - - -/** - * SECTION:trees-binary - * @title: Balanced Binary Trees - * @short_description: a sorted collection of key/value pairs optimized - * for searching and traversing in order - * - * The #GTree structure and its associated functions provide a sorted - * collection of key/value pairs optimized for searching and traversing - * in order. This means that most of the operations (access, search, - * insertion, deletion, ...) on #GTree are O(log(n)) in average and O(n) - * in worst case for time complexity. But, note that maintaining a - * balanced sorted #GTree of n elements is done in time O(n log(n)). - * - * To create a new #GTree use g_tree_new(). - * - * To insert a key/value pair into a #GTree use g_tree_insert() - * (O(n log(n))). - * - * To remove a key/value pair use g_tree_remove() (O(n log(n))). - * - * To look up the value corresponding to a given key, use - * g_tree_lookup() and g_tree_lookup_extended(). - * - * To find out the number of nodes in a #GTree, use g_tree_nnodes(). To - * get the height of a #GTree, use g_tree_height(). - * - * To traverse a #GTree, calling a function for each node visited in - * the traversal, use g_tree_foreach(). - * - * To destroy a #GTree, use g_tree_destroy(). - */ - - -/** - * SECTION:trees-nary - * @title: N-ary Trees - * @short_description: trees of data with any number of branches - * - * The #GNode struct and its associated functions provide a N-ary tree - * data structure, where nodes in the tree can contain arbitrary data. - * - * To create a new tree use g_node_new(). - * - * To insert a node into a tree use g_node_insert(), - * g_node_insert_before(), g_node_append() and g_node_prepend(). - * - * To create a new node and insert it into a tree use - * g_node_insert_data(), g_node_insert_data_after(), - * g_node_insert_data_before(), g_node_append_data() - * and g_node_prepend_data(). - * - * To reverse the children of a node use g_node_reverse_children(). - * - * To find a node use g_node_get_root(), g_node_find(), - * g_node_find_child(), g_node_child_index(), g_node_child_position(), - * g_node_first_child(), g_node_last_child(), g_node_nth_child(), - * g_node_first_sibling(), g_node_prev_sibling(), g_node_next_sibling() - * or g_node_last_sibling(). - * - * To get information about a node or tree use G_NODE_IS_LEAF(), - * G_NODE_IS_ROOT(), g_node_depth(), g_node_n_nodes(), - * g_node_n_children(), g_node_is_ancestor() or g_node_max_height(). - * - * To traverse a tree, calling a function for each node visited in the - * traversal, use g_node_traverse() or g_node_children_foreach(). - * - * To remove a node or subtree from a tree use g_node_unlink() or - * g_node_destroy(). - */ - - -/** - * SECTION:type_conversion - * @title: Type Conversion Macros - * @short_description: portably storing integers in pointer variables - * - * Many times GLib, GTK+, and other libraries allow you to pass "user - * data" to a callback, in the form of a void pointer. From time to time - * you want to pass an integer instead of a pointer. You could allocate - * an integer, with something like: - * |[<!-- language="C" --> - * int *ip = g_new (int, 1); - * *ip = 42; - * ]| - * But this is inconvenient, and it's annoying to have to free the - * memory at some later time. - * - * Pointers are always at least 32 bits in size (on all platforms GLib - * intends to support). Thus you can store at least 32-bit integer values - * in a pointer value. Naively, you might try this, but it's incorrect: - * |[<!-- language="C" --> - * gpointer p; - * int i; - * p = (void*) 42; - * i = (int) p; - * ]| - * Again, that example was not correct, don't copy it. - * The problem is that on some systems you need to do this: - * |[<!-- language="C" --> - * gpointer p; - * int i; - * p = (void*) (long) 42; - * i = (int) (long) p; - * ]| - * The GLib macros GPOINTER_TO_INT(), GINT_TO_POINTER(), etc. take care - * to do the right thing on every platform. - * - * Warning: You may not store pointers in integers. This is not - * portable in any way, shape or form. These macros only allow storing - * integers in pointers, and only preserve 32 bits of the integer; values - * outside the range of a 32-bit integer will be mangled. - */ - - -/** - * SECTION:types - * @title: Basic Types - * @short_description: standard GLib types, defined for ease-of-use - * and portability - * - * GLib defines a number of commonly used types, which can be divided - * into several groups: - * - New types which are not part of standard C (but are defined in - * various C standard library header files) — #gboolean, #gssize. - * - Integer types which are guaranteed to be the same size across - * all platforms — #gint8, #guint8, #gint16, #guint16, #gint32, - * #guint32, #gint64, #guint64. - * - Types which are easier to use than their standard C counterparts - - * #gpointer, #gconstpointer, #guchar, #guint, #gushort, #gulong. - * - Types which correspond exactly to standard C types, but are - * included for completeness — #gchar, #gint, #gshort, #glong, - * #gfloat, #gdouble. - * - Types which correspond exactly to standard C99 types, but are available - * to use even if your compiler does not support C99 — #gsize, #goffset, - * #gintptr, #guintptr. - * - * GLib also defines macros for the limits of some of the standard - * integer and floating point types, as well as macros for suitable - * printf() formats for these types. - * - * Note that depending on the platform and build configuration, the format - * macros might not be compatible with the system provided printf() function, - * because GLib might use a different printf() implementation internally. - * The format macros will always work with GLib API (like g_print()), and with - * any C99 compatible printf() implementation. - */ - - -/** - * SECTION:unicode - * @Title: Unicode Manipulation - * @Short_description: functions operating on Unicode characters and - * UTF-8 strings - * @See_also: g_locale_to_utf8(), g_locale_from_utf8() - * - * This section describes a number of functions for dealing with - * Unicode characters and strings. There are analogues of the - * traditional `ctype.h` character classification and case conversion - * functions, UTF-8 analogues of some string utility functions, - * functions to perform normalization, case conversion and collation - * on UTF-8 strings and finally functions to convert between the UTF-8, - * UTF-16 and UCS-4 encodings of Unicode. - * - * The implementations of the Unicode functions in GLib are based - * on the Unicode Character Data tables, which are available from - * [www.unicode.org](http://www.unicode.org/). - * - * * Unicode 4.0 was added in GLib 2.8 - * * Unicode 4.1 was added in GLib 2.10 - * * Unicode 5.0 was added in GLib 2.12 - * * Unicode 5.1 was added in GLib 2.16.3 - * * Unicode 6.0 was added in GLib 2.30 - * * Unicode 6.1 was added in GLib 2.32 - * * Unicode 6.2 was added in GLib 2.36 - * * Unicode 6.3 was added in GLib 2.40 - * * Unicode 7.0 was added in GLib 2.42 - * * Unicode 8.0 was added in GLib 2.48 - * * Unicode 9.0 was added in GLib 2.50.1 - * * Unicode 10.0 was added in GLib 2.54 - * * Unicode 11.10 was added in GLib 2.58 - * * Unicode 12.0 was added in GLib 2.62 - * * Unicode 12.1 was added in GLib 2.62 - * * Unicode 13.0 was added in GLib 2.66 - */ - - -/** - * SECTION:uuid - * @title: GUuid - * @short_description: a universally unique identifier - * - * A UUID, or Universally unique identifier, is intended to uniquely - * identify information in a distributed environment. For the - * definition of UUID, see [RFC 4122](https://tools.ietf.org/html/rfc4122.html). - * - * The creation of UUIDs does not require a centralized authority. - * - * UUIDs are of relatively small size (128 bits, or 16 bytes). The - * common string representation (ex: - * 1d6c0810-2bd6-45f3-9890-0268422a6f14) needs 37 bytes. - * - * The UUID specification defines 5 versions, and calling - * g_uuid_string_random() will generate a unique (or rather random) - * UUID of the most common version, version 4. - * - * Since: 2.52 - */ - - -/** - * SECTION:version - * @Title: Version Information - * @Short_description: variables and functions to check the GLib version - * - * GLib provides version information, primarily useful in configure - * checks for builds that have a configure script. Applications will - * not typically use the features described here. - * - * The GLib headers annotate deprecated APIs in a way that produces - * compiler warnings if these deprecated APIs are used. The warnings - * can be turned off by defining the macro %GLIB_DISABLE_DEPRECATION_WARNINGS - * before including the glib.h header. - * - * GLib also provides support for building applications against - * defined subsets of deprecated or new GLib APIs. Define the macro - * %GLIB_VERSION_MIN_REQUIRED to specify up to what version of GLib - * you want to receive warnings about deprecated APIs. Define the - * macro %GLIB_VERSION_MAX_ALLOWED to specify the newest version of - * GLib whose API you want to use. - */ - - -/** - * SECTION:warnings - * @title: Warnings and Assertions - * @short_description: warnings and assertions to use in runtime code - * - * GLib defines several warning functions and assertions which can be used to - * warn of programmer errors when calling functions, and print error messages - * from command line programs. - * - * The g_return_if_fail(), g_return_val_if_fail(), g_return_if_reached() and - * g_return_val_if_reached() macros are intended as pre-condition assertions, to - * be used at the top of a public function to check that the function’s - * arguments are acceptable. Any failure of such a pre-condition assertion is - * considered a programming error on the part of the caller of the public API, - * and the program is considered to be in an undefined state afterwards. They - * are similar to the libc assert() function, but provide more context on - * failures. - * - * For example: - * |[<!-- language="C" --> - * gboolean - * g_dtls_connection_shutdown (GDtlsConnection *conn, - * gboolean shutdown_read, - * gboolean shutdown_write, - * GCancellable *cancellable, - * GError **error) - * { - * // local variable declarations - * - * g_return_val_if_fail (G_IS_DTLS_CONNECTION (conn), FALSE); - * g_return_val_if_fail (cancellable == NULL || G_IS_CANCELLABLE (cancellable), FALSE); - * g_return_val_if_fail (error == NULL || *error == NULL, FALSE); - * - * // function body - * - * return return_val; - * } - * ]| - * - * g_print(), g_printerr() and g_set_print_handler() are intended to be used for - * output from command line applications, since they output to standard output - * and standard error by default — whereas functions like g_message() and - * g_log() may be redirected to special purpose message windows, files, or the - * system journal. - */ - - -/** - * SECTION:windows - * @title: Windows Compatibility Functions - * @short_description: UNIX emulation on Windows - * - * These functions provide some level of UNIX emulation on the - * Windows platform. If your application really needs the POSIX - * APIs, we suggest you try the Cygwin project. - */ - - -/** - * TRUE: - * - * Defines the %TRUE value for the #gboolean type. - */ - - -/** - * _: - * @String: the string to be translated - * - * Marks a string for translation, gets replaced with the translated string - * at runtime. - * - * Since: 2.4 - */ - - -/** - * _glib_get_locale_dir: - * - * Return the path to the share\locale or lib\locale subfolder of the - * GLib installation folder. The path is in the system codepage. We - * have to use system codepage as bindtextdomain() doesn't have a - * UTF-8 interface. - */ - - -/** - * g_abort: - * - * A wrapper for the POSIX abort() function. - * - * On Windows it is a function that makes extra effort (including a call - * to abort()) to ensure that a debugger-catchable exception is thrown - * before the program terminates. - * - * See your C library manual for more details about abort(). - * - * Since: 2.50 - */ - - -/** - * g_access: - * @filename: (type filename): a pathname in the GLib file name encoding - * (UTF-8 on Windows) - * @mode: as in access() - * - * A wrapper for the POSIX access() function. This function is used to - * test a pathname for one or several of read, write or execute - * permissions, or just existence. - * - * On Windows, the file protection mechanism is not at all POSIX-like, - * and the underlying function in the C library only checks the - * FAT-style READONLY attribute, and does not look at the ACL of a - * file at all. This function is this in practise almost useless on - * Windows. Software that needs to handle file permissions on Windows - * more exactly should use the Win32 API. - * - * See your C library manual for more details about access(). - * - * Returns: zero if the pathname refers to an existing file system - * object that has all the tested permissions, or -1 otherwise - * or on error. - * Since: 2.8 - */ - - -/** - * g_array_append_val: - * @a: a #GArray - * @v: the value to append to the #GArray - * - * Adds the value on to the end of the array. The array will grow in - * size automatically if necessary. - * - * g_array_append_val() is a macro which uses a reference to the value - * parameter @v. This means that you cannot use it with literal values - * such as "27". You must use variables. - * - * Returns: the #GArray - */ - - -/** - * g_array_append_vals: - * @array: a #GArray - * @data: (not nullable): a pointer to the elements to append to the end of the array - * @len: the number of elements to append - * - * Adds @len elements onto the end of the array. - * - * Returns: the #GArray - */ - - -/** - * g_array_binary_search: - * @array: a #GArray. - * @target: a pointer to the item to look up. - * @compare_func: A #GCompareFunc used to locate @target. - * @out_match_index: (optional) (out): return location - * for the index of the element, if found. - * - * Checks whether @target exists in @array by performing a binary - * search based on the given comparison function @compare_func which - * get pointers to items as arguments. If the element is found, %TRUE - * is returned and the element’s index is returned in @out_match_index - * (if non-%NULL). Otherwise, %FALSE is returned and @out_match_index - * is undefined. If @target exists multiple times in @array, the index - * of the first instance is returned. This search is using a binary - * search, so the @array must absolutely be sorted to return a correct - * result (if not, the function may produce false-negative). - * - * This example defines a comparison function and search an element in a #GArray: - * |[<!-- language="C" --> - * static gint* - * cmpint (gconstpointer a, gconstpointer b) - * { - * const gint *_a = a; - * const gint *_b = b; - * - * return *_a - *_b; - * } - * ... - * gint i = 424242; - * guint matched_index; - * gboolean result = g_array_binary_search (garray, &i, cmpint, &matched_index); - * ... - * ]| - * - * Returns: %TRUE if @target is one of the elements of @array, %FALSE otherwise. - * Since: 2.62 - */ - - -/** - * g_array_copy: - * @array: A #GArray. - * - * Create a shallow copy of a #GArray. If the array elements consist of - * pointers to data, the pointers are copied but the actual data is not. - * - * Returns: (transfer container): A copy of @array. - * Since: 2.62 - */ - - -/** - * g_array_free: - * @array: a #GArray - * @free_segment: if %TRUE the actual element data is freed as well - * - * Frees the memory allocated for the #GArray. If @free_segment is - * %TRUE it frees the memory block holding the elements as well. Pass - * %FALSE if you want to free the #GArray wrapper but preserve the - * underlying array for use elsewhere. If the reference count of - * @array is greater than one, the #GArray wrapper is preserved but - * the size of @array will be set to zero. - * - * If array contents point to dynamically-allocated memory, they should - * be freed separately if @free_seg is %TRUE and no @clear_func - * function has been set for @array. - * - * This function is not thread-safe. If using a #GArray from multiple - * threads, use only the atomic g_array_ref() and g_array_unref() - * functions. - * - * Returns: the element data if @free_segment is %FALSE, otherwise - * %NULL. The element data should be freed using g_free(). - */ - - -/** - * g_array_get_element_size: - * @array: A #GArray - * - * Gets the size of the elements in @array. - * - * Returns: Size of each element, in bytes - * Since: 2.22 - */ - - -/** - * g_array_index: - * @a: a #GArray - * @t: the type of the elements - * @i: the index of the element to return - * - * Returns the element of a #GArray at the given index. The return - * value is cast to the given type. This is the main way to read or write an - * element in a #GArray. - * - * Writing an element is typically done by reference, as in the following - * example. This example gets a pointer to an element in a #GArray, and then - * writes to a field in it: - * |[<!-- language="C" --> - * EDayViewEvent *event; - * // This gets a pointer to the 4th element in the array of - * // EDayViewEvent structs. - * event = &g_array_index (events, EDayViewEvent, 3); - * event->start_time = g_get_current_time (); - * ]| - * - * This example reads from and writes to an array of integers: - * |[<!-- language="C" --> - * g_autoptr(GArray) int_array = g_array_new (FALSE, FALSE, sizeof (guint)); - * for (guint i = 0; i < 10; i++) - * g_array_append_val (int_array, i); - * - * guint *my_int = &g_array_index (int_array, guint, 1); - * g_print ("Int at index 1 is %u; decrementing it\n", *my_int); - * *my_int = *my_int - 1; - * ]| - * - * Returns: the element of the #GArray at the index given by @i - */ - - -/** - * g_array_insert_val: - * @a: a #GArray - * @i: the index to place the element at - * @v: the value to insert into the array - * - * Inserts an element into an array at the given index. - * - * g_array_insert_val() is a macro which uses a reference to the value - * parameter @v. This means that you cannot use it with literal values - * such as "27". You must use variables. - * - * Returns: the #GArray - */ - - -/** - * g_array_insert_vals: - * @array: a #GArray - * @index_: the index to place the elements at - * @data: (nullable): a pointer to the elements to insert - * @len: the number of elements to insert - * - * Inserts @len elements into a #GArray at the given index. - * - * If @index_ is greater than the array’s current length, the array is expanded. - * The elements between the old end of the array and the newly inserted elements - * will be initialised to zero if the array was configured to clear elements; - * otherwise their values will be undefined. - * - * If @index_ is less than the array’s current length, new entries will be - * inserted into the array, and the existing entries above @index_ will be moved - * upwards. - * - * @data may be %NULL if (and only if) @len is zero. If @len is zero, this - * function is a no-op. - * - * Returns: the #GArray - */ - - -/** - * g_array_new: - * @zero_terminated: %TRUE if the array should have an extra element at - * the end which is set to 0 - * @clear_: %TRUE if #GArray elements should be automatically cleared - * to 0 when they are allocated - * @element_size: the size of each element in bytes - * - * Creates a new #GArray with a reference count of 1. - * - * Returns: the new #GArray - */ - - -/** - * g_array_prepend_val: - * @a: a #GArray - * @v: the value to prepend to the #GArray - * - * Adds the value on to the start of the array. The array will grow in - * size automatically if necessary. - * - * This operation is slower than g_array_append_val() since the - * existing elements in the array have to be moved to make space for - * the new element. - * - * g_array_prepend_val() is a macro which uses a reference to the value - * parameter @v. This means that you cannot use it with literal values - * such as "27". You must use variables. - * - * Returns: the #GArray - */ - - -/** - * g_array_prepend_vals: - * @array: a #GArray - * @data: (nullable): a pointer to the elements to prepend to the start of the array - * @len: the number of elements to prepend, which may be zero - * - * Adds @len elements onto the start of the array. - * - * @data may be %NULL if (and only if) @len is zero. If @len is zero, this - * function is a no-op. - * - * This operation is slower than g_array_append_vals() since the - * existing elements in the array have to be moved to make space for - * the new elements. - * - * Returns: the #GArray - */ - - -/** - * g_array_ref: - * @array: A #GArray - * - * Atomically increments the reference count of @array by one. - * This function is thread-safe and may be called from any thread. - * - * Returns: The passed in #GArray - * Since: 2.22 - */ - - -/** - * g_array_remove_index: - * @array: a #GArray - * @index_: the index of the element to remove - * - * Removes the element at the given index from a #GArray. The following - * elements are moved down one place. - * - * Returns: the #GArray - */ - - -/** - * g_array_remove_index_fast: - * @array: a @GArray - * @index_: the index of the element to remove - * - * Removes the element at the given index from a #GArray. The last - * element in the array is used to fill in the space, so this function - * does not preserve the order of the #GArray. But it is faster than - * g_array_remove_index(). - * - * Returns: the #GArray - */ - - -/** - * g_array_remove_range: - * @array: a @GArray - * @index_: the index of the first element to remove - * @length: the number of elements to remove - * - * Removes the given number of elements starting at the given index - * from a #GArray. The following elements are moved to close the gap. - * - * Returns: the #GArray - * Since: 2.4 - */ - - -/** - * g_array_set_clear_func: - * @array: A #GArray - * @clear_func: a function to clear an element of @array - * - * Sets a function to clear an element of @array. - * - * The @clear_func will be called when an element in the array - * data segment is removed and when the array is freed and data - * segment is deallocated as well. @clear_func will be passed a - * pointer to the element to clear, rather than the element itself. - * - * Note that in contrast with other uses of #GDestroyNotify - * functions, @clear_func is expected to clear the contents of - * the array element it is given, but not free the element itself. - * - * |[<!-- language="C" --> - * typedef struct - * { - * gchar *str; - * GObject *obj; - * } ArrayElement; - * - * static void - * array_element_clear (ArrayElement *element) - * { - * g_clear_pointer (&element->str, g_free); - * g_clear_object (&element->obj); - * } - * - * // main code - * GArray *garray = g_array_new (FALSE, FALSE, sizeof (ArrayElement)); - * g_array_set_clear_func (garray, (GDestroyNotify) array_element_clear); - * // assign data to the structure - * g_array_free (garray, TRUE); - * ]| - * - * Since: 2.32 - */ - - -/** - * g_array_set_size: - * @array: a #GArray - * @length: the new size of the #GArray - * - * Sets the size of the array, expanding it if necessary. If the array - * was created with @clear_ set to %TRUE, the new elements are set to 0. - * - * Returns: the #GArray - */ - - -/** - * g_array_sized_new: - * @zero_terminated: %TRUE if the array should have an extra element at - * the end with all bits cleared - * @clear_: %TRUE if all bits in the array should be cleared to 0 on - * allocation - * @element_size: size of each element in the array - * @reserved_size: number of elements preallocated - * - * Creates a new #GArray with @reserved_size elements preallocated and - * a reference count of 1. This avoids frequent reallocation, if you - * are going to add many elements to the array. Note however that the - * size of the array is still 0. - * - * Returns: the new #GArray - */ - - -/** - * g_array_sort: - * @array: a #GArray - * @compare_func: comparison function - * - * Sorts a #GArray using @compare_func which should be a qsort()-style - * comparison function (returns less than zero for first arg is less - * than second arg, zero for equal, greater zero if first arg is - * greater than second arg). - * - * This is guaranteed to be a stable sort since version 2.32. - */ - - -/** - * g_array_sort_with_data: - * @array: a #GArray - * @compare_func: comparison function - * @user_data: data to pass to @compare_func - * - * Like g_array_sort(), but the comparison function receives an extra - * user data argument. - * - * This is guaranteed to be a stable sort since version 2.32. - * - * There used to be a comment here about making the sort stable by - * using the addresses of the elements in the comparison function. - * This did not actually work, so any such code should be removed. - */ - - -/** - * g_array_steal: - * @array: a #GArray. - * @len: (optional) (out): pointer to retrieve the number of - * elements of the original array - * - * Frees the data in the array and resets the size to zero, while - * the underlying array is preserved for use elsewhere and returned - * to the caller. - * - * If the array was created with the @zero_terminate property - * set to %TRUE, the returned data is zero terminated too. - * - * If array elements contain dynamically-allocated memory, - * the array elements should also be freed by the caller. - * - * A short example of use: - * |[<!-- language="C" --> - * ... - * gpointer data; - * gsize data_len; - * data = g_array_steal (some_array, &data_len); - * ... - * ]| - * - * Returns: (transfer full): the element data, which should be - * freed using g_free(). - * Since: 2.64 - */ - - -/** - * g_array_unref: - * @array: A #GArray - * - * Atomically decrements the reference count of @array by one. If the - * reference count drops to 0, all memory allocated by the array is - * released. This function is thread-safe and may be called from any - * thread. - * - * Since: 2.22 - */ - - -/** - * g_ascii_digit_value: - * @c: an ASCII character - * - * Determines the numeric value of a character as a decimal digit. - * Differs from g_unichar_digit_value() because it takes a char, so - * there's no worry about sign extension if characters are signed. - * - * Returns: If @c is a decimal digit (according to g_ascii_isdigit()), - * its numeric value. Otherwise, -1. - */ - - -/** - * g_ascii_dtostr: - * @buffer: A buffer to place the resulting string in - * @buf_len: The length of the buffer. - * @d: The #gdouble to convert - * - * Converts a #gdouble to a string, using the '.' as - * decimal point. - * - * This function generates enough precision that converting - * the string back using g_ascii_strtod() gives the same machine-number - * (on machines with IEEE compatible 64bit doubles). It is - * guaranteed that the size of the resulting string will never - * be larger than @G_ASCII_DTOSTR_BUF_SIZE bytes, including the terminating - * nul character, which is always added. - * - * Returns: The pointer to the buffer with the converted string. - */ - - -/** - * g_ascii_formatd: - * @buffer: A buffer to place the resulting string in - * @buf_len: The length of the buffer. - * @format: The printf()-style format to use for the - * code to use for converting. - * @d: The #gdouble to convert - * - * Converts a #gdouble to a string, using the '.' as - * decimal point. To format the number you pass in - * a printf()-style format string. Allowed conversion - * specifiers are 'e', 'E', 'f', 'F', 'g' and 'G'. - * - * The returned buffer is guaranteed to be nul-terminated. - * - * If you just want to want to serialize the value into a - * string, use g_ascii_dtostr(). - * - * Returns: The pointer to the buffer with the converted string. - */ - - -/** - * g_ascii_isalnum: - * @c: any character - * - * Determines whether a character is alphanumeric. - * - * Unlike the standard C library isalnum() function, this only - * recognizes standard ASCII letters and ignores the locale, - * returning %FALSE for all non-ASCII characters. Also, unlike - * the standard library function, this takes a char, not an int, - * so don't call it on %EOF, but no need to cast to #guchar before - * passing a possibly non-ASCII character in. - * - * Returns: %TRUE if @c is an ASCII alphanumeric character - */ - - -/** - * g_ascii_isalpha: - * @c: any character - * - * Determines whether a character is alphabetic (i.e. a letter). - * - * Unlike the standard C library isalpha() function, this only - * recognizes standard ASCII letters and ignores the locale, - * returning %FALSE for all non-ASCII characters. Also, unlike - * the standard library function, this takes a char, not an int, - * so don't call it on %EOF, but no need to cast to #guchar before - * passing a possibly non-ASCII character in. - * - * Returns: %TRUE if @c is an ASCII alphabetic character - */ - - -/** - * g_ascii_iscntrl: - * @c: any character - * - * Determines whether a character is a control character. - * - * Unlike the standard C library iscntrl() function, this only - * recognizes standard ASCII control characters and ignores the - * locale, returning %FALSE for all non-ASCII characters. Also, - * unlike the standard library function, this takes a char, not - * an int, so don't call it on %EOF, but no need to cast to #guchar - * before passing a possibly non-ASCII character in. - * - * Returns: %TRUE if @c is an ASCII control character. - */ - - -/** - * g_ascii_isdigit: - * @c: any character - * - * Determines whether a character is digit (0-9). - * - * Unlike the standard C library isdigit() function, this takes - * a char, not an int, so don't call it on %EOF, but no need to - * cast to #guchar before passing a possibly non-ASCII character in. - * - * Returns: %TRUE if @c is an ASCII digit. - */ - - -/** - * g_ascii_isgraph: - * @c: any character - * - * Determines whether a character is a printing character and not a space. - * - * Unlike the standard C library isgraph() function, this only - * recognizes standard ASCII characters and ignores the locale, - * returning %FALSE for all non-ASCII characters. Also, unlike - * the standard library function, this takes a char, not an int, - * so don't call it on %EOF, but no need to cast to #guchar before - * passing a possibly non-ASCII character in. - * - * Returns: %TRUE if @c is an ASCII printing character other than space. - */ - - -/** - * g_ascii_islower: - * @c: any character - * - * Determines whether a character is an ASCII lower case letter. - * - * Unlike the standard C library islower() function, this only - * recognizes standard ASCII letters and ignores the locale, - * returning %FALSE for all non-ASCII characters. Also, unlike - * the standard library function, this takes a char, not an int, - * so don't call it on %EOF, but no need to worry about casting - * to #guchar before passing a possibly non-ASCII character in. - * - * Returns: %TRUE if @c is an ASCII lower case letter - */ - - -/** - * g_ascii_isprint: - * @c: any character - * - * Determines whether a character is a printing character. - * - * Unlike the standard C library isprint() function, this only - * recognizes standard ASCII characters and ignores the locale, - * returning %FALSE for all non-ASCII characters. Also, unlike - * the standard library function, this takes a char, not an int, - * so don't call it on %EOF, but no need to cast to #guchar before - * passing a possibly non-ASCII character in. - * - * Returns: %TRUE if @c is an ASCII printing character. - */ - - -/** - * g_ascii_ispunct: - * @c: any character - * - * Determines whether a character is a punctuation character. - * - * Unlike the standard C library ispunct() function, this only - * recognizes standard ASCII letters and ignores the locale, - * returning %FALSE for all non-ASCII characters. Also, unlike - * the standard library function, this takes a char, not an int, - * so don't call it on %EOF, but no need to cast to #guchar before - * passing a possibly non-ASCII character in. - * - * Returns: %TRUE if @c is an ASCII punctuation character. - */ - - -/** - * g_ascii_isspace: - * @c: any character - * - * Determines whether a character is a white-space character. - * - * Unlike the standard C library isspace() function, this only - * recognizes standard ASCII white-space and ignores the locale, - * returning %FALSE for all non-ASCII characters. Also, unlike - * the standard library function, this takes a char, not an int, - * so don't call it on %EOF, but no need to cast to #guchar before - * passing a possibly non-ASCII character in. - * - * Returns: %TRUE if @c is an ASCII white-space character - */ - - -/** - * g_ascii_isupper: - * @c: any character - * - * Determines whether a character is an ASCII upper case letter. - * - * Unlike the standard C library isupper() function, this only - * recognizes standard ASCII letters and ignores the locale, - * returning %FALSE for all non-ASCII characters. Also, unlike - * the standard library function, this takes a char, not an int, - * so don't call it on %EOF, but no need to worry about casting - * to #guchar before passing a possibly non-ASCII character in. - * - * Returns: %TRUE if @c is an ASCII upper case letter - */ - - -/** - * g_ascii_isxdigit: - * @c: any character - * - * Determines whether a character is a hexadecimal-digit character. - * - * Unlike the standard C library isxdigit() function, this takes - * a char, not an int, so don't call it on %EOF, but no need to - * cast to #guchar before passing a possibly non-ASCII character in. - * - * Returns: %TRUE if @c is an ASCII hexadecimal-digit character. - */ - - -/** - * g_ascii_strcasecmp: - * @s1: string to compare with @s2 - * @s2: string to compare with @s1 - * - * Compare two strings, ignoring the case of ASCII characters. - * - * Unlike the BSD strcasecmp() function, this only recognizes standard - * ASCII letters and ignores the locale, treating all non-ASCII - * bytes as if they are not letters. - * - * This function should be used only on strings that are known to be - * in encodings where the bytes corresponding to ASCII letters always - * represent themselves. This includes UTF-8 and the ISO-8859-* - * charsets, but not for instance double-byte encodings like the - * Windows Codepage 932, where the trailing bytes of double-byte - * characters include all ASCII letters. If you compare two CP932 - * strings using this function, you will get false matches. - * - * Both @s1 and @s2 must be non-%NULL. - * - * Returns: 0 if the strings match, a negative value if @s1 < @s2, - * or a positive value if @s1 > @s2. - */ - - -/** - * g_ascii_strdown: - * @str: a string - * @len: length of @str in bytes, or -1 if @str is nul-terminated - * - * Converts all upper case ASCII letters to lower case ASCII letters. - * - * Returns: a newly-allocated string, with all the upper case - * characters in @str converted to lower case, with semantics that - * exactly match g_ascii_tolower(). (Note that this is unlike the - * old g_strdown(), which modified the string in place.) - */ - - -/** - * g_ascii_string_to_signed: - * @str: a string - * @base: base of a parsed number - * @min: a lower bound (inclusive) - * @max: an upper bound (inclusive) - * @out_num: (out) (optional): a return location for a number - * @error: a return location for #GError - * - * A convenience function for converting a string to a signed number. - * - * This function assumes that @str contains only a number of the given - * @base that is within inclusive bounds limited by @min and @max. If - * this is true, then the converted number is stored in @out_num. An - * empty string is not a valid input. A string with leading or - * trailing whitespace is also an invalid input. - * - * @base can be between 2 and 36 inclusive. Hexadecimal numbers must - * not be prefixed with "0x" or "0X". Such a problem does not exist - * for octal numbers, since they were usually prefixed with a zero - * which does not change the value of the parsed number. - * - * Parsing failures result in an error with the %G_NUMBER_PARSER_ERROR - * domain. If the input is invalid, the error code will be - * %G_NUMBER_PARSER_ERROR_INVALID. If the parsed number is out of - * bounds - %G_NUMBER_PARSER_ERROR_OUT_OF_BOUNDS. - * - * See g_ascii_strtoll() if you have more complex needs such as - * parsing a string which starts with a number, but then has other - * characters. - * - * Returns: %TRUE if @str was a number, otherwise %FALSE. - * Since: 2.54 - */ - - -/** - * g_ascii_string_to_unsigned: - * @str: a string - * @base: base of a parsed number - * @min: a lower bound (inclusive) - * @max: an upper bound (inclusive) - * @out_num: (out) (optional): a return location for a number - * @error: a return location for #GError - * - * A convenience function for converting a string to an unsigned number. - * - * This function assumes that @str contains only a number of the given - * @base that is within inclusive bounds limited by @min and @max. If - * this is true, then the converted number is stored in @out_num. An - * empty string is not a valid input. A string with leading or - * trailing whitespace is also an invalid input. A string with a leading sign - * (`-` or `+`) is not a valid input for the unsigned parser. - * - * @base can be between 2 and 36 inclusive. Hexadecimal numbers must - * not be prefixed with "0x" or "0X". Such a problem does not exist - * for octal numbers, since they were usually prefixed with a zero - * which does not change the value of the parsed number. - * - * Parsing failures result in an error with the %G_NUMBER_PARSER_ERROR - * domain. If the input is invalid, the error code will be - * %G_NUMBER_PARSER_ERROR_INVALID. If the parsed number is out of - * bounds - %G_NUMBER_PARSER_ERROR_OUT_OF_BOUNDS. - * - * See g_ascii_strtoull() if you have more complex needs such as - * parsing a string which starts with a number, but then has other - * characters. - * - * Returns: %TRUE if @str was a number, otherwise %FALSE. - * Since: 2.54 - */ - - -/** - * g_ascii_strncasecmp: - * @s1: string to compare with @s2 - * @s2: string to compare with @s1 - * @n: number of characters to compare - * - * Compare @s1 and @s2, ignoring the case of ASCII characters and any - * characters after the first @n in each string. - * - * Unlike the BSD strcasecmp() function, this only recognizes standard - * ASCII letters and ignores the locale, treating all non-ASCII - * characters as if they are not letters. - * - * The same warning as in g_ascii_strcasecmp() applies: Use this - * function only on strings known to be in encodings where bytes - * corresponding to ASCII letters always represent themselves. - * - * Returns: 0 if the strings match, a negative value if @s1 < @s2, - * or a positive value if @s1 > @s2. - */ - - -/** - * g_ascii_strtod: - * @nptr: the string to convert to a numeric value. - * @endptr: (out) (transfer none) (optional): if non-%NULL, it returns the - * character after the last character used in the conversion. - * - * Converts a string to a #gdouble value. - * - * This function behaves like the standard strtod() function - * does in the C locale. It does this without actually changing - * the current locale, since that would not be thread-safe. - * A limitation of the implementation is that this function - * will still accept localized versions of infinities and NANs. - * - * This function is typically used when reading configuration - * files or other non-user input that should be locale independent. - * To handle input from the user you should normally use the - * locale-sensitive system strtod() function. - * - * To convert from a #gdouble to a string in a locale-insensitive - * way, use g_ascii_dtostr(). - * - * If the correct value would cause overflow, plus or minus %HUGE_VAL - * is returned (according to the sign of the value), and %ERANGE is - * stored in %errno. If the correct value would cause underflow, - * zero is returned and %ERANGE is stored in %errno. - * - * This function resets %errno before calling strtod() so that - * you can reliably detect overflow and underflow. - * - * Returns: the #gdouble value. - */ - - -/** - * g_ascii_strtoll: - * @nptr: the string to convert to a numeric value. - * @endptr: (out) (transfer none) (optional): if non-%NULL, it returns the - * character after the last character used in the conversion. - * @base: to be used for the conversion, 2..36 or 0 - * - * Converts a string to a #gint64 value. - * This function behaves like the standard strtoll() function - * does in the C locale. It does this without actually - * changing the current locale, since that would not be - * thread-safe. - * - * This function is typically used when reading configuration - * files or other non-user input that should be locale independent. - * To handle input from the user you should normally use the - * locale-sensitive system strtoll() function. - * - * If the correct value would cause overflow, %G_MAXINT64 or %G_MININT64 - * is returned, and `ERANGE` is stored in `errno`. - * If the base is outside the valid range, zero is returned, and - * `EINVAL` is stored in `errno`. If the - * string conversion fails, zero is returned, and @endptr returns @nptr - * (if @endptr is non-%NULL). - * - * Returns: the #gint64 value or zero on error. - * Since: 2.12 - */ - - -/** - * g_ascii_strtoull: - * @nptr: the string to convert to a numeric value. - * @endptr: (out) (transfer none) (optional): if non-%NULL, it returns the - * character after the last character used in the conversion. - * @base: to be used for the conversion, 2..36 or 0 - * - * Converts a string to a #guint64 value. - * This function behaves like the standard strtoull() function - * does in the C locale. It does this without actually - * changing the current locale, since that would not be - * thread-safe. - * - * Note that input with a leading minus sign (`-`) is accepted, and will return - * the negation of the parsed number, unless that would overflow a #guint64. - * Critically, this means you cannot assume that a short fixed length input will - * never result in a low return value, as the input could have a leading `-`. - * - * This function is typically used when reading configuration - * files or other non-user input that should be locale independent. - * To handle input from the user you should normally use the - * locale-sensitive system strtoull() function. - * - * If the correct value would cause overflow, %G_MAXUINT64 - * is returned, and `ERANGE` is stored in `errno`. - * If the base is outside the valid range, zero is returned, and - * `EINVAL` is stored in `errno`. - * If the string conversion fails, zero is returned, and @endptr returns - * @nptr (if @endptr is non-%NULL). - * - * Returns: the #guint64 value or zero on error. - * Since: 2.2 - */ - - -/** - * g_ascii_strup: - * @str: a string - * @len: length of @str in bytes, or -1 if @str is nul-terminated - * - * Converts all lower case ASCII letters to upper case ASCII letters. - * - * Returns: a newly allocated string, with all the lower case - * characters in @str converted to upper case, with semantics that - * exactly match g_ascii_toupper(). (Note that this is unlike the - * old g_strup(), which modified the string in place.) - */ - - -/** - * g_ascii_tolower: - * @c: any character - * - * Convert a character to ASCII lower case. - * - * Unlike the standard C library tolower() function, this only - * recognizes standard ASCII letters and ignores the locale, returning - * all non-ASCII characters unchanged, even if they are lower case - * letters in a particular character set. Also unlike the standard - * library function, this takes and returns a char, not an int, so - * don't call it on %EOF but no need to worry about casting to #guchar - * before passing a possibly non-ASCII character in. - * - * Returns: the result of converting @c to lower case. If @c is - * not an ASCII upper case letter, @c is returned unchanged. - */ - - -/** - * g_ascii_toupper: - * @c: any character - * - * Convert a character to ASCII upper case. - * - * Unlike the standard C library toupper() function, this only - * recognizes standard ASCII letters and ignores the locale, returning - * all non-ASCII characters unchanged, even if they are upper case - * letters in a particular character set. Also unlike the standard - * library function, this takes and returns a char, not an int, so - * don't call it on %EOF but no need to worry about casting to #guchar - * before passing a possibly non-ASCII character in. - * - * Returns: the result of converting @c to upper case. If @c is not - * an ASCII lower case letter, @c is returned unchanged. - */ - - -/** - * g_ascii_xdigit_value: - * @c: an ASCII character. - * - * Determines the numeric value of a character as a hexadecimal - * digit. Differs from g_unichar_xdigit_value() because it takes - * a char, so there's no worry about sign extension if characters - * are signed. - * - * Returns: If @c is a hex digit (according to g_ascii_isxdigit()), - * its numeric value. Otherwise, -1. - */ - - -/** - * g_assert: - * @expr: the expression to check - * - * Debugging macro to terminate the application if the assertion - * fails. If the assertion fails (i.e. the expression is not true), - * an error message is logged and the application is terminated. - * - * The macro can be turned off in final releases of code by defining - * `G_DISABLE_ASSERT` when compiling the application, so code must - * not depend on any side effects from @expr. Similarly, it must not be used - * in unit tests, otherwise the unit tests will be ineffective if compiled with - * `G_DISABLE_ASSERT`. Use g_assert_true() and related macros in unit tests - * instead. - */ - - -/** - * g_assert_cmpfloat: - * @n1: a floating point number - * @cmp: The comparison operator to use. - * One of `==`, `!=`, `<`, `>`, `<=`, `>=`. - * @n2: another floating point number - * - * Debugging macro to compare two floating point numbers. - * - * The effect of `g_assert_cmpfloat (n1, op, n2)` is - * the same as `g_assert_true (n1 op n2)`. The advantage - * of this macro is that it can produce a message that includes the - * actual values of @n1 and @n2. - * - * Since: 2.16 - */ - - -/** - * g_assert_cmpfloat_with_epsilon: - * @n1: a floating point number - * @n2: another floating point number - * @epsilon: a numeric value that expresses the expected tolerance - * between @n1 and @n2 - * - * Debugging macro to compare two floating point numbers within an epsilon. - * - * The effect of `g_assert_cmpfloat_with_epsilon (n1, n2, epsilon)` is - * the same as `g_assert_true (abs (n1 - n2) < epsilon)`. The advantage - * of this macro is that it can produce a message that includes the - * actual values of @n1 and @n2. - * - * Since: 2.58 - */ - - -/** - * g_assert_cmphex: - * @n1: an unsigned integer - * @cmp: The comparison operator to use. - * One of `==`, `!=`, `<`, `>`, `<=`, `>=`. - * @n2: another unsigned integer - * - * Debugging macro to compare to unsigned integers. - * - * This is a variant of g_assert_cmpuint() that displays the numbers - * in hexadecimal notation in the message. - * - * Since: 2.16 - */ - - -/** - * g_assert_cmpint: - * @n1: an integer - * @cmp: The comparison operator to use. - * One of `==`, `!=`, `<`, `>`, `<=`, `>=`. - * @n2: another integer - * - * Debugging macro to compare two integers. - * - * The effect of `g_assert_cmpint (n1, op, n2)` is - * the same as `g_assert_true (n1 op n2)`. The advantage - * of this macro is that it can produce a message that includes the - * actual values of @n1 and @n2. - * - * Since: 2.16 - */ - - -/** - * g_assert_cmpmem: - * @m1: (nullable): pointer to a buffer - * @l1: length of @m1 - * @m2: (nullable): pointer to another buffer - * @l2: length of @m2 - * - * Debugging macro to compare memory regions. If the comparison fails, - * an error message is logged and the application is either terminated - * or the testcase marked as failed. - * - * The effect of `g_assert_cmpmem (m1, l1, m2, l2)` is - * the same as `g_assert_true (l1 == l2 && memcmp (m1, m2, l1) == 0)`. - * The advantage of this macro is that it can produce a message that - * includes the actual values of @l1 and @l2. - * - * @m1 may be %NULL if (and only if) @l1 is zero; similarly for @m2 and @l2. - * - * |[<!-- language="C" --> - * g_assert_cmpmem (buf->data, buf->len, expected, sizeof (expected)); - * ]| - * - * Since: 2.46 - */ - - -/** - * g_assert_cmpstr: - * @s1: a string (may be %NULL) - * @cmp: The comparison operator to use. - * One of `==`, `!=`, `<`, `>`, `<=`, `>=`. - * @s2: another string (may be %NULL) - * - * Debugging macro to compare two strings. If the comparison fails, - * an error message is logged and the application is either terminated - * or the testcase marked as failed. - * The strings are compared using g_strcmp0(). - * - * The effect of `g_assert_cmpstr (s1, op, s2)` is - * the same as `g_assert_true (g_strcmp0 (s1, s2) op 0)`. - * The advantage of this macro is that it can produce a message that - * includes the actual values of @s1 and @s2. - * - * |[<!-- language="C" --> - * g_assert_cmpstr (mystring, ==, "fubar"); - * ]| - * - * Since: 2.16 - */ - - -/** - * g_assert_cmpstrv: - * @strv1: (nullable): a string array (may be %NULL) - * @strv2: (nullable): another string array (may be %NULL) - * - * Debugging macro to check if two %NULL-terminated string arrays (i.e. 2 - * #GStrv) are equal. If they are not equal, an error message is logged and the - * application is either terminated or the testcase marked as failed. - * If both arrays are %NULL, the check passes. If one array is %NULL but the - * other is not, an error message is logged. - * - * The effect of `g_assert_cmpstrv (strv1, strv2)` is the same as - * `g_assert_true (g_strv_equal (strv1, strv2))` (if both arrays are not - * %NULL). The advantage of this macro is that it can produce a message that - * includes how @strv1 and @strv2 are different. - * - * |[<!-- language="C" --> - * const char *expected[] = { "one", "two", "three", NULL }; - * g_assert_cmpstrv (mystrv, expected); - * ]| - * - * Since: 2.68 - */ - - -/** - * g_assert_cmpuint: - * @n1: an unsigned integer - * @cmp: The comparison operator to use. - * One of `==`, `!=`, `<`, `>`, `<=`, `>=`. - * @n2: another unsigned integer - * - * Debugging macro to compare two unsigned integers. - * - * The effect of `g_assert_cmpuint (n1, op, n2)` is - * the same as `g_assert_true (n1 op n2)`. The advantage - * of this macro is that it can produce a message that includes the - * actual values of @n1 and @n2. - * - * Since: 2.16 - */ - - -/** - * g_assert_cmpvariant: - * @v1: pointer to a #GVariant - * @v2: pointer to another #GVariant - * - * Debugging macro to compare two #GVariants. If the comparison fails, - * an error message is logged and the application is either terminated - * or the testcase marked as failed. The variants are compared using - * g_variant_equal(). - * - * The effect of `g_assert_cmpvariant (v1, v2)` is the same as - * `g_assert_true (g_variant_equal (v1, v2))`. The advantage of this macro is - * that it can produce a message that includes the actual values of @v1 and @v2. - * - * Since: 2.60 - */ - - -/** - * g_assert_error: - * @err: a #GError, possibly %NULL - * @dom: the expected error domain (a #GQuark) - * @c: the expected error code - * - * Debugging macro to check that a method has returned - * the correct #GError. - * - * The effect of `g_assert_error (err, dom, c)` is - * the same as `g_assert_true (err != NULL && err->domain - * == dom && err->code == c)`. The advantage of this - * macro is that it can produce a message that includes the incorrect - * error message and code. - * - * This can only be used to test for a specific error. If you want to - * test that @err is set, but don't care what it's set to, just use - * `g_assert_nonnull (err)`. - * - * Since: 2.20 - */ - - -/** - * g_assert_false: - * @expr: the expression to check - * - * Debugging macro to check an expression is false. - * - * If the assertion fails (i.e. the expression is not false), - * an error message is logged and the application is either - * terminated or the testcase marked as failed. - * - * Note that unlike g_assert(), this macro is unaffected by whether - * `G_DISABLE_ASSERT` is defined. Hence it should only be used in tests and, - * conversely, g_assert() should not be used in tests. - * - * See g_test_set_nonfatal_assertions(). - * - * Since: 2.38 - */ - - -/** - * g_assert_no_errno: - * @expr: the expression to check - * - * Debugging macro to check that an expression has a non-negative return value, - * as used by traditional POSIX functions (such as `rmdir()`) to indicate - * success. - * - * If the assertion fails (i.e. the @expr returns a negative value), an error - * message is logged and the testcase is marked as failed. The error message - * will contain the value of `errno` and its human-readable message from - * g_strerror(). - * - * This macro will clear the value of `errno` before executing @expr. - * - * Since: 2.66 - */ - - -/** - * g_assert_no_error: - * @err: a #GError, possibly %NULL - * - * Debugging macro to check that a #GError is not set. - * - * The effect of `g_assert_no_error (err)` is - * the same as `g_assert_true (err == NULL)`. The advantage - * of this macro is that it can produce a message that includes - * the error message and code. - * - * Since: 2.20 - */ - - -/** - * g_assert_nonnull: - * @expr: the expression to check - * - * Debugging macro to check an expression is not %NULL. - * - * If the assertion fails (i.e. the expression is %NULL), - * an error message is logged and the application is either - * terminated or the testcase marked as failed. - * - * Note that unlike g_assert(), this macro is unaffected by whether - * `G_DISABLE_ASSERT` is defined. Hence it should only be used in tests and, - * conversely, g_assert() should not be used in tests. - * - * See g_test_set_nonfatal_assertions(). - * - * Since: 2.40 - */ - - -/** - * g_assert_not_reached: - * - * Debugging macro to terminate the application if it is ever - * reached. If it is reached, an error message is logged and the - * application is terminated. - * - * The macro can be turned off in final releases of code by defining - * `G_DISABLE_ASSERT` when compiling the application. Hence, it should not be - * used in unit tests, where assertions should always be effective. - */ - - -/** - * g_assert_null: - * @expr: the expression to check - * - * Debugging macro to check an expression is %NULL. - * - * If the assertion fails (i.e. the expression is not %NULL), - * an error message is logged and the application is either - * terminated or the testcase marked as failed. - * - * Note that unlike g_assert(), this macro is unaffected by whether - * `G_DISABLE_ASSERT` is defined. Hence it should only be used in tests and, - * conversely, g_assert() should not be used in tests. - * - * See g_test_set_nonfatal_assertions(). - * - * Since: 2.38 - */ - - -/** - * g_assert_true: - * @expr: the expression to check - * - * Debugging macro to check that an expression is true. - * - * If the assertion fails (i.e. the expression is not true), - * an error message is logged and the application is either - * terminated or the testcase marked as failed. - * - * Note that unlike g_assert(), this macro is unaffected by whether - * `G_DISABLE_ASSERT` is defined. Hence it should only be used in tests and, - * conversely, g_assert() should not be used in tests. - * - * See g_test_set_nonfatal_assertions(). - * - * Since: 2.38 - */ - - -/** - * g_assertion_message_expr: (skip) - * @domain: (nullable): log domain - * @file: file containing the assertion - * @line: line number of the assertion - * @func: function containing the assertion - * @expr: (nullable): expression which failed - * - * Internal function used to print messages from the public g_assert() and - * g_assert_not_reached() macros. - */ - - -/** - * g_async_queue_length: - * @queue: a #GAsyncQueue. - * - * Returns the length of the queue. - * - * Actually this function returns the number of data items in - * the queue minus the number of waiting threads, so a negative - * value means waiting threads, and a positive value means available - * entries in the @queue. A return value of 0 could mean n entries - * in the queue and n threads waiting. This can happen due to locking - * of the queue or due to scheduling. - * - * Returns: the length of the @queue - */ - - -/** - * g_async_queue_length_unlocked: - * @queue: a #GAsyncQueue - * - * Returns the length of the queue. - * - * Actually this function returns the number of data items in - * the queue minus the number of waiting threads, so a negative - * value means waiting threads, and a positive value means available - * entries in the @queue. A return value of 0 could mean n entries - * in the queue and n threads waiting. This can happen due to locking - * of the queue or due to scheduling. - * - * This function must be called while holding the @queue's lock. - * - * Returns: the length of the @queue. - */ - - -/** - * g_async_queue_lock: - * @queue: a #GAsyncQueue - * - * Acquires the @queue's lock. If another thread is already - * holding the lock, this call will block until the lock - * becomes available. - * - * Call g_async_queue_unlock() to drop the lock again. - * - * While holding the lock, you can only call the - * g_async_queue_*_unlocked() functions on @queue. Otherwise, - * deadlock may occur. - */ - - -/** - * g_async_queue_new: - * - * Creates a new asynchronous queue. - * - * Returns: a new #GAsyncQueue. Free with g_async_queue_unref() - */ - - -/** - * g_async_queue_new_full: - * @item_free_func: (nullable): function to free queue elements - * - * Creates a new asynchronous queue and sets up a destroy notify - * function that is used to free any remaining queue items when - * the queue is destroyed after the final unref. - * - * Returns: a new #GAsyncQueue. Free with g_async_queue_unref() - * Since: 2.16 - */ - - -/** - * g_async_queue_pop: - * @queue: a #GAsyncQueue - * - * Pops data from the @queue. If @queue is empty, this function - * blocks until data becomes available. - * - * Returns: data from the queue - */ - - -/** - * g_async_queue_pop_unlocked: - * @queue: a #GAsyncQueue - * - * Pops data from the @queue. If @queue is empty, this function - * blocks until data becomes available. - * - * This function must be called while holding the @queue's lock. - * - * Returns: data from the queue. - */ - - -/** - * g_async_queue_push: - * @queue: a #GAsyncQueue - * @data: @data to push into the @queue - * - * Pushes the @data into the @queue. @data must not be %NULL. - */ - - -/** - * g_async_queue_push_front: - * @queue: a #GAsyncQueue - * @item: data to push into the @queue - * - * Pushes the @item into the @queue. @item must not be %NULL. - * In contrast to g_async_queue_push(), this function - * pushes the new item ahead of the items already in the queue, - * so that it will be the next one to be popped off the queue. - * - * Since: 2.46 - */ - - -/** - * g_async_queue_push_front_unlocked: - * @queue: a #GAsyncQueue - * @item: data to push into the @queue - * - * Pushes the @item into the @queue. @item must not be %NULL. - * In contrast to g_async_queue_push_unlocked(), this function - * pushes the new item ahead of the items already in the queue, - * so that it will be the next one to be popped off the queue. - * - * This function must be called while holding the @queue's lock. - * - * Since: 2.46 - */ - - -/** - * g_async_queue_push_sorted: - * @queue: a #GAsyncQueue - * @data: the @data to push into the @queue - * @func: the #GCompareDataFunc is used to sort @queue - * @user_data: user data passed to @func. - * - * Inserts @data into @queue using @func to determine the new - * position. - * - * This function requires that the @queue is sorted before pushing on - * new elements, see g_async_queue_sort(). - * - * This function will lock @queue before it sorts the queue and unlock - * it when it is finished. - * - * For an example of @func see g_async_queue_sort(). - * - * Since: 2.10 - */ - - -/** - * g_async_queue_push_sorted_unlocked: - * @queue: a #GAsyncQueue - * @data: the @data to push into the @queue - * @func: the #GCompareDataFunc is used to sort @queue - * @user_data: user data passed to @func. - * - * Inserts @data into @queue using @func to determine the new - * position. - * - * The sort function @func is passed two elements of the @queue. - * It should return 0 if they are equal, a negative value if the - * first element should be higher in the @queue or a positive value - * if the first element should be lower in the @queue than the second - * element. - * - * This function requires that the @queue is sorted before pushing on - * new elements, see g_async_queue_sort(). - * - * This function must be called while holding the @queue's lock. - * - * For an example of @func see g_async_queue_sort(). - * - * Since: 2.10 - */ - - -/** - * g_async_queue_push_unlocked: - * @queue: a #GAsyncQueue - * @data: @data to push into the @queue - * - * Pushes the @data into the @queue. @data must not be %NULL. - * - * This function must be called while holding the @queue's lock. - */ - - -/** - * g_async_queue_ref: - * @queue: a #GAsyncQueue - * - * Increases the reference count of the asynchronous @queue by 1. - * You do not need to hold the lock to call this function. - * - * Returns: the @queue that was passed in (since 2.6) - */ - - -/** - * g_async_queue_ref_unlocked: - * @queue: a #GAsyncQueue - * - * Increases the reference count of the asynchronous @queue by 1. - * - * Deprecated: 2.8: Reference counting is done atomically. - * so g_async_queue_ref() can be used regardless of the @queue's - * lock. - */ - - -/** - * g_async_queue_remove: - * @queue: a #GAsyncQueue - * @item: the data to remove from the @queue - * - * Remove an item from the queue. - * - * Returns: %TRUE if the item was removed - * Since: 2.46 - */ - - -/** - * g_async_queue_remove_unlocked: - * @queue: a #GAsyncQueue - * @item: the data to remove from the @queue - * - * Remove an item from the queue. - * - * This function must be called while holding the @queue's lock. - * - * Returns: %TRUE if the item was removed - * Since: 2.46 - */ - - -/** - * g_async_queue_sort: - * @queue: a #GAsyncQueue - * @func: the #GCompareDataFunc is used to sort @queue - * @user_data: user data passed to @func - * - * Sorts @queue using @func. - * - * The sort function @func is passed two elements of the @queue. - * It should return 0 if they are equal, a negative value if the - * first element should be higher in the @queue or a positive value - * if the first element should be lower in the @queue than the second - * element. - * - * This function will lock @queue before it sorts the queue and unlock - * it when it is finished. - * - * If you were sorting a list of priority numbers to make sure the - * lowest priority would be at the top of the queue, you could use: - * |[<!-- language="C" --> - * gint32 id1; - * gint32 id2; - * - * id1 = GPOINTER_TO_INT (element1); - * id2 = GPOINTER_TO_INT (element2); - * - * return (id1 > id2 ? +1 : id1 == id2 ? 0 : -1); - * ]| - * - * Since: 2.10 - */ - - -/** - * g_async_queue_sort_unlocked: - * @queue: a #GAsyncQueue - * @func: the #GCompareDataFunc is used to sort @queue - * @user_data: user data passed to @func - * - * Sorts @queue using @func. - * - * The sort function @func is passed two elements of the @queue. - * It should return 0 if they are equal, a negative value if the - * first element should be higher in the @queue or a positive value - * if the first element should be lower in the @queue than the second - * element. - * - * This function must be called while holding the @queue's lock. - * - * Since: 2.10 - */ - - -/** - * g_async_queue_timed_pop: - * @queue: a #GAsyncQueue - * @end_time: a #GTimeVal, determining the final time - * - * Pops data from the @queue. If the queue is empty, blocks until - * @end_time or until data becomes available. - * - * If no data is received before @end_time, %NULL is returned. - * - * To easily calculate @end_time, a combination of g_get_real_time() - * and g_time_val_add() can be used. - * - * Returns: (nullable): data from the queue or %NULL, when no data is - * received before @end_time. - * Deprecated: use g_async_queue_timeout_pop(). - */ - - -/** - * g_async_queue_timed_pop_unlocked: - * @queue: a #GAsyncQueue - * @end_time: a #GTimeVal, determining the final time - * - * Pops data from the @queue. If the queue is empty, blocks until - * @end_time or until data becomes available. - * - * If no data is received before @end_time, %NULL is returned. - * - * To easily calculate @end_time, a combination of g_get_real_time() - * and g_time_val_add() can be used. - * - * This function must be called while holding the @queue's lock. - * - * Returns: (nullable): data from the queue or %NULL, when no data is - * received before @end_time. - * Deprecated: use g_async_queue_timeout_pop_unlocked(). - */ - - -/** - * g_async_queue_timeout_pop: - * @queue: a #GAsyncQueue - * @timeout: the number of microseconds to wait - * - * Pops data from the @queue. If the queue is empty, blocks for - * @timeout microseconds, or until data becomes available. - * - * If no data is received before the timeout, %NULL is returned. - * - * Returns: (nullable): data from the queue or %NULL, when no data is - * received before the timeout. - */ - - -/** - * g_async_queue_timeout_pop_unlocked: - * @queue: a #GAsyncQueue - * @timeout: the number of microseconds to wait - * - * Pops data from the @queue. If the queue is empty, blocks for - * @timeout microseconds, or until data becomes available. - * - * If no data is received before the timeout, %NULL is returned. - * - * This function must be called while holding the @queue's lock. - * - * Returns: (nullable): data from the queue or %NULL, when no data is - * received before the timeout. - */ - - -/** - * g_async_queue_try_pop: - * @queue: a #GAsyncQueue - * - * Tries to pop data from the @queue. If no data is available, - * %NULL is returned. - * - * Returns: (nullable): data from the queue or %NULL, when no data is - * available immediately. - */ - - -/** - * g_async_queue_try_pop_unlocked: - * @queue: a #GAsyncQueue - * - * Tries to pop data from the @queue. If no data is available, - * %NULL is returned. - * - * This function must be called while holding the @queue's lock. - * - * Returns: (nullable): data from the queue or %NULL, when no data is - * available immediately. - */ - - -/** - * g_async_queue_unlock: - * @queue: a #GAsyncQueue - * - * Releases the queue's lock. - * - * Calling this function when you have not acquired - * the with g_async_queue_lock() leads to undefined - * behaviour. - */ - - -/** - * g_async_queue_unref: - * @queue: a #GAsyncQueue. - * - * Decreases the reference count of the asynchronous @queue by 1. - * - * If the reference count went to 0, the @queue will be destroyed - * and the memory allocated will be freed. So you are not allowed - * to use the @queue afterwards, as it might have disappeared. - * You do not need to hold the lock to call this function. - */ - - -/** - * g_async_queue_unref_and_unlock: - * @queue: a #GAsyncQueue - * - * Decreases the reference count of the asynchronous @queue by 1 - * and releases the lock. This function must be called while holding - * the @queue's lock. If the reference count went to 0, the @queue - * will be destroyed and the memory allocated will be freed. - * - * Deprecated: 2.8: Reference counting is done atomically. - * so g_async_queue_unref() can be used regardless of the @queue's - * lock. - */ - - -/** - * g_atexit: - * @func: (scope async): the function to call on normal program termination. - * - * Specifies a function to be called at normal program termination. - * - * Since GLib 2.8.2, on Windows g_atexit() actually is a preprocessor - * macro that maps to a call to the atexit() function in the C - * library. This means that in case the code that calls g_atexit(), - * i.e. atexit(), is in a DLL, the function will be called when the - * DLL is detached from the program. This typically makes more sense - * than that the function is called when the GLib DLL is detached, - * which happened earlier when g_atexit() was a function in the GLib - * DLL. - * - * The behaviour of atexit() in the context of dynamically loaded - * modules is not formally specified and varies wildly. - * - * On POSIX systems, calling g_atexit() (or atexit()) in a dynamically - * loaded module which is unloaded before the program terminates might - * well cause a crash at program exit. - * - * Some POSIX systems implement atexit() like Windows, and have each - * dynamically loaded module maintain an own atexit chain that is - * called when the module is unloaded. - * - * On other POSIX systems, before a dynamically loaded module is - * unloaded, the registered atexit functions (if any) residing in that - * module are called, regardless where the code that registered them - * resided. This is presumably the most robust approach. - * - * As can be seen from the above, for portability it's best to avoid - * calling g_atexit() (or atexit()) except in the main executable of a - * program. - * - * Deprecated: 2.32: It is best to avoid g_atexit(). - */ - - -/** - * g_atomic_int_add: - * @atomic: a pointer to a #gint or #guint - * @val: the value to add - * - * Atomically adds @val to the value of @atomic. - * - * Think of this operation as an atomic version of - * `{ tmp = *atomic; *atomic += val; return tmp; }`. - * - * This call acts as a full compiler and hardware memory barrier. - * - * Before version 2.30, this function did not return a value - * (but g_atomic_int_exchange_and_add() did, and had the same meaning). - * - * While @atomic has a `volatile` qualifier, this is a historical artifact and - * the pointer passed to it should not be `volatile`. - * - * Returns: the value of @atomic before the add, signed - * Since: 2.4 - */ - - -/** - * g_atomic_int_and: - * @atomic: a pointer to a #gint or #guint - * @val: the value to 'and' - * - * Performs an atomic bitwise 'and' of the value of @atomic and @val, - * storing the result back in @atomic. - * - * This call acts as a full compiler and hardware memory barrier. - * - * Think of this operation as an atomic version of - * `{ tmp = *atomic; *atomic &= val; return tmp; }`. - * - * While @atomic has a `volatile` qualifier, this is a historical artifact and - * the pointer passed to it should not be `volatile`. - * - * Returns: the value of @atomic before the operation, unsigned - * Since: 2.30 - */ - - -/** - * g_atomic_int_compare_and_exchange: - * @atomic: a pointer to a #gint or #guint - * @oldval: the value to compare with - * @newval: the value to conditionally replace with - * - * Compares @atomic to @oldval and, if equal, sets it to @newval. - * If @atomic was not equal to @oldval then no change occurs. - * - * This compare and exchange is done atomically. - * - * Think of this operation as an atomic version of - * `{ if (*atomic == oldval) { *atomic = newval; return TRUE; } else return FALSE; }`. - * - * This call acts as a full compiler and hardware memory barrier. - * - * While @atomic has a `volatile` qualifier, this is a historical artifact and - * the pointer passed to it should not be `volatile`. - * - * Returns: %TRUE if the exchange took place - * Since: 2.4 - */ - - -/** - * g_atomic_int_dec_and_test: - * @atomic: a pointer to a #gint or #guint - * - * Decrements the value of @atomic by 1. - * - * Think of this operation as an atomic version of - * `{ *atomic -= 1; return (*atomic == 0); }`. - * - * This call acts as a full compiler and hardware memory barrier. - * - * While @atomic has a `volatile` qualifier, this is a historical artifact and - * the pointer passed to it should not be `volatile`. - * - * Returns: %TRUE if the resultant value is zero - * Since: 2.4 - */ - - -/** - * g_atomic_int_exchange_and_add: - * @atomic: a pointer to a #gint - * @val: the value to add - * - * This function existed before g_atomic_int_add() returned the prior - * value of the integer (which it now does). It is retained only for - * compatibility reasons. Don't use this function in new code. - * - * Returns: the value of @atomic before the add, signed - * Since: 2.4 - * Deprecated: 2.30: Use g_atomic_int_add() instead. - */ - - -/** - * g_atomic_int_get: - * @atomic: a pointer to a #gint or #guint - * - * Gets the current value of @atomic. - * - * This call acts as a full compiler and hardware - * memory barrier (before the get). - * - * While @atomic has a `volatile` qualifier, this is a historical artifact and - * the pointer passed to it should not be `volatile`. - * - * Returns: the value of the integer - * Since: 2.4 - */ - - -/** - * g_atomic_int_inc: - * @atomic: a pointer to a #gint or #guint - * - * Increments the value of @atomic by 1. - * - * Think of this operation as an atomic version of `{ *atomic += 1; }`. - * - * This call acts as a full compiler and hardware memory barrier. - * - * While @atomic has a `volatile` qualifier, this is a historical artifact and - * the pointer passed to it should not be `volatile`. - * - * Since: 2.4 - */ - - -/** - * g_atomic_int_or: - * @atomic: a pointer to a #gint or #guint - * @val: the value to 'or' - * - * Performs an atomic bitwise 'or' of the value of @atomic and @val, - * storing the result back in @atomic. - * - * Think of this operation as an atomic version of - * `{ tmp = *atomic; *atomic |= val; return tmp; }`. - * - * This call acts as a full compiler and hardware memory barrier. - * - * While @atomic has a `volatile` qualifier, this is a historical artifact and - * the pointer passed to it should not be `volatile`. - * - * Returns: the value of @atomic before the operation, unsigned - * Since: 2.30 - */ - - -/** - * g_atomic_int_set: - * @atomic: a pointer to a #gint or #guint - * @newval: a new value to store - * - * Sets the value of @atomic to @newval. - * - * This call acts as a full compiler and hardware - * memory barrier (after the set). - * - * While @atomic has a `volatile` qualifier, this is a historical artifact and - * the pointer passed to it should not be `volatile`. - * - * Since: 2.4 - */ - - -/** - * g_atomic_int_xor: - * @atomic: a pointer to a #gint or #guint - * @val: the value to 'xor' - * - * Performs an atomic bitwise 'xor' of the value of @atomic and @val, - * storing the result back in @atomic. - * - * Think of this operation as an atomic version of - * `{ tmp = *atomic; *atomic ^= val; return tmp; }`. - * - * This call acts as a full compiler and hardware memory barrier. - * - * While @atomic has a `volatile` qualifier, this is a historical artifact and - * the pointer passed to it should not be `volatile`. - * - * Returns: the value of @atomic before the operation, unsigned - * Since: 2.30 - */ - - -/** - * g_atomic_pointer_add: - * @atomic: (not nullable): a pointer to a #gpointer-sized value - * @val: the value to add - * - * Atomically adds @val to the value of @atomic. - * - * Think of this operation as an atomic version of - * `{ tmp = *atomic; *atomic += val; return tmp; }`. - * - * This call acts as a full compiler and hardware memory barrier. - * - * While @atomic has a `volatile` qualifier, this is a historical artifact and - * the pointer passed to it should not be `volatile`. - * - * Returns: the value of @atomic before the add, signed - * Since: 2.30 - */ - - -/** - * g_atomic_pointer_and: - * @atomic: (not nullable): a pointer to a #gpointer-sized value - * @val: the value to 'and' - * - * Performs an atomic bitwise 'and' of the value of @atomic and @val, - * storing the result back in @atomic. - * - * Think of this operation as an atomic version of - * `{ tmp = *atomic; *atomic &= val; return tmp; }`. - * - * This call acts as a full compiler and hardware memory barrier. - * - * While @atomic has a `volatile` qualifier, this is a historical artifact and - * the pointer passed to it should not be `volatile`. - * - * Returns: the value of @atomic before the operation, unsigned - * Since: 2.30 - */ - - -/** - * g_atomic_pointer_compare_and_exchange: - * @atomic: (not nullable): a pointer to a #gpointer-sized value - * @oldval: the value to compare with - * @newval: the value to conditionally replace with - * - * Compares @atomic to @oldval and, if equal, sets it to @newval. - * If @atomic was not equal to @oldval then no change occurs. - * - * This compare and exchange is done atomically. - * - * Think of this operation as an atomic version of - * `{ if (*atomic == oldval) { *atomic = newval; return TRUE; } else return FALSE; }`. - * - * This call acts as a full compiler and hardware memory barrier. - * - * While @atomic has a `volatile` qualifier, this is a historical artifact and - * the pointer passed to it should not be `volatile`. - * - * Returns: %TRUE if the exchange took place - * Since: 2.4 - */ - - -/** - * g_atomic_pointer_get: - * @atomic: (not nullable): a pointer to a #gpointer-sized value - * - * Gets the current value of @atomic. - * - * This call acts as a full compiler and hardware - * memory barrier (before the get). - * - * While @atomic has a `volatile` qualifier, this is a historical artifact and - * the pointer passed to it should not be `volatile`. - * - * Returns: the value of the pointer - * Since: 2.4 - */ - - -/** - * g_atomic_pointer_or: - * @atomic: (not nullable): a pointer to a #gpointer-sized value - * @val: the value to 'or' - * - * Performs an atomic bitwise 'or' of the value of @atomic and @val, - * storing the result back in @atomic. - * - * Think of this operation as an atomic version of - * `{ tmp = *atomic; *atomic |= val; return tmp; }`. - * - * This call acts as a full compiler and hardware memory barrier. - * - * While @atomic has a `volatile` qualifier, this is a historical artifact and - * the pointer passed to it should not be `volatile`. - * - * Returns: the value of @atomic before the operation, unsigned - * Since: 2.30 - */ - - -/** - * g_atomic_pointer_set: - * @atomic: (not nullable): a pointer to a #gpointer-sized value - * @newval: a new value to store - * - * Sets the value of @atomic to @newval. - * - * This call acts as a full compiler and hardware - * memory barrier (after the set). - * - * While @atomic has a `volatile` qualifier, this is a historical artifact and - * the pointer passed to it should not be `volatile`. - * - * Since: 2.4 - */ - - -/** - * g_atomic_pointer_xor: - * @atomic: (not nullable): a pointer to a #gpointer-sized value - * @val: the value to 'xor' - * - * Performs an atomic bitwise 'xor' of the value of @atomic and @val, - * storing the result back in @atomic. - * - * Think of this operation as an atomic version of - * `{ tmp = *atomic; *atomic ^= val; return tmp; }`. - * - * This call acts as a full compiler and hardware memory barrier. - * - * While @atomic has a `volatile` qualifier, this is a historical artifact and - * the pointer passed to it should not be `volatile`. - * - * Returns: the value of @atomic before the operation, unsigned - * Since: 2.30 - */ - - -/** - * g_atomic_rc_box_acquire: - * @mem_block: (not nullable): a pointer to reference counted data - * - * Atomically acquires a reference on the data pointed by @mem_block. - * - * Returns: (transfer full) (not nullable): a pointer to the data, - * with its reference count increased - * Since: 2.58 - */ - - -/** - * g_atomic_rc_box_alloc: - * @block_size: the size of the allocation, must be greater than 0 - * - * Allocates @block_size bytes of memory, and adds atomic - * reference counting semantics to it. - * - * The data will be freed when its reference count drops to - * zero. - * - * The allocated data is guaranteed to be suitably aligned for any - * built-in type. - * - * Returns: (transfer full) (not nullable): a pointer to the allocated memory - * Since: 2.58 - */ - - -/** - * g_atomic_rc_box_alloc0: - * @block_size: the size of the allocation, must be greater than 0 - * - * Allocates @block_size bytes of memory, and adds atomic - * reference counting semantics to it. - * - * The contents of the returned data is set to zero. - * - * The data will be freed when its reference count drops to - * zero. - * - * The allocated data is guaranteed to be suitably aligned for any - * built-in type. - * - * Returns: (transfer full) (not nullable): a pointer to the allocated memory - * Since: 2.58 - */ - - -/** - * g_atomic_rc_box_dup: - * @block_size: the number of bytes to copy, must be greater than 0 - * @mem_block: (not nullable): the memory to copy - * - * Allocates a new block of data with atomic reference counting - * semantics, and copies @block_size bytes of @mem_block - * into it. - * - * Returns: (transfer full) (not nullable): a pointer to the allocated - * memory - * Since: 2.58 - */ - - -/** - * g_atomic_rc_box_get_size: - * @mem_block: (not nullable): a pointer to reference counted data - * - * Retrieves the size of the reference counted data pointed by @mem_block. - * - * Returns: the size of the data, in bytes - * Since: 2.58 - */ - - -/** - * g_atomic_rc_box_new: - * @type: the type to allocate, typically a structure name - * - * A convenience macro to allocate atomically reference counted - * data with the size of the given @type. - * - * This macro calls g_atomic_rc_box_alloc() with `sizeof (@type)` and - * casts the returned pointer to a pointer of the given @type, - * avoiding a type cast in the source code. - * - * Returns: (transfer full) (not nullable): a pointer to the allocated - * memory, cast to a pointer for the given @type - * Since: 2.58 - */ - - -/** - * g_atomic_rc_box_new0: - * @type: the type to allocate, typically a structure name - * - * A convenience macro to allocate atomically reference counted - * data with the size of the given @type, and set its contents - * to zero. - * - * This macro calls g_atomic_rc_box_alloc0() with `sizeof (@type)` and - * casts the returned pointer to a pointer of the given @type, - * avoiding a type cast in the source code. - * - * Returns: (transfer full) (not nullable): a pointer to the allocated - * memory, cast to a pointer for the given @type - * Since: 2.58 - */ - - -/** - * g_atomic_rc_box_release: - * @mem_block: (transfer full) (not nullable): a pointer to reference counted data - * - * Atomically releases a reference on the data pointed by @mem_block. - * - * If the reference was the last one, it will free the - * resources allocated for @mem_block. - * - * Since: 2.58 - */ - - -/** - * g_atomic_rc_box_release_full: - * @mem_block: (transfer full) (not nullable): a pointer to reference counted data - * @clear_func: (not nullable): a function to call when clearing the data - * - * Atomically releases a reference on the data pointed by @mem_block. - * - * If the reference was the last one, it will call @clear_func - * to clear the contents of @mem_block, and then will free the - * resources allocated for @mem_block. - * - * Since: 2.58 - */ - - -/** - * g_atomic_ref_count_compare: - * @arc: the address of an atomic reference count variable - * @val: the value to compare - * - * Atomically compares the current value of @arc with @val. - * - * Returns: %TRUE if the reference count is the same - * as the given value - * Since: 2.58 - */ - - -/** - * g_atomic_ref_count_dec: - * @arc: the address of an atomic reference count variable - * - * Atomically decreases the reference count. - * - * If %TRUE is returned, the reference count reached 0. After this point, @arc - * is an undefined state and must be reinitialized with - * g_atomic_ref_count_init() to be used again. - * - * Returns: %TRUE if the reference count reached 0, and %FALSE otherwise - * Since: 2.58 - */ - - -/** - * g_atomic_ref_count_inc: - * @arc: the address of an atomic reference count variable - * - * Atomically increases the reference count. - * - * Since: 2.58 - */ - - -/** - * g_atomic_ref_count_init: - * @arc: the address of an atomic reference count variable - * - * Initializes a reference count variable to 1. - * - * Since: 2.58 - */ - - -/** - * g_auto: - * @TypeName: a supported variable type - * - * Helper to declare a variable with automatic cleanup. - * - * The variable is cleaned up in a way appropriate to its type when the - * variable goes out of scope. The type must support this. - * The way to clean up the type must have been defined using one of the macros - * G_DEFINE_AUTO_CLEANUP_CLEAR_FUNC() or G_DEFINE_AUTO_CLEANUP_FREE_FUNC(). - * - * This feature is only supported on GCC and clang. This macro is not - * defined on other compilers and should not be used in programs that - * are intended to be portable to those compilers. - * - * This is meant to be used with stack-allocated structures and - * non-pointer types. For the (more commonly used) pointer version, see - * g_autoptr(). - * - * This macro can be used to avoid having to do explicit cleanups of - * local variables when exiting functions. It often vastly simplifies - * handling of error conditions, removing the need for various tricks - * such as `goto out` or repeating of cleanup code. It is also helpful - * for non-error cases. - * - * Consider the following example: - * - * |[ - * GVariant * - * my_func(void) - * { - * g_auto(GQueue) queue = G_QUEUE_INIT; - * g_auto(GVariantBuilder) builder; - * g_auto(GStrv) strv; - * - * g_variant_builder_init (&builder, G_VARIANT_TYPE_VARDICT); - * strv = g_strsplit("a:b:c", ":", -1); - * - * ... - * - * if (error_condition) - * return NULL; - * - * ... - * - * return g_variant_builder_end (&builder); - * } - * ]| - * - * You must initialize the variable in some way — either by use of an - * initialiser or by ensuring that an `_init` function will be called on - * it unconditionally before it goes out of scope. - * - * Since: 2.44 - */ - - -/** - * g_autofree: - * - * Macro to add an attribute to pointer variable to ensure automatic - * cleanup using g_free(). - * - * This macro differs from g_autoptr() in that it is an attribute supplied - * before the type name, rather than wrapping the type definition. Instead - * of using a type-specific lookup, this macro always calls g_free() directly. - * - * This means it's useful for any type that is returned from - * g_malloc(). - * - * Otherwise, this macro has similar constraints as g_autoptr(): only - * supported on GCC and clang, the variable must be initialized, etc. - * - * |[ - * gboolean - * operate_on_malloc_buf (void) - * { - * g_autofree guint8* membuf = NULL; - * - * membuf = g_malloc (8192); - * - * // Some computation on membuf - * - * // membuf will be automatically freed here - * return TRUE; - * } - * ]| - * - * Since: 2.44 - */ - - -/** - * g_autolist: - * @TypeName: a supported variable type - * - * Helper to declare a list variable with automatic deep cleanup. - * - * The list is deeply freed, in a way appropriate to the specified type, when the - * variable goes out of scope. The type must support this. - * - * This feature is only supported on GCC and clang. This macro is not - * defined on other compilers and should not be used in programs that - * are intended to be portable to those compilers. - * - * This is meant to be used to declare lists of a type with a cleanup - * function. The type of the variable is a `GList *`. You - * must not add your own `*`. - * - * This macro can be used to avoid having to do explicit cleanups of - * local variables when exiting functions. It often vastly simplifies - * handling of error conditions, removing the need for various tricks - * such as `goto out` or repeating of cleanup code. It is also helpful - * for non-error cases. - * - * See also g_autoslist(), g_autoptr() and g_steal_pointer(). - * - * Since: 2.56 - */ - - -/** - * g_autoptr: - * @TypeName: a supported variable type - * - * Helper to declare a pointer variable with automatic cleanup. - * - * The variable is cleaned up in a way appropriate to its type when the - * variable goes out of scope. The type must support this. - * The way to clean up the type must have been defined using the macro - * G_DEFINE_AUTOPTR_CLEANUP_FUNC(). - * - * This feature is only supported on GCC and clang. This macro is not - * defined on other compilers and should not be used in programs that - * are intended to be portable to those compilers. - * - * This is meant to be used to declare pointers to types with cleanup - * functions. The type of the variable is a pointer to @TypeName. You - * must not add your own `*`. - * - * This macro can be used to avoid having to do explicit cleanups of - * local variables when exiting functions. It often vastly simplifies - * handling of error conditions, removing the need for various tricks - * such as `goto out` or repeating of cleanup code. It is also helpful - * for non-error cases. - * - * Consider the following example: - * - * |[ - * gboolean - * check_exists(GVariant *dict) - * { - * g_autoptr(GVariant) dirname, basename = NULL; - * g_autofree gchar *path = NULL; - * - * dirname = g_variant_lookup_value (dict, "dirname", G_VARIANT_TYPE_STRING); - * - * if (dirname == NULL) - * return FALSE; - * - * basename = g_variant_lookup_value (dict, "basename", G_VARIANT_TYPE_STRING); - * - * if (basename == NULL) - * return FALSE; - * - * path = g_build_filename (g_variant_get_string (dirname, NULL), - * g_variant_get_string (basename, NULL), - * NULL); - * - * return g_access (path, R_OK) == 0; - * } - * ]| - * - * You must initialise the variable in some way — either by use of an - * initialiser or by ensuring that it is assigned to unconditionally - * before it goes out of scope. - * - * See also g_auto(), g_autofree() and g_steal_pointer(). - * - * Since: 2.44 - */ - - -/** - * g_autoqueue: - * @TypeName: a supported variable type - * - * Helper to declare a double-ended queue variable with automatic deep cleanup. - * - * The queue is deeply freed, in a way appropriate to the specified type, when the - * variable goes out of scope. The type must support this. - * - * This feature is only supported on GCC and clang. This macro is not - * defined on other compilers and should not be used in programs that - * are intended to be portable to those compilers. - * - * This is meant to be used to declare queues of a type with a cleanup - * function. The type of the variable is a `GQueue *`. You - * must not add your own `*`. - * - * This macro can be used to avoid having to do explicit cleanups of - * local variables when exiting functions. It often vastly simplifies - * handling of error conditions, removing the need for various tricks - * such as `goto out` or repeating of cleanup code. It is also helpful - * for non-error cases. - * - * See also g_autolist(), g_autoptr() and g_steal_pointer(). - * - * Since: 2.62 - */ - - -/** - * g_autoslist: - * @TypeName: a supported variable type - * - * Helper to declare a singly linked list variable with automatic deep cleanup. - * - * The list is deeply freed, in a way appropriate to the specified type, when the - * variable goes out of scope. The type must support this. - * - * This feature is only supported on GCC and clang. This macro is not - * defined on other compilers and should not be used in programs that - * are intended to be portable to those compilers. - * - * This is meant to be used to declare lists of a type with a cleanup - * function. The type of the variable is a `GSList *`. You - * must not add your own `*`. - * - * This macro can be used to avoid having to do explicit cleanups of - * local variables when exiting functions. It often vastly simplifies - * handling of error conditions, removing the need for various tricks - * such as `goto out` or repeating of cleanup code. It is also helpful - * for non-error cases. - * - * See also g_autolist(), g_autoptr() and g_steal_pointer(). - * - * Since: 2.56 - */ - - -/** - * g_base64_decode: - * @text: (not nullable): zero-terminated string with base64 text to decode - * @out_len: (out): The length of the decoded data is written here - * - * Decode a sequence of Base-64 encoded text into binary data. Note - * that the returned binary data is not necessarily zero-terminated, - * so it should not be used as a character string. - * - * Returns: (transfer full) (array length=out_len) (element-type guint8): - * newly allocated buffer containing the binary data - * that @text represents. The returned buffer must - * be freed with g_free(). - * Since: 2.12 - */ - - -/** - * g_base64_decode_inplace: - * @text: (inout) (array length=out_len) (element-type guint8): zero-terminated - * string with base64 text to decode - * @out_len: (inout): The length of the decoded data is written here - * - * Decode a sequence of Base-64 encoded text into binary data - * by overwriting the input data. - * - * Returns: (transfer none): The binary data that @text responds. This pointer - * is the same as the input @text. - * Since: 2.20 - */ - - -/** - * g_base64_decode_step: (skip) - * @in: (array length=len) (element-type guint8): binary input data - * @len: max length of @in data to decode - * @out: (out caller-allocates) (array) (element-type guint8): output buffer - * @state: (inout): Saved state between steps, initialize to 0 - * @save: (inout): Saved state between steps, initialize to 0 - * - * Incrementally decode a sequence of binary data from its Base-64 stringified - * representation. By calling this function multiple times you can convert - * data in chunks to avoid having to have the full encoded data in memory. - * - * The output buffer must be large enough to fit all the data that will - * be written to it. Since base64 encodes 3 bytes in 4 chars you need - * at least: (@len / 4) * 3 + 3 bytes (+ 3 may be needed in case of non-zero - * state). - * - * Returns: The number of bytes of output that was written - * Since: 2.12 - */ - - -/** - * g_base64_encode: - * @data: (array length=len) (element-type guint8) (nullable): the binary data to encode - * @len: the length of @data - * - * Encode a sequence of binary data into its Base-64 stringified - * representation. - * - * Returns: (transfer full): a newly allocated, zero-terminated Base-64 - * encoded string representing @data. The returned string must - * be freed with g_free(). - * Since: 2.12 - */ - - -/** - * g_base64_encode_close: - * @break_lines: whether to break long lines - * @out: (out) (array) (element-type guint8): pointer to destination buffer - * @state: (inout): Saved state from g_base64_encode_step() - * @save: (inout): Saved state from g_base64_encode_step() - * - * Flush the status from a sequence of calls to g_base64_encode_step(). - * - * The output buffer must be large enough to fit all the data that will - * be written to it. It will need up to 4 bytes, or up to 5 bytes if - * line-breaking is enabled. - * - * The @out array will not be automatically nul-terminated. - * - * Returns: The number of bytes of output that was written - * Since: 2.12 - */ - - -/** - * g_base64_encode_step: - * @in: (array length=len) (element-type guint8): the binary data to encode - * @len: the length of @in - * @break_lines: whether to break long lines - * @out: (out) (array) (element-type guint8): pointer to destination buffer - * @state: (inout): Saved state between steps, initialize to 0 - * @save: (inout): Saved state between steps, initialize to 0 - * - * Incrementally encode a sequence of binary data into its Base-64 stringified - * representation. By calling this function multiple times you can convert - * data in chunks to avoid having to have the full encoded data in memory. - * - * When all of the data has been converted you must call - * g_base64_encode_close() to flush the saved state. - * - * The output buffer must be large enough to fit all the data that will - * be written to it. Due to the way base64 encodes you will need - * at least: (@len / 3 + 1) * 4 + 4 bytes (+ 4 may be needed in case of - * non-zero state). If you enable line-breaking you will need at least: - * ((@len / 3 + 1) * 4 + 4) / 76 + 1 bytes of extra space. - * - * @break_lines is typically used when putting base64-encoded data in emails. - * It breaks the lines at 76 columns instead of putting all of the text on - * the same line. This avoids problems with long lines in the email system. - * Note however that it breaks the lines with `LF` characters, not - * `CR LF` sequences, so the result cannot be passed directly to SMTP - * or certain other protocols. - * - * Returns: The number of bytes of output that was written - * Since: 2.12 - */ - - -/** - * g_basename: - * @file_name: (type filename): the name of the file - * - * Gets the name of the file without any leading directory - * components. It returns a pointer into the given file name - * string. - * - * Returns: (type filename): the name of the file without any leading - * directory components - * Deprecated: 2.2: Use g_path_get_basename() instead, but notice - * that g_path_get_basename() allocates new memory for the - * returned string, unlike this function which returns a pointer - * into the argument. - */ - - -/** - * g_bit_lock: - * @address: a pointer to an integer - * @lock_bit: a bit value between 0 and 31 - * - * Sets the indicated @lock_bit in @address. If the bit is already - * set, this call will block until g_bit_unlock() unsets the - * corresponding bit. - * - * Attempting to lock on two different bits within the same integer is - * not supported and will very probably cause deadlocks. - * - * The value of the bit that is set is (1u << @bit). If @bit is not - * between 0 and 31 then the result is undefined. - * - * This function accesses @address atomically. All other accesses to - * @address must be atomic in order for this function to work - * reliably. While @address has a `volatile` qualifier, this is a historical - * artifact and the argument passed to it should not be `volatile`. - * - * Since: 2.24 - */ - - -/** - * g_bit_nth_lsf: - * @mask: a #gulong containing flags - * @nth_bit: the index of the bit to start the search from - * - * Find the position of the first bit set in @mask, searching - * from (but not including) @nth_bit upwards. Bits are numbered - * from 0 (least significant) to sizeof(#gulong) * 8 - 1 (31 or 63, - * usually). To start searching from the 0th bit, set @nth_bit to -1. - * - * Returns: the index of the first bit set which is higher than @nth_bit, or -1 - * if no higher bits are set - */ - - -/** - * g_bit_nth_msf: - * @mask: a #gulong containing flags - * @nth_bit: the index of the bit to start the search from - * - * Find the position of the first bit set in @mask, searching - * from (but not including) @nth_bit downwards. Bits are numbered - * from 0 (least significant) to sizeof(#gulong) * 8 - 1 (31 or 63, - * usually). To start searching from the last bit, set @nth_bit to - * -1 or GLIB_SIZEOF_LONG * 8. - * - * Returns: the index of the first bit set which is lower than @nth_bit, or -1 - * if no lower bits are set - */ - - -/** - * g_bit_storage: - * @number: a #guint - * - * Gets the number of bits used to hold @number, - * e.g. if @number is 4, 3 bits are needed. - * - * Returns: the number of bits used to hold @number - */ - - -/** - * g_bit_trylock: - * @address: a pointer to an integer - * @lock_bit: a bit value between 0 and 31 - * - * Sets the indicated @lock_bit in @address, returning %TRUE if - * successful. If the bit is already set, returns %FALSE immediately. - * - * Attempting to lock on two different bits within the same integer is - * not supported. - * - * The value of the bit that is set is (1u << @bit). If @bit is not - * between 0 and 31 then the result is undefined. - * - * This function accesses @address atomically. All other accesses to - * @address must be atomic in order for this function to work - * reliably. While @address has a `volatile` qualifier, this is a historical - * artifact and the argument passed to it should not be `volatile`. - * - * Returns: %TRUE if the lock was acquired - * Since: 2.24 - */ - - -/** - * g_bit_unlock: - * @address: a pointer to an integer - * @lock_bit: a bit value between 0 and 31 - * - * Clears the indicated @lock_bit in @address. If another thread is - * currently blocked in g_bit_lock() on this same bit then it will be - * woken up. - * - * This function accesses @address atomically. All other accesses to - * @address must be atomic in order for this function to work - * reliably. While @address has a `volatile` qualifier, this is a historical - * artifact and the argument passed to it should not be `volatile`. - * - * Since: 2.24 - */ - - -/** - * g_bookmark_file_add_application: - * @bookmark: a #GBookmarkFile - * @uri: a valid URI - * @name: (nullable): the name of the application registering the bookmark - * or %NULL - * @exec: (nullable): command line to be used to launch the bookmark or %NULL - * - * Adds the application with @name and @exec to the list of - * applications that have registered a bookmark for @uri into - * @bookmark. - * - * Every bookmark inside a #GBookmarkFile must have at least an - * application registered. Each application must provide a name, a - * command line useful for launching the bookmark, the number of times - * the bookmark has been registered by the application and the last - * time the application registered this bookmark. - * - * If @name is %NULL, the name of the application will be the - * same returned by g_get_application_name(); if @exec is %NULL, the - * command line will be a composition of the program name as - * returned by g_get_prgname() and the "\%u" modifier, which will be - * expanded to the bookmark's URI. - * - * This function will automatically take care of updating the - * registrations count and timestamping in case an application - * with the same @name had already registered a bookmark for - * @uri inside @bookmark. - * - * If no bookmark for @uri is found, one is created. - * - * Since: 2.12 - */ - - -/** - * g_bookmark_file_add_group: - * @bookmark: a #GBookmarkFile - * @uri: a valid URI - * @group: the group name to be added - * - * Adds @group to the list of groups to which the bookmark for @uri - * belongs to. - * - * If no bookmark for @uri is found then it is created. - * - * Since: 2.12 - */ - - -/** - * g_bookmark_file_free: - * @bookmark: a #GBookmarkFile - * - * Frees a #GBookmarkFile. - * - * Since: 2.12 - */ - - -/** - * g_bookmark_file_get_added: - * @bookmark: a #GBookmarkFile - * @uri: a valid URI - * @error: return location for a #GError, or %NULL - * - * Gets the time the bookmark for @uri was added to @bookmark - * - * In the event the URI cannot be found, -1 is returned and - * @error is set to #G_BOOKMARK_FILE_ERROR_URI_NOT_FOUND. - * - * Returns: a timestamp - * Since: 2.12 - * Deprecated: 2.66: Use g_bookmark_file_get_added_date_time() instead, as - * `time_t` is deprecated due to the year 2038 problem. - */ - - -/** - * g_bookmark_file_get_added_date_time: - * @bookmark: a #GBookmarkFile - * @uri: a valid URI - * @error: return location for a #GError, or %NULL - * - * Gets the time the bookmark for @uri was added to @bookmark - * - * In the event the URI cannot be found, %NULL is returned and - * @error is set to #G_BOOKMARK_FILE_ERROR_URI_NOT_FOUND. - * - * Returns: (transfer none): a #GDateTime - * Since: 2.66 - */ - - -/** - * g_bookmark_file_get_app_info: - * @bookmark: a #GBookmarkFile - * @uri: a valid URI - * @name: an application's name - * @exec: (out) (optional): return location for the command line of the application, or %NULL - * @count: (out) (optional): return location for the registration count, or %NULL - * @stamp: (out) (optional): return location for the last registration time, or %NULL - * @error: return location for a #GError, or %NULL - * - * Gets the registration information of @app_name for the bookmark for - * @uri. See g_bookmark_file_set_application_info() for more information about - * the returned data. - * - * The string returned in @app_exec must be freed. - * - * In the event the URI cannot be found, %FALSE is returned and - * @error is set to #G_BOOKMARK_FILE_ERROR_URI_NOT_FOUND. In the - * event that no application with name @app_name has registered a bookmark - * for @uri, %FALSE is returned and error is set to - * #G_BOOKMARK_FILE_ERROR_APP_NOT_REGISTERED. In the event that unquoting - * the command line fails, an error of the #G_SHELL_ERROR domain is - * set and %FALSE is returned. - * - * Returns: %TRUE on success. - * Since: 2.12 - * Deprecated: 2.66: Use g_bookmark_file_get_application_info() instead, as - * `time_t` is deprecated due to the year 2038 problem. - */ - - -/** - * g_bookmark_file_get_application_info: - * @bookmark: a #GBookmarkFile - * @uri: a valid URI - * @name: an application's name - * @exec: (out) (optional): return location for the command line of the application, or %NULL - * @count: (out) (optional): return location for the registration count, or %NULL - * @stamp: (out) (optional) (transfer none): return location for the last registration time, or %NULL - * @error: return location for a #GError, or %NULL - * - * Gets the registration information of @app_name for the bookmark for - * @uri. See g_bookmark_file_set_application_info() for more information about - * the returned data. - * - * The string returned in @app_exec must be freed. - * - * In the event the URI cannot be found, %FALSE is returned and - * @error is set to #G_BOOKMARK_FILE_ERROR_URI_NOT_FOUND. In the - * event that no application with name @app_name has registered a bookmark - * for @uri, %FALSE is returned and error is set to - * #G_BOOKMARK_FILE_ERROR_APP_NOT_REGISTERED. In the event that unquoting - * the command line fails, an error of the #G_SHELL_ERROR domain is - * set and %FALSE is returned. - * - * Returns: %TRUE on success. - * Since: 2.66 - */ - - -/** - * g_bookmark_file_get_applications: - * @bookmark: a #GBookmarkFile - * @uri: a valid URI - * @length: (out) (optional): return location of the length of the returned list, or %NULL - * @error: return location for a #GError, or %NULL - * - * Retrieves the names of the applications that have registered the - * bookmark for @uri. - * - * In the event the URI cannot be found, %NULL is returned and - * @error is set to #G_BOOKMARK_FILE_ERROR_URI_NOT_FOUND. - * - * Returns: (array length=length) (transfer full): a newly allocated %NULL-terminated array of strings. - * Use g_strfreev() to free it. - * Since: 2.12 - */ - - -/** - * g_bookmark_file_get_description: - * @bookmark: a #GBookmarkFile - * @uri: a valid URI - * @error: return location for a #GError, or %NULL - * - * Retrieves the description of the bookmark for @uri. - * - * In the event the URI cannot be found, %NULL is returned and - * @error is set to #G_BOOKMARK_FILE_ERROR_URI_NOT_FOUND. - * - * Returns: (transfer full): a newly allocated string or %NULL if the specified - * URI cannot be found. - * Since: 2.12 - */ - - -/** - * g_bookmark_file_get_groups: - * @bookmark: a #GBookmarkFile - * @uri: a valid URI - * @length: (out) (optional): return location for the length of the returned string, or %NULL - * @error: return location for a #GError, or %NULL - * - * Retrieves the list of group names of the bookmark for @uri. - * - * In the event the URI cannot be found, %NULL is returned and - * @error is set to #G_BOOKMARK_FILE_ERROR_URI_NOT_FOUND. - * - * The returned array is %NULL terminated, so @length may optionally - * be %NULL. - * - * Returns: (array length=length) (transfer full): a newly allocated %NULL-terminated array of group names. - * Use g_strfreev() to free it. - * Since: 2.12 - */ - - -/** - * g_bookmark_file_get_icon: - * @bookmark: a #GBookmarkFile - * @uri: a valid URI - * @href: (out) (optional): return location for the icon's location or %NULL - * @mime_type: (out) (optional): return location for the icon's MIME type or %NULL - * @error: return location for a #GError or %NULL - * - * Gets the icon of the bookmark for @uri. - * - * In the event the URI cannot be found, %FALSE is returned and - * @error is set to #G_BOOKMARK_FILE_ERROR_URI_NOT_FOUND. - * - * Returns: %TRUE if the icon for the bookmark for the URI was found. - * You should free the returned strings. - * Since: 2.12 - */ - - -/** - * g_bookmark_file_get_is_private: - * @bookmark: a #GBookmarkFile - * @uri: a valid URI - * @error: return location for a #GError, or %NULL - * - * Gets whether the private flag of the bookmark for @uri is set. - * - * In the event the URI cannot be found, %FALSE is returned and - * @error is set to #G_BOOKMARK_FILE_ERROR_URI_NOT_FOUND. In the - * event that the private flag cannot be found, %FALSE is returned and - * @error is set to #G_BOOKMARK_FILE_ERROR_INVALID_VALUE. - * - * Returns: %TRUE if the private flag is set, %FALSE otherwise. - * Since: 2.12 - */ - - -/** - * g_bookmark_file_get_mime_type: - * @bookmark: a #GBookmarkFile - * @uri: a valid URI - * @error: return location for a #GError, or %NULL - * - * Retrieves the MIME type of the resource pointed by @uri. - * - * In the event the URI cannot be found, %NULL is returned and - * @error is set to #G_BOOKMARK_FILE_ERROR_URI_NOT_FOUND. In the - * event that the MIME type cannot be found, %NULL is returned and - * @error is set to #G_BOOKMARK_FILE_ERROR_INVALID_VALUE. - * - * Returns: (transfer full): a newly allocated string or %NULL if the specified - * URI cannot be found. - * Since: 2.12 - */ - - -/** - * g_bookmark_file_get_modified: - * @bookmark: a #GBookmarkFile - * @uri: a valid URI - * @error: return location for a #GError, or %NULL - * - * Gets the time when the bookmark for @uri was last modified. - * - * In the event the URI cannot be found, -1 is returned and - * @error is set to #G_BOOKMARK_FILE_ERROR_URI_NOT_FOUND. - * - * Returns: a timestamp - * Since: 2.12 - * Deprecated: 2.66: Use g_bookmark_file_get_modified_date_time() instead, as - * `time_t` is deprecated due to the year 2038 problem. - */ - - -/** - * g_bookmark_file_get_modified_date_time: - * @bookmark: a #GBookmarkFile - * @uri: a valid URI - * @error: return location for a #GError, or %NULL - * - * Gets the time when the bookmark for @uri was last modified. - * - * In the event the URI cannot be found, %NULL is returned and - * @error is set to #G_BOOKMARK_FILE_ERROR_URI_NOT_FOUND. - * - * Returns: (transfer none): a #GDateTime - * Since: 2.66 - */ - - -/** - * g_bookmark_file_get_size: - * @bookmark: a #GBookmarkFile - * - * Gets the number of bookmarks inside @bookmark. - * - * Returns: the number of bookmarks - * Since: 2.12 - */ - - -/** - * g_bookmark_file_get_title: - * @bookmark: a #GBookmarkFile - * @uri: (nullable): a valid URI or %NULL - * @error: return location for a #GError, or %NULL - * - * Returns the title of the bookmark for @uri. - * - * If @uri is %NULL, the title of @bookmark is returned. - * - * In the event the URI cannot be found, %NULL is returned and - * @error is set to #G_BOOKMARK_FILE_ERROR_URI_NOT_FOUND. - * - * Returns: (transfer full): a newly allocated string or %NULL if the specified - * URI cannot be found. - * Since: 2.12 - */ - - -/** - * g_bookmark_file_get_uris: - * @bookmark: a #GBookmarkFile - * @length: (out) (optional): return location for the number of returned URIs, or %NULL - * - * Returns all URIs of the bookmarks in the bookmark file @bookmark. - * The array of returned URIs will be %NULL-terminated, so @length may - * optionally be %NULL. - * - * Returns: (array length=length) (transfer full): a newly allocated %NULL-terminated array of strings. - * Use g_strfreev() to free it. - * Since: 2.12 - */ - - -/** - * g_bookmark_file_get_visited: - * @bookmark: a #GBookmarkFile - * @uri: a valid URI - * @error: return location for a #GError, or %NULL - * - * Gets the time the bookmark for @uri was last visited. - * - * In the event the URI cannot be found, -1 is returned and - * @error is set to #G_BOOKMARK_FILE_ERROR_URI_NOT_FOUND. - * - * Returns: a timestamp. - * Since: 2.12 - * Deprecated: 2.66: Use g_bookmark_file_get_visited_date_time() instead, as - * `time_t` is deprecated due to the year 2038 problem. - */ - - -/** - * g_bookmark_file_get_visited_date_time: - * @bookmark: a #GBookmarkFile - * @uri: a valid URI - * @error: return location for a #GError, or %NULL - * - * Gets the time the bookmark for @uri was last visited. - * - * In the event the URI cannot be found, %NULL is returned and - * @error is set to #G_BOOKMARK_FILE_ERROR_URI_NOT_FOUND. - * - * Returns: (transfer none): a #GDateTime - * Since: 2.66 - */ - - -/** - * g_bookmark_file_has_application: - * @bookmark: a #GBookmarkFile - * @uri: a valid URI - * @name: the name of the application - * @error: return location for a #GError or %NULL - * - * Checks whether the bookmark for @uri inside @bookmark has been - * registered by application @name. - * - * In the event the URI cannot be found, %FALSE is returned and - * @error is set to #G_BOOKMARK_FILE_ERROR_URI_NOT_FOUND. - * - * Returns: %TRUE if the application @name was found - * Since: 2.12 - */ - - -/** - * g_bookmark_file_has_group: - * @bookmark: a #GBookmarkFile - * @uri: a valid URI - * @group: the group name to be searched - * @error: return location for a #GError, or %NULL - * - * Checks whether @group appears in the list of groups to which - * the bookmark for @uri belongs to. - * - * In the event the URI cannot be found, %FALSE is returned and - * @error is set to #G_BOOKMARK_FILE_ERROR_URI_NOT_FOUND. - * - * Returns: %TRUE if @group was found. - * Since: 2.12 - */ - - -/** - * g_bookmark_file_has_item: - * @bookmark: a #GBookmarkFile - * @uri: a valid URI - * - * Looks whether the desktop bookmark has an item with its URI set to @uri. - * - * Returns: %TRUE if @uri is inside @bookmark, %FALSE otherwise - * Since: 2.12 - */ - - -/** - * g_bookmark_file_load_from_data: - * @bookmark: an empty #GBookmarkFile struct - * @data: (array length=length) (element-type guint8): desktop bookmarks - * loaded in memory - * @length: the length of @data in bytes - * @error: return location for a #GError, or %NULL - * - * Loads a bookmark file from memory into an empty #GBookmarkFile - * structure. If the object cannot be created then @error is set to a - * #GBookmarkFileError. - * - * Returns: %TRUE if a desktop bookmark could be loaded. - * Since: 2.12 - */ - - -/** - * g_bookmark_file_load_from_data_dirs: - * @bookmark: a #GBookmarkFile - * @file: (type filename): a relative path to a filename to open and parse - * @full_path: (out) (optional) (type filename): return location for a string - * containing the full path of the file, or %NULL - * @error: return location for a #GError, or %NULL - * - * This function looks for a desktop bookmark file named @file in the - * paths returned from g_get_user_data_dir() and g_get_system_data_dirs(), - * loads the file into @bookmark and returns the file's full path in - * @full_path. If the file could not be loaded then @error is - * set to either a #GFileError or #GBookmarkFileError. - * - * Returns: %TRUE if a key file could be loaded, %FALSE otherwise - * Since: 2.12 - */ - - -/** - * g_bookmark_file_load_from_file: - * @bookmark: an empty #GBookmarkFile struct - * @filename: (type filename): the path of a filename to load, in the - * GLib file name encoding - * @error: return location for a #GError, or %NULL - * - * Loads a desktop bookmark file into an empty #GBookmarkFile structure. - * If the file could not be loaded then @error is set to either a #GFileError - * or #GBookmarkFileError. - * - * Returns: %TRUE if a desktop bookmark file could be loaded - * Since: 2.12 - */ - - -/** - * g_bookmark_file_move_item: - * @bookmark: a #GBookmarkFile - * @old_uri: a valid URI - * @new_uri: (nullable): a valid URI, or %NULL - * @error: return location for a #GError or %NULL - * - * Changes the URI of a bookmark item from @old_uri to @new_uri. Any - * existing bookmark for @new_uri will be overwritten. If @new_uri is - * %NULL, then the bookmark is removed. - * - * In the event the URI cannot be found, %FALSE is returned and - * @error is set to #G_BOOKMARK_FILE_ERROR_URI_NOT_FOUND. - * - * Returns: %TRUE if the URI was successfully changed - * Since: 2.12 - */ - - -/** - * g_bookmark_file_new: (constructor) - * - * Creates a new empty #GBookmarkFile object. - * - * Use g_bookmark_file_load_from_file(), g_bookmark_file_load_from_data() - * or g_bookmark_file_load_from_data_dirs() to read an existing bookmark - * file. - * - * Returns: an empty #GBookmarkFile - * Since: 2.12 - */ - - -/** - * g_bookmark_file_remove_application: - * @bookmark: a #GBookmarkFile - * @uri: a valid URI - * @name: the name of the application - * @error: return location for a #GError or %NULL - * - * Removes application registered with @name from the list of applications - * that have registered a bookmark for @uri inside @bookmark. - * - * In the event the URI cannot be found, %FALSE is returned and - * @error is set to #G_BOOKMARK_FILE_ERROR_URI_NOT_FOUND. - * In the event that no application with name @app_name has registered - * a bookmark for @uri, %FALSE is returned and error is set to - * #G_BOOKMARK_FILE_ERROR_APP_NOT_REGISTERED. - * - * Returns: %TRUE if the application was successfully removed. - * Since: 2.12 - */ - - -/** - * g_bookmark_file_remove_group: - * @bookmark: a #GBookmarkFile - * @uri: a valid URI - * @group: the group name to be removed - * @error: return location for a #GError, or %NULL - * - * Removes @group from the list of groups to which the bookmark - * for @uri belongs to. - * - * In the event the URI cannot be found, %FALSE is returned and - * @error is set to #G_BOOKMARK_FILE_ERROR_URI_NOT_FOUND. - * In the event no group was defined, %FALSE is returned and - * @error is set to #G_BOOKMARK_FILE_ERROR_INVALID_VALUE. - * - * Returns: %TRUE if @group was successfully removed. - * Since: 2.12 - */ - - -/** - * g_bookmark_file_remove_item: - * @bookmark: a #GBookmarkFile - * @uri: a valid URI - * @error: return location for a #GError, or %NULL - * - * Removes the bookmark for @uri from the bookmark file @bookmark. - * - * Returns: %TRUE if the bookmark was removed successfully. - * Since: 2.12 - */ - - -/** - * g_bookmark_file_set_added: - * @bookmark: a #GBookmarkFile - * @uri: a valid URI - * @added: a timestamp or -1 to use the current time - * - * Sets the time the bookmark for @uri was added into @bookmark. - * - * If no bookmark for @uri is found then it is created. - * - * Since: 2.12 - * Deprecated: 2.66: Use g_bookmark_file_set_added_date_time() instead, as - * `time_t` is deprecated due to the year 2038 problem. - */ - - -/** - * g_bookmark_file_set_added_date_time: - * @bookmark: a #GBookmarkFile - * @uri: a valid URI - * @added: a #GDateTime - * - * Sets the time the bookmark for @uri was added into @bookmark. - * - * If no bookmark for @uri is found then it is created. - * - * Since: 2.66 - */ - - -/** - * g_bookmark_file_set_app_info: - * @bookmark: a #GBookmarkFile - * @uri: a valid URI - * @name: an application's name - * @exec: an application's command line - * @count: the number of registrations done for this application - * @stamp: the time of the last registration for this application - * @error: return location for a #GError or %NULL - * - * Sets the meta-data of application @name inside the list of - * applications that have registered a bookmark for @uri inside - * @bookmark. - * - * You should rarely use this function; use g_bookmark_file_add_application() - * and g_bookmark_file_remove_application() instead. - * - * @name can be any UTF-8 encoded string used to identify an - * application. - * @exec can have one of these two modifiers: "\%f", which will - * be expanded as the local file name retrieved from the bookmark's - * URI; "\%u", which will be expanded as the bookmark's URI. - * The expansion is done automatically when retrieving the stored - * command line using the g_bookmark_file_get_application_info() function. - * @count is the number of times the application has registered the - * bookmark; if is < 0, the current registration count will be increased - * by one, if is 0, the application with @name will be removed from - * the list of registered applications. - * @stamp is the Unix time of the last registration; if it is -1, the - * current time will be used. - * - * If you try to remove an application by setting its registration count to - * zero, and no bookmark for @uri is found, %FALSE is returned and - * @error is set to #G_BOOKMARK_FILE_ERROR_URI_NOT_FOUND; similarly, - * in the event that no application @name has registered a bookmark - * for @uri, %FALSE is returned and error is set to - * #G_BOOKMARK_FILE_ERROR_APP_NOT_REGISTERED. Otherwise, if no bookmark - * for @uri is found, one is created. - * - * Returns: %TRUE if the application's meta-data was successfully - * changed. - * Since: 2.12 - * Deprecated: 2.66: Use g_bookmark_file_set_application_info() instead, as - * `time_t` is deprecated due to the year 2038 problem. - */ - - -/** - * g_bookmark_file_set_application_info: - * @bookmark: a #GBookmarkFile - * @uri: a valid URI - * @name: an application's name - * @exec: an application's command line - * @count: the number of registrations done for this application - * @stamp: (nullable): the time of the last registration for this application, - * which may be %NULL if @count is 0 - * @error: return location for a #GError or %NULL - * - * Sets the meta-data of application @name inside the list of - * applications that have registered a bookmark for @uri inside - * @bookmark. - * - * You should rarely use this function; use g_bookmark_file_add_application() - * and g_bookmark_file_remove_application() instead. - * - * @name can be any UTF-8 encoded string used to identify an - * application. - * @exec can have one of these two modifiers: "\%f", which will - * be expanded as the local file name retrieved from the bookmark's - * URI; "\%u", which will be expanded as the bookmark's URI. - * The expansion is done automatically when retrieving the stored - * command line using the g_bookmark_file_get_application_info() function. - * @count is the number of times the application has registered the - * bookmark; if is < 0, the current registration count will be increased - * by one, if is 0, the application with @name will be removed from - * the list of registered applications. - * @stamp is the Unix time of the last registration. - * - * If you try to remove an application by setting its registration count to - * zero, and no bookmark for @uri is found, %FALSE is returned and - * @error is set to #G_BOOKMARK_FILE_ERROR_URI_NOT_FOUND; similarly, - * in the event that no application @name has registered a bookmark - * for @uri, %FALSE is returned and error is set to - * #G_BOOKMARK_FILE_ERROR_APP_NOT_REGISTERED. Otherwise, if no bookmark - * for @uri is found, one is created. - * - * Returns: %TRUE if the application's meta-data was successfully - * changed. - * Since: 2.66 - */ - - -/** - * g_bookmark_file_set_description: - * @bookmark: a #GBookmarkFile - * @uri: (nullable): a valid URI or %NULL - * @description: a string - * - * Sets @description as the description of the bookmark for @uri. - * - * If @uri is %NULL, the description of @bookmark is set. - * - * If a bookmark for @uri cannot be found then it is created. - * - * Since: 2.12 - */ - - -/** - * g_bookmark_file_set_groups: - * @bookmark: a #GBookmarkFile - * @uri: an item's URI - * @groups: (nullable) (array length=length) (element-type utf8): an array of - * group names, or %NULL to remove all groups - * @length: number of group name values in @groups - * - * Sets a list of group names for the item with URI @uri. Each previously - * set group name list is removed. - * - * If @uri cannot be found then an item for it is created. - * - * Since: 2.12 - */ - - -/** - * g_bookmark_file_set_icon: - * @bookmark: a #GBookmarkFile - * @uri: a valid URI - * @href: (nullable): the URI of the icon for the bookmark, or %NULL - * @mime_type: the MIME type of the icon for the bookmark - * - * Sets the icon for the bookmark for @uri. If @href is %NULL, unsets - * the currently set icon. @href can either be a full URL for the icon - * file or the icon name following the Icon Naming specification. - * - * If no bookmark for @uri is found one is created. - * - * Since: 2.12 - */ - - -/** - * g_bookmark_file_set_is_private: - * @bookmark: a #GBookmarkFile - * @uri: a valid URI - * @is_private: %TRUE if the bookmark should be marked as private - * - * Sets the private flag of the bookmark for @uri. - * - * If a bookmark for @uri cannot be found then it is created. - * - * Since: 2.12 - */ - - -/** - * g_bookmark_file_set_mime_type: - * @bookmark: a #GBookmarkFile - * @uri: a valid URI - * @mime_type: a MIME type - * - * Sets @mime_type as the MIME type of the bookmark for @uri. - * - * If a bookmark for @uri cannot be found then it is created. - * - * Since: 2.12 - */ - - -/** - * g_bookmark_file_set_modified: - * @bookmark: a #GBookmarkFile - * @uri: a valid URI - * @modified: a timestamp or -1 to use the current time - * - * Sets the last time the bookmark for @uri was last modified. - * - * If no bookmark for @uri is found then it is created. - * - * The "modified" time should only be set when the bookmark's meta-data - * was actually changed. Every function of #GBookmarkFile that - * modifies a bookmark also changes the modification time, except for - * g_bookmark_file_set_visited_date_time(). - * - * Since: 2.12 - * Deprecated: 2.66: Use g_bookmark_file_set_modified_date_time() instead, as - * `time_t` is deprecated due to the year 2038 problem. - */ - - -/** - * g_bookmark_file_set_modified_date_time: - * @bookmark: a #GBookmarkFile - * @uri: a valid URI - * @modified: a #GDateTime - * - * Sets the last time the bookmark for @uri was last modified. - * - * If no bookmark for @uri is found then it is created. - * - * The "modified" time should only be set when the bookmark's meta-data - * was actually changed. Every function of #GBookmarkFile that - * modifies a bookmark also changes the modification time, except for - * g_bookmark_file_set_visited_date_time(). - * - * Since: 2.66 - */ - - -/** - * g_bookmark_file_set_title: - * @bookmark: a #GBookmarkFile - * @uri: (nullable): a valid URI or %NULL - * @title: a UTF-8 encoded string - * - * Sets @title as the title of the bookmark for @uri inside the - * bookmark file @bookmark. - * - * If @uri is %NULL, the title of @bookmark is set. - * - * If a bookmark for @uri cannot be found then it is created. - * - * Since: 2.12 - */ - - -/** - * g_bookmark_file_set_visited: - * @bookmark: a #GBookmarkFile - * @uri: a valid URI - * @visited: a timestamp or -1 to use the current time - * - * Sets the time the bookmark for @uri was last visited. - * - * If no bookmark for @uri is found then it is created. - * - * The "visited" time should only be set if the bookmark was launched, - * either using the command line retrieved by g_bookmark_file_get_application_info() - * or by the default application for the bookmark's MIME type, retrieved - * using g_bookmark_file_get_mime_type(). Changing the "visited" time - * does not affect the "modified" time. - * - * Since: 2.12 - * Deprecated: 2.66: Use g_bookmark_file_set_visited_date_time() instead, as - * `time_t` is deprecated due to the year 2038 problem. - */ - - -/** - * g_bookmark_file_set_visited_date_time: - * @bookmark: a #GBookmarkFile - * @uri: a valid URI - * @visited: a #GDateTime - * - * Sets the time the bookmark for @uri was last visited. - * - * If no bookmark for @uri is found then it is created. - * - * The "visited" time should only be set if the bookmark was launched, - * either using the command line retrieved by g_bookmark_file_get_application_info() - * or by the default application for the bookmark's MIME type, retrieved - * using g_bookmark_file_get_mime_type(). Changing the "visited" time - * does not affect the "modified" time. - * - * Since: 2.66 - */ - - -/** - * g_bookmark_file_to_data: - * @bookmark: a #GBookmarkFile - * @length: (out) (optional): return location for the length of the returned string, or %NULL - * @error: return location for a #GError, or %NULL - * - * This function outputs @bookmark as a string. - * - * Returns: (transfer full) (array length=length) (element-type guint8): - * a newly allocated string holding the contents of the #GBookmarkFile - * Since: 2.12 - */ - - -/** - * g_bookmark_file_to_file: - * @bookmark: a #GBookmarkFile - * @filename: (type filename): path of the output file - * @error: return location for a #GError, or %NULL - * - * This function outputs @bookmark into a file. The write process is - * guaranteed to be atomic by using g_file_set_contents() internally. - * - * Returns: %TRUE if the file was successfully written. - * Since: 2.12 - */ - - -/** - * g_build_filename: - * @first_element: (type filename): the first element in the path - * @...: remaining elements in path, terminated by %NULL - * - * Creates a filename from a series of elements using the correct - * separator for filenames. - * - * On Unix, this function behaves identically to `g_build_path - * (G_DIR_SEPARATOR_S, first_element, ....)`. - * - * On Windows, it takes into account that either the backslash - * (`\` or slash (`/`) can be used as separator in filenames, but - * otherwise behaves as on UNIX. When file pathname separators need - * to be inserted, the one that last previously occurred in the - * parameters (reading from left to right) is used. - * - * No attempt is made to force the resulting filename to be an absolute - * path. If the first element is a relative path, the result will - * be a relative path. - * - * Returns: (type filename): a newly-allocated string that must be freed with - * g_free(). - */ - - -/** - * g_build_filename_valist: - * @first_element: (type filename): the first element in the path - * @args: va_list of remaining elements in path - * - * Behaves exactly like g_build_filename(), but takes the path elements - * as a va_list. This function is mainly meant for language bindings. - * - * Returns: (type filename): a newly-allocated string that must be freed - * with g_free(). - * Since: 2.56 - */ - - -/** - * g_build_filenamev: - * @args: (array zero-terminated=1) (element-type filename): %NULL-terminated - * array of strings containing the path elements. - * - * Behaves exactly like g_build_filename(), but takes the path elements - * as a string array, instead of varargs. This function is mainly - * meant for language bindings. - * - * Returns: (type filename): a newly-allocated string that must be freed - * with g_free(). - * Since: 2.8 - */ - - -/** - * g_build_path: - * @separator: (type filename): a string used to separator the elements of the path. - * @first_element: (type filename): the first element in the path - * @...: remaining elements in path, terminated by %NULL - * - * Creates a path from a series of elements using @separator as the - * separator between elements. At the boundary between two elements, - * any trailing occurrences of separator in the first element, or - * leading occurrences of separator in the second element are removed - * and exactly one copy of the separator is inserted. - * - * Empty elements are ignored. - * - * The number of leading copies of the separator on the result is - * the same as the number of leading copies of the separator on - * the first non-empty element. - * - * The number of trailing copies of the separator on the result is - * the same as the number of trailing copies of the separator on - * the last non-empty element. (Determination of the number of - * trailing copies is done without stripping leading copies, so - * if the separator is `ABA`, then `ABABA` has 1 trailing copy.) - * - * However, if there is only a single non-empty element, and there - * are no characters in that element not part of the leading or - * trailing separators, then the result is exactly the original value - * of that element. - * - * Other than for determination of the number of leading and trailing - * copies of the separator, elements consisting only of copies - * of the separator are ignored. - * - * Returns: (type filename): a newly-allocated string that must be freed with - * g_free(). - */ - - -/** - * g_build_pathv: - * @separator: a string used to separator the elements of the path. - * @args: (array zero-terminated=1) (element-type filename): %NULL-terminated - * array of strings containing the path elements. - * - * Behaves exactly like g_build_path(), but takes the path elements - * as a string array, instead of varargs. This function is mainly - * meant for language bindings. - * - * Returns: (type filename): a newly-allocated string that must be freed - * with g_free(). - * Since: 2.8 - */ - - -/** - * g_byte_array_append: - * @array: a #GByteArray - * @data: the byte data to be added - * @len: the number of bytes to add - * - * Adds the given bytes to the end of the #GByteArray. - * The array will grow in size automatically if necessary. - * - * Returns: the #GByteArray - */ - - -/** - * g_byte_array_free: - * @array: a #GByteArray - * @free_segment: if %TRUE the actual byte data is freed as well - * - * Frees the memory allocated by the #GByteArray. If @free_segment is - * %TRUE it frees the actual byte data. If the reference count of - * @array is greater than one, the #GByteArray wrapper is preserved but - * the size of @array will be set to zero. - * - * Returns: the element data if @free_segment is %FALSE, otherwise - * %NULL. The element data should be freed using g_free(). - */ - - -/** - * g_byte_array_free_to_bytes: - * @array: (transfer full): a #GByteArray - * - * Transfers the data from the #GByteArray into a new immutable #GBytes. - * - * The #GByteArray is freed unless the reference count of @array is greater - * than one, the #GByteArray wrapper is preserved but the size of @array - * will be set to zero. - * - * This is identical to using g_bytes_new_take() and g_byte_array_free() - * together. - * - * Since: 2.32 - * Returns: (transfer full): a new immutable #GBytes representing same - * byte data that was in the array - */ - - -/** - * g_byte_array_new: - * - * Creates a new #GByteArray with a reference count of 1. - * - * Returns: (transfer full): the new #GByteArray - */ - - -/** - * g_byte_array_new_take: - * @data: (transfer full) (array length=len): byte data for the array - * @len: length of @data - * - * Create byte array containing the data. The data will be owned by the array - * and will be freed with g_free(), i.e. it could be allocated using g_strdup(). - * - * Do not use it if @len is greater than %G_MAXUINT. #GByteArray - * stores the length of its data in #guint, which may be shorter than - * #gsize. - * - * Since: 2.32 - * Returns: (transfer full): a new #GByteArray - */ - - -/** - * g_byte_array_prepend: - * @array: a #GByteArray - * @data: the byte data to be added - * @len: the number of bytes to add - * - * Adds the given data to the start of the #GByteArray. - * The array will grow in size automatically if necessary. - * - * Returns: the #GByteArray - */ - - -/** - * g_byte_array_ref: - * @array: A #GByteArray - * - * Atomically increments the reference count of @array by one. - * This function is thread-safe and may be called from any thread. - * - * Returns: The passed in #GByteArray - * Since: 2.22 - */ - - -/** - * g_byte_array_remove_index: - * @array: a #GByteArray - * @index_: the index of the byte to remove - * - * Removes the byte at the given index from a #GByteArray. - * The following bytes are moved down one place. - * - * Returns: the #GByteArray - */ - - -/** - * g_byte_array_remove_index_fast: - * @array: a #GByteArray - * @index_: the index of the byte to remove - * - * Removes the byte at the given index from a #GByteArray. The last - * element in the array is used to fill in the space, so this function - * does not preserve the order of the #GByteArray. But it is faster - * than g_byte_array_remove_index(). - * - * Returns: the #GByteArray - */ - - -/** - * g_byte_array_remove_range: - * @array: a @GByteArray - * @index_: the index of the first byte to remove - * @length: the number of bytes to remove - * - * Removes the given number of bytes starting at the given index from a - * #GByteArray. The following elements are moved to close the gap. - * - * Returns: the #GByteArray - * Since: 2.4 - */ - - -/** - * g_byte_array_set_size: - * @array: a #GByteArray - * @length: the new size of the #GByteArray - * - * Sets the size of the #GByteArray, expanding it if necessary. - * - * Returns: the #GByteArray - */ - - -/** - * g_byte_array_sized_new: - * @reserved_size: number of bytes preallocated - * - * Creates a new #GByteArray with @reserved_size bytes preallocated. - * This avoids frequent reallocation, if you are going to add many - * bytes to the array. Note however that the size of the array is still - * 0. - * - * Returns: the new #GByteArray - */ - - -/** - * g_byte_array_sort: - * @array: a #GByteArray - * @compare_func: comparison function - * - * Sorts a byte array, using @compare_func which should be a - * qsort()-style comparison function (returns less than zero for first - * arg is less than second arg, zero for equal, greater than zero if - * first arg is greater than second arg). - * - * If two array elements compare equal, their order in the sorted array - * is undefined. If you want equal elements to keep their order (i.e. - * you want a stable sort) you can write a comparison function that, - * if two elements would otherwise compare equal, compares them by - * their addresses. - */ - - -/** - * g_byte_array_sort_with_data: - * @array: a #GByteArray - * @compare_func: comparison function - * @user_data: data to pass to @compare_func - * - * Like g_byte_array_sort(), but the comparison function takes an extra - * user data argument. - */ - - -/** - * g_byte_array_steal: - * @array: a #GByteArray. - * @len: (optional) (out): pointer to retrieve the number of - * elements of the original array - * - * Frees the data in the array and resets the size to zero, while - * the underlying array is preserved for use elsewhere and returned - * to the caller. - * - * Returns: (transfer full): the element data, which should be - * freed using g_free(). - * Since: 2.64 - */ - - -/** - * g_byte_array_unref: - * @array: A #GByteArray - * - * Atomically decrements the reference count of @array by one. If the - * reference count drops to 0, all memory allocated by the array is - * released. This function is thread-safe and may be called from any - * thread. - * - * Since: 2.22 - */ - - -/** - * g_bytes_compare: - * @bytes1: (type GLib.Bytes): a pointer to a #GBytes - * @bytes2: (type GLib.Bytes): a pointer to a #GBytes to compare with @bytes1 - * - * Compares the two #GBytes values. - * - * This function can be used to sort GBytes instances in lexicographical order. - * - * If @bytes1 and @bytes2 have different length but the shorter one is a - * prefix of the longer one then the shorter one is considered to be less than - * the longer one. Otherwise the first byte where both differ is used for - * comparison. If @bytes1 has a smaller value at that position it is - * considered less, otherwise greater than @bytes2. - * - * Returns: a negative value if @bytes1 is less than @bytes2, a positive value - * if @bytes1 is greater than @bytes2, and zero if @bytes1 is equal to - * @bytes2 - * Since: 2.32 - */ - - -/** - * g_bytes_equal: - * @bytes1: (type GLib.Bytes): a pointer to a #GBytes - * @bytes2: (type GLib.Bytes): a pointer to a #GBytes to compare with @bytes1 - * - * Compares the two #GBytes values being pointed to and returns - * %TRUE if they are equal. - * - * This function can be passed to g_hash_table_new() as the @key_equal_func - * parameter, when using non-%NULL #GBytes pointers as keys in a #GHashTable. - * - * Returns: %TRUE if the two keys match. - * Since: 2.32 - */ - - -/** - * g_bytes_get_data: - * @bytes: a #GBytes - * @size: (out) (optional): location to return size of byte data - * - * Get the byte data in the #GBytes. This data should not be modified. - * - * This function will always return the same pointer for a given #GBytes. - * - * %NULL may be returned if @size is 0. This is not guaranteed, as the #GBytes - * may represent an empty string with @data non-%NULL and @size as 0. %NULL will - * not be returned if @size is non-zero. - * - * Returns: (transfer none) (array length=size) (element-type guint8) (nullable): - * a pointer to the byte data, or %NULL - * Since: 2.32 - */ - - -/** - * g_bytes_get_region: - * @bytes: a #GBytes - * @element_size: a non-zero element size - * @offset: an offset to the start of the region within the @bytes - * @n_elements: the number of elements in the region - * - * Gets a pointer to a region in @bytes. - * - * The region starts at @offset many bytes from the start of the data - * and contains @n_elements many elements of @element_size size. - * - * @n_elements may be zero, but @element_size must always be non-zero. - * Ideally, @element_size is a static constant (eg: sizeof a struct). - * - * This function does careful bounds checking (including checking for - * arithmetic overflows) and returns a non-%NULL pointer if the - * specified region lies entirely within the @bytes. If the region is - * in some way out of range, or if an overflow has occurred, then %NULL - * is returned. - * - * Note: it is possible to have a valid zero-size region. In this case, - * the returned pointer will be equal to the base pointer of the data of - * @bytes, plus @offset. This will be non-%NULL except for the case - * where @bytes itself was a zero-sized region. Since it is unlikely - * that you will be using this function to check for a zero-sized region - * in a zero-sized @bytes, %NULL effectively always means "error". - * - * Returns: (nullable): the requested region, or %NULL in case of an error - * Since: 2.70 - */ - - -/** - * g_bytes_get_size: - * @bytes: a #GBytes - * - * Get the size of the byte data in the #GBytes. - * - * This function will always return the same value for a given #GBytes. - * - * Returns: the size - * Since: 2.32 - */ - - -/** - * g_bytes_hash: - * @bytes: (type GLib.Bytes): a pointer to a #GBytes key - * - * Creates an integer hash code for the byte data in the #GBytes. - * - * This function can be passed to g_hash_table_new() as the @key_hash_func - * parameter, when using non-%NULL #GBytes pointers as keys in a #GHashTable. - * - * Returns: a hash value corresponding to the key. - * Since: 2.32 - */ - - -/** - * g_bytes_new: - * @data: (transfer none) (array length=size) (element-type guint8) (nullable): - * the data to be used for the bytes - * @size: the size of @data - * - * Creates a new #GBytes from @data. - * - * @data is copied. If @size is 0, @data may be %NULL. - * - * Returns: (transfer full): a new #GBytes - * Since: 2.32 - */ - - -/** - * g_bytes_new_from_bytes: - * @bytes: a #GBytes - * @offset: offset which subsection starts at - * @length: length of subsection - * - * Creates a #GBytes which is a subsection of another #GBytes. The @offset + - * @length may not be longer than the size of @bytes. - * - * A reference to @bytes will be held by the newly created #GBytes until - * the byte data is no longer needed. - * - * Since 2.56, if @offset is 0 and @length matches the size of @bytes, then - * @bytes will be returned with the reference count incremented by 1. If @bytes - * is a slice of another #GBytes, then the resulting #GBytes will reference - * the same #GBytes instead of @bytes. This allows consumers to simplify the - * usage of #GBytes when asynchronously writing to streams. - * - * Returns: (transfer full): a new #GBytes - * Since: 2.32 - */ - - -/** - * g_bytes_new_static: (skip) - * @data: (transfer full) (array length=size) (element-type guint8) (nullable): - * the data to be used for the bytes - * @size: the size of @data - * - * Creates a new #GBytes from static data. - * - * @data must be static (ie: never modified or freed). It may be %NULL if @size - * is 0. - * - * Returns: (transfer full): a new #GBytes - * Since: 2.32 - */ - - -/** - * g_bytes_new_take: - * @data: (transfer full) (array length=size) (element-type guint8) (nullable): - * the data to be used for the bytes - * @size: the size of @data - * - * Creates a new #GBytes from @data. - * - * After this call, @data belongs to the bytes and may no longer be - * modified by the caller. g_free() will be called on @data when the - * bytes is no longer in use. Because of this @data must have been created by - * a call to g_malloc(), g_malloc0() or g_realloc() or by one of the many - * functions that wrap these calls (such as g_new(), g_strdup(), etc). - * - * For creating #GBytes with memory from other allocators, see - * g_bytes_new_with_free_func(). - * - * @data may be %NULL if @size is 0. - * - * Returns: (transfer full): a new #GBytes - * Since: 2.32 - */ - - -/** - * g_bytes_new_with_free_func: (skip) - * @data: (array length=size) (element-type guint8) (nullable): - * the data to be used for the bytes - * @size: the size of @data - * @free_func: the function to call to release the data - * @user_data: data to pass to @free_func - * - * Creates a #GBytes from @data. - * - * When the last reference is dropped, @free_func will be called with the - * @user_data argument. - * - * @data must not be modified after this call is made until @free_func has - * been called to indicate that the bytes is no longer in use. - * - * @data may be %NULL if @size is 0. - * - * Returns: (transfer full): a new #GBytes - * Since: 2.32 - */ - - -/** - * g_bytes_ref: - * @bytes: a #GBytes - * - * Increase the reference count on @bytes. - * - * Returns: the #GBytes - * Since: 2.32 - */ - - -/** - * g_bytes_unref: - * @bytes: (nullable): a #GBytes - * - * Releases a reference on @bytes. This may result in the bytes being - * freed. If @bytes is %NULL, it will return immediately. - * - * Since: 2.32 - */ - - -/** - * g_bytes_unref_to_array: - * @bytes: (transfer full): a #GBytes - * - * Unreferences the bytes, and returns a new mutable #GByteArray containing - * the same byte data. - * - * As an optimization, the byte data is transferred to the array without copying - * if this was the last reference to bytes and bytes was created with - * g_bytes_new(), g_bytes_new_take() or g_byte_array_free_to_bytes(). In all - * other cases the data is copied. - * - * Do not use it if @bytes contains more than %G_MAXUINT - * bytes. #GByteArray stores the length of its data in #guint, which - * may be shorter than #gsize, that @bytes is using. - * - * Returns: (transfer full): a new mutable #GByteArray containing the same byte data - * Since: 2.32 - */ - - -/** - * g_bytes_unref_to_data: - * @bytes: (transfer full): a #GBytes - * @size: (out): location to place the length of the returned data - * - * Unreferences the bytes, and returns a pointer the same byte data - * contents. - * - * As an optimization, the byte data is returned without copying if this was - * the last reference to bytes and bytes was created with g_bytes_new(), - * g_bytes_new_take() or g_byte_array_free_to_bytes(). In all other cases the - * data is copied. - * - * Returns: (transfer full) (array length=size) (element-type guint8) (not nullable): a pointer to the same byte data, which should be - * freed with g_free() - * Since: 2.32 - */ - - -/** - * g_canonicalize_filename: - * @filename: (type filename): the name of the file - * @relative_to: (type filename) (nullable): the relative directory, or %NULL - * to use the current working directory - * - * Gets the canonical file name from @filename. All triple slashes are turned into - * single slashes, and all `..` and `.`s resolved against @relative_to. - * - * Symlinks are not followed, and the returned path is guaranteed to be absolute. - * - * If @filename is an absolute path, @relative_to is ignored. Otherwise, - * @relative_to will be prepended to @filename to make it absolute. @relative_to - * must be an absolute path, or %NULL. If @relative_to is %NULL, it'll fallback - * to g_get_current_dir(). - * - * This function never fails, and will canonicalize file paths even if they don't - * exist. - * - * No file system I/O is done. - * - * Returns: (type filename) (transfer full): a newly allocated string with the - * canonical file path - * Since: 2.58 - */ - - -/** - * g_chdir: - * @path: (type filename): a pathname in the GLib file name encoding - * (UTF-8 on Windows) - * - * A wrapper for the POSIX chdir() function. The function changes the - * current directory of the process to @path. - * - * See your C library manual for more details about chdir(). - * - * Returns: 0 on success, -1 if an error occurred. - * Since: 2.8 - */ - - -/** - * g_checksum_copy: - * @checksum: the #GChecksum to copy - * - * Copies a #GChecksum. If @checksum has been closed, by calling - * g_checksum_get_string() or g_checksum_get_digest(), the copied - * checksum will be closed as well. - * - * Returns: (transfer full): the copy of the passed #GChecksum. Use - * g_checksum_free() when finished using it. - * Since: 2.16 - */ - - -/** - * g_checksum_free: - * @checksum: a #GChecksum - * - * Frees the memory allocated for @checksum. - * - * Since: 2.16 - */ - - -/** - * g_checksum_get_digest: (skip) - * @checksum: a #GChecksum - * @buffer: (array length=digest_len): output buffer - * @digest_len: (inout): an inout parameter. The caller initializes it to the size of @buffer. - * After the call it contains the length of the digest. - * - * Gets the digest from @checksum as a raw binary vector and places it - * into @buffer. The size of the digest depends on the type of checksum. - * - * Once this function has been called, the #GChecksum is closed and can - * no longer be updated with g_checksum_update(). - * - * Since: 2.16 - */ - - -/** - * g_checksum_get_string: - * @checksum: a #GChecksum - * - * Gets the digest as a hexadecimal string. - * - * Once this function has been called the #GChecksum can no longer be - * updated with g_checksum_update(). - * - * The hexadecimal characters will be lower case. - * - * Returns: the hexadecimal representation of the checksum. The - * returned string is owned by the checksum and should not be modified - * or freed. - * Since: 2.16 - */ - - -/** - * g_checksum_new: - * @checksum_type: the desired type of checksum - * - * Creates a new #GChecksum, using the checksum algorithm @checksum_type. - * If the @checksum_type is not known, %NULL is returned. - * A #GChecksum can be used to compute the checksum, or digest, of an - * arbitrary binary blob, using different hashing algorithms. - * - * A #GChecksum works by feeding a binary blob through g_checksum_update() - * until there is data to be checked; the digest can then be extracted - * using g_checksum_get_string(), which will return the checksum as a - * hexadecimal string; or g_checksum_get_digest(), which will return a - * vector of raw bytes. Once either g_checksum_get_string() or - * g_checksum_get_digest() have been called on a #GChecksum, the checksum - * will be closed and it won't be possible to call g_checksum_update() - * on it anymore. - * - * Returns: (transfer full) (nullable): the newly created #GChecksum, or %NULL. - * Use g_checksum_free() to free the memory allocated by it. - * Since: 2.16 - */ - - -/** - * g_checksum_reset: - * @checksum: the #GChecksum to reset - * - * Resets the state of the @checksum back to its initial state. - * - * Since: 2.18 - */ - - -/** - * g_checksum_type_get_length: - * @checksum_type: a #GChecksumType - * - * Gets the length in bytes of digests of type @checksum_type - * - * Returns: the checksum length, or -1 if @checksum_type is - * not supported. - * Since: 2.16 - */ - - -/** - * g_checksum_update: - * @checksum: a #GChecksum - * @data: (array length=length) (element-type guint8): buffer used to compute the checksum - * @length: size of the buffer, or -1 if it is a null-terminated string. - * - * Feeds @data into an existing #GChecksum. The checksum must still be - * open, that is g_checksum_get_string() or g_checksum_get_digest() must - * not have been called on @checksum. - * - * Since: 2.16 - */ - - -/** - * g_child_watch_add: - * @pid: process id to watch. On POSIX the positive pid of a child - * process. On Windows a handle for a process (which doesn't have - * to be a child). - * @function: function to call - * @data: data to pass to @function - * - * Sets a function to be called when the child indicated by @pid - * exits, at a default priority, %G_PRIORITY_DEFAULT. - * - * If you obtain @pid from g_spawn_async() or g_spawn_async_with_pipes() - * you will need to pass %G_SPAWN_DO_NOT_REAP_CHILD as flag to - * the spawn function for the child watching to work. - * - * Note that on platforms where #GPid must be explicitly closed - * (see g_spawn_close_pid()) @pid must not be closed while the - * source is still active. Typically, you will want to call - * g_spawn_close_pid() in the callback function for the source. - * - * GLib supports only a single callback per process id. - * On POSIX platforms, the same restrictions mentioned for - * g_child_watch_source_new() apply to this function. - * - * This internally creates a main loop source using - * g_child_watch_source_new() and attaches it to the main loop context - * using g_source_attach(). You can do these steps manually if you - * need greater control. - * - * Returns: the ID (greater than 0) of the event source. - * Since: 2.4 - */ - - -/** - * g_child_watch_add_full: (rename-to g_child_watch_add) - * @priority: the priority of the idle source. Typically this will be in the - * range between %G_PRIORITY_DEFAULT_IDLE and %G_PRIORITY_HIGH_IDLE. - * @pid: process to watch. On POSIX the positive pid of a child process. On - * Windows a handle for a process (which doesn't have to be a child). - * @function: function to call - * @data: data to pass to @function - * @notify: (nullable): function to call when the idle is removed, or %NULL - * - * Sets a function to be called when the child indicated by @pid - * exits, at the priority @priority. - * - * If you obtain @pid from g_spawn_async() or g_spawn_async_with_pipes() - * you will need to pass %G_SPAWN_DO_NOT_REAP_CHILD as flag to - * the spawn function for the child watching to work. - * - * In many programs, you will want to call g_spawn_check_wait_status() - * in the callback to determine whether or not the child exited - * successfully. - * - * Also, note that on platforms where #GPid must be explicitly closed - * (see g_spawn_close_pid()) @pid must not be closed while the source - * is still active. Typically, you should invoke g_spawn_close_pid() - * in the callback function for the source. - * - * GLib supports only a single callback per process id. - * On POSIX platforms, the same restrictions mentioned for - * g_child_watch_source_new() apply to this function. - * - * This internally creates a main loop source using - * g_child_watch_source_new() and attaches it to the main loop context - * using g_source_attach(). You can do these steps manually if you - * need greater control. - * - * Returns: the ID (greater than 0) of the event source. - * Since: 2.4 - */ - - -/** - * g_child_watch_source_new: - * @pid: process to watch. On POSIX the positive pid of a child process. On - * Windows a handle for a process (which doesn't have to be a child). - * - * Creates a new child_watch source. - * - * The source will not initially be associated with any #GMainContext - * and must be added to one with g_source_attach() before it will be - * executed. - * - * Note that child watch sources can only be used in conjunction with - * `g_spawn...` when the %G_SPAWN_DO_NOT_REAP_CHILD flag is used. - * - * Note that on platforms where #GPid must be explicitly closed - * (see g_spawn_close_pid()) @pid must not be closed while the - * source is still active. Typically, you will want to call - * g_spawn_close_pid() in the callback function for the source. - * - * On POSIX platforms, the following restrictions apply to this API - * due to limitations in POSIX process interfaces: - * - * * @pid must be a child of this process - * * @pid must be positive - * * the application must not call `waitpid` with a non-positive - * first argument, for instance in another thread - * * the application must not wait for @pid to exit by any other - * mechanism, including `waitpid(pid, ...)` or a second child-watch - * source for the same @pid - * * the application must not ignore `SIGCHLD` - * - * If any of those conditions are not met, this and related APIs will - * not work correctly. This can often be diagnosed via a GLib warning - * stating that `ECHILD` was received by `waitpid`. - * - * Calling `waitpid` for specific processes other than @pid remains a - * valid thing to do. - * - * Returns: the newly-created child watch source - * Since: 2.4 - */ - - -/** - * g_chmod: - * @filename: (type filename): a pathname in the GLib file name encoding - * (UTF-8 on Windows) - * @mode: as in chmod() - * - * A wrapper for the POSIX chmod() function. The chmod() function is - * used to set the permissions of a file system object. - * - * On Windows the file protection mechanism is not at all POSIX-like, - * and the underlying chmod() function in the C library just sets or - * clears the FAT-style READONLY attribute. It does not touch any - * ACL. Software that needs to manage file permissions on Windows - * exactly should use the Win32 API. - * - * See your C library manual for more details about chmod(). - * - * Returns: 0 if the operation succeeded, -1 on error - * Since: 2.8 - */ - - -/** - * g_clear_error: - * @err: a #GError return location - * - * If @err or *@err is %NULL, does nothing. Otherwise, - * calls g_error_free() on *@err and sets *@err to %NULL. - */ - - -/** - * g_clear_handle_id: (skip) - * @tag_ptr: (not nullable): a pointer to the handler ID - * @clear_func: (not nullable): the function to call to clear the handler - * - * Clears a numeric handler, such as a #GSource ID. - * - * @tag_ptr must be a valid pointer to the variable holding the handler. - * - * If the ID is zero then this function does nothing. - * Otherwise, clear_func() is called with the ID as a parameter, and the tag is - * set to zero. - * - * A macro is also included that allows this function to be used without - * pointer casts. - * - * Since: 2.56 - */ - - -/** - * g_clear_list: (skip) - * @list_ptr: (not nullable): a #GList return location - * @destroy: (nullable): the function to pass to g_list_free_full() or %NULL to not free elements - * - * Clears a pointer to a #GList, freeing it and, optionally, freeing its elements using @destroy. - * - * @list_ptr must be a valid pointer. If @list_ptr points to a null #GList, this does nothing. - * - * Since: 2.64 - */ - - -/** - * g_clear_pointer: (skip) - * @pp: (not nullable): a pointer to a variable, struct member etc. holding a - * pointer - * @destroy: a function to which a gpointer can be passed, to destroy *@pp - * - * Clears a reference to a variable. - * - * @pp must not be %NULL. - * - * If the reference is %NULL then this function does nothing. - * Otherwise, the variable is destroyed using @destroy and the - * pointer is set to %NULL. - * - * A macro is also included that allows this function to be used without - * pointer casts. This will mask any warnings about incompatible function types - * or calling conventions, so you must ensure that your @destroy function is - * compatible with being called as `GDestroyNotify` using the standard calling - * convention for the platform that GLib was compiled for; otherwise the program - * will experience undefined behaviour. - * - * Since: 2.34 - */ - - -/** - * g_clear_slist: (skip) - * @slist_ptr: (not nullable): a #GSList return location - * @destroy: (nullable): the function to pass to g_slist_free_full() or %NULL to not free elements - * - * Clears a pointer to a #GSList, freeing it and, optionally, freeing its elements using @destroy. - * - * @slist_ptr must be a valid pointer. If @slist_ptr points to a null #GSList, this does nothing. - * - * Since: 2.64 - */ - - -/** - * g_close: - * @fd: A file descriptor - * @error: a #GError - * - * This wraps the close() call; in case of error, %errno will be - * preserved, but the error will also be stored as a #GError in @error. - * - * Besides using #GError, there is another major reason to prefer this - * function over the call provided by the system; on Unix, it will - * attempt to correctly handle %EINTR, which has platform-specific - * semantics. - * - * Returns: %TRUE on success, %FALSE if there was an error. - * Since: 2.36 - */ - - -/** - * g_compute_checksum_for_bytes: - * @checksum_type: a #GChecksumType - * @data: binary blob to compute the digest of - * - * Computes the checksum for a binary @data. This is a - * convenience wrapper for g_checksum_new(), g_checksum_get_string() - * and g_checksum_free(). - * - * The hexadecimal string returned will be in lower case. - * - * Returns: (transfer full) (nullable): the digest of the binary data as a - * string in hexadecimal, or %NULL if g_checksum_new() fails for - * @checksum_type. The returned string should be freed with g_free() when - * done using it. - * Since: 2.34 - */ - - -/** - * g_compute_checksum_for_data: - * @checksum_type: a #GChecksumType - * @data: (array length=length) (element-type guint8): binary blob to compute the digest of - * @length: length of @data - * - * Computes the checksum for a binary @data of @length. This is a - * convenience wrapper for g_checksum_new(), g_checksum_get_string() - * and g_checksum_free(). - * - * The hexadecimal string returned will be in lower case. - * - * Returns: (transfer full) (nullable): the digest of the binary data as a - * string in hexadecimal, or %NULL if g_checksum_new() fails for - * @checksum_type. The returned string should be freed with g_free() when - * done using it. - * Since: 2.16 - */ - - -/** - * g_compute_checksum_for_string: - * @checksum_type: a #GChecksumType - * @str: the string to compute the checksum of - * @length: the length of the string, or -1 if the string is null-terminated. - * - * Computes the checksum of a string. - * - * The hexadecimal string returned will be in lower case. - * - * Returns: (transfer full) (nullable): the checksum as a hexadecimal string, - * or %NULL if g_checksum_new() fails for @checksum_type. The returned string - * should be freed with g_free() when done using it. - * Since: 2.16 - */ - - -/** - * g_compute_hmac_for_bytes: - * @digest_type: a #GChecksumType to use for the HMAC - * @key: the key to use in the HMAC - * @data: binary blob to compute the HMAC of - * - * Computes the HMAC for a binary @data. This is a - * convenience wrapper for g_hmac_new(), g_hmac_get_string() - * and g_hmac_unref(). - * - * The hexadecimal string returned will be in lower case. - * - * Returns: the HMAC of the binary data as a string in hexadecimal. - * The returned string should be freed with g_free() when done using it. - * Since: 2.50 - */ - - -/** - * g_compute_hmac_for_data: - * @digest_type: a #GChecksumType to use for the HMAC - * @key: (array length=key_len): the key to use in the HMAC - * @key_len: the length of the key - * @data: (array length=length): binary blob to compute the HMAC of - * @length: length of @data - * - * Computes the HMAC for a binary @data of @length. This is a - * convenience wrapper for g_hmac_new(), g_hmac_get_string() - * and g_hmac_unref(). - * - * The hexadecimal string returned will be in lower case. - * - * Returns: the HMAC of the binary data as a string in hexadecimal. - * The returned string should be freed with g_free() when done using it. - * Since: 2.30 - */ - - -/** - * g_compute_hmac_for_string: - * @digest_type: a #GChecksumType to use for the HMAC - * @key: (array length=key_len): the key to use in the HMAC - * @key_len: the length of the key - * @str: the string to compute the HMAC for - * @length: the length of the string, or -1 if the string is nul-terminated - * - * Computes the HMAC for a string. - * - * The hexadecimal string returned will be in lower case. - * - * Returns: the HMAC as a hexadecimal string. - * The returned string should be freed with g_free() - * when done using it. - * Since: 2.30 - */ - - -/** - * g_cond_broadcast: - * @cond: a #GCond - * - * If threads are waiting for @cond, all of them are unblocked. - * If no threads are waiting for @cond, this function has no effect. - * It is good practice to lock the same mutex as the waiting threads - * while calling this function, though not required. - */ - - -/** - * g_cond_clear: - * @cond: an initialised #GCond - * - * Frees the resources allocated to a #GCond with g_cond_init(). - * - * This function should not be used with a #GCond that has been - * statically allocated. - * - * Calling g_cond_clear() for a #GCond on which threads are - * blocking leads to undefined behaviour. - * - * Since: 2.32 - */ - - -/** - * g_cond_init: - * @cond: an uninitialized #GCond - * - * Initialises a #GCond so that it can be used. - * - * This function is useful to initialise a #GCond that has been - * allocated as part of a larger structure. It is not necessary to - * initialise a #GCond that has been statically allocated. - * - * To undo the effect of g_cond_init() when a #GCond is no longer - * needed, use g_cond_clear(). - * - * Calling g_cond_init() on an already-initialised #GCond leads - * to undefined behaviour. - * - * Since: 2.32 - */ - - -/** - * g_cond_signal: - * @cond: a #GCond - * - * If threads are waiting for @cond, at least one of them is unblocked. - * If no threads are waiting for @cond, this function has no effect. - * It is good practice to hold the same lock as the waiting thread - * while calling this function, though not required. - */ - - -/** - * g_cond_wait: - * @cond: a #GCond - * @mutex: a #GMutex that is currently locked - * - * Atomically releases @mutex and waits until @cond is signalled. - * When this function returns, @mutex is locked again and owned by the - * calling thread. - * - * When using condition variables, it is possible that a spurious wakeup - * may occur (ie: g_cond_wait() returns even though g_cond_signal() was - * not called). It's also possible that a stolen wakeup may occur. - * This is when g_cond_signal() is called, but another thread acquires - * @mutex before this thread and modifies the state of the program in - * such a way that when g_cond_wait() is able to return, the expected - * condition is no longer met. - * - * For this reason, g_cond_wait() must always be used in a loop. See - * the documentation for #GCond for a complete example. - */ - - -/** - * g_cond_wait_until: - * @cond: a #GCond - * @mutex: a #GMutex that is currently locked - * @end_time: the monotonic time to wait until - * - * Waits until either @cond is signalled or @end_time has passed. - * - * As with g_cond_wait() it is possible that a spurious or stolen wakeup - * could occur. For that reason, waiting on a condition variable should - * always be in a loop, based on an explicitly-checked predicate. - * - * %TRUE is returned if the condition variable was signalled (or in the - * case of a spurious wakeup). %FALSE is returned if @end_time has - * passed. - * - * The following code shows how to correctly perform a timed wait on a - * condition variable (extending the example presented in the - * documentation for #GCond): - * - * |[<!-- language="C" --> - * gpointer - * pop_data_timed (void) - * { - * gint64 end_time; - * gpointer data; - * - * g_mutex_lock (&data_mutex); - * - * end_time = g_get_monotonic_time () + 5 * G_TIME_SPAN_SECOND; - * while (!current_data) - * if (!g_cond_wait_until (&data_cond, &data_mutex, end_time)) - * { - * // timeout has passed. - * g_mutex_unlock (&data_mutex); - * return NULL; - * } - * - * // there is data for us - * data = current_data; - * current_data = NULL; - * - * g_mutex_unlock (&data_mutex); - * - * return data; - * } - * ]| - * - * Notice that the end time is calculated once, before entering the - * loop and reused. This is the motivation behind the use of absolute - * time on this API -- if a relative time of 5 seconds were passed - * directly to the call and a spurious wakeup occurred, the program would - * have to start over waiting again (which would lead to a total wait - * time of more than 5 seconds). - * - * Returns: %TRUE on a signal, %FALSE on a timeout - * Since: 2.32 - */ - - -/** - * g_convert: - * @str: (array length=len) (element-type guint8): - * the string to convert. - * @len: the length of the string in bytes, or -1 if the string is - * nul-terminated (Note that some encodings may allow nul - * bytes to occur inside strings. In that case, using -1 - * for the @len parameter is unsafe) - * @to_codeset: name of character set into which to convert @str - * @from_codeset: character set of @str. - * @bytes_read: (out) (optional): location to store the number of bytes in - * the input string that were successfully converted, or %NULL. - * Even if the conversion was successful, this may be - * less than @len if there were partial characters - * at the end of the input. If the error - * #G_CONVERT_ERROR_ILLEGAL_SEQUENCE occurs, the value - * stored will be the byte offset after the last valid - * input sequence. - * @bytes_written: (out) (optional): the number of bytes stored in - * the output buffer (not including the terminating nul). - * @error: location to store the error occurring, or %NULL to ignore - * errors. Any of the errors in #GConvertError may occur. - * - * Converts a string from one character set to another. - * - * Note that you should use g_iconv() for streaming conversions. - * Despite the fact that @bytes_read can return information about partial - * characters, the g_convert_... functions are not generally suitable - * for streaming. If the underlying converter maintains internal state, - * then this won't be preserved across successive calls to g_convert(), - * g_convert_with_iconv() or g_convert_with_fallback(). (An example of - * this is the GNU C converter for CP1255 which does not emit a base - * character until it knows that the next character is not a mark that - * could combine with the base character.) - * - * Using extensions such as "//TRANSLIT" may not work (or may not work - * well) on many platforms. Consider using g_str_to_ascii() instead. - * - * Returns: (array length=bytes_written) (element-type guint8) (transfer full): - * If the conversion was successful, a newly allocated buffer - * containing the converted string, which must be freed with g_free(). - * Otherwise %NULL and @error will be set. - */ - - -/** - * g_convert_with_fallback: - * @str: (array length=len) (element-type guint8): - * the string to convert. - * @len: the length of the string in bytes, or -1 if the string is - * nul-terminated (Note that some encodings may allow nul - * bytes to occur inside strings. In that case, using -1 - * for the @len parameter is unsafe) - * @to_codeset: name of character set into which to convert @str - * @from_codeset: character set of @str. - * @fallback: UTF-8 string to use in place of characters not - * present in the target encoding. (The string must be - * representable in the target encoding). - * If %NULL, characters not in the target encoding will - * be represented as Unicode escapes \uxxxx or \Uxxxxyyyy. - * @bytes_read: (out) (optional): location to store the number of bytes in - * the input string that were successfully converted, or %NULL. - * Even if the conversion was successful, this may be - * less than @len if there were partial characters - * at the end of the input. - * @bytes_written: (out) (optional): the number of bytes stored in - * the output buffer (not including the terminating nul). - * @error: location to store the error occurring, or %NULL to ignore - * errors. Any of the errors in #GConvertError may occur. - * - * Converts a string from one character set to another, possibly - * including fallback sequences for characters not representable - * in the output. Note that it is not guaranteed that the specification - * for the fallback sequences in @fallback will be honored. Some - * systems may do an approximate conversion from @from_codeset - * to @to_codeset in their iconv() functions, - * in which case GLib will simply return that approximate conversion. - * - * Note that you should use g_iconv() for streaming conversions. - * Despite the fact that @bytes_read can return information about partial - * characters, the g_convert_... functions are not generally suitable - * for streaming. If the underlying converter maintains internal state, - * then this won't be preserved across successive calls to g_convert(), - * g_convert_with_iconv() or g_convert_with_fallback(). (An example of - * this is the GNU C converter for CP1255 which does not emit a base - * character until it knows that the next character is not a mark that - * could combine with the base character.) - * - * Returns: (array length=bytes_written) (element-type guint8) (transfer full): - * If the conversion was successful, a newly allocated buffer - * containing the converted string, which must be freed with g_free(). - * Otherwise %NULL and @error will be set. - */ - - -/** - * g_convert_with_iconv: (skip) - * @str: (array length=len) (element-type guint8): - * the string to convert. - * @len: the length of the string in bytes, or -1 if the string is - * nul-terminated (Note that some encodings may allow nul - * bytes to occur inside strings. In that case, using -1 - * for the @len parameter is unsafe) - * @converter: conversion descriptor from g_iconv_open() - * @bytes_read: (out) (optional): location to store the number of bytes in - * the input string that were successfully converted, or %NULL. - * Even if the conversion was successful, this may be - * less than @len if there were partial characters - * at the end of the input. If the error - * #G_CONVERT_ERROR_ILLEGAL_SEQUENCE occurs, the value - * stored will be the byte offset after the last valid - * input sequence. - * @bytes_written: (out) (optional): the number of bytes stored in - * the output buffer (not including the terminating nul). - * @error: location to store the error occurring, or %NULL to ignore - * errors. Any of the errors in #GConvertError may occur. - * - * Converts a string from one character set to another. - * - * Note that you should use g_iconv() for streaming conversions. - * Despite the fact that @bytes_read can return information about partial - * characters, the g_convert_... functions are not generally suitable - * for streaming. If the underlying converter maintains internal state, - * then this won't be preserved across successive calls to g_convert(), - * g_convert_with_iconv() or g_convert_with_fallback(). (An example of - * this is the GNU C converter for CP1255 which does not emit a base - * character until it knows that the next character is not a mark that - * could combine with the base character.) - * - * Characters which are valid in the input character set, but which have no - * representation in the output character set will result in a - * %G_CONVERT_ERROR_ILLEGAL_SEQUENCE error. This is in contrast to the iconv() - * specification, which leaves this behaviour implementation defined. Note that - * this is the same error code as is returned for an invalid byte sequence in - * the input character set. To get defined behaviour for conversion of - * unrepresentable characters, use g_convert_with_fallback(). - * - * Returns: (array length=bytes_written) (element-type guint8) (transfer full): - * If the conversion was successful, a newly allocated buffer - * containing the converted string, which must be freed with - * g_free(). Otherwise %NULL and @error will be set. - */ - - -/** - * g_creat: - * @filename: (type filename): a pathname in the GLib file name encoding - * (UTF-8 on Windows) - * @mode: as in creat() - * - * A wrapper for the POSIX creat() function. The creat() function is - * used to convert a pathname into a file descriptor, creating a file - * if necessary. - * - * On POSIX systems file descriptors are implemented by the operating - * system. On Windows, it's the C library that implements creat() and - * file descriptors. The actual Windows API for opening files is - * different, see MSDN documentation for CreateFile(). The Win32 API - * uses file handles, which are more randomish integers, not small - * integers like file descriptors. - * - * Because file descriptors are specific to the C library on Windows, - * the file descriptor returned by this function makes sense only to - * functions in the same C library. Thus if the GLib-using code uses a - * different C library than GLib does, the file descriptor returned by - * this function cannot be passed to C library functions like write() - * or read(). - * - * See your C library manual for more details about creat(). - * - * Returns: a new file descriptor, or -1 if an error occurred. - * The return value can be used exactly like the return value - * from creat(). - * Since: 2.8 - */ - - -/** - * g_critical: - * @...: format string, followed by parameters to insert - * into the format string (as with printf()) - * - * Logs a "critical warning" (%G_LOG_LEVEL_CRITICAL). - * - * Critical warnings are intended to be used in the event of an error - * that originated in the current process (a programmer error). - * Logging of a critical error is by definition an indication of a bug - * somewhere in the current program (or its libraries). - * - * g_return_if_fail(), g_return_val_if_fail(), g_return_if_reached() and - * g_return_val_if_reached() log at %G_LOG_LEVEL_CRITICAL. - * - * You can make critical warnings fatal at runtime by - * setting the `G_DEBUG` environment variable (see - * [Running GLib Applications](glib-running.html)): - * - * |[ - * G_DEBUG=fatal-warnings gdb ./my-program - * ]| - * - * You can also use g_log_set_always_fatal(). - * - * Any unrelated failures can be skipped over in - * [gdb](https://www.gnu.org/software/gdb/) using the `continue` command. - * - * The message should typically *not* be translated to the - * user's language. - * - * If g_log_default_handler() is used as the log handler function, a new-line - * character will automatically be appended to @..., and need not be entered - * manually. - * - * If structured logging is enabled, this will use g_log_structured(); - * otherwise it will use g_log(). See - * [Using Structured Logging][using-structured-logging]. - */ - - -/** - * g_datalist_clear: (skip) - * @datalist: a datalist. - * - * Frees all the data elements of the datalist. - * The data elements' destroy functions are called - * if they have been set. - */ - - -/** - * g_datalist_foreach: - * @datalist: a datalist. - * @func: (scope call): the function to call for each data element. - * @user_data: (closure): user data to pass to the function. - * - * Calls the given function for each data element of the datalist. The - * function is called with each data element's #GQuark id and data, - * together with the given @user_data parameter. Note that this - * function is NOT thread-safe. So unless @datalist can be protected - * from any modifications during invocation of this function, it should - * not be called. - * - * @func can make changes to @datalist, but the iteration will not - * reflect changes made during the g_datalist_foreach() call, other - * than skipping over elements that are removed. - */ - - -/** - * g_datalist_get_data: - * @datalist: a datalist. - * @key: the string identifying a data element. - * - * Gets a data element, using its string identifier. This is slower than - * g_datalist_id_get_data() because it compares strings. - * - * Returns: (transfer none) (nullable): the data element, or %NULL if it - * is not found. - */ - - -/** - * g_datalist_get_flags: - * @datalist: pointer to the location that holds a list - * - * Gets flags values packed in together with the datalist. - * See g_datalist_set_flags(). - * - * Returns: the flags of the datalist - * Since: 2.8 - */ - - -/** - * g_datalist_id_dup_data: (skip) - * @datalist: location of a datalist - * @key_id: the #GQuark identifying a data element - * @dup_func: (nullable) (scope call): function to duplicate the old value - * @user_data: (closure): passed as user_data to @dup_func - * - * This is a variant of g_datalist_id_get_data() which - * returns a 'duplicate' of the value. @dup_func defines the - * meaning of 'duplicate' in this context, it could e.g. - * take a reference on a ref-counted object. - * - * If the @key_id is not set in the datalist then @dup_func - * will be called with a %NULL argument. - * - * Note that @dup_func is called while the datalist is locked, so it - * is not allowed to read or modify the datalist. - * - * This function can be useful to avoid races when multiple - * threads are using the same datalist and the same key. - * - * Returns: (nullable): the result of calling @dup_func on the value - * associated with @key_id in @datalist, or %NULL if not set. - * If @dup_func is %NULL, the value is returned unmodified. - * Since: 2.34 - */ - - -/** - * g_datalist_id_get_data: - * @datalist: a datalist. - * @key_id: the #GQuark identifying a data element. - * - * Retrieves the data element corresponding to @key_id. - * - * Returns: (transfer none) (nullable): the data element, or %NULL if - * it is not found. - */ - - -/** - * g_datalist_id_remove_data: - * @dl: a datalist. - * @q: the #GQuark identifying the data element. - * - * Removes an element, using its #GQuark identifier. - */ - - -/** - * g_datalist_id_remove_no_notify: (skip) - * @datalist: a datalist. - * @key_id: the #GQuark identifying a data element. - * - * Removes an element, without calling its destroy notification - * function. - * - * Returns: (nullable): the data previously stored at @key_id, - * or %NULL if none. - */ - - -/** - * g_datalist_id_replace_data: (skip) - * @datalist: location of a datalist - * @key_id: the #GQuark identifying a data element - * @oldval: (nullable): the old value to compare against - * @newval: (nullable): the new value to replace it with - * @destroy: (nullable): destroy notify for the new value - * @old_destroy: (out) (optional): destroy notify for the existing value - * - * Compares the member that is associated with @key_id in - * @datalist to @oldval, and if they are the same, replace - * @oldval with @newval. - * - * This is like a typical atomic compare-and-exchange - * operation, for a member of @datalist. - * - * If the previous value was replaced then ownership of the - * old value (@oldval) is passed to the caller, including - * the registered destroy notify for it (passed out in @old_destroy). - * Its up to the caller to free this as he wishes, which may - * or may not include using @old_destroy as sometimes replacement - * should not destroy the object in the normal way. - * - * Returns: %TRUE if the existing value for @key_id was replaced - * by @newval, %FALSE otherwise. - * Since: 2.34 - */ - - -/** - * g_datalist_id_set_data: - * @dl: a datalist. - * @q: the #GQuark to identify the data element. - * @d: (nullable): the data element, or %NULL to remove any previous element - * corresponding to @q. - * - * Sets the data corresponding to the given #GQuark id. Any previous - * data with the same key is removed, and its destroy function is - * called. - */ - - -/** - * g_datalist_id_set_data_full: (skip) - * @datalist: a datalist. - * @key_id: the #GQuark to identify the data element. - * @data: (nullable): the data element or %NULL to remove any previous element - * corresponding to @key_id. - * @destroy_func: (nullable): the function to call when the data element is - * removed. This function will be called with the data - * element and can be used to free any memory allocated - * for it. If @data is %NULL, then @destroy_func must - * also be %NULL. - * - * Sets the data corresponding to the given #GQuark id, and the - * function to be called when the element is removed from the datalist. - * Any previous data with the same key is removed, and its destroy - * function is called. - */ - - -/** - * g_datalist_init: (skip) - * @datalist: a pointer to a pointer to a datalist. - * - * Resets the datalist to %NULL. It does not free any memory or call - * any destroy functions. - */ - - -/** - * g_datalist_remove_data: - * @dl: a datalist. - * @k: the string identifying the data element. - * - * Removes an element using its string identifier. The data element's - * destroy function is called if it has been set. - */ - - -/** - * g_datalist_remove_no_notify: (skip) - * @dl: a datalist. - * @k: the string identifying the data element. - * - * Removes an element, without calling its destroy notifier. - */ - - -/** - * g_datalist_set_data: - * @dl: a datalist. - * @k: the string to identify the data element. - * @d: (nullable): the data element, or %NULL to remove any previous element - * corresponding to @k. - * - * Sets the data element corresponding to the given string identifier. - */ - - -/** - * g_datalist_set_data_full: (skip) - * @dl: a datalist. - * @k: the string to identify the data element. - * @d: (nullable): the data element, or %NULL to remove any previous element - * corresponding to @k. - * @f: (nullable): the function to call when the data element is removed. - * This function will be called with the data element and can be used to - * free any memory allocated for it. If @d is %NULL, then @f must - * also be %NULL. - * - * Sets the data element corresponding to the given string identifier, - * and the function to be called when the data element is removed. - */ - - -/** - * g_datalist_set_flags: - * @datalist: pointer to the location that holds a list - * @flags: the flags to turn on. The values of the flags are - * restricted by %G_DATALIST_FLAGS_MASK (currently - * 3; giving two possible boolean flags). - * A value for @flags that doesn't fit within the mask is - * an error. - * - * Turns on flag values for a data list. This function is used - * to keep a small number of boolean flags in an object with - * a data list without using any additional space. It is - * not generally useful except in circumstances where space - * is very tight. (It is used in the base #GObject type, for - * example.) - * - * Since: 2.8 - */ - - -/** - * g_datalist_unset_flags: - * @datalist: pointer to the location that holds a list - * @flags: the flags to turn off. The values of the flags are - * restricted by %G_DATALIST_FLAGS_MASK (currently - * 3: giving two possible boolean flags). - * A value for @flags that doesn't fit within the mask is - * an error. - * - * Turns off flag values for a data list. See g_datalist_unset_flags() - * - * Since: 2.8 - */ - - -/** - * g_dataset_destroy: - * @dataset_location: (not nullable): the location identifying the dataset. - * - * Destroys the dataset, freeing all memory allocated, and calling any - * destroy functions set for data elements. - */ - - -/** - * g_dataset_foreach: - * @dataset_location: (not nullable): the location identifying the dataset. - * @func: (scope call): the function to call for each data element. - * @user_data: (closure): user data to pass to the function. - * - * Calls the given function for each data element which is associated - * with the given location. Note that this function is NOT thread-safe. - * So unless @dataset_location can be protected from any modifications - * during invocation of this function, it should not be called. - * - * @func can make changes to the dataset, but the iteration will not - * reflect changes made during the g_dataset_foreach() call, other - * than skipping over elements that are removed. - */ - - -/** - * g_dataset_get_data: - * @l: the location identifying the dataset. - * @k: the string identifying the data element. - * - * Gets the data element corresponding to a string. - * - * Returns: (transfer none) (nullable): the data element corresponding to - * the string, or %NULL if it is not found. - */ - - -/** - * g_dataset_id_get_data: - * @dataset_location: (not nullable): the location identifying the dataset. - * @key_id: the #GQuark id to identify the data element. - * - * Gets the data element corresponding to a #GQuark. - * - * Returns: (transfer none) (nullable): the data element corresponding to - * the #GQuark, or %NULL if it is not found. - */ - - -/** - * g_dataset_id_remove_data: - * @l: the location identifying the dataset. - * @k: the #GQuark id identifying the data element. - * - * Removes a data element from a dataset. The data element's destroy - * function is called if it has been set. - */ - - -/** - * g_dataset_id_remove_no_notify: (skip) - * @dataset_location: (not nullable): the location identifying the dataset. - * @key_id: the #GQuark ID identifying the data element. - * - * Removes an element, without calling its destroy notification - * function. - * - * Returns: (nullable): the data previously stored at @key_id, - * or %NULL if none. - */ - - -/** - * g_dataset_id_set_data: - * @l: the location identifying the dataset. - * @k: the #GQuark id to identify the data element. - * @d: the data element. - * - * Sets the data element associated with the given #GQuark id. Any - * previous data with the same key is removed, and its destroy function - * is called. - */ - - -/** - * g_dataset_id_set_data_full: (skip) - * @dataset_location: (not nullable): the location identifying the dataset. - * @key_id: the #GQuark id to identify the data element. - * @data: the data element. - * @destroy_func: the function to call when the data element is - * removed. This function will be called with the data - * element and can be used to free any memory allocated - * for it. - * - * Sets the data element associated with the given #GQuark id, and also - * the function to call when the data element is destroyed. Any - * previous data with the same key is removed, and its destroy function - * is called. - */ - - -/** - * g_dataset_remove_data: - * @l: the location identifying the dataset. - * @k: the string identifying the data element. - * - * Removes a data element corresponding to a string. Its destroy - * function is called if it has been set. - */ - - -/** - * g_dataset_remove_no_notify: (skip) - * @l: the location identifying the dataset. - * @k: the string identifying the data element. - * - * Removes an element, without calling its destroy notifier. - */ - - -/** - * g_dataset_set_data: - * @l: the location identifying the dataset. - * @k: the string to identify the data element. - * @d: the data element. - * - * Sets the data corresponding to the given string identifier. - */ - - -/** - * g_dataset_set_data_full: (skip) - * @l: the location identifying the dataset. - * @k: the string to identify the data element. - * @d: the data element. - * @f: the function to call when the data element is removed. This - * function will be called with the data element and can be used to - * free any memory allocated for it. - * - * Sets the data corresponding to the given string identifier, and the - * function to call when the data element is destroyed. - */ - - -/** - * g_date_add_days: - * @date: a #GDate to increment - * @n_days: number of days to move the date forward - * - * Increments a date some number of days. - * To move forward by weeks, add weeks*7 days. - * The date must be valid. - */ - - -/** - * g_date_add_months: - * @date: a #GDate to increment - * @n_months: number of months to move forward - * - * Increments a date by some number of months. - * If the day of the month is greater than 28, - * this routine may change the day of the month - * (because the destination month may not have - * the current day in it). The date must be valid. - */ - - -/** - * g_date_add_years: - * @date: a #GDate to increment - * @n_years: number of years to move forward - * - * Increments a date by some number of years. - * If the date is February 29, and the destination - * year is not a leap year, the date will be changed - * to February 28. The date must be valid. - */ - - -/** - * g_date_clamp: - * @date: a #GDate to clamp - * @min_date: minimum accepted value for @date - * @max_date: maximum accepted value for @date - * - * If @date is prior to @min_date, sets @date equal to @min_date. - * If @date falls after @max_date, sets @date equal to @max_date. - * Otherwise, @date is unchanged. - * Either of @min_date and @max_date may be %NULL. - * All non-%NULL dates must be valid. - */ - - -/** - * g_date_clear: - * @date: pointer to one or more dates to clear - * @n_dates: number of dates to clear - * - * Initializes one or more #GDate structs to a safe but invalid - * state. The cleared dates will not represent an existing date, but will - * not contain garbage. Useful to init a date declared on the stack. - * Validity can be tested with g_date_valid(). - */ - - -/** - * g_date_compare: - * @lhs: first date to compare - * @rhs: second date to compare - * - * qsort()-style comparison function for dates. - * Both dates must be valid. - * - * Returns: 0 for equal, less than zero if @lhs is less than @rhs, - * greater than zero if @lhs is greater than @rhs - */ - - -/** - * g_date_copy: - * @date: a #GDate to copy - * - * Copies a GDate to a newly-allocated GDate. If the input was invalid - * (as determined by g_date_valid()), the invalid state will be copied - * as is into the new object. - * - * Returns: (transfer full): a newly-allocated #GDate initialized from @date - * Since: 2.56 - */ - - -/** - * g_date_days_between: - * @date1: the first date - * @date2: the second date - * - * Computes the number of days between two dates. - * If @date2 is prior to @date1, the returned value is negative. - * Both dates must be valid. - * - * Returns: the number of days between @date1 and @date2 - */ - - -/** - * g_date_free: - * @date: a #GDate to free - * - * Frees a #GDate returned from g_date_new(). - */ - - -/** - * g_date_get_day: - * @date: a #GDate to extract the day of the month from - * - * Returns the day of the month. The date must be valid. - * - * Returns: day of the month - */ - - -/** - * g_date_get_day_of_year: - * @date: a #GDate to extract day of year from - * - * Returns the day of the year, where Jan 1 is the first day of the - * year. The date must be valid. - * - * Returns: day of the year - */ - - -/** - * g_date_get_days_in_month: - * @month: month - * @year: year - * - * Returns the number of days in a month, taking leap - * years into account. - * - * Returns: number of days in @month during the @year - */ - - -/** - * g_date_get_iso8601_week_of_year: - * @date: a valid #GDate - * - * Returns the week of the year, where weeks are interpreted according - * to ISO 8601. - * - * Returns: ISO 8601 week number of the year. - * Since: 2.6 - */ - - -/** - * g_date_get_julian: - * @date: a #GDate to extract the Julian day from - * - * Returns the Julian day or "serial number" of the #GDate. The - * Julian day is simply the number of days since January 1, Year 1; i.e., - * January 1, Year 1 is Julian day 1; January 2, Year 1 is Julian day 2, - * etc. The date must be valid. - * - * Returns: Julian day - */ - - -/** - * g_date_get_monday_week_of_year: - * @date: a #GDate - * - * Returns the week of the year, where weeks are understood to start on - * Monday. If the date is before the first Monday of the year, return 0. - * The date must be valid. - * - * Returns: week of the year - */ - - -/** - * g_date_get_monday_weeks_in_year: - * @year: a year - * - * Returns the number of weeks in the year, where weeks - * are taken to start on Monday. Will be 52 or 53. The - * date must be valid. (Years always have 52 7-day periods, - * plus 1 or 2 extra days depending on whether it's a leap - * year. This function is basically telling you how many - * Mondays are in the year, i.e. there are 53 Mondays if - * one of the extra days happens to be a Monday.) - * - * Returns: number of Mondays in the year - */ - - -/** - * g_date_get_month: - * @date: a #GDate to get the month from - * - * Returns the month of the year. The date must be valid. - * - * Returns: month of the year as a #GDateMonth - */ - - -/** - * g_date_get_sunday_week_of_year: - * @date: a #GDate - * - * Returns the week of the year during which this date falls, if - * weeks are understood to begin on Sunday. The date must be valid. - * Can return 0 if the day is before the first Sunday of the year. - * - * Returns: week number - */ - - -/** - * g_date_get_sunday_weeks_in_year: - * @year: year to count weeks in - * - * Returns the number of weeks in the year, where weeks - * are taken to start on Sunday. Will be 52 or 53. The - * date must be valid. (Years always have 52 7-day periods, - * plus 1 or 2 extra days depending on whether it's a leap - * year. This function is basically telling you how many - * Sundays are in the year, i.e. there are 53 Sundays if - * one of the extra days happens to be a Sunday.) - * - * Returns: the number of weeks in @year - */ - - -/** - * g_date_get_weekday: - * @date: a #GDate - * - * Returns the day of the week for a #GDate. The date must be valid. - * - * Returns: day of the week as a #GDateWeekday. - */ - - -/** - * g_date_get_year: - * @date: a #GDate - * - * Returns the year of a #GDate. The date must be valid. - * - * Returns: year in which the date falls - */ - - -/** - * g_date_is_first_of_month: - * @date: a #GDate to check - * - * Returns %TRUE if the date is on the first of a month. - * The date must be valid. - * - * Returns: %TRUE if the date is the first of the month - */ - - -/** - * g_date_is_last_of_month: - * @date: a #GDate to check - * - * Returns %TRUE if the date is the last day of the month. - * The date must be valid. - * - * Returns: %TRUE if the date is the last day of the month - */ - - -/** - * g_date_is_leap_year: - * @year: year to check - * - * Returns %TRUE if the year is a leap year. - * - * For the purposes of this function, leap year is every year - * divisible by 4 unless that year is divisible by 100. If it - * is divisible by 100 it would be a leap year only if that year - * is also divisible by 400. - * - * Returns: %TRUE if the year is a leap year - */ - - -/** - * g_date_new: - * - * Allocates a #GDate and initializes - * it to a safe state. The new date will - * be cleared (as if you'd called g_date_clear()) but invalid (it won't - * represent an existing day). Free the return value with g_date_free(). - * - * Returns: a newly-allocated #GDate - */ - - -/** - * g_date_new_dmy: - * @day: day of the month - * @month: month of the year - * @year: year - * - * Like g_date_new(), but also sets the value of the date. Assuming the - * day-month-year triplet you pass in represents an existing day, the - * returned date will be valid. - * - * Returns: a newly-allocated #GDate initialized with @day, @month, and @year - */ - - -/** - * g_date_new_julian: - * @julian_day: days since January 1, Year 1 - * - * Like g_date_new(), but also sets the value of the date. Assuming the - * Julian day number you pass in is valid (greater than 0, less than an - * unreasonably large number), the returned date will be valid. - * - * Returns: a newly-allocated #GDate initialized with @julian_day - */ - - -/** - * g_date_order: - * @date1: the first date - * @date2: the second date - * - * Checks if @date1 is less than or equal to @date2, - * and swap the values if this is not the case. - */ - - -/** - * g_date_set_day: - * @date: a #GDate - * @day: day to set - * - * Sets the day of the month for a #GDate. If the resulting - * day-month-year triplet is invalid, the date will be invalid. - */ - - -/** - * g_date_set_dmy: - * @date: a #GDate - * @day: day - * @month: month - * @y: year - * - * Sets the value of a #GDate from a day, month, and year. - * The day-month-year triplet must be valid; if you aren't - * sure it is, call g_date_valid_dmy() to check before you - * set it. - */ - - -/** - * g_date_set_julian: - * @date: a #GDate - * @julian_date: Julian day number (days since January 1, Year 1) - * - * Sets the value of a #GDate from a Julian day number. - */ - - -/** - * g_date_set_month: - * @date: a #GDate - * @month: month to set - * - * Sets the month of the year for a #GDate. If the resulting - * day-month-year triplet is invalid, the date will be invalid. - */ - - -/** - * g_date_set_parse: - * @date: a #GDate to fill in - * @str: string to parse - * - * Parses a user-inputted string @str, and try to figure out what date it - * represents, taking the [current locale][setlocale] into account. If the - * string is successfully parsed, the date will be valid after the call. - * Otherwise, it will be invalid. You should check using g_date_valid() - * to see whether the parsing succeeded. - * - * This function is not appropriate for file formats and the like; it - * isn't very precise, and its exact behavior varies with the locale. - * It's intended to be a heuristic routine that guesses what the user - * means by a given string (and it does work pretty well in that - * capacity). - */ - - -/** - * g_date_set_time: - * @date: a #GDate. - * @time_: #GTime value to set. - * - * Sets the value of a date from a #GTime value. - * The time to date conversion is done using the user's current timezone. - * - * Deprecated: 2.10: Use g_date_set_time_t() instead. - */ - - -/** - * g_date_set_time_t: - * @date: a #GDate - * @timet: time_t value to set - * - * Sets the value of a date to the date corresponding to a time - * specified as a time_t. The time to date conversion is done using - * the user's current timezone. - * - * To set the value of a date to the current day, you could write: - * |[<!-- language="C" --> - * time_t now = time (NULL); - * if (now == (time_t) -1) - * // handle the error - * g_date_set_time_t (date, now); - * ]| - * - * Since: 2.10 - */ - - -/** - * g_date_set_time_val: - * @date: a #GDate - * @timeval: #GTimeVal value to set - * - * Sets the value of a date from a #GTimeVal value. Note that the - * @tv_usec member is ignored, because #GDate can't make use of the - * additional precision. - * - * The time to date conversion is done using the user's current timezone. - * - * Since: 2.10 - * Deprecated: 2.62: #GTimeVal is not year-2038-safe. Use g_date_set_time_t() - * instead. - */ - - -/** - * g_date_set_year: - * @date: a #GDate - * @year: year to set - * - * Sets the year for a #GDate. If the resulting day-month-year - * triplet is invalid, the date will be invalid. - */ - - -/** - * g_date_strftime: - * @s: destination buffer - * @slen: buffer size - * @format: format string - * @date: valid #GDate - * - * Generates a printed representation of the date, in a - * [locale][setlocale]-specific way. - * Works just like the platform's C library strftime() function, - * but only accepts date-related formats; time-related formats - * give undefined results. Date must be valid. Unlike strftime() - * (which uses the locale encoding), works on a UTF-8 format - * string and stores a UTF-8 result. - * - * This function does not provide any conversion specifiers in - * addition to those implemented by the platform's C library. - * For example, don't expect that using g_date_strftime() would - * make the \%F provided by the C99 strftime() work on Windows - * where the C library only complies to C89. - * - * Returns: number of characters written to the buffer, or 0 the buffer was too small - */ - - -/** - * g_date_subtract_days: - * @date: a #GDate to decrement - * @n_days: number of days to move - * - * Moves a date some number of days into the past. - * To move by weeks, just move by weeks*7 days. - * The date must be valid. - */ - - -/** - * g_date_subtract_months: - * @date: a #GDate to decrement - * @n_months: number of months to move - * - * Moves a date some number of months into the past. - * If the current day of the month doesn't exist in - * the destination month, the day of the month - * may change. The date must be valid. - */ - - -/** - * g_date_subtract_years: - * @date: a #GDate to decrement - * @n_years: number of years to move - * - * Moves a date some number of years into the past. - * If the current day doesn't exist in the destination - * year (i.e. it's February 29 and you move to a non-leap-year) - * then the day is changed to February 29. The date - * must be valid. - */ - - -/** - * g_date_time_add: - * @datetime: a #GDateTime - * @timespan: a #GTimeSpan - * - * Creates a copy of @datetime and adds the specified timespan to the copy. - * - * Returns: (transfer full) (nullable): the newly created #GDateTime which - * should be freed with g_date_time_unref(), or %NULL - * Since: 2.26 - */ - - -/** - * g_date_time_add_days: - * @datetime: a #GDateTime - * @days: the number of days - * - * Creates a copy of @datetime and adds the specified number of days to the - * copy. Add negative values to subtract days. - * - * Returns: (transfer full) (nullable): the newly created #GDateTime which - * should be freed with g_date_time_unref(), or %NULL - * Since: 2.26 - */ - - -/** - * g_date_time_add_full: - * @datetime: a #GDateTime - * @years: the number of years to add - * @months: the number of months to add - * @days: the number of days to add - * @hours: the number of hours to add - * @minutes: the number of minutes to add - * @seconds: the number of seconds to add - * - * Creates a new #GDateTime adding the specified values to the current date and - * time in @datetime. Add negative values to subtract. - * - * Returns: (transfer full) (nullable): the newly created #GDateTime which - * should be freed with g_date_time_unref(), or %NULL - * Since: 2.26 - */ - - -/** - * g_date_time_add_hours: - * @datetime: a #GDateTime - * @hours: the number of hours to add - * - * Creates a copy of @datetime and adds the specified number of hours. - * Add negative values to subtract hours. - * - * Returns: (transfer full) (nullable): the newly created #GDateTime which - * should be freed with g_date_time_unref(), or %NULL - * Since: 2.26 - */ - - -/** - * g_date_time_add_minutes: - * @datetime: a #GDateTime - * @minutes: the number of minutes to add - * - * Creates a copy of @datetime adding the specified number of minutes. - * Add negative values to subtract minutes. - * - * Returns: (transfer full) (nullable): the newly created #GDateTime which - * should be freed with g_date_time_unref(), or %NULL - * Since: 2.26 - */ - - -/** - * g_date_time_add_months: - * @datetime: a #GDateTime - * @months: the number of months - * - * Creates a copy of @datetime and adds the specified number of months to the - * copy. Add negative values to subtract months. - * - * The day of the month of the resulting #GDateTime is clamped to the number - * of days in the updated calendar month. For example, if adding 1 month to - * 31st January 2018, the result would be 28th February 2018. In 2020 (a leap - * year), the result would be 29th February. - * - * Returns: (transfer full) (nullable): the newly created #GDateTime which - * should be freed with g_date_time_unref(), or %NULL - * Since: 2.26 - */ - - -/** - * g_date_time_add_seconds: - * @datetime: a #GDateTime - * @seconds: the number of seconds to add - * - * Creates a copy of @datetime and adds the specified number of seconds. - * Add negative values to subtract seconds. - * - * Returns: (transfer full) (nullable): the newly created #GDateTime which - * should be freed with g_date_time_unref(), or %NULL - * Since: 2.26 - */ - - -/** - * g_date_time_add_weeks: - * @datetime: a #GDateTime - * @weeks: the number of weeks - * - * Creates a copy of @datetime and adds the specified number of weeks to the - * copy. Add negative values to subtract weeks. - * - * Returns: (transfer full) (nullable): the newly created #GDateTime which - * should be freed with g_date_time_unref(), or %NULL - * Since: 2.26 - */ - - -/** - * g_date_time_add_years: - * @datetime: a #GDateTime - * @years: the number of years - * - * Creates a copy of @datetime and adds the specified number of years to the - * copy. Add negative values to subtract years. - * - * As with g_date_time_add_months(), if the resulting date would be 29th - * February on a non-leap year, the day will be clamped to 28th February. - * - * Returns: (transfer full) (nullable): the newly created #GDateTime which - * should be freed with g_date_time_unref(), or %NULL - * Since: 2.26 - */ - - -/** - * g_date_time_compare: - * @dt1: (type GDateTime) (not nullable): first #GDateTime to compare - * @dt2: (type GDateTime) (not nullable): second #GDateTime to compare - * - * A comparison function for #GDateTimes that is suitable - * as a #GCompareFunc. Both #GDateTimes must be non-%NULL. - * - * Returns: -1, 0 or 1 if @dt1 is less than, equal to or greater - * than @dt2. - * Since: 2.26 - */ - - -/** - * g_date_time_difference: - * @end: a #GDateTime - * @begin: a #GDateTime - * - * Calculates the difference in time between @end and @begin. The - * #GTimeSpan that is returned is effectively @end - @begin (ie: - * positive if the first parameter is larger). - * - * Returns: the difference between the two #GDateTime, as a time - * span expressed in microseconds. - * Since: 2.26 - */ - - -/** - * g_date_time_equal: - * @dt1: (type GDateTime) (not nullable): a #GDateTime - * @dt2: (type GDateTime) (not nullable): a #GDateTime - * - * Checks to see if @dt1 and @dt2 are equal. - * - * Equal here means that they represent the same moment after converting - * them to the same time zone. - * - * Returns: %TRUE if @dt1 and @dt2 are equal - * Since: 2.26 - */ - - -/** - * g_date_time_format: - * @datetime: A #GDateTime - * @format: a valid UTF-8 string, containing the format for the - * #GDateTime - * - * Creates a newly allocated string representing the requested @format. - * - * The format strings understood by this function are a subset of the - * strftime() format language as specified by C99. The \%D, \%U and \%W - * conversions are not supported, nor is the 'E' modifier. The GNU - * extensions \%k, \%l, \%s and \%P are supported, however, as are the - * '0', '_' and '-' modifiers. The Python extension \%f is also supported. - * - * In contrast to strftime(), this function always produces a UTF-8 - * string, regardless of the current locale. Note that the rendering of - * many formats is locale-dependent and may not match the strftime() - * output exactly. - * - * The following format specifiers are supported: - * - * - \%a: the abbreviated weekday name according to the current locale - * - \%A: the full weekday name according to the current locale - * - \%b: the abbreviated month name according to the current locale - * - \%B: the full month name according to the current locale - * - \%c: the preferred date and time representation for the current locale - * - \%C: the century number (year/100) as a 2-digit integer (00-99) - * - \%d: the day of the month as a decimal number (range 01 to 31) - * - \%e: the day of the month as a decimal number (range 1 to 31) - * - \%F: equivalent to `%Y-%m-%d` (the ISO 8601 date format) - * - \%g: the last two digits of the ISO 8601 week-based year as a - * decimal number (00-99). This works well with \%V and \%u. - * - \%G: the ISO 8601 week-based year as a decimal number. This works - * well with \%V and \%u. - * - \%h: equivalent to \%b - * - \%H: the hour as a decimal number using a 24-hour clock (range 00 to 23) - * - \%I: the hour as a decimal number using a 12-hour clock (range 01 to 12) - * - \%j: the day of the year as a decimal number (range 001 to 366) - * - \%k: the hour (24-hour clock) as a decimal number (range 0 to 23); - * single digits are preceded by a blank - * - \%l: the hour (12-hour clock) as a decimal number (range 1 to 12); - * single digits are preceded by a blank - * - \%m: the month as a decimal number (range 01 to 12) - * - \%M: the minute as a decimal number (range 00 to 59) - * - \%f: the microsecond as a decimal number (range 000000 to 999999) - * - \%p: either "AM" or "PM" according to the given time value, or the - * corresponding strings for the current locale. Noon is treated as - * "PM" and midnight as "AM". Use of this format specifier is discouraged, as - * many locales have no concept of AM/PM formatting. Use \%c or \%X instead. - * - \%P: like \%p but lowercase: "am" or "pm" or a corresponding string for - * the current locale. Use of this format specifier is discouraged, as - * many locales have no concept of AM/PM formatting. Use \%c or \%X instead. - * - \%r: the time in a.m. or p.m. notation. Use of this format specifier is - * discouraged, as many locales have no concept of AM/PM formatting. Use \%c - * or \%X instead. - * - \%R: the time in 24-hour notation (\%H:\%M) - * - \%s: the number of seconds since the Epoch, that is, since 1970-01-01 - * 00:00:00 UTC - * - \%S: the second as a decimal number (range 00 to 60) - * - \%t: a tab character - * - \%T: the time in 24-hour notation with seconds (\%H:\%M:\%S) - * - \%u: the ISO 8601 standard day of the week as a decimal, range 1 to 7, - * Monday being 1. This works well with \%G and \%V. - * - \%V: the ISO 8601 standard week number of the current year as a decimal - * number, range 01 to 53, where week 1 is the first week that has at - * least 4 days in the new year. See g_date_time_get_week_of_year(). - * This works well with \%G and \%u. - * - \%w: the day of the week as a decimal, range 0 to 6, Sunday being 0. - * This is not the ISO 8601 standard format -- use \%u instead. - * - \%x: the preferred date representation for the current locale without - * the time - * - \%X: the preferred time representation for the current locale without - * the date - * - \%y: the year as a decimal number without the century - * - \%Y: the year as a decimal number including the century - * - \%z: the time zone as an offset from UTC (+hhmm) - * - \%:z: the time zone as an offset from UTC (+hh:mm). - * This is a gnulib strftime() extension. Since: 2.38 - * - \%::z: the time zone as an offset from UTC (+hh:mm:ss). This is a - * gnulib strftime() extension. Since: 2.38 - * - \%:::z: the time zone as an offset from UTC, with : to necessary - * precision (e.g., -04, +05:30). This is a gnulib strftime() extension. Since: 2.38 - * - \%Z: the time zone or name or abbreviation - * - \%\%: a literal \% character - * - * Some conversion specifications can be modified by preceding the - * conversion specifier by one or more modifier characters. The - * following modifiers are supported for many of the numeric - * conversions: - * - * - O: Use alternative numeric symbols, if the current locale supports those. - * - _: Pad a numeric result with spaces. This overrides the default padding - * for the specifier. - * - -: Do not pad a numeric result. This overrides the default padding - * for the specifier. - * - 0: Pad a numeric result with zeros. This overrides the default padding - * for the specifier. - * - * Additionally, when O is used with B, b, or h, it produces the alternative - * form of a month name. The alternative form should be used when the month - * name is used without a day number (e.g., standalone). It is required in - * some languages (Baltic, Slavic, Greek, and more) due to their grammatical - * rules. For other languages there is no difference. \%OB is a GNU and BSD - * strftime() extension expected to be added to the future POSIX specification, - * \%Ob and \%Oh are GNU strftime() extensions. Since: 2.56 - * - * Returns: (transfer full) (nullable): a newly allocated string formatted to - * the requested format or %NULL in the case that there was an error (such - * as a format specifier not being supported in the current locale). The - * string should be freed with g_free(). - * Since: 2.26 - */ - - -/** - * g_date_time_format_iso8601: - * @datetime: A #GDateTime - * - * Format @datetime in [ISO 8601 format](https://en.wikipedia.org/wiki/ISO_8601), - * including the date, time and time zone, and return that as a UTF-8 encoded - * string. - * - * Since GLib 2.66, this will output to sub-second precision if needed. - * - * Returns: (transfer full) (nullable): a newly allocated string formatted in - * ISO 8601 format or %NULL in the case that there was an error. The string - * should be freed with g_free(). - * Since: 2.62 - */ - - -/** - * g_date_time_get_day_of_month: - * @datetime: a #GDateTime - * - * Retrieves the day of the month represented by @datetime in the gregorian - * calendar. - * - * Returns: the day of the month - * Since: 2.26 - */ - - -/** - * g_date_time_get_day_of_week: - * @datetime: a #GDateTime - * - * Retrieves the ISO 8601 day of the week on which @datetime falls (1 is - * Monday, 2 is Tuesday... 7 is Sunday). - * - * Returns: the day of the week - * Since: 2.26 - */ - - -/** - * g_date_time_get_day_of_year: - * @datetime: a #GDateTime - * - * Retrieves the day of the year represented by @datetime in the Gregorian - * calendar. - * - * Returns: the day of the year - * Since: 2.26 - */ - - -/** - * g_date_time_get_hour: - * @datetime: a #GDateTime - * - * Retrieves the hour of the day represented by @datetime - * - * Returns: the hour of the day - * Since: 2.26 - */ - - -/** - * g_date_time_get_microsecond: - * @datetime: a #GDateTime - * - * Retrieves the microsecond of the date represented by @datetime - * - * Returns: the microsecond of the second - * Since: 2.26 - */ - - -/** - * g_date_time_get_minute: - * @datetime: a #GDateTime - * - * Retrieves the minute of the hour represented by @datetime - * - * Returns: the minute of the hour - * Since: 2.26 - */ - - -/** - * g_date_time_get_month: - * @datetime: a #GDateTime - * - * Retrieves the month of the year represented by @datetime in the Gregorian - * calendar. - * - * Returns: the month represented by @datetime - * Since: 2.26 - */ - - -/** - * g_date_time_get_second: - * @datetime: a #GDateTime - * - * Retrieves the second of the minute represented by @datetime - * - * Returns: the second represented by @datetime - * Since: 2.26 - */ - - -/** - * g_date_time_get_seconds: - * @datetime: a #GDateTime - * - * Retrieves the number of seconds since the start of the last minute, - * including the fractional part. - * - * Returns: the number of seconds - * Since: 2.26 - */ - - -/** - * g_date_time_get_timezone: - * @datetime: a #GDateTime - * - * Get the time zone for this @datetime. - * - * Returns: (transfer none): the time zone - * Since: 2.58 - */ - - -/** - * g_date_time_get_timezone_abbreviation: - * @datetime: a #GDateTime - * - * Determines the time zone abbreviation to be used at the time and in - * the time zone of @datetime. - * - * For example, in Toronto this is currently "EST" during the winter - * months and "EDT" during the summer months when daylight savings - * time is in effect. - * - * Returns: (transfer none): the time zone abbreviation. The returned - * string is owned by the #GDateTime and it should not be - * modified or freed - * Since: 2.26 - */ - - -/** - * g_date_time_get_utc_offset: - * @datetime: a #GDateTime - * - * Determines the offset to UTC in effect at the time and in the time - * zone of @datetime. - * - * The offset is the number of microseconds that you add to UTC time to - * arrive at local time for the time zone (ie: negative numbers for time - * zones west of GMT, positive numbers for east). - * - * If @datetime represents UTC time, then the offset is always zero. - * - * Returns: the number of microseconds that should be added to UTC to - * get the local time - * Since: 2.26 - */ - - -/** - * g_date_time_get_week_numbering_year: - * @datetime: a #GDateTime - * - * Returns the ISO 8601 week-numbering year in which the week containing - * @datetime falls. - * - * This function, taken together with g_date_time_get_week_of_year() and - * g_date_time_get_day_of_week() can be used to determine the full ISO - * week date on which @datetime falls. - * - * This is usually equal to the normal Gregorian year (as returned by - * g_date_time_get_year()), except as detailed below: - * - * For Thursday, the week-numbering year is always equal to the usual - * calendar year. For other days, the number is such that every day - * within a complete week (Monday to Sunday) is contained within the - * same week-numbering year. - * - * For Monday, Tuesday and Wednesday occurring near the end of the year, - * this may mean that the week-numbering year is one greater than the - * calendar year (so that these days have the same week-numbering year - * as the Thursday occurring early in the next year). - * - * For Friday, Saturday and Sunday occurring near the start of the year, - * this may mean that the week-numbering year is one less than the - * calendar year (so that these days have the same week-numbering year - * as the Thursday occurring late in the previous year). - * - * An equivalent description is that the week-numbering year is equal to - * the calendar year containing the majority of the days in the current - * week (Monday to Sunday). - * - * Note that January 1 0001 in the proleptic Gregorian calendar is a - * Monday, so this function never returns 0. - * - * Returns: the ISO 8601 week-numbering year for @datetime - * Since: 2.26 - */ - - -/** - * g_date_time_get_week_of_year: - * @datetime: a #GDateTime - * - * Returns the ISO 8601 week number for the week containing @datetime. - * The ISO 8601 week number is the same for every day of the week (from - * Moday through Sunday). That can produce some unusual results - * (described below). - * - * The first week of the year is week 1. This is the week that contains - * the first Thursday of the year. Equivalently, this is the first week - * that has more than 4 of its days falling within the calendar year. - * - * The value 0 is never returned by this function. Days contained - * within a year but occurring before the first ISO 8601 week of that - * year are considered as being contained in the last week of the - * previous year. Similarly, the final days of a calendar year may be - * considered as being part of the first ISO 8601 week of the next year - * if 4 or more days of that week are contained within the new year. - * - * Returns: the ISO 8601 week number for @datetime. - * Since: 2.26 - */ - - -/** - * g_date_time_get_year: - * @datetime: A #GDateTime - * - * Retrieves the year represented by @datetime in the Gregorian calendar. - * - * Returns: the year represented by @datetime - * Since: 2.26 - */ - - -/** - * g_date_time_get_ymd: - * @datetime: a #GDateTime. - * @year: (out) (optional): the return location for the gregorian year, or %NULL. - * @month: (out) (optional): the return location for the month of the year, or %NULL. - * @day: (out) (optional): the return location for the day of the month, or %NULL. - * - * Retrieves the Gregorian day, month, and year of a given #GDateTime. - * - * Since: 2.26 - */ - - -/** - * g_date_time_hash: - * @datetime: (type GDateTime) (not nullable): a #GDateTime - * - * Hashes @datetime into a #guint, suitable for use within #GHashTable. - * - * Returns: a #guint containing the hash - * Since: 2.26 - */ - - -/** - * g_date_time_is_daylight_savings: - * @datetime: a #GDateTime - * - * Determines if daylight savings time is in effect at the time and in - * the time zone of @datetime. - * - * Returns: %TRUE if daylight savings time is in effect - * Since: 2.26 - */ - - -/** - * g_date_time_new: (constructor) - * @tz: a #GTimeZone - * @year: the year component of the date - * @month: the month component of the date - * @day: the day component of the date - * @hour: the hour component of the date - * @minute: the minute component of the date - * @seconds: the number of seconds past the minute - * - * Creates a new #GDateTime corresponding to the given date and time in - * the time zone @tz. - * - * The @year must be between 1 and 9999, @month between 1 and 12 and @day - * between 1 and 28, 29, 30 or 31 depending on the month and the year. - * - * @hour must be between 0 and 23 and @minute must be between 0 and 59. - * - * @seconds must be at least 0.0 and must be strictly less than 60.0. - * It will be rounded down to the nearest microsecond. - * - * If the given time is not representable in the given time zone (for - * example, 02:30 on March 14th 2010 in Toronto, due to daylight savings - * time) then the time will be rounded up to the nearest existing time - * (in this case, 03:00). If this matters to you then you should verify - * the return value for containing the same as the numbers you gave. - * - * In the case that the given time is ambiguous in the given time zone - * (for example, 01:30 on November 7th 2010 in Toronto, due to daylight - * savings time) then the time falling within standard (ie: - * non-daylight) time is taken. - * - * It not considered a programmer error for the values to this function - * to be out of range, but in the case that they are, the function will - * return %NULL. - * - * You should release the return value by calling g_date_time_unref() - * when you are done with it. - * - * Returns: (transfer full) (nullable): a new #GDateTime, or %NULL - * Since: 2.26 - */ - - -/** - * g_date_time_new_from_iso8601: (constructor) - * @text: an ISO 8601 formatted time string. - * @default_tz: (nullable): a #GTimeZone to use if the text doesn't contain a - * timezone, or %NULL. - * - * Creates a #GDateTime corresponding to the given - * [ISO 8601 formatted string](https://en.wikipedia.org/wiki/ISO_8601) - * @text. ISO 8601 strings of the form <date><sep><time><tz> are supported, with - * some extensions from [RFC 3339](https://tools.ietf.org/html/rfc3339) as - * mentioned below. - * - * Note that as #GDateTime "is oblivious to leap seconds", leap seconds information - * in an ISO-8601 string will be ignored, so a `23:59:60` time would be parsed as - * `23:59:59`. - * - * <sep> is the separator and can be either 'T', 't' or ' '. The latter two - * separators are an extension from - * [RFC 3339](https://tools.ietf.org/html/rfc3339#section-5.6). - * - * <date> is in the form: - * - * - `YYYY-MM-DD` - Year/month/day, e.g. 2016-08-24. - * - `YYYYMMDD` - Same as above without dividers. - * - `YYYY-DDD` - Ordinal day where DDD is from 001 to 366, e.g. 2016-237. - * - `YYYYDDD` - Same as above without dividers. - * - `YYYY-Www-D` - Week day where ww is from 01 to 52 and D from 1-7, - * e.g. 2016-W34-3. - * - `YYYYWwwD` - Same as above without dividers. - * - * <time> is in the form: - * - * - `hh:mm:ss(.sss)` - Hours, minutes, seconds (subseconds), e.g. 22:10:42.123. - * - `hhmmss(.sss)` - Same as above without dividers. - * - * <tz> is an optional timezone suffix of the form: - * - * - `Z` - UTC. - * - `+hh:mm` or `-hh:mm` - Offset from UTC in hours and minutes, e.g. +12:00. - * - `+hh` or `-hh` - Offset from UTC in hours, e.g. +12. - * - * If the timezone is not provided in @text it must be provided in @default_tz - * (this field is otherwise ignored). - * - * This call can fail (returning %NULL) if @text is not a valid ISO 8601 - * formatted string. - * - * You should release the return value by calling g_date_time_unref() - * when you are done with it. - * - * Returns: (transfer full) (nullable): a new #GDateTime, or %NULL - * Since: 2.56 - */ - - -/** - * g_date_time_new_from_timeval_local: (constructor) - * @tv: a #GTimeVal - * - * Creates a #GDateTime corresponding to the given #GTimeVal @tv in the - * local time zone. - * - * The time contained in a #GTimeVal is always stored in the form of - * seconds elapsed since 1970-01-01 00:00:00 UTC, regardless of the - * local time offset. - * - * This call can fail (returning %NULL) if @tv represents a time outside - * of the supported range of #GDateTime. - * - * You should release the return value by calling g_date_time_unref() - * when you are done with it. - * - * Returns: (transfer full) (nullable): a new #GDateTime, or %NULL - * Since: 2.26 - * Deprecated: 2.62: #GTimeVal is not year-2038-safe. Use - * g_date_time_new_from_unix_local() instead. - */ - - -/** - * g_date_time_new_from_timeval_utc: (constructor) - * @tv: a #GTimeVal - * - * Creates a #GDateTime corresponding to the given #GTimeVal @tv in UTC. - * - * The time contained in a #GTimeVal is always stored in the form of - * seconds elapsed since 1970-01-01 00:00:00 UTC. - * - * This call can fail (returning %NULL) if @tv represents a time outside - * of the supported range of #GDateTime. - * - * You should release the return value by calling g_date_time_unref() - * when you are done with it. - * - * Returns: (transfer full) (nullable): a new #GDateTime, or %NULL - * Since: 2.26 - * Deprecated: 2.62: #GTimeVal is not year-2038-safe. Use - * g_date_time_new_from_unix_utc() instead. - */ - - -/** - * g_date_time_new_from_unix_local: (constructor) - * @t: the Unix time - * - * Creates a #GDateTime corresponding to the given Unix time @t in the - * local time zone. - * - * Unix time is the number of seconds that have elapsed since 1970-01-01 - * 00:00:00 UTC, regardless of the local time offset. - * - * This call can fail (returning %NULL) if @t represents a time outside - * of the supported range of #GDateTime. - * - * You should release the return value by calling g_date_time_unref() - * when you are done with it. - * - * Returns: (transfer full) (nullable): a new #GDateTime, or %NULL - * Since: 2.26 - */ - - -/** - * g_date_time_new_from_unix_utc: (constructor) - * @t: the Unix time - * - * Creates a #GDateTime corresponding to the given Unix time @t in UTC. - * - * Unix time is the number of seconds that have elapsed since 1970-01-01 - * 00:00:00 UTC. - * - * This call can fail (returning %NULL) if @t represents a time outside - * of the supported range of #GDateTime. - * - * You should release the return value by calling g_date_time_unref() - * when you are done with it. - * - * Returns: (transfer full) (nullable): a new #GDateTime, or %NULL - * Since: 2.26 - */ - - -/** - * g_date_time_new_local: (constructor) - * @year: the year component of the date - * @month: the month component of the date - * @day: the day component of the date - * @hour: the hour component of the date - * @minute: the minute component of the date - * @seconds: the number of seconds past the minute - * - * Creates a new #GDateTime corresponding to the given date and time in - * the local time zone. - * - * This call is equivalent to calling g_date_time_new() with the time - * zone returned by g_time_zone_new_local(). - * - * Returns: (transfer full) (nullable): a #GDateTime, or %NULL - * Since: 2.26 - */ - - -/** - * g_date_time_new_now: (constructor) - * @tz: a #GTimeZone - * - * Creates a #GDateTime corresponding to this exact instant in the given - * time zone @tz. The time is as accurate as the system allows, to a - * maximum accuracy of 1 microsecond. - * - * This function will always succeed unless GLib is still being used after the - * year 9999. - * - * You should release the return value by calling g_date_time_unref() - * when you are done with it. - * - * Returns: (transfer full) (nullable): a new #GDateTime, or %NULL - * Since: 2.26 - */ - - -/** - * g_date_time_new_now_local: (constructor) - * - * Creates a #GDateTime corresponding to this exact instant in the local - * time zone. - * - * This is equivalent to calling g_date_time_new_now() with the time - * zone returned by g_time_zone_new_local(). - * - * Returns: (transfer full) (nullable): a new #GDateTime, or %NULL - * Since: 2.26 - */ - - -/** - * g_date_time_new_now_utc: (constructor) - * - * Creates a #GDateTime corresponding to this exact instant in UTC. - * - * This is equivalent to calling g_date_time_new_now() with the time - * zone returned by g_time_zone_new_utc(). - * - * Returns: (transfer full) (nullable): a new #GDateTime, or %NULL - * Since: 2.26 - */ - - -/** - * g_date_time_new_utc: (constructor) - * @year: the year component of the date - * @month: the month component of the date - * @day: the day component of the date - * @hour: the hour component of the date - * @minute: the minute component of the date - * @seconds: the number of seconds past the minute - * - * Creates a new #GDateTime corresponding to the given date and time in - * UTC. - * - * This call is equivalent to calling g_date_time_new() with the time - * zone returned by g_time_zone_new_utc(). - * - * Returns: (transfer full) (nullable): a #GDateTime, or %NULL - * Since: 2.26 - */ - - -/** - * g_date_time_ref: - * @datetime: a #GDateTime - * - * Atomically increments the reference count of @datetime by one. - * - * Returns: the #GDateTime with the reference count increased - * Since: 2.26 - */ - - -/** - * g_date_time_to_local: - * @datetime: a #GDateTime - * - * Creates a new #GDateTime corresponding to the same instant in time as - * @datetime, but in the local time zone. - * - * This call is equivalent to calling g_date_time_to_timezone() with the - * time zone returned by g_time_zone_new_local(). - * - * Returns: (transfer full) (nullable): the newly created #GDateTime which - * should be freed with g_date_time_unref(), or %NULL - * Since: 2.26 - */ - - -/** - * g_date_time_to_timeval: - * @datetime: a #GDateTime - * @tv: a #GTimeVal to modify - * - * Stores the instant in time that @datetime represents into @tv. - * - * The time contained in a #GTimeVal is always stored in the form of - * seconds elapsed since 1970-01-01 00:00:00 UTC, regardless of the time - * zone associated with @datetime. - * - * On systems where 'long' is 32bit (ie: all 32bit systems and all - * Windows systems), a #GTimeVal is incapable of storing the entire - * range of values that #GDateTime is capable of expressing. On those - * systems, this function returns %FALSE to indicate that the time is - * out of range. - * - * On systems where 'long' is 64bit, this function never fails. - * - * Returns: %TRUE if successful, else %FALSE - * Since: 2.26 - * Deprecated: 2.62: #GTimeVal is not year-2038-safe. Use - * g_date_time_to_unix() instead. - */ - - -/** - * g_date_time_to_timezone: - * @datetime: a #GDateTime - * @tz: the new #GTimeZone - * - * Create a new #GDateTime corresponding to the same instant in time as - * @datetime, but in the time zone @tz. - * - * This call can fail in the case that the time goes out of bounds. For - * example, converting 0001-01-01 00:00:00 UTC to a time zone west of - * Greenwich will fail (due to the year 0 being out of range). - * - * Returns: (transfer full) (nullable): the newly created #GDateTime which - * should be freed with g_date_time_unref(), or %NULL - * Since: 2.26 - */ - - -/** - * g_date_time_to_unix: - * @datetime: a #GDateTime - * - * Gives the Unix time corresponding to @datetime, rounding down to the - * nearest second. - * - * Unix time is the number of seconds that have elapsed since 1970-01-01 - * 00:00:00 UTC, regardless of the time zone associated with @datetime. - * - * Returns: the Unix time corresponding to @datetime - * Since: 2.26 - */ - - -/** - * g_date_time_to_utc: - * @datetime: a #GDateTime - * - * Creates a new #GDateTime corresponding to the same instant in time as - * @datetime, but in UTC. - * - * This call is equivalent to calling g_date_time_to_timezone() with the - * time zone returned by g_time_zone_new_utc(). - * - * Returns: (transfer full) (nullable): the newly created #GDateTime which - * should be freed with g_date_time_unref(), or %NULL - * Since: 2.26 - */ - - -/** - * g_date_time_unref: - * @datetime: a #GDateTime - * - * Atomically decrements the reference count of @datetime by one. - * - * When the reference count reaches zero, the resources allocated by - * @datetime are freed - * - * Since: 2.26 - */ - - -/** - * g_date_to_struct_tm: - * @date: a #GDate to set the struct tm from - * @tm: (not nullable): struct tm to fill - * - * Fills in the date-related bits of a struct tm using the @date value. - * Initializes the non-date parts with something safe but meaningless. - */ - - -/** - * g_date_valid: - * @date: a #GDate to check - * - * Returns %TRUE if the #GDate represents an existing day. The date must not - * contain garbage; it should have been initialized with g_date_clear() - * if it wasn't allocated by one of the g_date_new() variants. - * - * Returns: Whether the date is valid - */ - - -/** - * g_date_valid_day: - * @day: day to check - * - * Returns %TRUE if the day of the month is valid (a day is valid if it's - * between 1 and 31 inclusive). - * - * Returns: %TRUE if the day is valid - */ - - -/** - * g_date_valid_dmy: - * @day: day - * @month: month - * @year: year - * - * Returns %TRUE if the day-month-year triplet forms a valid, existing day - * in the range of days #GDate understands (Year 1 or later, no more than - * a few thousand years in the future). - * - * Returns: %TRUE if the date is a valid one - */ - - -/** - * g_date_valid_julian: - * @julian_date: Julian day to check - * - * Returns %TRUE if the Julian day is valid. Anything greater than zero - * is basically a valid Julian, though there is a 32-bit limit. - * - * Returns: %TRUE if the Julian day is valid - */ - - -/** - * g_date_valid_month: - * @month: month - * - * Returns %TRUE if the month value is valid. The 12 #GDateMonth - * enumeration values are the only valid months. - * - * Returns: %TRUE if the month is valid - */ - - -/** - * g_date_valid_weekday: - * @weekday: weekday - * - * Returns %TRUE if the weekday is valid. The seven #GDateWeekday enumeration - * values are the only valid weekdays. - * - * Returns: %TRUE if the weekday is valid - */ - - -/** - * g_date_valid_year: - * @year: year - * - * Returns %TRUE if the year is valid. Any year greater than 0 is valid, - * though there is a 16-bit limit to what #GDate will understand. - * - * Returns: %TRUE if the year is valid - */ - - -/** - * g_dcgettext: - * @domain: (nullable): the translation domain to use, or %NULL to use - * the domain set with textdomain() - * @msgid: message to translate - * @category: a locale category - * - * This is a variant of g_dgettext() that allows specifying a locale - * category instead of always using `LC_MESSAGES`. See g_dgettext() for - * more information about how this functions differs from calling - * dcgettext() directly. - * - * Returns: the translated string for the given locale category - * Since: 2.26 - */ - - -/** - * g_debug: - * @...: format string, followed by parameters to insert - * into the format string (as with printf()) - * - * A convenience function/macro to log a debug message. The message should - * typically *not* be translated to the user's language. - * - * If g_log_default_handler() is used as the log handler function, a new-line - * character will automatically be appended to @..., and need not be entered - * manually. - * - * Such messages are suppressed by the g_log_default_handler() and - * g_log_writer_default() unless the `G_MESSAGES_DEBUG` environment variable is - * set appropriately. - * - * If structured logging is enabled, this will use g_log_structured(); - * otherwise it will use g_log(). See - * [Using Structured Logging][using-structured-logging]. - * - * Since: 2.6 - */ - - -/** - * g_dgettext: - * @domain: (nullable): the translation domain to use, or %NULL to use - * the domain set with textdomain() - * @msgid: message to translate - * - * This function is a wrapper of dgettext() which does not translate - * the message if the default domain as set with textdomain() has no - * translations for the current locale. - * - * The advantage of using this function over dgettext() proper is that - * libraries using this function (like GTK+) will not use translations - * if the application using the library does not have translations for - * the current locale. This results in a consistent English-only - * interface instead of one having partial translations. For this - * feature to work, the call to textdomain() and setlocale() should - * precede any g_dgettext() invocations. For GTK+, it means calling - * textdomain() before gtk_init or its variants. - * - * This function disables translations if and only if upon its first - * call all the following conditions hold: - * - * - @domain is not %NULL - * - * - textdomain() has been called to set a default text domain - * - * - there is no translations available for the default text domain - * and the current locale - * - * - current locale is not "C" or any English locales (those - * starting with "en_") - * - * Note that this behavior may not be desired for example if an application - * has its untranslated messages in a language other than English. In those - * cases the application should call textdomain() after initializing GTK+. - * - * Applications should normally not use this function directly, - * but use the _() macro for translations. - * - * Returns: The translated string - * Since: 2.18 - */ - - -/** - * g_dir_close: - * @dir: a #GDir* created by g_dir_open() - * - * Closes the directory and deallocates all related resources. - */ - - -/** - * g_dir_make_tmp: - * @tmpl: (type filename) (nullable): Template for directory name, - * as in g_mkdtemp(), basename only, or %NULL for a default template - * @error: return location for a #GError - * - * Creates a subdirectory in the preferred directory for temporary - * files (as returned by g_get_tmp_dir()). - * - * @tmpl should be a string in the GLib file name encoding containing - * a sequence of six 'X' characters, as the parameter to g_mkstemp(). - * However, unlike these functions, the template should only be a - * basename, no directory components are allowed. If template is - * %NULL, a default template is used. - * - * Note that in contrast to g_mkdtemp() (and mkdtemp()) @tmpl is not - * modified, and might thus be a read-only literal string. - * - * Returns: (type filename): The actual name used. This string - * should be freed with g_free() when not needed any longer and is - * is in the GLib file name encoding. In case of errors, %NULL is - * returned and @error will be set. - * Since: 2.30 - */ - - -/** - * g_dir_open: - * @path: the path to the directory you are interested in. On Unix - * in the on-disk encoding. On Windows in UTF-8 - * @flags: Currently must be set to 0. Reserved for future use. - * @error: return location for a #GError, or %NULL. - * If non-%NULL, an error will be set if and only if - * g_dir_open() fails. - * - * Opens a directory for reading. The names of the files in the - * directory can then be retrieved using g_dir_read_name(). Note - * that the ordering is not defined. - * - * Returns: a newly allocated #GDir on success, %NULL on failure. - * If non-%NULL, you must free the result with g_dir_close() - * when you are finished with it. - */ - - -/** - * g_dir_read_name: - * @dir: a #GDir* created by g_dir_open() - * - * Retrieves the name of another entry in the directory, or %NULL. - * The order of entries returned from this function is not defined, - * and may vary by file system or other operating-system dependent - * factors. - * - * %NULL may also be returned in case of errors. On Unix, you can - * check `errno` to find out if %NULL was returned because of an error. - * - * On Unix, the '.' and '..' entries are omitted, and the returned - * name is in the on-disk encoding. - * - * On Windows, as is true of all GLib functions which operate on - * filenames, the returned name is in UTF-8. - * - * Returns: (type filename): The entry's name or %NULL if there are no - * more entries. The return value is owned by GLib and - * must not be modified or freed. - */ - - -/** - * g_dir_rewind: - * @dir: a #GDir* created by g_dir_open() - * - * Resets the given directory. The next call to g_dir_read_name() - * will return the first entry again. - */ - - -/** - * g_direct_equal: - * @v1: (nullable): a key - * @v2: (nullable): a key to compare with @v1 - * - * Compares two #gpointer arguments and returns %TRUE if they are equal. - * It can be passed to g_hash_table_new() as the @key_equal_func - * parameter, when using opaque pointers compared by pointer value as - * keys in a #GHashTable. - * - * This equality function is also appropriate for keys that are integers - * stored in pointers, such as `GINT_TO_POINTER (n)`. - * - * Returns: %TRUE if the two keys match. - */ - - -/** - * g_direct_hash: - * @v: (nullable): a #gpointer key - * - * Converts a gpointer to a hash value. - * It can be passed to g_hash_table_new() as the @hash_func parameter, - * when using opaque pointers compared by pointer value as keys in a - * #GHashTable. - * - * This hash function is also appropriate for keys that are integers - * stored in pointers, such as `GINT_TO_POINTER (n)`. - * - * Returns: a hash value corresponding to the key. - */ - - -/** - * g_dirname: - * @file_name: (type filename): the name of the file - * - * Gets the directory components of a file name. - * - * If the file name has no directory components "." is returned. - * The returned string should be freed when no longer needed. - * - * Returns: (type filename): the directory components of the file - * Deprecated: use g_path_get_dirname() instead - */ - - -/** - * g_dngettext: - * @domain: (nullable): the translation domain to use, or %NULL to use - * the domain set with textdomain() - * @msgid: message to translate - * @msgid_plural: plural form of the message - * @n: the quantity for which translation is needed - * - * This function is a wrapper of dngettext() which does not translate - * the message if the default domain as set with textdomain() has no - * translations for the current locale. - * - * See g_dgettext() for details of how this differs from dngettext() - * proper. - * - * Returns: The translated string - * Since: 2.18 - */ - - -/** - * g_double_equal: - * @v1: (not nullable): a pointer to a #gdouble key - * @v2: (not nullable): a pointer to a #gdouble key to compare with @v1 - * - * Compares the two #gdouble values being pointed to and returns - * %TRUE if they are equal. - * It can be passed to g_hash_table_new() as the @key_equal_func - * parameter, when using non-%NULL pointers to doubles as keys in a - * #GHashTable. - * - * Returns: %TRUE if the two keys match. - * Since: 2.22 - */ - - -/** - * g_double_hash: - * @v: (not nullable): a pointer to a #gdouble key - * - * Converts a pointer to a #gdouble to a hash value. - * It can be passed to g_hash_table_new() as the @hash_func parameter, - * It can be passed to g_hash_table_new() as the @hash_func parameter, - * when using non-%NULL pointers to doubles as keys in a #GHashTable. - * - * Returns: a hash value corresponding to the key. - * Since: 2.22 - */ - - -/** - * g_dpgettext: - * @domain: (nullable): the translation domain to use, or %NULL to use - * the domain set with textdomain() - * @msgctxtid: a combined message context and message id, separated - * by a \004 character - * @msgidoffset: the offset of the message id in @msgctxid - * - * This function is a variant of g_dgettext() which supports - * a disambiguating message context. GNU gettext uses the - * '\004' character to separate the message context and - * message id in @msgctxtid. - * If 0 is passed as @msgidoffset, this function will fall back to - * trying to use the deprecated convention of using "|" as a separation - * character. - * - * This uses g_dgettext() internally. See that functions for differences - * with dgettext() proper. - * - * Applications should normally not use this function directly, - * but use the C_() macro for translations with context. - * - * Returns: The translated string - * Since: 2.16 - */ - - -/** - * g_dpgettext2: - * @domain: (nullable): the translation domain to use, or %NULL to use - * the domain set with textdomain() - * @context: the message context - * @msgid: the message - * - * This function is a variant of g_dgettext() which supports - * a disambiguating message context. GNU gettext uses the - * '\004' character to separate the message context and - * message id in @msgctxtid. - * - * This uses g_dgettext() internally. See that functions for differences - * with dgettext() proper. - * - * This function differs from C_() in that it is not a macro and - * thus you may use non-string-literals as context and msgid arguments. - * - * Returns: The translated string - * Since: 2.18 - */ - - -/** - * g_environ_getenv: - * @envp: (nullable) (array zero-terminated=1) (transfer none) (element-type filename): - * an environment list (eg, as returned from g_get_environ()), or %NULL - * for an empty environment list - * @variable: (type filename): the environment variable to get - * - * Returns the value of the environment variable @variable in the - * provided list @envp. - * - * Returns: (type filename): the value of the environment variable, or %NULL if - * the environment variable is not set in @envp. The returned - * string is owned by @envp, and will be freed if @variable is - * set or unset again. - * Since: 2.32 - */ - - -/** - * g_environ_setenv: - * @envp: (nullable) (array zero-terminated=1) (element-type filename) (transfer full): - * an environment list that can be freed using g_strfreev() (e.g., as - * returned from g_get_environ()), or %NULL for an empty - * environment list - * @variable: (type filename): the environment variable to set, must not - * contain '=' - * @value: (type filename): the value for to set the variable to - * @overwrite: whether to change the variable if it already exists - * - * Sets the environment variable @variable in the provided list - * @envp to @value. - * - * Returns: (array zero-terminated=1) (element-type filename) (transfer full): - * the updated environment list. Free it using g_strfreev(). - * Since: 2.32 - */ - - -/** - * g_environ_unsetenv: - * @envp: (nullable) (array zero-terminated=1) (element-type filename) (transfer full): - * an environment list that can be freed using g_strfreev() (e.g., as - * returned from g_get_environ()), or %NULL for an empty environment list - * @variable: (type filename): the environment variable to remove, must not - * contain '=' - * - * Removes the environment variable @variable from the provided - * environment @envp. - * - * Returns: (array zero-terminated=1) (element-type filename) (transfer full): - * the updated environment list. Free it using g_strfreev(). - * Since: 2.32 - */ - - -/** - * g_error: - * @...: format string, followed by parameters to insert - * into the format string (as with printf()) - * - * A convenience function/macro to log an error message. The message should - * typically *not* be translated to the user's language. - * - * This is not intended for end user error reporting. Use of #GError is - * preferred for that instead, as it allows calling functions to perform actions - * conditional on the type of error. - * - * Error messages are always fatal, resulting in a call to G_BREAKPOINT() - * to terminate the application. This function will - * result in a core dump; don't use it for errors you expect. - * Using this function indicates a bug in your program, i.e. - * an assertion failure. - * - * If g_log_default_handler() is used as the log handler function, a new-line - * character will automatically be appended to @..., and need not be entered - * manually. - * - * If structured logging is enabled, this will use g_log_structured(); - * otherwise it will use g_log(). See - * [Using Structured Logging][using-structured-logging]. - */ - - -/** - * g_error_copy: - * @error: a #GError - * - * Makes a copy of @error. - * - * Returns: a new #GError - */ - - -/** - * g_error_domain_register: - * @error_type_name: string to create a #GQuark from - * @error_type_private_size: size of the private error data in bytes - * @error_type_init: function initializing fields of the private error data - * @error_type_copy: function copying fields of the private error data - * @error_type_clear: function freeing fields of the private error data - * - * This function registers an extended #GError domain. - * @error_type_name will be duplicated. Otherwise does the same as - * g_error_domain_register_static(). - * - * Returns: #GQuark representing the error domain - * Since: 2.68 - */ - - -/** - * g_error_domain_register_static: - * @error_type_name: static string to create a #GQuark from - * @error_type_private_size: size of the private error data in bytes - * @error_type_init: function initializing fields of the private error data - * @error_type_copy: function copying fields of the private error data - * @error_type_clear: function freeing fields of the private error data - * - * This function registers an extended #GError domain. - * - * @error_type_name should not be freed. @error_type_private_size must - * be greater than 0. - * - * @error_type_init receives an initialized #GError and should then initialize - * the private data. - * - * @error_type_copy is a function that receives both original and a copy - * #GError and should copy the fields of the private error data. The standard - * #GError fields are already handled. - * - * @error_type_clear receives the pointer to the error, and it should free the - * fields of the private error data. It should not free the struct itself though. - * - * Normally, it is better to use G_DEFINE_EXTENDED_ERROR(), as it - * already takes care of passing valid information to this function. - * - * Returns: #GQuark representing the error domain - * Since: 2.68 - */ - - -/** - * g_error_free: - * @error: a #GError - * - * Frees a #GError and associated resources. - */ - - -/** - * g_error_matches: - * @error: (nullable): a #GError - * @domain: an error domain - * @code: an error code - * - * Returns %TRUE if @error matches @domain and @code, %FALSE - * otherwise. In particular, when @error is %NULL, %FALSE will - * be returned. - * - * If @domain contains a `FAILED` (or otherwise generic) error code, - * you should generally not check for it explicitly, but should - * instead treat any not-explicitly-recognized error code as being - * equivalent to the `FAILED` code. This way, if the domain is - * extended in the future to provide a more specific error code for - * a certain case, your code will still work. - * - * Returns: whether @error has @domain and @code - */ - - -/** - * g_error_new: - * @domain: error domain - * @code: error code - * @format: printf()-style format for error message - * @...: parameters for message format - * - * Creates a new #GError with the given @domain and @code, - * and a message formatted with @format. - * - * Returns: a new #GError - */ - - -/** - * g_error_new_literal: - * @domain: error domain - * @code: error code - * @message: error message - * - * Creates a new #GError; unlike g_error_new(), @message is - * not a printf()-style format string. Use this function if - * @message contains text you don't have control over, - * that could include printf() escape sequences. - * - * Returns: a new #GError - */ - - -/** - * g_error_new_valist: - * @domain: error domain - * @code: error code - * @format: printf()-style format for error message - * @args: #va_list of parameters for the message format - * - * Creates a new #GError with the given @domain and @code, - * and a message formatted with @format. - * - * Returns: a new #GError - * Since: 2.22 - */ - - -/** - * g_file_error_from_errno: - * @err_no: an "errno" value - * - * Gets a #GFileError constant based on the passed-in @err_no. - * - * For example, if you pass in `EEXIST` this function returns - * %G_FILE_ERROR_EXIST. Unlike `errno` values, you can portably - * assume that all #GFileError values will exist. - * - * Normally a #GFileError value goes into a #GError returned - * from a function that manipulates files. So you would use - * g_file_error_from_errno() when constructing a #GError. - * - * Returns: #GFileError corresponding to the given @err_no - */ - - -/** - * g_file_get_contents: - * @filename: (type filename): name of a file to read contents from, in the GLib file name encoding - * @contents: (out) (array length=length) (element-type guint8): location to store an allocated string, use g_free() to free - * the returned string - * @length: (nullable): location to store length in bytes of the contents, or %NULL - * @error: return location for a #GError, or %NULL - * - * Reads an entire file into allocated memory, with good error - * checking. - * - * If the call was successful, it returns %TRUE and sets @contents to the file - * contents and @length to the length of the file contents in bytes. The string - * stored in @contents will be nul-terminated, so for text files you can pass - * %NULL for the @length argument. If the call was not successful, it returns - * %FALSE and sets @error. The error domain is #G_FILE_ERROR. Possible error - * codes are those in the #GFileError enumeration. In the error case, - * @contents is set to %NULL and @length is set to zero. - * - * Returns: %TRUE on success, %FALSE if an error occurred - */ - - -/** - * g_file_open_tmp: - * @tmpl: (type filename) (nullable): Template for file name, as in - * g_mkstemp(), basename only, or %NULL for a default template - * @name_used: (out) (type filename): location to store actual name used, - * or %NULL - * @error: return location for a #GError - * - * Opens a file for writing in the preferred directory for temporary - * files (as returned by g_get_tmp_dir()). - * - * @tmpl should be a string in the GLib file name encoding containing - * a sequence of six 'X' characters, as the parameter to g_mkstemp(). - * However, unlike these functions, the template should only be a - * basename, no directory components are allowed. If template is - * %NULL, a default template is used. - * - * Note that in contrast to g_mkstemp() (and mkstemp()) @tmpl is not - * modified, and might thus be a read-only literal string. - * - * Upon success, and if @name_used is non-%NULL, the actual name used - * is returned in @name_used. This string should be freed with g_free() - * when not needed any longer. The returned name is in the GLib file - * name encoding. - * - * Returns: A file handle (as from open()) to the file opened for - * reading and writing. The file is opened in binary mode on platforms - * where there is a difference. The file handle should be closed with - * close(). In case of errors, -1 is returned and @error will be set. - */ - - -/** - * g_file_read_link: - * @filename: (type filename): the symbolic link - * @error: return location for a #GError - * - * Reads the contents of the symbolic link @filename like the POSIX - * readlink() function. The returned string is in the encoding used - * for filenames. Use g_filename_to_utf8() to convert it to UTF-8. - * - * Returns: (type filename): A newly-allocated string with the contents of - * the symbolic link, or %NULL if an error occurred. - * Since: 2.4 - */ - - -/** - * g_file_set_contents: - * @filename: (type filename): name of a file to write @contents to, in the GLib file name - * encoding - * @contents: (array length=length) (element-type guint8): string to write to the file - * @length: length of @contents, or -1 if @contents is a nul-terminated string - * @error: return location for a #GError, or %NULL - * - * Writes all of @contents to a file named @filename. This is a convenience - * wrapper around calling g_file_set_contents_full() with `flags` set to - * `G_FILE_SET_CONTENTS_CONSISTENT | G_FILE_SET_CONTENTS_ONLY_EXISTING` and - * `mode` set to `0666`. - * - * Returns: %TRUE on success, %FALSE if an error occurred - * Since: 2.8 - */ - - -/** - * g_file_set_contents_full: - * @filename: (type filename): name of a file to write @contents to, in the GLib file name - * encoding - * @contents: (array length=length) (element-type guint8): string to write to the file - * @length: length of @contents, or -1 if @contents is a nul-terminated string - * @flags: flags controlling the safety vs speed of the operation - * @mode: file mode, as passed to `open()`; typically this will be `0666` - * @error: return location for a #GError, or %NULL - * - * Writes all of @contents to a file named @filename, with good error checking. - * If a file called @filename already exists it will be overwritten. - * - * @flags control the properties of the write operation: whether it’s atomic, - * and what the tradeoff is between returning quickly or being resilient to - * system crashes. - * - * As this function performs file I/O, it is recommended to not call it anywhere - * where blocking would cause problems, such as in the main loop of a graphical - * application. In particular, if @flags has any value other than - * %G_FILE_SET_CONTENTS_NONE then this function may call `fsync()`. - * - * If %G_FILE_SET_CONTENTS_CONSISTENT is set in @flags, the operation is atomic - * in the sense that it is first written to a temporary file which is then - * renamed to the final name. - * - * Notes: - * - * - On UNIX, if @filename already exists hard links to @filename will break. - * Also since the file is recreated, existing permissions, access control - * lists, metadata etc. may be lost. If @filename is a symbolic link, - * the link itself will be replaced, not the linked file. - * - * - On UNIX, if @filename already exists and is non-empty, and if the system - * supports it (via a journalling filesystem or equivalent), and if - * %G_FILE_SET_CONTENTS_CONSISTENT is set in @flags, the `fsync()` call (or - * equivalent) will be used to ensure atomic replacement: @filename - * will contain either its old contents or @contents, even in the face of - * system power loss, the disk being unsafely removed, etc. - * - * - On UNIX, if @filename does not already exist or is empty, there is a - * possibility that system power loss etc. after calling this function will - * leave @filename empty or full of NUL bytes, depending on the underlying - * filesystem, unless %G_FILE_SET_CONTENTS_DURABLE and - * %G_FILE_SET_CONTENTS_CONSISTENT are set in @flags. - * - * - On Windows renaming a file will not remove an existing file with the - * new name, so on Windows there is a race condition between the existing - * file being removed and the temporary file being renamed. - * - * - On Windows there is no way to remove a file that is open to some - * process, or mapped into memory. Thus, this function will fail if - * @filename already exists and is open. - * - * If the call was successful, it returns %TRUE. If the call was not successful, - * it returns %FALSE and sets @error. The error domain is #G_FILE_ERROR. - * Possible error codes are those in the #GFileError enumeration. - * - * Note that the name for the temporary file is constructed by appending up - * to 7 characters to @filename. - * - * If the file didn’t exist before and is created, it will be given the - * permissions from @mode. Otherwise, the permissions of the existing file may - * be changed to @mode depending on @flags, or they may remain unchanged. - * - * Returns: %TRUE on success, %FALSE if an error occurred - * Since: 2.66 - */ - - -/** - * g_file_test: - * @filename: (type filename): a filename to test in the - * GLib file name encoding - * @test: bitfield of #GFileTest flags - * - * Returns %TRUE if any of the tests in the bitfield @test are - * %TRUE. For example, `(G_FILE_TEST_EXISTS | G_FILE_TEST_IS_DIR)` - * will return %TRUE if the file exists; the check whether it's a - * directory doesn't matter since the existence test is %TRUE. With - * the current set of available tests, there's no point passing in - * more than one test at a time. - * - * Apart from %G_FILE_TEST_IS_SYMLINK all tests follow symbolic links, - * so for a symbolic link to a regular file g_file_test() will return - * %TRUE for both %G_FILE_TEST_IS_SYMLINK and %G_FILE_TEST_IS_REGULAR. - * - * Note, that for a dangling symbolic link g_file_test() will return - * %TRUE for %G_FILE_TEST_IS_SYMLINK and %FALSE for all other flags. - * - * You should never use g_file_test() to test whether it is safe - * to perform an operation, because there is always the possibility - * of the condition changing before you actually perform the operation. - * For example, you might think you could use %G_FILE_TEST_IS_SYMLINK - * to know whether it is safe to write to a file without being - * tricked into writing into a different location. It doesn't work! - * |[<!-- language="C" --> - * // DON'T DO THIS - * if (!g_file_test (filename, G_FILE_TEST_IS_SYMLINK)) - * { - * fd = g_open (filename, O_WRONLY); - * // write to fd - * } - * ]| - * - * Another thing to note is that %G_FILE_TEST_EXISTS and - * %G_FILE_TEST_IS_EXECUTABLE are implemented using the access() - * system call. This usually doesn't matter, but if your program - * is setuid or setgid it means that these tests will give you - * the answer for the real user ID and group ID, rather than the - * effective user ID and group ID. - * - * On Windows, there are no symlinks, so testing for - * %G_FILE_TEST_IS_SYMLINK will always return %FALSE. Testing for - * %G_FILE_TEST_IS_EXECUTABLE will just check that the file exists and - * its name indicates that it is executable, checking for well-known - * extensions and those listed in the `PATHEXT` environment variable. - * - * Returns: whether a test was %TRUE - */ - - -/** - * g_filename_display_basename: - * @filename: (type filename): an absolute pathname in the - * GLib file name encoding - * - * Returns the display basename for the particular filename, guaranteed - * to be valid UTF-8. The display name might not be identical to the filename, - * for instance there might be problems converting it to UTF-8, and some files - * can be translated in the display. - * - * If GLib cannot make sense of the encoding of @filename, as a last resort it - * replaces unknown characters with U+FFFD, the Unicode replacement character. - * You can search the result for the UTF-8 encoding of this character (which is - * "\357\277\275" in octal notation) to find out if @filename was in an invalid - * encoding. - * - * You must pass the whole absolute pathname to this functions so that - * translation of well known locations can be done. - * - * This function is preferred over g_filename_display_name() if you know the - * whole path, as it allows translation. - * - * Returns: a newly allocated string containing - * a rendition of the basename of the filename in valid UTF-8 - * Since: 2.6 - */ - - -/** - * g_filename_display_name: - * @filename: (type filename): a pathname hopefully in the - * GLib file name encoding - * - * Converts a filename into a valid UTF-8 string. The conversion is - * not necessarily reversible, so you should keep the original around - * and use the return value of this function only for display purposes. - * Unlike g_filename_to_utf8(), the result is guaranteed to be non-%NULL - * even if the filename actually isn't in the GLib file name encoding. - * - * If GLib cannot make sense of the encoding of @filename, as a last resort it - * replaces unknown characters with U+FFFD, the Unicode replacement character. - * You can search the result for the UTF-8 encoding of this character (which is - * "\357\277\275" in octal notation) to find out if @filename was in an invalid - * encoding. - * - * If you know the whole pathname of the file you should use - * g_filename_display_basename(), since that allows location-based - * translation of filenames. - * - * Returns: a newly allocated string containing - * a rendition of the filename in valid UTF-8 - * Since: 2.6 - */ - - -/** - * g_filename_from_uri: - * @uri: a uri describing a filename (escaped, encoded in ASCII). - * @hostname: (out) (optional) (nullable): Location to store hostname for the URI. - * If there is no hostname in the URI, %NULL will be - * stored in this location. - * @error: location to store the error occurring, or %NULL to ignore - * errors. Any of the errors in #GConvertError may occur. - * - * Converts an escaped ASCII-encoded URI to a local filename in the - * encoding used for filenames. - * - * Returns: (type filename): a newly-allocated string holding - * the resulting filename, or %NULL on an error. - */ - - -/** - * g_filename_from_utf8: - * @utf8string: (type utf8): a UTF-8 encoded string. - * @len: the length of the string, or -1 if the string is - * nul-terminated. - * @bytes_read: (out) (optional): location to store the number of bytes in - * the input string that were successfully converted, or %NULL. - * Even if the conversion was successful, this may be - * less than @len if there were partial characters - * at the end of the input. If the error - * %G_CONVERT_ERROR_ILLEGAL_SEQUENCE occurs, the value - * stored will be the byte offset after the last valid - * input sequence. - * @bytes_written: (out) (optional): the number of bytes stored in - * the output buffer (not including the terminating nul). - * @error: location to store the error occurring, or %NULL to ignore - * errors. Any of the errors in #GConvertError may occur. - * - * Converts a string from UTF-8 to the encoding GLib uses for - * filenames. Note that on Windows GLib uses UTF-8 for filenames; - * on other platforms, this function indirectly depends on the - * [current locale][setlocale]. - * - * The input string shall not contain nul characters even if the @len - * argument is positive. A nul character found inside the string will result - * in error %G_CONVERT_ERROR_ILLEGAL_SEQUENCE. If the filename encoding is - * not UTF-8 and the conversion output contains a nul character, the error - * %G_CONVERT_ERROR_EMBEDDED_NUL is set and the function returns %NULL. - * - * Returns: (type filename): - * The converted string, or %NULL on an error. - */ - - -/** - * g_filename_to_uri: - * @filename: (type filename): an absolute filename specified in the GLib file - * name encoding, which is the on-disk file name bytes on Unix, and UTF-8 - * on Windows - * @hostname: (nullable): A UTF-8 encoded hostname, or %NULL for none. - * @error: location to store the error occurring, or %NULL to ignore - * errors. Any of the errors in #GConvertError may occur. - * - * Converts an absolute filename to an escaped ASCII-encoded URI, with the path - * component following Section 3.3. of RFC 2396. - * - * Returns: a newly-allocated string holding the resulting - * URI, or %NULL on an error. - */ - - -/** - * g_filename_to_utf8: - * @opsysstring: (type filename): a string in the encoding for filenames - * @len: the length of the string, or -1 if the string is - * nul-terminated (Note that some encodings may allow nul - * bytes to occur inside strings. In that case, using -1 - * for the @len parameter is unsafe) - * @bytes_read: (out) (optional): location to store the number of bytes in the - * input string that were successfully converted, or %NULL. - * Even if the conversion was successful, this may be - * less than @len if there were partial characters - * at the end of the input. If the error - * %G_CONVERT_ERROR_ILLEGAL_SEQUENCE occurs, the value - * stored will be the byte offset after the last valid - * input sequence. - * @bytes_written: (out) (optional): the number of bytes stored in the output - * buffer (not including the terminating nul). - * @error: location to store the error occurring, or %NULL to ignore - * errors. Any of the errors in #GConvertError may occur. - * - * Converts a string which is in the encoding used by GLib for - * filenames into a UTF-8 string. Note that on Windows GLib uses UTF-8 - * for filenames; on other platforms, this function indirectly depends on - * the [current locale][setlocale]. - * - * The input string shall not contain nul characters even if the @len - * argument is positive. A nul character found inside the string will result - * in error %G_CONVERT_ERROR_ILLEGAL_SEQUENCE. - * If the source encoding is not UTF-8 and the conversion output contains a - * nul character, the error %G_CONVERT_ERROR_EMBEDDED_NUL is set and the - * function returns %NULL. Use g_convert() to produce output that - * may contain embedded nul characters. - * - * Returns: (type utf8): The converted string, or %NULL on an error. - */ - - -/** - * g_find_program_in_path: - * @program: (type filename): a program name in the GLib file name encoding - * - * Locates the first executable named @program in the user's path, in the - * same way that execvp() would locate it. Returns an allocated string - * with the absolute path name, or %NULL if the program is not found in - * the path. If @program is already an absolute path, returns a copy of - * @program if @program exists and is executable, and %NULL otherwise. - * - * On Windows, if @program does not have a file type suffix, tries - * with the suffixes .exe, .cmd, .bat and .com, and the suffixes in - * the `PATHEXT` environment variable. - * - * On Windows, it looks for the file in the same way as CreateProcess() - * would. This means first in the directory where the executing - * program was loaded from, then in the current directory, then in the - * Windows 32-bit system directory, then in the Windows directory, and - * finally in the directories in the `PATH` environment variable. If - * the program is found, the return value contains the full name - * including the type suffix. - * - * Returns: (type filename) (transfer full) (nullable): a newly-allocated - * string with the absolute path, or %NULL - */ - - -/** - * g_fopen: - * @filename: (type filename): a pathname in the GLib file name encoding - * (UTF-8 on Windows) - * @mode: a string describing the mode in which the file should be opened - * - * A wrapper for the stdio `fopen()` function. The `fopen()` function - * opens a file and associates a new stream with it. - * - * Because file descriptors are specific to the C library on Windows, - * and a file descriptor is part of the `FILE` struct, the `FILE*` returned - * by this function makes sense only to functions in the same C library. - * Thus if the GLib-using code uses a different C library than GLib does, - * the FILE* returned by this function cannot be passed to C library - * functions like `fprintf()` or `fread()`. - * - * See your C library manual for more details about `fopen()`. - * - * As `close()` and `fclose()` are part of the C library, this implies that it is - * currently impossible to close a file if the application C library and the C library - * used by GLib are different. Convenience functions like g_file_set_contents_full() - * avoid this problem. - * - * Returns: A `FILE*` if the file was successfully opened, or %NULL if - * an error occurred - * Since: 2.6 - */ - - -/** - * g_format_size: - * @size: a size in bytes - * - * Formats a size (for example the size of a file) into a human readable - * string. Sizes are rounded to the nearest size prefix (kB, MB, GB) - * and are displayed rounded to the nearest tenth. E.g. the file size - * 3292528 bytes will be converted into the string "3.2 MB". The returned string - * is UTF-8, and may use a non-breaking space to separate the number and units, - * to ensure they aren’t separated when line wrapped. - * - * The prefix units base is 1000 (i.e. 1 kB is 1000 bytes). - * - * This string should be freed with g_free() when not needed any longer. - * - * See g_format_size_full() for more options about how the size might be - * formatted. - * - * Returns: (transfer full): a newly-allocated formatted string containing - * a human readable file size - * Since: 2.30 - */ - - -/** - * g_format_size_for_display: - * @size: a size in bytes - * - * Formats a size (for example the size of a file) into a human - * readable string. Sizes are rounded to the nearest size prefix - * (KB, MB, GB) and are displayed rounded to the nearest tenth. - * E.g. the file size 3292528 bytes will be converted into the - * string "3.1 MB". - * - * The prefix units base is 1024 (i.e. 1 KB is 1024 bytes). - * - * This string should be freed with g_free() when not needed any longer. - * - * Returns: (transfer full): a newly-allocated formatted string - * containing a human readable file size - * Since: 2.16 - * Deprecated: 2.30: This function is broken due to its use of SI - * suffixes to denote IEC units. Use g_format_size() instead. - */ - - -/** - * g_format_size_full: - * @size: a size in bytes - * @flags: #GFormatSizeFlags to modify the output - * - * Formats a size. - * - * This function is similar to g_format_size() but allows for flags - * that modify the output. See #GFormatSizeFlags. - * - * Returns: (transfer full): a newly-allocated formatted string - * containing a human readable file size - * Since: 2.30 - */ - - -/** - * g_fprintf: - * @file: (not nullable): the stream to write to. - * @format: a standard printf() format string, but notice - * [string precision pitfalls][string-precision] - * @...: the arguments to insert in the output. - * - * An implementation of the standard fprintf() function which supports - * positional parameters, as specified in the Single Unix Specification. - * - * `glib/gprintf.h` must be explicitly included in order to use this function. - * - * Returns: the number of bytes printed. - * Since: 2.2 - */ - - -/** - * g_free: - * @mem: (nullable): the memory to free - * - * Frees the memory pointed to by @mem. - * - * If @mem is %NULL it simply returns, so there is no need to check @mem - * against %NULL before calling this function. - */ - - -/** - * g_freopen: - * @filename: (type filename): a pathname in the GLib file name encoding - * (UTF-8 on Windows) - * @mode: a string describing the mode in which the file should be opened - * @stream: (nullable): an existing stream which will be reused, or %NULL - * - * A wrapper for the POSIX freopen() function. The freopen() function - * opens a file and associates it with an existing stream. - * - * See your C library manual for more details about freopen(). - * - * Returns: A FILE* if the file was successfully opened, or %NULL if - * an error occurred. - * Since: 2.6 - */ - - -/** - * g_fsync: - * @fd: a file descriptor - * - * A wrapper for the POSIX `fsync()` function. On Windows, `_commit()` will be - * used. On macOS, `fcntl(F_FULLFSYNC)` will be used. - * The `fsync()` function is used to synchronize a file's in-core - * state with that of the disk. - * - * This wrapper will handle retrying on `EINTR`. - * - * See the C library manual for more details about fsync(). - * - * Returns: 0 on success, or -1 if an error occurred. - * The return value can be used exactly like the return value from fsync(). - * Since: 2.64 - */ - - -/** - * g_get_application_name: - * - * Gets a human-readable name for the application, as set by - * g_set_application_name(). This name should be localized if - * possible, and is intended for display to the user. Contrast with - * g_get_prgname(), which gets a non-localized name. If - * g_set_application_name() has not been called, returns the result of - * g_get_prgname() (which may be %NULL if g_set_prgname() has also not - * been called). - * - * Returns: (transfer none) (nullable): human-readable application - * name. May return %NULL - * Since: 2.2 - */ - - -/** - * g_get_charset: - * @charset: (out) (optional) (transfer none): return location for character set - * name, or %NULL. - * - * Obtains the character set for the [current locale][setlocale]; you - * might use this character set as an argument to g_convert(), to convert - * from the current locale's encoding to some other encoding. (Frequently - * g_locale_to_utf8() and g_locale_from_utf8() are nice shortcuts, though.) - * - * On Windows the character set returned by this function is the - * so-called system default ANSI code-page. That is the character set - * used by the "narrow" versions of C library and Win32 functions that - * handle file names. It might be different from the character set - * used by the C library's current locale. - * - * On Linux, the character set is found by consulting nl_langinfo() if - * available. If not, the environment variables `LC_ALL`, `LC_CTYPE`, `LANG` - * and `CHARSET` are queried in order. - * - * The return value is %TRUE if the locale's encoding is UTF-8, in that - * case you can perhaps avoid calling g_convert(). - * - * The string returned in @charset is not allocated, and should not be - * freed. - * - * Returns: %TRUE if the returned charset is UTF-8 - */ - - -/** - * g_get_codeset: - * - * Gets the character set for the current locale. - * - * Returns: a newly allocated string containing the name - * of the character set. This string must be freed with g_free(). - */ - - -/** - * g_get_console_charset: - * @charset: (out) (optional) (transfer none): return location for character set - * name, or %NULL. - * - * Obtains the character set used by the console attached to the process, - * which is suitable for printing output to the terminal. - * - * Usually this matches the result returned by g_get_charset(), but in - * environments where the locale's character set does not match the encoding - * of the console this function tries to guess a more suitable value instead. - * - * On Windows the character set returned by this function is the - * output code page used by the console associated with the calling process. - * If the codepage can't be determined (for example because there is no - * console attached) UTF-8 is assumed. - * - * The return value is %TRUE if the locale's encoding is UTF-8, in that - * case you can perhaps avoid calling g_convert(). - * - * The string returned in @charset is not allocated, and should not be - * freed. - * - * Returns: %TRUE if the returned charset is UTF-8 - * Since: 2.62 - */ - - -/** - * g_get_current_dir: - * - * Gets the current directory. - * - * The returned string should be freed when no longer needed. - * The encoding of the returned string is system defined. - * On Windows, it is always UTF-8. - * - * Since GLib 2.40, this function will return the value of the "PWD" - * environment variable if it is set and it happens to be the same as - * the current directory. This can make a difference in the case that - * the current directory is the target of a symbolic link. - * - * Returns: (type filename): the current directory - */ - - -/** - * g_get_current_time: - * @result: #GTimeVal structure in which to store current time. - * - * Equivalent to the UNIX gettimeofday() function, but portable. - * - * You may find g_get_real_time() to be more convenient. - * - * Deprecated: 2.62: #GTimeVal is not year-2038-safe. Use g_get_real_time() - * instead. - */ - - -/** - * g_get_environ: - * - * Gets the list of environment variables for the current process. - * - * The list is %NULL terminated and each item in the list is of the - * form 'NAME=VALUE'. - * - * This is equivalent to direct access to the 'environ' global variable, - * except portable. - * - * The return value is freshly allocated and it should be freed with - * g_strfreev() when it is no longer needed. - * - * Returns: (array zero-terminated=1) (element-type filename) (transfer full): - * the list of environment variables - * Since: 2.28 - */ - - -/** - * g_get_filename_charsets: - * @filename_charsets: (out) (transfer none) (array zero-terminated=1): - * return location for the %NULL-terminated list of encoding names - * - * Determines the preferred character sets used for filenames. - * The first character set from the @charsets is the filename encoding, the - * subsequent character sets are used when trying to generate a displayable - * representation of a filename, see g_filename_display_name(). - * - * On Unix, the character sets are determined by consulting the - * environment variables `G_FILENAME_ENCODING` and `G_BROKEN_FILENAMES`. - * On Windows, the character set used in the GLib API is always UTF-8 - * and said environment variables have no effect. - * - * `G_FILENAME_ENCODING` may be set to a comma-separated list of - * character set names. The special token "\@locale" is taken - * to mean the character set for the [current locale][setlocale]. - * If `G_FILENAME_ENCODING` is not set, but `G_BROKEN_FILENAMES` is, - * the character set of the current locale is taken as the filename - * encoding. If neither environment variable is set, UTF-8 is taken - * as the filename encoding, but the character set of the current locale - * is also put in the list of encodings. - * - * The returned @charsets belong to GLib and must not be freed. - * - * Note that on Unix, regardless of the locale character set or - * `G_FILENAME_ENCODING` value, the actual file names present - * on a system might be in any random encoding or just gibberish. - * - * Returns: %TRUE if the filename encoding is UTF-8. - * Since: 2.6 - */ - - -/** - * g_get_home_dir: - * - * Gets the current user's home directory. - * - * As with most UNIX tools, this function will return the value of the - * `HOME` environment variable if it is set to an existing absolute path - * name, falling back to the `passwd` file in the case that it is unset. - * - * If the path given in `HOME` is non-absolute, does not exist, or is - * not a directory, the result is undefined. - * - * Before version 2.36 this function would ignore the `HOME` environment - * variable, taking the value from the `passwd` database instead. This was - * changed to increase the compatibility of GLib with other programs (and - * the XDG basedir specification) and to increase testability of programs - * based on GLib (by making it easier to run them from test frameworks). - * - * If your program has a strong requirement for either the new or the - * old behaviour (and if you don't wish to increase your GLib - * dependency to ensure that the new behaviour is in effect) then you - * should either directly check the `HOME` environment variable yourself - * or unset it before calling any functions in GLib. - * - * Returns: (type filename) (transfer none): the current user's home directory - */ - - -/** - * g_get_host_name: - * - * Return a name for the machine. - * - * The returned name is not necessarily a fully-qualified domain name, - * or even present in DNS or some other name service at all. It need - * not even be unique on your local network or site, but usually it - * is. Callers should not rely on the return value having any specific - * properties like uniqueness for security purposes. Even if the name - * of the machine is changed while an application is running, the - * return value from this function does not change. The returned - * string is owned by GLib and should not be modified or freed. If no - * name can be determined, a default fixed string "localhost" is - * returned. - * - * The encoding of the returned string is UTF-8. - * - * Returns: (transfer none): the host name of the machine. - * Since: 2.8 - */ - - -/** - * g_get_language_names: - * - * Computes a list of applicable locale names, which can be used to - * e.g. construct locale-dependent filenames or search paths. The returned - * list is sorted from most desirable to least desirable and always contains - * the default locale "C". - * - * For example, if LANGUAGE=de:en_US, then the returned list is - * "de", "en_US", "en", "C". - * - * This function consults the environment variables `LANGUAGE`, `LC_ALL`, - * `LC_MESSAGES` and `LANG` to find the list of locales specified by the - * user. - * - * Returns: (array zero-terminated=1) (transfer none): a %NULL-terminated array of strings owned by GLib - * that must not be modified or freed. - * Since: 2.6 - */ - - -/** - * g_get_language_names_with_category: - * @category_name: a locale category name - * - * Computes a list of applicable locale names with a locale category name, - * which can be used to construct the fallback locale-dependent filenames - * or search paths. The returned list is sorted from most desirable to - * least desirable and always contains the default locale "C". - * - * This function consults the environment variables `LANGUAGE`, `LC_ALL`, - * @category_name, and `LANG` to find the list of locales specified by the - * user. - * - * g_get_language_names() returns g_get_language_names_with_category("LC_MESSAGES"). - * - * Returns: (array zero-terminated=1) (transfer none): a %NULL-terminated array of strings owned by - * the thread g_get_language_names_with_category was called from. - * It must not be modified or freed. It must be copied if planned to be used in another thread. - * Since: 2.58 - */ - - -/** - * g_get_locale_variants: - * @locale: a locale identifier - * - * Returns a list of derived variants of @locale, which can be used to - * e.g. construct locale-dependent filenames or search paths. The returned - * list is sorted from most desirable to least desirable. - * This function handles territory, charset and extra locale modifiers. See - * [`setlocale(3)`](man:setlocale) for information about locales and their format. - * - * @locale itself is guaranteed to be returned in the output. - * - * For example, if @locale is `fr_BE`, then the returned list - * is `fr_BE`, `fr`. If @locale is `en_GB.UTF-8@euro`, then the returned list - * is `en_GB.UTF-8@euro`, `en_GB.UTF-8`, `en_GB@euro`, `en_GB`, `en.UTF-8@euro`, - * `en.UTF-8`, `en@euro`, `en`. - * - * If you need the list of variants for the current locale, - * use g_get_language_names(). - * - * Returns: (transfer full) (array zero-terminated=1) (element-type utf8): a newly - * allocated array of newly allocated strings with the locale variants. Free with - * g_strfreev(). - * Since: 2.28 - */ - - -/** - * g_get_monotonic_time: - * - * Queries the system monotonic time. - * - * The monotonic clock will always increase and doesn't suffer - * discontinuities when the user (or NTP) changes the system time. It - * may or may not continue to tick during times where the machine is - * suspended. - * - * We try to use the clock that corresponds as closely as possible to - * the passage of time as measured by system calls such as poll() but it - * may not always be possible to do this. - * - * Returns: the monotonic time, in microseconds - * Since: 2.28 - */ - - -/** - * g_get_num_processors: - * - * Determine the approximate number of threads that the system will - * schedule simultaneously for this process. This is intended to be - * used as a parameter to g_thread_pool_new() for CPU bound tasks and - * similar cases. - * - * Returns: Number of schedulable threads, always greater than 0 - * Since: 2.36 - */ - - -/** - * g_get_os_info: - * @key_name: a key for the OS info being requested, for example %G_OS_INFO_KEY_NAME. - * - * Get information about the operating system. - * - * On Linux this comes from the `/etc/os-release` file. On other systems, it may - * come from a variety of sources. You can either use the standard key names - * like %G_OS_INFO_KEY_NAME or pass any UTF-8 string key name. For example, - * `/etc/os-release` provides a number of other less commonly used values that may - * be useful. No key is guaranteed to be provided, so the caller should always - * check if the result is %NULL. - * - * Returns: (nullable): The associated value for the requested key or %NULL if - * this information is not provided. - * Since: 2.64 - */ - - -/** - * g_get_prgname: - * - * Gets the name of the program. This name should not be localized, - * in contrast to g_get_application_name(). - * - * If you are using #GApplication the program name is set in - * g_application_run(). In case of GDK or GTK+ it is set in - * gdk_init(), which is called by gtk_init() and the - * #GtkApplication::startup handler. The program name is found by - * taking the last component of @argv[0]. - * - * Returns: (nullable) (transfer none): the name of the program, - * or %NULL if it has not been set yet. The returned string belongs - * to GLib and must not be modified or freed. - */ - - -/** - * g_get_real_name: - * - * Gets the real name of the user. This usually comes from the user's - * entry in the `passwd` file. The encoding of the returned string is - * system-defined. (On Windows, it is, however, always UTF-8.) If the - * real user name cannot be determined, the string "Unknown" is - * returned. - * - * Returns: (type filename) (transfer none): the user's real name. - */ - - -/** - * g_get_real_time: - * - * Queries the system wall-clock time. - * - * This call is functionally equivalent to g_get_current_time() except - * that the return value is often more convenient than dealing with a - * #GTimeVal. - * - * You should only use this call if you are actually interested in the real - * wall-clock time. g_get_monotonic_time() is probably more useful for - * measuring intervals. - * - * Returns: the number of microseconds since January 1, 1970 UTC. - * Since: 2.28 - */ - - -/** - * g_get_system_config_dirs: - * - * Returns an ordered list of base directories in which to access - * system-wide configuration information. - * - * On UNIX platforms this is determined using the mechanisms described - * in the - * [XDG Base Directory Specification](http://www.freedesktop.org/Standards/basedir-spec). - * In this case the list of directories retrieved will be `XDG_CONFIG_DIRS`. - * - * On Windows it follows XDG Base Directory Specification if `XDG_CONFIG_DIRS` is defined. - * If `XDG_CONFIG_DIRS` is undefined, the directory that contains application - * data for all users is used instead. A typical path is - * `C:\Documents and Settings\All Users\Application Data`. - * This folder is used for application data - * that is not user specific. For example, an application can store - * a spell-check dictionary, a database of clip art, or a log file in the - * FOLDERID_ProgramData folder. This information will not roam and is available - * to anyone using the computer. - * - * The return value is cached and modifying it at runtime is not supported, as - * it’s not thread-safe to modify environment variables at runtime. - * - * Returns: (array zero-terminated=1) (element-type filename) (transfer none): - * a %NULL-terminated array of strings owned by GLib that must not be - * modified or freed. - * Since: 2.6 - */ - - -/** - * g_get_system_data_dirs: - * - * Returns an ordered list of base directories in which to access - * system-wide application data. - * - * On UNIX platforms this is determined using the mechanisms described - * in the - * [XDG Base Directory Specification](http://www.freedesktop.org/Standards/basedir-spec) - * In this case the list of directories retrieved will be `XDG_DATA_DIRS`. - * - * On Windows it follows XDG Base Directory Specification if `XDG_DATA_DIRS` is defined. - * If `XDG_DATA_DIRS` is undefined, - * the first elements in the list are the Application Data - * and Documents folders for All Users. (These can be determined only - * on Windows 2000 or later and are not present in the list on other - * Windows versions.) See documentation for FOLDERID_ProgramData and - * FOLDERID_PublicDocuments. - * - * Then follows the "share" subfolder in the installation folder for - * the package containing the DLL that calls this function, if it can - * be determined. - * - * Finally the list contains the "share" subfolder in the installation - * folder for GLib, and in the installation folder for the package the - * application's .exe file belongs to. - * - * The installation folders above are determined by looking up the - * folder where the module (DLL or EXE) in question is located. If the - * folder's name is "bin", its parent is used, otherwise the folder - * itself. - * - * Note that on Windows the returned list can vary depending on where - * this function is called. - * - * The return value is cached and modifying it at runtime is not supported, as - * it’s not thread-safe to modify environment variables at runtime. - * - * Returns: (array zero-terminated=1) (element-type filename) (transfer none): - * a %NULL-terminated array of strings owned by GLib that must not be - * modified or freed. - * Since: 2.6 - */ - - -/** - * g_get_tmp_dir: - * - * Gets the directory to use for temporary files. - * - * On UNIX, this is taken from the `TMPDIR` environment variable. - * If the variable is not set, `P_tmpdir` is - * used, as defined by the system C library. Failing that, a - * hard-coded default of "/tmp" is returned. - * - * On Windows, the `TEMP` environment variable is used, with the - * root directory of the Windows installation (eg: "C:\") used - * as a default. - * - * The encoding of the returned string is system-defined. On Windows, - * it is always UTF-8. The return value is never %NULL or the empty - * string. - * - * Returns: (type filename) (transfer none): the directory to use for temporary files. - */ - - -/** - * g_get_user_cache_dir: - * - * Returns a base directory in which to store non-essential, cached - * data specific to particular user. - * - * On UNIX platforms this is determined using the mechanisms described - * in the - * [XDG Base Directory Specification](http://www.freedesktop.org/Standards/basedir-spec). - * In this case the directory retrieved will be `XDG_CACHE_HOME`. - * - * On Windows it follows XDG Base Directory Specification if `XDG_CACHE_HOME` is defined. - * If `XDG_CACHE_HOME` is undefined, the directory that serves as a common - * repository for temporary Internet files is used instead. A typical path is - * `C:\Documents and Settings\username\Local Settings\Temporary Internet Files`. - * See the [documentation for `FOLDERID_InternetCache`](https://docs.microsoft.com/en-us/windows/win32/shell/knownfolderid). - * - * The return value is cached and modifying it at runtime is not supported, as - * it’s not thread-safe to modify environment variables at runtime. - * - * Returns: (type filename) (transfer none): a string owned by GLib that - * must not be modified or freed. - * Since: 2.6 - */ - - -/** - * g_get_user_config_dir: - * - * Returns a base directory in which to store user-specific application - * configuration information such as user preferences and settings. - * - * On UNIX platforms this is determined using the mechanisms described - * in the - * [XDG Base Directory Specification](http://www.freedesktop.org/Standards/basedir-spec). - * In this case the directory retrieved will be `XDG_CONFIG_HOME`. - * - * On Windows it follows XDG Base Directory Specification if `XDG_CONFIG_HOME` is defined. - * If `XDG_CONFIG_HOME` is undefined, the folder to use for local (as opposed - * to roaming) application data is used instead. See the - * [documentation for `FOLDERID_LocalAppData`](https://docs.microsoft.com/en-us/windows/win32/shell/knownfolderid). - * Note that in this case on Windows it will be the same - * as what g_get_user_data_dir() returns. - * - * The return value is cached and modifying it at runtime is not supported, as - * it’s not thread-safe to modify environment variables at runtime. - * - * Returns: (type filename) (transfer none): a string owned by GLib that - * must not be modified or freed. - * Since: 2.6 - */ - - -/** - * g_get_user_data_dir: - * - * Returns a base directory in which to access application data such - * as icons that is customized for a particular user. - * - * On UNIX platforms this is determined using the mechanisms described - * in the - * [XDG Base Directory Specification](http://www.freedesktop.org/Standards/basedir-spec). - * In this case the directory retrieved will be `XDG_DATA_HOME`. - * - * On Windows it follows XDG Base Directory Specification if `XDG_DATA_HOME` - * is defined. If `XDG_DATA_HOME` is undefined, the folder to use for local (as - * opposed to roaming) application data is used instead. See the - * [documentation for `FOLDERID_LocalAppData`](https://docs.microsoft.com/en-us/windows/win32/shell/knownfolderid). - * Note that in this case on Windows it will be the same - * as what g_get_user_config_dir() returns. - * - * The return value is cached and modifying it at runtime is not supported, as - * it’s not thread-safe to modify environment variables at runtime. - * - * Returns: (type filename) (transfer none): a string owned by GLib that must - * not be modified or freed. - * Since: 2.6 - */ - - -/** - * g_get_user_name: - * - * Gets the user name of the current user. The encoding of the returned - * string is system-defined. On UNIX, it might be the preferred file name - * encoding, or something else, and there is no guarantee that it is even - * consistent on a machine. On Windows, it is always UTF-8. - * - * Returns: (type filename) (transfer none): the user name of the current user. - */ - - -/** - * g_get_user_runtime_dir: - * - * Returns a directory that is unique to the current user on the local - * system. - * - * This is determined using the mechanisms described - * in the - * [XDG Base Directory Specification](http://www.freedesktop.org/Standards/basedir-spec). - * This is the directory - * specified in the `XDG_RUNTIME_DIR` environment variable. - * In the case that this variable is not set, we return the value of - * g_get_user_cache_dir(), after verifying that it exists. - * - * The return value is cached and modifying it at runtime is not supported, as - * it’s not thread-safe to modify environment variables at runtime. - * - * Returns: (type filename): a string owned by GLib that must not be - * modified or freed. - * Since: 2.28 - */ - - -/** - * g_get_user_special_dir: - * @directory: the logical id of special directory - * - * Returns the full path of a special directory using its logical id. - * - * On UNIX this is done using the XDG special user directories. - * For compatibility with existing practise, %G_USER_DIRECTORY_DESKTOP - * falls back to `$HOME/Desktop` when XDG special user directories have - * not been set up. - * - * Depending on the platform, the user might be able to change the path - * of the special directory without requiring the session to restart; GLib - * will not reflect any change once the special directories are loaded. - * - * Returns: (type filename): the path to the specified special directory, or - * %NULL if the logical id was not found. The returned string is owned by - * GLib and should not be modified or freed. - * Since: 2.14 - */ - - -/** - * g_getenv: - * @variable: (type filename): the environment variable to get - * - * Returns the value of an environment variable. - * - * On UNIX, the name and value are byte strings which might or might not - * be in some consistent character set and encoding. On Windows, they are - * in UTF-8. - * On Windows, in case the environment variable's value contains - * references to other environment variables, they are expanded. - * - * Returns: (type filename): the value of the environment variable, or %NULL if - * the environment variable is not found. The returned string - * may be overwritten by the next call to g_getenv(), g_setenv() - * or g_unsetenv(). - */ - - -/** - * g_hash_table_add: - * @hash_table: a #GHashTable - * @key: (transfer full): a key to insert - * - * This is a convenience function for using a #GHashTable as a set. It - * is equivalent to calling g_hash_table_replace() with @key as both the - * key and the value. - * - * In particular, this means that if @key already exists in the hash table, then - * the old copy of @key in the hash table is freed and @key replaces it in the - * table. - * - * When a hash table only ever contains keys that have themselves as the - * corresponding value it is able to be stored more efficiently. See - * the discussion in the section description. - * - * Starting from GLib 2.40, this function returns a boolean value to - * indicate whether the newly added value was already in the hash table - * or not. - * - * Returns: %TRUE if the key did not exist yet - * Since: 2.32 - */ - - -/** - * g_hash_table_contains: - * @hash_table: a #GHashTable - * @key: a key to check - * - * Checks if @key is in @hash_table. - * - * Returns: %TRUE if @key is in @hash_table, %FALSE otherwise. - * Since: 2.32 - */ - - -/** - * g_hash_table_destroy: - * @hash_table: a #GHashTable - * - * Destroys all keys and values in the #GHashTable and decrements its - * reference count by 1. If keys and/or values are dynamically allocated, - * you should either free them first or create the #GHashTable with destroy - * notifiers using g_hash_table_new_full(). In the latter case the destroy - * functions you supplied will be called on all keys and values during the - * destruction phase. - */ - - -/** - * g_hash_table_find: - * @hash_table: a #GHashTable - * @predicate: function to test the key/value pairs for a certain property - * @user_data: user data to pass to the function - * - * Calls the given function for key/value pairs in the #GHashTable - * until @predicate returns %TRUE. The function is passed the key - * and value of each pair, and the given @user_data parameter. The - * hash table may not be modified while iterating over it (you can't - * add/remove items). - * - * Note, that hash tables are really only optimized for forward - * lookups, i.e. g_hash_table_lookup(). So code that frequently issues - * g_hash_table_find() or g_hash_table_foreach() (e.g. in the order of - * once per every entry in a hash table) should probably be reworked - * to use additional or different data structures for reverse lookups - * (keep in mind that an O(n) find/foreach operation issued for all n - * values in a hash table ends up needing O(n*n) operations). - * - * Returns: (nullable): The value of the first key/value pair is returned, - * for which @predicate evaluates to %TRUE. If no pair with the - * requested property is found, %NULL is returned. - * Since: 2.4 - */ - - -/** - * g_hash_table_foreach: - * @hash_table: a #GHashTable - * @func: the function to call for each key/value pair - * @user_data: user data to pass to the function - * - * Calls the given function for each of the key/value pairs in the - * #GHashTable. The function is passed the key and value of each - * pair, and the given @user_data parameter. The hash table may not - * be modified while iterating over it (you can't add/remove - * items). To remove all items matching a predicate, use - * g_hash_table_foreach_remove(). - * - * The order in which g_hash_table_foreach() iterates over the keys/values in - * the hash table is not defined. - * - * See g_hash_table_find() for performance caveats for linear - * order searches in contrast to g_hash_table_lookup(). - */ - - -/** - * g_hash_table_foreach_remove: - * @hash_table: a #GHashTable - * @func: the function to call for each key/value pair - * @user_data: user data to pass to the function - * - * Calls the given function for each key/value pair in the - * #GHashTable. If the function returns %TRUE, then the key/value - * pair is removed from the #GHashTable. If you supplied key or - * value destroy functions when creating the #GHashTable, they are - * used to free the memory allocated for the removed keys and values. - * - * See #GHashTableIter for an alternative way to loop over the - * key/value pairs in the hash table. - * - * Returns: the number of key/value pairs removed - */ - - -/** - * g_hash_table_foreach_steal: - * @hash_table: a #GHashTable - * @func: the function to call for each key/value pair - * @user_data: user data to pass to the function - * - * Calls the given function for each key/value pair in the - * #GHashTable. If the function returns %TRUE, then the key/value - * pair is removed from the #GHashTable, but no key or value - * destroy functions are called. - * - * See #GHashTableIter for an alternative way to loop over the - * key/value pairs in the hash table. - * - * Returns: the number of key/value pairs removed. - */ - - -/** - * g_hash_table_freeze: - * @hash_table: a #GHashTable - * - * This function is deprecated and will be removed in the next major - * release of GLib. It does nothing. - */ - - -/** - * g_hash_table_get_keys: - * @hash_table: a #GHashTable - * - * Retrieves every key inside @hash_table. The returned data is valid - * until changes to the hash release those keys. - * - * This iterates over every entry in the hash table to build its return value. - * To iterate over the entries in a #GHashTable more efficiently, use a - * #GHashTableIter. - * - * Returns: (transfer container): a #GList containing all the keys - * inside the hash table. The content of the list is owned by the - * hash table and should not be modified or freed. Use g_list_free() - * when done using the list. - * Since: 2.14 - */ - - -/** - * g_hash_table_get_keys_as_array: - * @hash_table: a #GHashTable - * @length: (out) (optional): the length of the returned array - * - * Retrieves every key inside @hash_table, as an array. - * - * The returned array is %NULL-terminated but may contain %NULL as a - * key. Use @length to determine the true length if it's possible that - * %NULL was used as the value for a key. - * - * Note: in the common case of a string-keyed #GHashTable, the return - * value of this function can be conveniently cast to (const gchar **). - * - * This iterates over every entry in the hash table to build its return value. - * To iterate over the entries in a #GHashTable more efficiently, use a - * #GHashTableIter. - * - * You should always free the return result with g_free(). In the - * above-mentioned case of a string-keyed hash table, it may be - * appropriate to use g_strfreev() if you call g_hash_table_steal_all() - * first to transfer ownership of the keys. - * - * Returns: (array length=length) (transfer container): a - * %NULL-terminated array containing each key from the table. - * Since: 2.40 - */ - - -/** - * g_hash_table_get_values: - * @hash_table: a #GHashTable - * - * Retrieves every value inside @hash_table. The returned data - * is valid until @hash_table is modified. - * - * This iterates over every entry in the hash table to build its return value. - * To iterate over the entries in a #GHashTable more efficiently, use a - * #GHashTableIter. - * - * Returns: (transfer container): a #GList containing all the values - * inside the hash table. The content of the list is owned by the - * hash table and should not be modified or freed. Use g_list_free() - * when done using the list. - * Since: 2.14 - */ - - -/** - * g_hash_table_insert: - * @hash_table: a #GHashTable - * @key: a key to insert - * @value: the value to associate with the key - * - * Inserts a new key and value into a #GHashTable. - * - * If the key already exists in the #GHashTable its current - * value is replaced with the new value. If you supplied a - * @value_destroy_func when creating the #GHashTable, the old - * value is freed using that function. If you supplied a - * @key_destroy_func when creating the #GHashTable, the passed - * key is freed using that function. - * - * Starting from GLib 2.40, this function returns a boolean value to - * indicate whether the newly added value was already in the hash table - * or not. - * - * Returns: %TRUE if the key did not exist yet - */ - - -/** - * g_hash_table_iter_get_hash_table: - * @iter: an initialized #GHashTableIter - * - * Returns the #GHashTable associated with @iter. - * - * Returns: the #GHashTable associated with @iter. - * Since: 2.16 - */ - - -/** - * g_hash_table_iter_init: - * @iter: an uninitialized #GHashTableIter - * @hash_table: a #GHashTable - * - * Initializes a key/value pair iterator and associates it with - * @hash_table. Modifying the hash table after calling this function - * invalidates the returned iterator. - * - * The iteration order of a #GHashTableIter over the keys/values in a hash - * table is not defined. - * - * |[<!-- language="C" --> - * GHashTableIter iter; - * gpointer key, value; - * - * g_hash_table_iter_init (&iter, hash_table); - * while (g_hash_table_iter_next (&iter, &key, &value)) - * { - * // do something with key and value - * } - * ]| - * - * Since: 2.16 - */ - - -/** - * g_hash_table_iter_next: - * @iter: an initialized #GHashTableIter - * @key: (out) (optional): a location to store the key - * @value: (out) (optional) (nullable): a location to store the value - * - * Advances @iter and retrieves the key and/or value that are now - * pointed to as a result of this advancement. If %FALSE is returned, - * @key and @value are not set, and the iterator becomes invalid. - * - * Returns: %FALSE if the end of the #GHashTable has been reached. - * Since: 2.16 - */ - - -/** - * g_hash_table_iter_remove: - * @iter: an initialized #GHashTableIter - * - * Removes the key/value pair currently pointed to by the iterator - * from its associated #GHashTable. Can only be called after - * g_hash_table_iter_next() returned %TRUE, and cannot be called - * more than once for the same key/value pair. - * - * If the #GHashTable was created using g_hash_table_new_full(), - * the key and value are freed using the supplied destroy functions, - * otherwise you have to make sure that any dynamically allocated - * values are freed yourself. - * - * It is safe to continue iterating the #GHashTable afterward: - * |[<!-- language="C" --> - * while (g_hash_table_iter_next (&iter, &key, &value)) - * { - * if (condition) - * g_hash_table_iter_remove (&iter); - * } - * ]| - * - * Since: 2.16 - */ - - -/** - * g_hash_table_iter_replace: - * @iter: an initialized #GHashTableIter - * @value: the value to replace with - * - * Replaces the value currently pointed to by the iterator - * from its associated #GHashTable. Can only be called after - * g_hash_table_iter_next() returned %TRUE. - * - * If you supplied a @value_destroy_func when creating the - * #GHashTable, the old value is freed using that function. - * - * Since: 2.30 - */ - - -/** - * g_hash_table_iter_steal: - * @iter: an initialized #GHashTableIter - * - * Removes the key/value pair currently pointed to by the - * iterator from its associated #GHashTable, without calling - * the key and value destroy functions. Can only be called - * after g_hash_table_iter_next() returned %TRUE, and cannot - * be called more than once for the same key/value pair. - * - * Since: 2.16 - */ - - -/** - * g_hash_table_lookup: - * @hash_table: a #GHashTable - * @key: the key to look up - * - * Looks up a key in a #GHashTable. Note that this function cannot - * distinguish between a key that is not present and one which is present - * and has the value %NULL. If you need this distinction, use - * g_hash_table_lookup_extended(). - * - * Returns: (nullable): the associated value, or %NULL if the key is not found - */ - - -/** - * g_hash_table_lookup_extended: - * @hash_table: a #GHashTable - * @lookup_key: the key to look up - * @orig_key: (out) (optional): return location for the original key - * @value: (out) (optional) (nullable): return location for the value associated - * with the key - * - * Looks up a key in the #GHashTable, returning the original key and the - * associated value and a #gboolean which is %TRUE if the key was found. This - * is useful if you need to free the memory allocated for the original key, - * for example before calling g_hash_table_remove(). - * - * You can actually pass %NULL for @lookup_key to test - * whether the %NULL key exists, provided the hash and equal functions - * of @hash_table are %NULL-safe. - * - * Returns: %TRUE if the key was found in the #GHashTable - */ - - -/** - * g_hash_table_new: - * @hash_func: a function to create a hash value from a key - * @key_equal_func: a function to check two keys for equality - * - * Creates a new #GHashTable with a reference count of 1. - * - * Hash values returned by @hash_func are used to determine where keys - * are stored within the #GHashTable data structure. The g_direct_hash(), - * g_int_hash(), g_int64_hash(), g_double_hash() and g_str_hash() - * functions are provided for some common types of keys. - * If @hash_func is %NULL, g_direct_hash() is used. - * - * @key_equal_func is used when looking up keys in the #GHashTable. - * The g_direct_equal(), g_int_equal(), g_int64_equal(), g_double_equal() - * and g_str_equal() functions are provided for the most common types - * of keys. If @key_equal_func is %NULL, keys are compared directly in - * a similar fashion to g_direct_equal(), but without the overhead of - * a function call. @key_equal_func is called with the key from the hash table - * as its first parameter, and the user-provided key to check against as - * its second. - * - * Returns: a new #GHashTable - */ - - -/** - * g_hash_table_new_full: - * @hash_func: a function to create a hash value from a key - * @key_equal_func: a function to check two keys for equality - * @key_destroy_func: (nullable): a function to free the memory allocated for the key - * used when removing the entry from the #GHashTable, or %NULL - * if you don't want to supply such a function. - * @value_destroy_func: (nullable): a function to free the memory allocated for the - * value used when removing the entry from the #GHashTable, or %NULL - * if you don't want to supply such a function. - * - * Creates a new #GHashTable like g_hash_table_new() with a reference - * count of 1 and allows to specify functions to free the memory - * allocated for the key and value that get called when removing the - * entry from the #GHashTable. - * - * Since version 2.42 it is permissible for destroy notify functions to - * recursively remove further items from the hash table. This is only - * permissible if the application still holds a reference to the hash table. - * This means that you may need to ensure that the hash table is empty by - * calling g_hash_table_remove_all() before releasing the last reference using - * g_hash_table_unref(). - * - * Returns: a new #GHashTable - */ - - -/** - * g_hash_table_ref: - * @hash_table: a valid #GHashTable - * - * Atomically increments the reference count of @hash_table by one. - * This function is MT-safe and may be called from any thread. - * - * Returns: the passed in #GHashTable - * Since: 2.10 - */ - - -/** - * g_hash_table_remove: - * @hash_table: a #GHashTable - * @key: the key to remove - * - * Removes a key and its associated value from a #GHashTable. - * - * If the #GHashTable was created using g_hash_table_new_full(), the - * key and value are freed using the supplied destroy functions, otherwise - * you have to make sure that any dynamically allocated values are freed - * yourself. - * - * Returns: %TRUE if the key was found and removed from the #GHashTable - */ - - -/** - * g_hash_table_remove_all: - * @hash_table: a #GHashTable - * - * Removes all keys and their associated values from a #GHashTable. - * - * If the #GHashTable was created using g_hash_table_new_full(), - * the keys and values are freed using the supplied destroy functions, - * otherwise you have to make sure that any dynamically allocated - * values are freed yourself. - * - * Since: 2.12 - */ - - -/** - * g_hash_table_replace: - * @hash_table: a #GHashTable - * @key: a key to insert - * @value: the value to associate with the key - * - * Inserts a new key and value into a #GHashTable similar to - * g_hash_table_insert(). The difference is that if the key - * already exists in the #GHashTable, it gets replaced by the - * new key. If you supplied a @value_destroy_func when creating - * the #GHashTable, the old value is freed using that function. - * If you supplied a @key_destroy_func when creating the - * #GHashTable, the old key is freed using that function. - * - * Starting from GLib 2.40, this function returns a boolean value to - * indicate whether the newly added value was already in the hash table - * or not. - * - * Returns: %TRUE if the key did not exist yet - */ - - -/** - * g_hash_table_size: - * @hash_table: a #GHashTable - * - * Returns the number of elements contained in the #GHashTable. - * - * Returns: the number of key/value pairs in the #GHashTable. - */ - - -/** - * g_hash_table_steal: - * @hash_table: a #GHashTable - * @key: the key to remove - * - * Removes a key and its associated value from a #GHashTable without - * calling the key and value destroy functions. - * - * Returns: %TRUE if the key was found and removed from the #GHashTable - */ - - -/** - * g_hash_table_steal_all: - * @hash_table: a #GHashTable - * - * Removes all keys and their associated values from a #GHashTable - * without calling the key and value destroy functions. - * - * Since: 2.12 - */ - - -/** - * g_hash_table_steal_extended: - * @hash_table: a #GHashTable - * @lookup_key: the key to look up - * @stolen_key: (out) (optional) (transfer full): return location for the - * original key - * @stolen_value: (out) (optional) (nullable) (transfer full): return location - * for the value associated with the key - * - * Looks up a key in the #GHashTable, stealing the original key and the - * associated value and returning %TRUE if the key was found. If the key was - * not found, %FALSE is returned. - * - * If found, the stolen key and value are removed from the hash table without - * calling the key and value destroy functions, and ownership is transferred to - * the caller of this method; as with g_hash_table_steal(). - * - * You can pass %NULL for @lookup_key, provided the hash and equal functions - * of @hash_table are %NULL-safe. - * - * Returns: %TRUE if the key was found in the #GHashTable - * Since: 2.58 - */ - - -/** - * g_hash_table_thaw: - * @hash_table: a #GHashTable - * - * This function is deprecated and will be removed in the next major - * release of GLib. It does nothing. - */ - - -/** - * g_hash_table_unref: - * @hash_table: a valid #GHashTable - * - * Atomically decrements the reference count of @hash_table by one. - * If the reference count drops to 0, all keys and values will be - * destroyed, and all memory allocated by the hash table is released. - * This function is MT-safe and may be called from any thread. - * - * Since: 2.10 - */ - - -/** - * g_hmac_copy: - * @hmac: the #GHmac to copy - * - * Copies a #GHmac. If @hmac has been closed, by calling - * g_hmac_get_string() or g_hmac_get_digest(), the copied - * HMAC will be closed as well. - * - * Returns: the copy of the passed #GHmac. Use g_hmac_unref() - * when finished using it. - * Since: 2.30 - */ - - -/** - * g_hmac_get_digest: - * @hmac: a #GHmac - * @buffer: (array length=digest_len): output buffer - * @digest_len: (inout): an inout parameter. The caller initializes it to the - * size of @buffer. After the call it contains the length of the digest - * - * Gets the digest from @checksum as a raw binary array and places it - * into @buffer. The size of the digest depends on the type of checksum. - * - * Once this function has been called, the #GHmac is closed and can - * no longer be updated with g_checksum_update(). - * - * Since: 2.30 - */ - - -/** - * g_hmac_get_string: - * @hmac: a #GHmac - * - * Gets the HMAC as a hexadecimal string. - * - * Once this function has been called the #GHmac can no longer be - * updated with g_hmac_update(). - * - * The hexadecimal characters will be lower case. - * - * Returns: the hexadecimal representation of the HMAC. The - * returned string is owned by the HMAC and should not be modified - * or freed. - * Since: 2.30 - */ - - -/** - * g_hmac_new: - * @digest_type: the desired type of digest - * @key: (array length=key_len): the key for the HMAC - * @key_len: the length of the keys - * - * Creates a new #GHmac, using the digest algorithm @digest_type. - * If the @digest_type is not known, %NULL is returned. - * A #GHmac can be used to compute the HMAC of a key and an - * arbitrary binary blob, using different hashing algorithms. - * - * A #GHmac works by feeding a binary blob through g_hmac_update() - * until the data is complete; the digest can then be extracted - * using g_hmac_get_string(), which will return the checksum as a - * hexadecimal string; or g_hmac_get_digest(), which will return a - * array of raw bytes. Once either g_hmac_get_string() or - * g_hmac_get_digest() have been called on a #GHmac, the HMAC - * will be closed and it won't be possible to call g_hmac_update() - * on it anymore. - * - * Support for digests of type %G_CHECKSUM_SHA512 has been added in GLib 2.42. - * Support for %G_CHECKSUM_SHA384 was added in GLib 2.52. - * - * Returns: the newly created #GHmac, or %NULL. - * Use g_hmac_unref() to free the memory allocated by it. - * Since: 2.30 - */ - - -/** - * g_hmac_ref: - * @hmac: a valid #GHmac - * - * Atomically increments the reference count of @hmac by one. - * - * This function is MT-safe and may be called from any thread. - * - * Returns: the passed in #GHmac. - * Since: 2.30 - */ - - -/** - * g_hmac_unref: - * @hmac: a #GHmac - * - * Atomically decrements the reference count of @hmac by one. - * - * If the reference count drops to 0, all keys and values will be - * destroyed, and all memory allocated by the hash table is released. - * This function is MT-safe and may be called from any thread. - * Frees the memory allocated for @hmac. - * - * Since: 2.30 - */ - - -/** - * g_hmac_update: - * @hmac: a #GHmac - * @data: (array length=length): buffer used to compute the checksum - * @length: size of the buffer, or -1 if it is a nul-terminated string - * - * Feeds @data into an existing #GHmac. - * - * The HMAC must still be open, that is g_hmac_get_string() or - * g_hmac_get_digest() must not have been called on @hmac. - * - * Since: 2.30 - */ - - -/** - * g_hook_alloc: - * @hook_list: a #GHookList - * - * Allocates space for a #GHook and initializes it. - * - * Returns: a new #GHook - */ - - -/** - * g_hook_append: - * @hook_list: a #GHookList - * @hook: the #GHook to add to the end of @hook_list - * - * Appends a #GHook onto the end of a #GHookList. - */ - - -/** - * g_hook_compare_ids: - * @new_hook: a #GHook - * @sibling: a #GHook to compare with @new_hook - * - * Compares the ids of two #GHook elements, returning a negative value - * if the second id is greater than the first. - * - * Returns: a value <= 0 if the id of @sibling is >= the id of @new_hook - */ - - -/** - * g_hook_destroy: - * @hook_list: a #GHookList - * @hook_id: a hook ID - * - * Destroys a #GHook, given its ID. - * - * Returns: %TRUE if the #GHook was found in the #GHookList and destroyed - */ - - -/** - * g_hook_destroy_link: - * @hook_list: a #GHookList - * @hook: the #GHook to remove - * - * Removes one #GHook from a #GHookList, marking it - * inactive and calling g_hook_unref() on it. - */ - - -/** - * g_hook_find: - * @hook_list: a #GHookList - * @need_valids: %TRUE if #GHook elements which have been destroyed - * should be skipped - * @func: the function to call for each #GHook, which should return - * %TRUE when the #GHook has been found - * @data: the data to pass to @func - * - * Finds a #GHook in a #GHookList using the given function to - * test for a match. - * - * Returns: the found #GHook or %NULL if no matching #GHook is found - */ - - -/** - * g_hook_find_data: - * @hook_list: a #GHookList - * @need_valids: %TRUE if #GHook elements which have been destroyed - * should be skipped - * @data: the data to find - * - * Finds a #GHook in a #GHookList with the given data. - * - * Returns: the #GHook with the given @data or %NULL if no matching - * #GHook is found - */ - - -/** - * g_hook_find_func: - * @hook_list: a #GHookList - * @need_valids: %TRUE if #GHook elements which have been destroyed - * should be skipped - * @func: the function to find - * - * Finds a #GHook in a #GHookList with the given function. - * - * Returns: the #GHook with the given @func or %NULL if no matching - * #GHook is found - */ - - -/** - * g_hook_find_func_data: - * @hook_list: a #GHookList - * @need_valids: %TRUE if #GHook elements which have been destroyed - * should be skipped - * @func: (not nullable): the function to find - * @data: the data to find - * - * Finds a #GHook in a #GHookList with the given function and data. - * - * Returns: the #GHook with the given @func and @data or %NULL if - * no matching #GHook is found - */ - - -/** - * g_hook_first_valid: - * @hook_list: a #GHookList - * @may_be_in_call: %TRUE if hooks which are currently running - * (e.g. in another thread) are considered valid. If set to %FALSE, - * these are skipped - * - * Returns the first #GHook in a #GHookList which has not been destroyed. - * The reference count for the #GHook is incremented, so you must call - * g_hook_unref() to restore it when no longer needed. (Or call - * g_hook_next_valid() if you are stepping through the #GHookList.) - * - * Returns: the first valid #GHook, or %NULL if none are valid - */ - - -/** - * g_hook_free: - * @hook_list: a #GHookList - * @hook: the #GHook to free - * - * Calls the #GHookList @finalize_hook function if it exists, - * and frees the memory allocated for the #GHook. - */ - - -/** - * g_hook_get: - * @hook_list: a #GHookList - * @hook_id: a hook id - * - * Returns the #GHook with the given id, or %NULL if it is not found. - * - * Returns: the #GHook with the given id, or %NULL if it is not found - */ - - -/** - * g_hook_insert_before: - * @hook_list: a #GHookList - * @sibling: (nullable): the #GHook to insert the new #GHook before - * @hook: the #GHook to insert - * - * Inserts a #GHook into a #GHookList, before a given #GHook. - */ - - -/** - * g_hook_insert_sorted: - * @hook_list: a #GHookList - * @hook: the #GHook to insert - * @func: the comparison function used to sort the #GHook elements - * - * Inserts a #GHook into a #GHookList, sorted by the given function. - */ - - -/** - * g_hook_list_clear: - * @hook_list: a #GHookList - * - * Removes all the #GHook elements from a #GHookList. - */ - - -/** - * g_hook_list_init: - * @hook_list: a #GHookList - * @hook_size: the size of each element in the #GHookList, - * typically `sizeof (GHook)`. - * - * Initializes a #GHookList. - * This must be called before the #GHookList is used. - */ - - -/** - * g_hook_list_invoke: - * @hook_list: a #GHookList - * @may_recurse: %TRUE if functions which are already running - * (e.g. in another thread) can be called. If set to %FALSE, - * these are skipped - * - * Calls all of the #GHook functions in a #GHookList. - */ - - -/** - * g_hook_list_invoke_check: - * @hook_list: a #GHookList - * @may_recurse: %TRUE if functions which are already running - * (e.g. in another thread) can be called. If set to %FALSE, - * these are skipped - * - * Calls all of the #GHook functions in a #GHookList. - * Any function which returns %FALSE is removed from the #GHookList. - */ - - -/** - * g_hook_list_marshal: - * @hook_list: a #GHookList - * @may_recurse: %TRUE if hooks which are currently running - * (e.g. in another thread) are considered valid. If set to %FALSE, - * these are skipped - * @marshaller: the function to call for each #GHook - * @marshal_data: data to pass to @marshaller - * - * Calls a function on each valid #GHook. - */ - - -/** - * g_hook_list_marshal_check: - * @hook_list: a #GHookList - * @may_recurse: %TRUE if hooks which are currently running - * (e.g. in another thread) are considered valid. If set to %FALSE, - * these are skipped - * @marshaller: the function to call for each #GHook - * @marshal_data: data to pass to @marshaller - * - * Calls a function on each valid #GHook and destroys it if the - * function returns %FALSE. - */ - - -/** - * g_hook_next_valid: - * @hook_list: a #GHookList - * @hook: the current #GHook - * @may_be_in_call: %TRUE if hooks which are currently running - * (e.g. in another thread) are considered valid. If set to %FALSE, - * these are skipped - * - * Returns the next #GHook in a #GHookList which has not been destroyed. - * The reference count for the #GHook is incremented, so you must call - * g_hook_unref() to restore it when no longer needed. (Or continue to call - * g_hook_next_valid() until %NULL is returned.) - * - * Returns: the next valid #GHook, or %NULL if none are valid - */ - - -/** - * g_hook_prepend: - * @hook_list: a #GHookList - * @hook: the #GHook to add to the start of @hook_list - * - * Prepends a #GHook on the start of a #GHookList. - */ - - -/** - * g_hook_ref: - * @hook_list: a #GHookList - * @hook: the #GHook to increment the reference count of - * - * Increments the reference count for a #GHook. - * - * Returns: the @hook that was passed in (since 2.6) - */ - - -/** - * g_hook_unref: - * @hook_list: a #GHookList - * @hook: the #GHook to unref - * - * Decrements the reference count of a #GHook. - * If the reference count falls to 0, the #GHook is removed - * from the #GHookList and g_hook_free() is called to free it. - */ - - -/** - * g_hostname_is_ascii_encoded: - * @hostname: a hostname - * - * Tests if @hostname contains segments with an ASCII-compatible - * encoding of an Internationalized Domain Name. If this returns - * %TRUE, you should decode the hostname with g_hostname_to_unicode() - * before displaying it to the user. - * - * Note that a hostname might contain a mix of encoded and unencoded - * segments, and so it is possible for g_hostname_is_non_ascii() and - * g_hostname_is_ascii_encoded() to both return %TRUE for a name. - * - * Returns: %TRUE if @hostname contains any ASCII-encoded - * segments. - * Since: 2.22 - */ - - -/** - * g_hostname_is_ip_address: - * @hostname: a hostname (or IP address in string form) - * - * Tests if @hostname is the string form of an IPv4 or IPv6 address. - * (Eg, "192.168.0.1".) - * - * Since 2.66, IPv6 addresses with a zone-id are accepted (RFC6874). - * - * Returns: %TRUE if @hostname is an IP address - * Since: 2.22 - */ - - -/** - * g_hostname_is_non_ascii: - * @hostname: a hostname - * - * Tests if @hostname contains Unicode characters. If this returns - * %TRUE, you need to encode the hostname with g_hostname_to_ascii() - * before using it in non-IDN-aware contexts. - * - * Note that a hostname might contain a mix of encoded and unencoded - * segments, and so it is possible for g_hostname_is_non_ascii() and - * g_hostname_is_ascii_encoded() to both return %TRUE for a name. - * - * Returns: %TRUE if @hostname contains any non-ASCII characters - * Since: 2.22 - */ - - -/** - * g_hostname_to_ascii: - * @hostname: a valid UTF-8 or ASCII hostname - * - * Converts @hostname to its canonical ASCII form; an ASCII-only - * string containing no uppercase letters and not ending with a - * trailing dot. - * - * Returns: (nullable) (transfer full): an ASCII hostname, which must be freed, - * or %NULL if @hostname is in some way invalid. - * Since: 2.22 - */ - - -/** - * g_hostname_to_unicode: - * @hostname: a valid UTF-8 or ASCII hostname - * - * Converts @hostname to its canonical presentation form; a UTF-8 - * string in Unicode normalization form C, containing no uppercase - * letters, no forbidden characters, and no ASCII-encoded segments, - * and not ending with a trailing dot. - * - * Of course if @hostname is not an internationalized hostname, then - * the canonical presentation form will be entirely ASCII. - * - * Returns: (nullable) (transfer full): a UTF-8 hostname, which must be freed, - * or %NULL if @hostname is in some way invalid. - * Since: 2.22 - */ - - -/** - * g_htonl: - * @val: a 32-bit integer value in host byte order - * - * Converts a 32-bit integer value from host to network byte order. - * - * Returns: @val converted to network byte order - */ - - -/** - * g_htons: - * @val: a 16-bit integer value in host byte order - * - * Converts a 16-bit integer value from host to network byte order. - * - * Returns: @val converted to network byte order - */ - - -/** - * g_iconv: (skip) - * @converter: conversion descriptor from g_iconv_open() - * @inbuf: bytes to convert - * @inbytes_left: inout parameter, bytes remaining to convert in @inbuf - * @outbuf: converted output bytes - * @outbytes_left: inout parameter, bytes available to fill in @outbuf - * - * Same as the standard UNIX routine iconv(), but - * may be implemented via libiconv on UNIX flavors that lack - * a native implementation. - * - * GLib provides g_convert() and g_locale_to_utf8() which are likely - * more convenient than the raw iconv wrappers. - * - * Note that the behaviour of iconv() for characters which are valid in the - * input character set, but which have no representation in the output character - * set, is implementation defined. This function may return success (with a - * positive number of non-reversible conversions as replacement characters were - * used), or it may return -1 and set an error such as %EILSEQ, in such a - * situation. - * - * Returns: count of non-reversible conversions, or -1 on error - */ - - -/** - * g_iconv_close: (skip) - * @converter: a conversion descriptor from g_iconv_open() - * - * Same as the standard UNIX routine iconv_close(), but - * may be implemented via libiconv on UNIX flavors that lack - * a native implementation. Should be called to clean up - * the conversion descriptor from g_iconv_open() when - * you are done converting things. - * - * GLib provides g_convert() and g_locale_to_utf8() which are likely - * more convenient than the raw iconv wrappers. - * - * Returns: -1 on error, 0 on success - */ - - -/** - * g_iconv_open: (skip) - * @to_codeset: destination codeset - * @from_codeset: source codeset - * - * Same as the standard UNIX routine iconv_open(), but - * may be implemented via libiconv on UNIX flavors that lack - * a native implementation. - * - * GLib provides g_convert() and g_locale_to_utf8() which are likely - * more convenient than the raw iconv wrappers. - * - * Returns: a "conversion descriptor", or (GIConv)-1 if - * opening the converter failed. - */ - - -/** - * g_idle_add: - * @function: function to call - * @data: data to pass to @function. - * - * Adds a function to be called whenever there are no higher priority - * events pending to the default main loop. The function is given the - * default idle priority, %G_PRIORITY_DEFAULT_IDLE. If the function - * returns %FALSE it is automatically removed from the list of event - * sources and will not be called again. - * - * See [memory management of sources][mainloop-memory-management] for details - * on how to handle the return value and memory management of @data. - * - * This internally creates a main loop source using g_idle_source_new() - * and attaches it to the global #GMainContext using g_source_attach(), so - * the callback will be invoked in whichever thread is running that main - * context. You can do these steps manually if you need greater control or to - * use a custom main context. - * - * Returns: the ID (greater than 0) of the event source. - */ - - -/** - * g_idle_add_full: (rename-to g_idle_add) - * @priority: the priority of the idle source. Typically this will be in the - * range between %G_PRIORITY_DEFAULT_IDLE and %G_PRIORITY_HIGH_IDLE. - * @function: function to call - * @data: data to pass to @function - * @notify: (nullable): function to call when the idle is removed, or %NULL - * - * Adds a function to be called whenever there are no higher priority - * events pending. - * - * If the function returns %G_SOURCE_REMOVE or %FALSE it is automatically - * removed from the list of event sources and will not be called again. - * - * See [memory management of sources][mainloop-memory-management] for details - * on how to handle the return value and memory management of @data. - * - * This internally creates a main loop source using g_idle_source_new() - * and attaches it to the global #GMainContext using g_source_attach(), so - * the callback will be invoked in whichever thread is running that main - * context. You can do these steps manually if you need greater control or to - * use a custom main context. - * - * Returns: the ID (greater than 0) of the event source. - */ - - -/** - * g_idle_remove_by_data: - * @data: the data for the idle source's callback. - * - * Removes the idle function with the given data. - * - * Returns: %TRUE if an idle source was found and removed. - */ - - -/** - * g_idle_source_new: - * - * Creates a new idle source. - * - * The source will not initially be associated with any #GMainContext - * and must be added to one with g_source_attach() before it will be - * executed. Note that the default priority for idle sources is - * %G_PRIORITY_DEFAULT_IDLE, as compared to other sources which - * have a default priority of %G_PRIORITY_DEFAULT. - * - * Returns: the newly-created idle source - */ - - -/** - * g_info: - * @...: format string, followed by parameters to insert - * into the format string (as with printf()) - * - * A convenience function/macro to log an informational message. Seldom used. - * - * If g_log_default_handler() is used as the log handler function, a new-line - * character will automatically be appended to @..., and need not be entered - * manually. - * - * Such messages are suppressed by the g_log_default_handler() and - * g_log_writer_default() unless the `G_MESSAGES_DEBUG` environment variable is - * set appropriately. - * - * If structured logging is enabled, this will use g_log_structured(); - * otherwise it will use g_log(). See - * [Using Structured Logging][using-structured-logging]. - * - * Since: 2.40 - */ - - -/** - * g_int64_equal: - * @v1: (not nullable): a pointer to a #gint64 key - * @v2: (not nullable): a pointer to a #gint64 key to compare with @v1 - * - * Compares the two #gint64 values being pointed to and returns - * %TRUE if they are equal. - * It can be passed to g_hash_table_new() as the @key_equal_func - * parameter, when using non-%NULL pointers to 64-bit integers as keys in a - * #GHashTable. - * - * Returns: %TRUE if the two keys match. - * Since: 2.22 - */ - - -/** - * g_int64_hash: - * @v: (not nullable): a pointer to a #gint64 key - * - * Converts a pointer to a #gint64 to a hash value. - * - * It can be passed to g_hash_table_new() as the @hash_func parameter, - * when using non-%NULL pointers to 64-bit integer values as keys in a - * #GHashTable. - * - * Returns: a hash value corresponding to the key. - * Since: 2.22 - */ - - -/** - * g_int_equal: - * @v1: (not nullable): a pointer to a #gint key - * @v2: (not nullable): a pointer to a #gint key to compare with @v1 - * - * Compares the two #gint values being pointed to and returns - * %TRUE if they are equal. - * It can be passed to g_hash_table_new() as the @key_equal_func - * parameter, when using non-%NULL pointers to integers as keys in a - * #GHashTable. - * - * Note that this function acts on pointers to #gint, not on #gint - * directly: if your hash table's keys are of the form - * `GINT_TO_POINTER (n)`, use g_direct_equal() instead. - * - * Returns: %TRUE if the two keys match. - */ - - -/** - * g_int_hash: - * @v: (not nullable): a pointer to a #gint key - * - * Converts a pointer to a #gint to a hash value. - * It can be passed to g_hash_table_new() as the @hash_func parameter, - * when using non-%NULL pointers to integer values as keys in a #GHashTable. - * - * Note that this function acts on pointers to #gint, not on #gint - * directly: if your hash table's keys are of the form - * `GINT_TO_POINTER (n)`, use g_direct_hash() instead. - * - * Returns: a hash value corresponding to the key. - */ - - -/** - * g_intern_static_string: - * @string: (nullable): a static string - * - * Returns a canonical representation for @string. Interned strings - * can be compared for equality by comparing the pointers, instead of - * using strcmp(). g_intern_static_string() does not copy the string, - * therefore @string must not be freed or modified. - * - * This function must not be used before library constructors have finished - * running. In particular, this means it cannot be used to initialize global - * variables in C++. - * - * Returns: a canonical representation for the string - * Since: 2.10 - */ - - -/** - * g_intern_string: - * @string: (nullable): a string - * - * Returns a canonical representation for @string. Interned strings - * can be compared for equality by comparing the pointers, instead of - * using strcmp(). - * - * This function must not be used before library constructors have finished - * running. In particular, this means it cannot be used to initialize global - * variables in C++. - * - * Returns: a canonical representation for the string - * Since: 2.10 - */ - - -/** - * g_io_add_watch: - * @channel: a #GIOChannel - * @condition: the condition to watch for - * @func: the function to call when the condition is satisfied - * @user_data: user data to pass to @func - * - * Adds the #GIOChannel into the default main loop context - * with the default priority. - * - * Returns: the event source id - */ - - -/** - * g_io_add_watch_full: (rename-to g_io_add_watch) - * @channel: a #GIOChannel - * @priority: the priority of the #GIOChannel source - * @condition: the condition to watch for - * @func: the function to call when the condition is satisfied - * @user_data: user data to pass to @func - * @notify: the function to call when the source is removed - * - * Adds the #GIOChannel into the default main loop context - * with the given priority. - * - * This internally creates a main loop source using g_io_create_watch() - * and attaches it to the main loop context with g_source_attach(). - * You can do these steps manually if you need greater control. - * - * Returns: the event source id - */ - - -/** - * g_io_channel_close: - * @channel: A #GIOChannel - * - * Close an IO channel. Any pending data to be written will be - * flushed, ignoring errors. The channel will not be freed until the - * last reference is dropped using g_io_channel_unref(). - * - * Deprecated: 2.2: Use g_io_channel_shutdown() instead. - */ - - -/** - * g_io_channel_error_from_errno: - * @en: an `errno` error number, e.g. `EINVAL` - * - * Converts an `errno` error number to a #GIOChannelError. - * - * Returns: a #GIOChannelError error number, e.g. - * %G_IO_CHANNEL_ERROR_INVAL. - */ - - -/** - * g_io_channel_flush: - * @channel: a #GIOChannel - * @error: location to store an error of type #GIOChannelError - * - * Flushes the write buffer for the GIOChannel. - * - * Returns: the status of the operation: One of - * #G_IO_STATUS_NORMAL, #G_IO_STATUS_AGAIN, or - * #G_IO_STATUS_ERROR. - */ - - -/** - * g_io_channel_get_buffer_condition: - * @channel: A #GIOChannel - * - * This function returns a #GIOCondition depending on whether there - * is data to be read/space to write data in the internal buffers in - * the #GIOChannel. Only the flags %G_IO_IN and %G_IO_OUT may be set. - * - * Returns: A #GIOCondition - */ - - -/** - * g_io_channel_get_buffer_size: - * @channel: a #GIOChannel - * - * Gets the buffer size. - * - * Returns: the size of the buffer. - */ - - -/** - * g_io_channel_get_buffered: - * @channel: a #GIOChannel - * - * Returns whether @channel is buffered. - * - * Returns: %TRUE if the @channel is buffered. - */ - - -/** - * g_io_channel_get_close_on_unref: - * @channel: a #GIOChannel. - * - * Returns whether the file/socket/whatever associated with @channel - * will be closed when @channel receives its final unref and is - * destroyed. The default value of this is %TRUE for channels created - * by g_io_channel_new_file (), and %FALSE for all other channels. - * - * Returns: %TRUE if the channel will be closed, %FALSE otherwise. - */ - - -/** - * g_io_channel_get_encoding: - * @channel: a #GIOChannel - * - * Gets the encoding for the input/output of the channel. - * The internal encoding is always UTF-8. The encoding %NULL - * makes the channel safe for binary data. - * - * Returns: A string containing the encoding, this string is - * owned by GLib and must not be freed. - */ - - -/** - * g_io_channel_get_flags: - * @channel: a #GIOChannel - * - * Gets the current flags for a #GIOChannel, including read-only - * flags such as %G_IO_FLAG_IS_READABLE. - * - * The values of the flags %G_IO_FLAG_IS_READABLE and %G_IO_FLAG_IS_WRITABLE - * are cached for internal use by the channel when it is created. - * If they should change at some later point (e.g. partial shutdown - * of a socket with the UNIX shutdown() function), the user - * should immediately call g_io_channel_get_flags() to update - * the internal values of these flags. - * - * Returns: the flags which are set on the channel - */ - - -/** - * g_io_channel_get_line_term: - * @channel: a #GIOChannel - * @length: a location to return the length of the line terminator - * - * This returns the string that #GIOChannel uses to determine - * where in the file a line break occurs. A value of %NULL - * indicates autodetection. - * - * Returns: The line termination string. This value - * is owned by GLib and must not be freed. - */ - - -/** - * g_io_channel_init: - * @channel: a #GIOChannel - * - * Initializes a #GIOChannel struct. - * - * This is called by each of the above functions when creating a - * #GIOChannel, and so is not often needed by the application - * programmer (unless you are creating a new type of #GIOChannel). - */ - - -/** - * g_io_channel_new_file: - * @filename: (type filename): A string containing the name of a file - * @mode: One of "r", "w", "a", "r+", "w+", "a+". These have - * the same meaning as in fopen() - * @error: A location to return an error of type %G_FILE_ERROR - * - * Open a file @filename as a #GIOChannel using mode @mode. This - * channel will be closed when the last reference to it is dropped, - * so there is no need to call g_io_channel_close() (though doing - * so will not cause problems, as long as no attempt is made to - * access the channel after it is closed). - * - * Returns: A #GIOChannel on success, %NULL on failure. - */ - - -/** - * g_io_channel_read: - * @channel: a #GIOChannel - * @buf: a buffer to read the data into (which should be at least - * count bytes long) - * @count: the number of bytes to read from the #GIOChannel - * @bytes_read: returns the number of bytes actually read - * - * Reads data from a #GIOChannel. - * - * Returns: %G_IO_ERROR_NONE if the operation was successful. - * Deprecated: 2.2: Use g_io_channel_read_chars() instead. - */ - - -/** - * g_io_channel_read_chars: - * @channel: a #GIOChannel - * @buf: (out caller-allocates) (array length=count) (element-type guint8): - * a buffer to read data into - * @count: (in): the size of the buffer. Note that the buffer may not be - * completely filled even if there is data in the buffer if the - * remaining data is not a complete character. - * @bytes_read: (out) (optional): The number of bytes read. This may be - * zero even on success if count < 6 and the channel's encoding - * is non-%NULL. This indicates that the next UTF-8 character is - * too wide for the buffer. - * @error: a location to return an error of type #GConvertError - * or #GIOChannelError. - * - * Replacement for g_io_channel_read() with the new API. - * - * Returns: the status of the operation. - */ - - -/** - * g_io_channel_read_line: - * @channel: a #GIOChannel - * @str_return: (out): The line read from the #GIOChannel, including the - * line terminator. This data should be freed with g_free() - * when no longer needed. This is a nul-terminated string. - * If a @length of zero is returned, this will be %NULL instead. - * @length: (out) (optional): location to store length of the read data, or %NULL - * @terminator_pos: (out) (optional): location to store position of line terminator, or %NULL - * @error: A location to return an error of type #GConvertError - * or #GIOChannelError - * - * Reads a line, including the terminating character(s), - * from a #GIOChannel into a newly-allocated string. - * @str_return will contain allocated memory if the return - * is %G_IO_STATUS_NORMAL. - * - * Returns: the status of the operation. - */ - - -/** - * g_io_channel_read_line_string: - * @channel: a #GIOChannel - * @buffer: a #GString into which the line will be written. - * If @buffer already contains data, the old data will - * be overwritten. - * @terminator_pos: (nullable): location to store position of line terminator, or %NULL - * @error: a location to store an error of type #GConvertError - * or #GIOChannelError - * - * Reads a line from a #GIOChannel, using a #GString as a buffer. - * - * Returns: the status of the operation. - */ - - -/** - * g_io_channel_read_to_end: - * @channel: a #GIOChannel - * @str_return: (out) (array length=length) (element-type guint8): Location to - * store a pointer to a string holding the remaining data in the - * #GIOChannel. This data should be freed with g_free() when no - * longer needed. This data is terminated by an extra nul - * character, but there may be other nuls in the intervening data. - * @length: (out): location to store length of the data - * @error: location to return an error of type #GConvertError - * or #GIOChannelError - * - * Reads all the remaining data from the file. - * - * Returns: %G_IO_STATUS_NORMAL on success. - * This function never returns %G_IO_STATUS_EOF. - */ - - -/** - * g_io_channel_read_unichar: - * @channel: a #GIOChannel - * @thechar: (out): a location to return a character - * @error: a location to return an error of type #GConvertError - * or #GIOChannelError - * - * Reads a Unicode character from @channel. - * This function cannot be called on a channel with %NULL encoding. - * - * Returns: a #GIOStatus - */ - - -/** - * g_io_channel_ref: - * @channel: a #GIOChannel - * - * Increments the reference count of a #GIOChannel. - * - * Returns: the @channel that was passed in (since 2.6) - */ - - -/** - * g_io_channel_seek: - * @channel: a #GIOChannel - * @offset: an offset, in bytes, which is added to the position specified - * by @type - * @type: the position in the file, which can be %G_SEEK_CUR (the current - * position), %G_SEEK_SET (the start of the file), or %G_SEEK_END - * (the end of the file) - * - * Sets the current position in the #GIOChannel, similar to the standard - * library function fseek(). - * - * Returns: %G_IO_ERROR_NONE if the operation was successful. - * Deprecated: 2.2: Use g_io_channel_seek_position() instead. - */ - - -/** - * g_io_channel_seek_position: - * @channel: a #GIOChannel - * @offset: The offset in bytes from the position specified by @type - * @type: a #GSeekType. The type %G_SEEK_CUR is only allowed in those - * cases where a call to g_io_channel_set_encoding () - * is allowed. See the documentation for - * g_io_channel_set_encoding () for details. - * @error: A location to return an error of type #GIOChannelError - * - * Replacement for g_io_channel_seek() with the new API. - * - * Returns: the status of the operation. - */ - - -/** - * g_io_channel_set_buffer_size: - * @channel: a #GIOChannel - * @size: the size of the buffer, or 0 to let GLib pick a good size - * - * Sets the buffer size. - */ - - -/** - * g_io_channel_set_buffered: - * @channel: a #GIOChannel - * @buffered: whether to set the channel buffered or unbuffered - * - * The buffering state can only be set if the channel's encoding - * is %NULL. For any other encoding, the channel must be buffered. - * - * A buffered channel can only be set unbuffered if the channel's - * internal buffers have been flushed. Newly created channels or - * channels which have returned %G_IO_STATUS_EOF - * not require such a flush. For write-only channels, a call to - * g_io_channel_flush () is sufficient. For all other channels, - * the buffers may be flushed by a call to g_io_channel_seek_position (). - * This includes the possibility of seeking with seek type %G_SEEK_CUR - * and an offset of zero. Note that this means that socket-based - * channels cannot be set unbuffered once they have had data - * read from them. - * - * On unbuffered channels, it is safe to mix read and write - * calls from the new and old APIs, if this is necessary for - * maintaining old code. - * - * The default state of the channel is buffered. - */ - - -/** - * g_io_channel_set_close_on_unref: - * @channel: a #GIOChannel - * @do_close: Whether to close the channel on the final unref of - * the GIOChannel data structure. - * - * Whether to close the channel on the final unref of the #GIOChannel - * data structure. The default value of this is %TRUE for channels - * created by g_io_channel_new_file (), and %FALSE for all other channels. - * - * Setting this flag to %TRUE for a channel you have already closed - * can cause problems when the final reference to the #GIOChannel is dropped. - */ - - -/** - * g_io_channel_set_encoding: - * @channel: a #GIOChannel - * @encoding: (nullable): the encoding type - * @error: location to store an error of type #GConvertError - * - * Sets the encoding for the input/output of the channel. - * The internal encoding is always UTF-8. The default encoding - * for the external file is UTF-8. - * - * The encoding %NULL is safe to use with binary data. - * - * The encoding can only be set if one of the following conditions - * is true: - * - * - The channel was just created, and has not been written to or read from yet. - * - * - The channel is write-only. - * - * - The channel is a file, and the file pointer was just repositioned - * by a call to g_io_channel_seek_position(). (This flushes all the - * internal buffers.) - * - * - The current encoding is %NULL or UTF-8. - * - * - One of the (new API) read functions has just returned %G_IO_STATUS_EOF - * (or, in the case of g_io_channel_read_to_end(), %G_IO_STATUS_NORMAL). - * - * - One of the functions g_io_channel_read_chars() or - * g_io_channel_read_unichar() has returned %G_IO_STATUS_AGAIN or - * %G_IO_STATUS_ERROR. This may be useful in the case of - * %G_CONVERT_ERROR_ILLEGAL_SEQUENCE. - * Returning one of these statuses from g_io_channel_read_line(), - * g_io_channel_read_line_string(), or g_io_channel_read_to_end() - * does not guarantee that the encoding can be changed. - * - * Channels which do not meet one of the above conditions cannot call - * g_io_channel_seek_position() with an offset of %G_SEEK_CUR, and, if - * they are "seekable", cannot call g_io_channel_write_chars() after - * calling one of the API "read" functions. - * - * Returns: %G_IO_STATUS_NORMAL if the encoding was successfully set - */ - - -/** - * g_io_channel_set_flags: - * @channel: a #GIOChannel - * @flags: the flags to set on the IO channel - * @error: A location to return an error of type #GIOChannelError - * - * Sets the (writeable) flags in @channel to (@flags & %G_IO_FLAG_SET_MASK). - * - * Returns: the status of the operation. - */ - - -/** - * g_io_channel_set_line_term: - * @channel: a #GIOChannel - * @line_term: (nullable): The line termination string. Use %NULL for - * autodetect. Autodetection breaks on "\n", "\r\n", "\r", "\0", - * and the Unicode paragraph separator. Autodetection should not be - * used for anything other than file-based channels. - * @length: The length of the termination string. If -1 is passed, the - * string is assumed to be nul-terminated. This option allows - * termination strings with embedded nuls. - * - * This sets the string that #GIOChannel uses to determine - * where in the file a line break occurs. - */ - - -/** - * g_io_channel_shutdown: - * @channel: a #GIOChannel - * @flush: if %TRUE, flush pending - * @err: location to store a #GIOChannelError - * - * Close an IO channel. Any pending data to be written will be - * flushed if @flush is %TRUE. The channel will not be freed until the - * last reference is dropped using g_io_channel_unref(). - * - * Returns: the status of the operation. - */ - - -/** - * g_io_channel_unix_get_fd: - * @channel: a #GIOChannel, created with g_io_channel_unix_new(). - * - * Returns the file descriptor of the #GIOChannel. - * - * On Windows this function returns the file descriptor or socket of - * the #GIOChannel. - * - * Returns: the file descriptor of the #GIOChannel. - */ - - -/** - * g_io_channel_unix_new: - * @fd: a file descriptor. - * - * Creates a new #GIOChannel given a file descriptor. On UNIX systems - * this works for plain files, pipes, and sockets. - * - * The returned #GIOChannel has a reference count of 1. - * - * The default encoding for #GIOChannel is UTF-8. If your application - * is reading output from a command using via pipe, you may need to set - * the encoding to the encoding of the current locale (see - * g_get_charset()) with the g_io_channel_set_encoding() function. - * By default, the fd passed will not be closed when the final reference - * to the #GIOChannel data structure is dropped. - * - * If you want to read raw binary data without interpretation, then - * call the g_io_channel_set_encoding() function with %NULL for the - * encoding argument. - * - * This function is available in GLib on Windows, too, but you should - * avoid using it on Windows. The domain of file descriptors and - * sockets overlap. There is no way for GLib to know which one you mean - * in case the argument you pass to this function happens to be both a - * valid file descriptor and socket. If that happens a warning is - * issued, and GLib assumes that it is the file descriptor you mean. - * - * Returns: a new #GIOChannel. - */ - - -/** - * g_io_channel_unref: - * @channel: a #GIOChannel - * - * Decrements the reference count of a #GIOChannel. - */ - - -/** - * g_io_channel_win32_new_fd: - * @fd: a C library file descriptor. - * - * Creates a new #GIOChannel given a file descriptor on Windows. This - * works for file descriptors from the C runtime. - * - * This function works for file descriptors as returned by the open(), - * creat(), pipe() and fileno() calls in the Microsoft C runtime. In - * order to meaningfully use this function your code should use the - * same C runtime as GLib uses, which is msvcrt.dll. Note that in - * current Microsoft compilers it is near impossible to convince it to - * build code that would use msvcrt.dll. The last Microsoft compiler - * version that supported using msvcrt.dll as the C runtime was version 6. - * The GNU compiler and toolchain for Windows, also known as Mingw, - * fully supports msvcrt.dll. - * - * If you have created a #GIOChannel for a file descriptor and started - * watching (polling) it, you shouldn't call read() on the file - * descriptor. This is because adding polling for a file descriptor is - * implemented in GLib on Windows by starting a thread that sits - * blocked in a read() from the file descriptor most of the time. All - * reads from the file descriptor should be done by this internal GLib - * thread. Your code should call only g_io_channel_read(). - * - * This function is available only in GLib on Windows. - * - * Returns: a new #GIOChannel. - */ - - -/** - * g_io_channel_win32_new_messages: - * @hwnd: a window handle. - * - * Creates a new #GIOChannel given a window handle on Windows. - * - * This function creates a #GIOChannel that can be used to poll for - * Windows messages for the window in question. - * - * Returns: a new #GIOChannel. - */ - - -/** - * g_io_channel_win32_new_socket: - * @socket: a Winsock socket - * - * Creates a new #GIOChannel given a socket on Windows. - * - * This function works for sockets created by Winsock. It's available - * only in GLib on Windows. - * - * Polling a #GSource created to watch a channel for a socket puts the - * socket in non-blocking mode. This is a side-effect of the - * implementation and unavoidable. - * - * Returns: a new #GIOChannel - */ - - -/** - * g_io_channel_write: - * @channel: a #GIOChannel - * @buf: the buffer containing the data to write - * @count: the number of bytes to write - * @bytes_written: the number of bytes actually written - * - * Writes data to a #GIOChannel. - * - * Returns: %G_IO_ERROR_NONE if the operation was successful. - * Deprecated: 2.2: Use g_io_channel_write_chars() instead. - */ - - -/** - * g_io_channel_write_chars: - * @channel: a #GIOChannel - * @buf: (array) (element-type guint8): a buffer to write data from - * @count: the size of the buffer. If -1, the buffer - * is taken to be a nul-terminated string. - * @bytes_written: (out): The number of bytes written. This can be nonzero - * even if the return value is not %G_IO_STATUS_NORMAL. - * If the return value is %G_IO_STATUS_NORMAL and the - * channel is blocking, this will always be equal - * to @count if @count >= 0. - * @error: a location to return an error of type #GConvertError - * or #GIOChannelError - * - * Replacement for g_io_channel_write() with the new API. - * - * On seekable channels with encodings other than %NULL or UTF-8, generic - * mixing of reading and writing is not allowed. A call to g_io_channel_write_chars () - * may only be made on a channel from which data has been read in the - * cases described in the documentation for g_io_channel_set_encoding (). - * - * Returns: the status of the operation. - */ - - -/** - * g_io_channel_write_unichar: - * @channel: a #GIOChannel - * @thechar: a character - * @error: location to return an error of type #GConvertError - * or #GIOChannelError - * - * Writes a Unicode character to @channel. - * This function cannot be called on a channel with %NULL encoding. - * - * Returns: a #GIOStatus - */ - - -/** - * g_io_create_watch: - * @channel: a #GIOChannel to watch - * @condition: conditions to watch for - * - * Creates a #GSource that's dispatched when @condition is met for the - * given @channel. For example, if condition is #G_IO_IN, the source will - * be dispatched when there's data available for reading. - * - * The callback function invoked by the #GSource should be added with - * g_source_set_callback(), but it has type #GIOFunc (not #GSourceFunc). - * - * g_io_add_watch() is a simpler interface to this same functionality, for - * the case where you want to add the source to the default main loop context - * at the default priority. - * - * On Windows, polling a #GSource created to watch a channel for a socket - * puts the socket in non-blocking mode. This is a side-effect of the - * implementation and unavoidable. - * - * Returns: a new #GSource - */ - - -/** - * g_key_file_free: (skip) - * @key_file: a #GKeyFile - * - * Clears all keys and groups from @key_file, and decreases the - * reference count by 1. If the reference count reaches zero, - * frees the key file and all its allocated memory. - * - * Since: 2.6 - */ - - -/** - * g_key_file_get_boolean: - * @key_file: a #GKeyFile - * @group_name: a group name - * @key: a key - * @error: return location for a #GError - * - * Returns the value associated with @key under @group_name as a - * boolean. - * - * If @key cannot be found then %FALSE is returned and @error is set - * to #G_KEY_FILE_ERROR_KEY_NOT_FOUND. Likewise, if the value - * associated with @key cannot be interpreted as a boolean then %FALSE - * is returned and @error is set to #G_KEY_FILE_ERROR_INVALID_VALUE. - * - * Returns: the value associated with the key as a boolean, - * or %FALSE if the key was not found or could not be parsed. - * Since: 2.6 - */ - - -/** - * g_key_file_get_boolean_list: - * @key_file: a #GKeyFile - * @group_name: a group name - * @key: a key - * @length: (out): the number of booleans returned - * @error: return location for a #GError - * - * Returns the values associated with @key under @group_name as - * booleans. - * - * If @key cannot be found then %NULL is returned and @error is set to - * #G_KEY_FILE_ERROR_KEY_NOT_FOUND. Likewise, if the values associated - * with @key cannot be interpreted as booleans then %NULL is returned - * and @error is set to #G_KEY_FILE_ERROR_INVALID_VALUE. - * - * Returns: (array length=length) (element-type gboolean) (transfer container): - * the values associated with the key as a list of booleans, or %NULL if the - * key was not found or could not be parsed. The returned list of booleans - * should be freed with g_free() when no longer needed. - * Since: 2.6 - */ - - -/** - * g_key_file_get_comment: - * @key_file: a #GKeyFile - * @group_name: (nullable): a group name, or %NULL - * @key: (nullable): a key - * @error: return location for a #GError - * - * Retrieves a comment above @key from @group_name. - * If @key is %NULL then @comment will be read from above - * @group_name. If both @key and @group_name are %NULL, then - * @comment will be read from above the first group in the file. - * - * Note that the returned string does not include the '#' comment markers, - * but does include any whitespace after them (on each line). It includes - * the line breaks between lines, but does not include the final line break. - * - * Returns: a comment that should be freed with g_free() - * Since: 2.6 - */ - - -/** - * g_key_file_get_double: - * @key_file: a #GKeyFile - * @group_name: a group name - * @key: a key - * @error: return location for a #GError - * - * Returns the value associated with @key under @group_name as a - * double. If @group_name is %NULL, the start_group is used. - * - * If @key cannot be found then 0.0 is returned and @error is set to - * #G_KEY_FILE_ERROR_KEY_NOT_FOUND. Likewise, if the value associated - * with @key cannot be interpreted as a double then 0.0 is returned - * and @error is set to #G_KEY_FILE_ERROR_INVALID_VALUE. - * - * Returns: the value associated with the key as a double, or - * 0.0 if the key was not found or could not be parsed. - * Since: 2.12 - */ - - -/** - * g_key_file_get_double_list: - * @key_file: a #GKeyFile - * @group_name: a group name - * @key: a key - * @length: (out): the number of doubles returned - * @error: return location for a #GError - * - * Returns the values associated with @key under @group_name as - * doubles. - * - * If @key cannot be found then %NULL is returned and @error is set to - * #G_KEY_FILE_ERROR_KEY_NOT_FOUND. Likewise, if the values associated - * with @key cannot be interpreted as doubles then %NULL is returned - * and @error is set to #G_KEY_FILE_ERROR_INVALID_VALUE. - * - * Returns: (array length=length) (element-type gdouble) (transfer container): - * the values associated with the key as a list of doubles, or %NULL if the - * key was not found or could not be parsed. The returned list of doubles - * should be freed with g_free() when no longer needed. - * Since: 2.12 - */ - - -/** - * g_key_file_get_groups: - * @key_file: a #GKeyFile - * @length: (out) (optional): return location for the number of returned groups, or %NULL - * - * Returns all groups in the key file loaded with @key_file. - * The array of returned groups will be %NULL-terminated, so - * @length may optionally be %NULL. - * - * Returns: (array zero-terminated=1) (transfer full): a newly-allocated %NULL-terminated array of strings. - * Use g_strfreev() to free it. - * Since: 2.6 - */ - - -/** - * g_key_file_get_int64: - * @key_file: a non-%NULL #GKeyFile - * @group_name: a non-%NULL group name - * @key: a non-%NULL key - * @error: return location for a #GError - * - * Returns the value associated with @key under @group_name as a signed - * 64-bit integer. This is similar to g_key_file_get_integer() but can return - * 64-bit results without truncation. - * - * Returns: the value associated with the key as a signed 64-bit integer, or - * 0 if the key was not found or could not be parsed. - * Since: 2.26 - */ - - -/** - * g_key_file_get_integer: - * @key_file: a #GKeyFile - * @group_name: a group name - * @key: a key - * @error: return location for a #GError - * - * Returns the value associated with @key under @group_name as an - * integer. - * - * If @key cannot be found then 0 is returned and @error is set to - * #G_KEY_FILE_ERROR_KEY_NOT_FOUND. Likewise, if the value associated - * with @key cannot be interpreted as an integer, or is out of range - * for a #gint, then 0 is returned - * and @error is set to #G_KEY_FILE_ERROR_INVALID_VALUE. - * - * Returns: the value associated with the key as an integer, or - * 0 if the key was not found or could not be parsed. - * Since: 2.6 - */ - - -/** - * g_key_file_get_integer_list: - * @key_file: a #GKeyFile - * @group_name: a group name - * @key: a key - * @length: (out): the number of integers returned - * @error: return location for a #GError - * - * Returns the values associated with @key under @group_name as - * integers. - * - * If @key cannot be found then %NULL is returned and @error is set to - * #G_KEY_FILE_ERROR_KEY_NOT_FOUND. Likewise, if the values associated - * with @key cannot be interpreted as integers, or are out of range for - * #gint, then %NULL is returned - * and @error is set to #G_KEY_FILE_ERROR_INVALID_VALUE. - * - * Returns: (array length=length) (element-type gint) (transfer container): - * the values associated with the key as a list of integers, or %NULL if - * the key was not found or could not be parsed. The returned list of - * integers should be freed with g_free() when no longer needed. - * Since: 2.6 - */ - - -/** - * g_key_file_get_keys: - * @key_file: a #GKeyFile - * @group_name: a group name - * @length: (out) (optional): return location for the number of keys returned, or %NULL - * @error: return location for a #GError, or %NULL - * - * Returns all keys for the group name @group_name. The array of - * returned keys will be %NULL-terminated, so @length may - * optionally be %NULL. In the event that the @group_name cannot - * be found, %NULL is returned and @error is set to - * #G_KEY_FILE_ERROR_GROUP_NOT_FOUND. - * - * Returns: (array zero-terminated=1) (transfer full): a newly-allocated %NULL-terminated array of strings. - * Use g_strfreev() to free it. - * Since: 2.6 - */ - - -/** - * g_key_file_get_locale_for_key: - * @key_file: a #GKeyFile - * @group_name: a group name - * @key: a key - * @locale: (nullable): a locale identifier or %NULL - * - * Returns the actual locale which the result of - * g_key_file_get_locale_string() or g_key_file_get_locale_string_list() - * came from. - * - * If calling g_key_file_get_locale_string() or - * g_key_file_get_locale_string_list() with exactly the same @key_file, - * @group_name, @key and @locale, the result of those functions will - * have originally been tagged with the locale that is the result of - * this function. - * - * Returns: (nullable): the locale from the file, or %NULL if the key was not - * found or the entry in the file was was untranslated - * Since: 2.56 - */ - - -/** - * g_key_file_get_locale_string: - * @key_file: a #GKeyFile - * @group_name: a group name - * @key: a key - * @locale: (nullable): a locale identifier or %NULL - * @error: return location for a #GError, or %NULL - * - * Returns the value associated with @key under @group_name - * translated in the given @locale if available. If @locale is - * %NULL then the current locale is assumed. - * - * If @locale is to be non-%NULL, or if the current locale will change over - * the lifetime of the #GKeyFile, it must be loaded with - * %G_KEY_FILE_KEEP_TRANSLATIONS in order to load strings for all locales. - * - * If @key cannot be found then %NULL is returned and @error is set - * to #G_KEY_FILE_ERROR_KEY_NOT_FOUND. If the value associated - * with @key cannot be interpreted or no suitable translation can - * be found then the untranslated value is returned. - * - * Returns: a newly allocated string or %NULL if the specified - * key cannot be found. - * Since: 2.6 - */ - - -/** - * g_key_file_get_locale_string_list: - * @key_file: a #GKeyFile - * @group_name: a group name - * @key: a key - * @locale: (nullable): a locale identifier or %NULL - * @length: (out) (optional): return location for the number of returned strings or %NULL - * @error: return location for a #GError or %NULL - * - * Returns the values associated with @key under @group_name - * translated in the given @locale if available. If @locale is - * %NULL then the current locale is assumed. - * - * If @locale is to be non-%NULL, or if the current locale will change over - * the lifetime of the #GKeyFile, it must be loaded with - * %G_KEY_FILE_KEEP_TRANSLATIONS in order to load strings for all locales. - * - * If @key cannot be found then %NULL is returned and @error is set - * to #G_KEY_FILE_ERROR_KEY_NOT_FOUND. If the values associated - * with @key cannot be interpreted or no suitable translations - * can be found then the untranslated values are returned. The - * returned array is %NULL-terminated, so @length may optionally - * be %NULL. - * - * Returns: (array zero-terminated=1 length=length) (element-type utf8) (transfer full): a newly allocated %NULL-terminated string array - * or %NULL if the key isn't found. The string array should be freed - * with g_strfreev(). - * Since: 2.6 - */ - - -/** - * g_key_file_get_start_group: - * @key_file: a #GKeyFile - * - * Returns the name of the start group of the file. - * - * Returns: (nullable): The start group of the key file. - * Since: 2.6 - */ - - -/** - * g_key_file_get_string: - * @key_file: a #GKeyFile - * @group_name: a group name - * @key: a key - * @error: return location for a #GError, or %NULL - * - * Returns the string value associated with @key under @group_name. - * Unlike g_key_file_get_value(), this function handles escape sequences - * like \s. - * - * In the event the key cannot be found, %NULL is returned and - * @error is set to #G_KEY_FILE_ERROR_KEY_NOT_FOUND. In the - * event that the @group_name cannot be found, %NULL is returned - * and @error is set to #G_KEY_FILE_ERROR_GROUP_NOT_FOUND. - * - * Returns: a newly allocated string or %NULL if the specified - * key cannot be found. - * Since: 2.6 - */ - - -/** - * g_key_file_get_string_list: - * @key_file: a #GKeyFile - * @group_name: a group name - * @key: a key - * @length: (out) (optional): return location for the number of returned strings, or %NULL - * @error: return location for a #GError, or %NULL - * - * Returns the values associated with @key under @group_name. - * - * In the event the key cannot be found, %NULL is returned and - * @error is set to #G_KEY_FILE_ERROR_KEY_NOT_FOUND. In the - * event that the @group_name cannot be found, %NULL is returned - * and @error is set to #G_KEY_FILE_ERROR_GROUP_NOT_FOUND. - * - * Returns: (array zero-terminated=1 length=length) (element-type utf8) (transfer full): - * a %NULL-terminated string array or %NULL if the specified - * key cannot be found. The array should be freed with g_strfreev(). - * Since: 2.6 - */ - - -/** - * g_key_file_get_uint64: - * @key_file: a non-%NULL #GKeyFile - * @group_name: a non-%NULL group name - * @key: a non-%NULL key - * @error: return location for a #GError - * - * Returns the value associated with @key under @group_name as an unsigned - * 64-bit integer. This is similar to g_key_file_get_integer() but can return - * large positive results without truncation. - * - * Returns: the value associated with the key as an unsigned 64-bit integer, - * or 0 if the key was not found or could not be parsed. - * Since: 2.26 - */ - - -/** - * g_key_file_get_value: - * @key_file: a #GKeyFile - * @group_name: a group name - * @key: a key - * @error: return location for a #GError, or %NULL - * - * Returns the raw value associated with @key under @group_name. - * Use g_key_file_get_string() to retrieve an unescaped UTF-8 string. - * - * In the event the key cannot be found, %NULL is returned and - * @error is set to #G_KEY_FILE_ERROR_KEY_NOT_FOUND. In the - * event that the @group_name cannot be found, %NULL is returned - * and @error is set to #G_KEY_FILE_ERROR_GROUP_NOT_FOUND. - * - * Returns: a newly allocated string or %NULL if the specified - * key cannot be found. - * Since: 2.6 - */ - - -/** - * g_key_file_has_group: - * @key_file: a #GKeyFile - * @group_name: a group name - * - * Looks whether the key file has the group @group_name. - * - * Returns: %TRUE if @group_name is a part of @key_file, %FALSE - * otherwise. - * Since: 2.6 - */ - - -/** - * g_key_file_has_key: (skip) - * @key_file: a #GKeyFile - * @group_name: a group name - * @key: a key name - * @error: return location for a #GError - * - * Looks whether the key file has the key @key in the group - * @group_name. - * - * Note that this function does not follow the rules for #GError strictly; - * the return value both carries meaning and signals an error. To use - * this function, you must pass a #GError pointer in @error, and check - * whether it is not %NULL to see if an error occurred. - * - * Language bindings should use g_key_file_get_value() to test whether - * or not a key exists. - * - * Returns: %TRUE if @key is a part of @group_name, %FALSE otherwise - * Since: 2.6 - */ - - -/** - * g_key_file_load_from_bytes: - * @key_file: an empty #GKeyFile struct - * @bytes: a #GBytes - * @flags: flags from #GKeyFileFlags - * @error: return location for a #GError, or %NULL - * - * Loads a key file from the data in @bytes into an empty #GKeyFile structure. - * If the object cannot be created then %error is set to a #GKeyFileError. - * - * Returns: %TRUE if a key file could be loaded, %FALSE otherwise - * Since: 2.50 - */ - - -/** - * g_key_file_load_from_data: - * @key_file: an empty #GKeyFile struct - * @data: key file loaded in memory - * @length: the length of @data in bytes (or (gsize)-1 if data is nul-terminated) - * @flags: flags from #GKeyFileFlags - * @error: return location for a #GError, or %NULL - * - * Loads a key file from memory into an empty #GKeyFile structure. - * If the object cannot be created then %error is set to a #GKeyFileError. - * - * Returns: %TRUE if a key file could be loaded, %FALSE otherwise - * Since: 2.6 - */ - - -/** - * g_key_file_load_from_data_dirs: - * @key_file: an empty #GKeyFile struct - * @file: (type filename): a relative path to a filename to open and parse - * @full_path: (out) (type filename) (optional): return location for a string containing the full path - * of the file, or %NULL - * @flags: flags from #GKeyFileFlags - * @error: return location for a #GError, or %NULL - * - * This function looks for a key file named @file in the paths - * returned from g_get_user_data_dir() and g_get_system_data_dirs(), - * loads the file into @key_file and returns the file's full path in - * @full_path. If the file could not be loaded then an %error is - * set to either a #GFileError or #GKeyFileError. - * - * Returns: %TRUE if a key file could be loaded, %FALSE otherwise - * Since: 2.6 - */ - - -/** - * g_key_file_load_from_dirs: - * @key_file: an empty #GKeyFile struct - * @file: (type filename): a relative path to a filename to open and parse - * @search_dirs: (array zero-terminated=1) (element-type filename): %NULL-terminated array of directories to search - * @full_path: (out) (type filename) (optional): return location for a string containing the full path - * of the file, or %NULL - * @flags: flags from #GKeyFileFlags - * @error: return location for a #GError, or %NULL - * - * This function looks for a key file named @file in the paths - * specified in @search_dirs, loads the file into @key_file and - * returns the file's full path in @full_path. - * - * If the file could not be found in any of the @search_dirs, - * %G_KEY_FILE_ERROR_NOT_FOUND is returned. If - * the file is found but the OS returns an error when opening or reading the - * file, a %G_FILE_ERROR is returned. If there is a problem parsing the file, a - * %G_KEY_FILE_ERROR is returned. - * - * Returns: %TRUE if a key file could be loaded, %FALSE otherwise - * Since: 2.14 - */ - - -/** - * g_key_file_load_from_file: - * @key_file: an empty #GKeyFile struct - * @file: (type filename): the path of a filename to load, in the GLib filename encoding - * @flags: flags from #GKeyFileFlags - * @error: return location for a #GError, or %NULL - * - * Loads a key file into an empty #GKeyFile structure. - * - * If the OS returns an error when opening or reading the file, a - * %G_FILE_ERROR is returned. If there is a problem parsing the file, a - * %G_KEY_FILE_ERROR is returned. - * - * This function will never return a %G_KEY_FILE_ERROR_NOT_FOUND error. If the - * @file is not found, %G_FILE_ERROR_NOENT is returned. - * - * Returns: %TRUE if a key file could be loaded, %FALSE otherwise - * Since: 2.6 - */ - - -/** - * g_key_file_new: - * - * Creates a new empty #GKeyFile object. Use - * g_key_file_load_from_file(), g_key_file_load_from_data(), - * g_key_file_load_from_dirs() or g_key_file_load_from_data_dirs() to - * read an existing key file. - * - * Returns: (transfer full): an empty #GKeyFile. - * Since: 2.6 - */ - - -/** - * g_key_file_ref: (skip) - * @key_file: a #GKeyFile - * - * Increases the reference count of @key_file. - * - * Returns: the same @key_file. - * Since: 2.32 - */ - - -/** - * g_key_file_remove_comment: - * @key_file: a #GKeyFile - * @group_name: (nullable): a group name, or %NULL - * @key: (nullable): a key - * @error: return location for a #GError - * - * Removes a comment above @key from @group_name. - * If @key is %NULL then @comment will be removed above @group_name. - * If both @key and @group_name are %NULL, then @comment will - * be removed above the first group in the file. - * - * Returns: %TRUE if the comment was removed, %FALSE otherwise - * Since: 2.6 - */ - - -/** - * g_key_file_remove_group: - * @key_file: a #GKeyFile - * @group_name: a group name - * @error: return location for a #GError or %NULL - * - * Removes the specified group, @group_name, - * from the key file. - * - * Returns: %TRUE if the group was removed, %FALSE otherwise - * Since: 2.6 - */ - - -/** - * g_key_file_remove_key: - * @key_file: a #GKeyFile - * @group_name: a group name - * @key: a key name to remove - * @error: return location for a #GError or %NULL - * - * Removes @key in @group_name from the key file. - * - * Returns: %TRUE if the key was removed, %FALSE otherwise - * Since: 2.6 - */ - - -/** - * g_key_file_save_to_file: - * @key_file: a #GKeyFile - * @filename: the name of the file to write to - * @error: a pointer to a %NULL #GError, or %NULL - * - * Writes the contents of @key_file to @filename using - * g_file_set_contents(). If you need stricter guarantees about durability of - * the written file than are provided by g_file_set_contents(), use - * g_file_set_contents_full() with the return value of g_key_file_to_data(). - * - * This function can fail for any of the reasons that - * g_file_set_contents() may fail. - * - * Returns: %TRUE if successful, else %FALSE with @error set - * Since: 2.40 - */ - - -/** - * g_key_file_set_boolean: - * @key_file: a #GKeyFile - * @group_name: a group name - * @key: a key - * @value: %TRUE or %FALSE - * - * Associates a new boolean value with @key under @group_name. - * If @key cannot be found then it is created. - * - * Since: 2.6 - */ - - -/** - * g_key_file_set_boolean_list: - * @key_file: a #GKeyFile - * @group_name: a group name - * @key: a key - * @list: (array length=length): an array of boolean values - * @length: length of @list - * - * Associates a list of boolean values with @key under @group_name. - * If @key cannot be found then it is created. - * If @group_name is %NULL, the start_group is used. - * - * Since: 2.6 - */ - - -/** - * g_key_file_set_comment: - * @key_file: a #GKeyFile - * @group_name: (nullable): a group name, or %NULL - * @key: (nullable): a key - * @comment: a comment - * @error: return location for a #GError - * - * Places a comment above @key from @group_name. - * - * If @key is %NULL then @comment will be written above @group_name. - * If both @key and @group_name are %NULL, then @comment will be - * written above the first group in the file. - * - * Note that this function prepends a '#' comment marker to - * each line of @comment. - * - * Returns: %TRUE if the comment was written, %FALSE otherwise - * Since: 2.6 - */ - - -/** - * g_key_file_set_double: - * @key_file: a #GKeyFile - * @group_name: a group name - * @key: a key - * @value: a double value - * - * Associates a new double value with @key under @group_name. - * If @key cannot be found then it is created. - * - * Since: 2.12 - */ - - -/** - * g_key_file_set_double_list: - * @key_file: a #GKeyFile - * @group_name: a group name - * @key: a key - * @list: (array length=length): an array of double values - * @length: number of double values in @list - * - * Associates a list of double values with @key under - * @group_name. If @key cannot be found then it is created. - * - * Since: 2.12 - */ - - -/** - * g_key_file_set_int64: - * @key_file: a #GKeyFile - * @group_name: a group name - * @key: a key - * @value: an integer value - * - * Associates a new integer value with @key under @group_name. - * If @key cannot be found then it is created. - * - * Since: 2.26 - */ - - -/** - * g_key_file_set_integer: - * @key_file: a #GKeyFile - * @group_name: a group name - * @key: a key - * @value: an integer value - * - * Associates a new integer value with @key under @group_name. - * If @key cannot be found then it is created. - * - * Since: 2.6 - */ - - -/** - * g_key_file_set_integer_list: - * @key_file: a #GKeyFile - * @group_name: a group name - * @key: a key - * @list: (array length=length): an array of integer values - * @length: number of integer values in @list - * - * Associates a list of integer values with @key under @group_name. - * If @key cannot be found then it is created. - * - * Since: 2.6 - */ - - -/** - * g_key_file_set_list_separator: - * @key_file: a #GKeyFile - * @separator: the separator - * - * Sets the character which is used to separate - * values in lists. Typically ';' or ',' are used - * as separators. The default list separator is ';'. - * - * Since: 2.6 - */ - - -/** - * g_key_file_set_locale_string: - * @key_file: a #GKeyFile - * @group_name: a group name - * @key: a key - * @locale: a locale identifier - * @string: a string - * - * Associates a string value for @key and @locale under @group_name. - * If the translation for @key cannot be found then it is created. - * - * Since: 2.6 - */ - - -/** - * g_key_file_set_locale_string_list: - * @key_file: a #GKeyFile - * @group_name: a group name - * @key: a key - * @locale: a locale identifier - * @list: (array zero-terminated=1 length=length): a %NULL-terminated array of locale string values - * @length: the length of @list - * - * Associates a list of string values for @key and @locale under - * @group_name. If the translation for @key cannot be found then - * it is created. - * - * Since: 2.6 - */ - - -/** - * g_key_file_set_string: - * @key_file: a #GKeyFile - * @group_name: a group name - * @key: a key - * @string: a string - * - * Associates a new string value with @key under @group_name. - * If @key cannot be found then it is created. - * If @group_name cannot be found then it is created. - * Unlike g_key_file_set_value(), this function handles characters - * that need escaping, such as newlines. - * - * Since: 2.6 - */ - - -/** - * g_key_file_set_string_list: - * @key_file: a #GKeyFile - * @group_name: a group name - * @key: a key - * @list: (array zero-terminated=1 length=length) (element-type utf8): an array of string values - * @length: number of string values in @list - * - * Associates a list of string values for @key under @group_name. - * If @key cannot be found then it is created. - * If @group_name cannot be found then it is created. - * - * Since: 2.6 - */ - - -/** - * g_key_file_set_uint64: - * @key_file: a #GKeyFile - * @group_name: a group name - * @key: a key - * @value: an integer value - * - * Associates a new integer value with @key under @group_name. - * If @key cannot be found then it is created. - * - * Since: 2.26 - */ - - -/** - * g_key_file_set_value: - * @key_file: a #GKeyFile - * @group_name: a group name - * @key: a key - * @value: a string - * - * Associates a new value with @key under @group_name. - * - * If @key cannot be found then it is created. If @group_name cannot - * be found then it is created. To set an UTF-8 string which may contain - * characters that need escaping (such as newlines or spaces), use - * g_key_file_set_string(). - * - * Since: 2.6 - */ - - -/** - * g_key_file_to_data: - * @key_file: a #GKeyFile - * @length: (out) (optional): return location for the length of the - * returned string, or %NULL - * @error: return location for a #GError, or %NULL - * - * This function outputs @key_file as a string. - * - * Note that this function never reports an error, - * so it is safe to pass %NULL as @error. - * - * Returns: a newly allocated string holding - * the contents of the #GKeyFile - * Since: 2.6 - */ - - -/** - * g_key_file_unref: - * @key_file: a #GKeyFile - * - * Decreases the reference count of @key_file by 1. If the reference count - * reaches zero, frees the key file and all its allocated memory. - * - * Since: 2.32 - */ - - -/** - * g_list_alloc: - * - * Allocates space for one #GList element. It is called by - * g_list_append(), g_list_prepend(), g_list_insert() and - * g_list_insert_sorted() and so is rarely used on its own. - * - * Returns: a pointer to the newly-allocated #GList element - */ - - -/** - * g_list_append: - * @list: a pointer to a #GList - * @data: the data for the new element - * - * Adds a new element on to the end of the list. - * - * Note that the return value is the new start of the list, - * if @list was empty; make sure you store the new value. - * - * g_list_append() has to traverse the entire list to find the end, - * which is inefficient when adding multiple elements. A common idiom - * to avoid the inefficiency is to use g_list_prepend() and reverse - * the list with g_list_reverse() when all elements have been added. - * - * |[<!-- language="C" --> - * // Notice that these are initialized to the empty list. - * GList *string_list = NULL, *number_list = NULL; - * - * // This is a list of strings. - * string_list = g_list_append (string_list, "first"); - * string_list = g_list_append (string_list, "second"); - * - * // 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 (14)); - * ]| - * - * Returns: either @list or the new start of the #GList if @list was %NULL - */ - - -/** - * g_list_concat: - * @list1: a #GList, this must point to the top of the list - * @list2: the #GList to add to the end of the first #GList, - * this must point to the top of the list - * - * Adds the second #GList onto the end of the first #GList. - * Note that the elements of the second #GList are not copied. - * They are used directly. - * - * This function is for example used to move an element in the list. - * The following example moves an element to the top of the list: - * |[<!-- language="C" --> - * list = g_list_remove_link (list, llink); - * list = g_list_concat (llink, list); - * ]| - * - * Returns: the start of the new #GList, which equals @list1 if not %NULL - */ - - -/** - * g_list_copy: - * @list: a #GList, this must point to the top of the list - * - * Copies a #GList. - * - * Note that this is a "shallow" copy. If the list elements - * consist of pointers to data, the pointers are copied but - * the actual data is not. See g_list_copy_deep() if you need - * to copy the data as well. - * - * Returns: the start of the new list that holds the same data as @list - */ - - -/** - * g_list_copy_deep: - * @list: a #GList, this must point to the top of the list - * @func: a copy function used to copy every element in the list - * @user_data: user data passed to the copy function @func, or %NULL - * - * Makes a full (deep) copy of a #GList. - * - * In contrast with g_list_copy(), this function uses @func to make - * a copy of each list element, in addition to copying the list - * container itself. - * - * @func, as a #GCopyFunc, takes two arguments, the data to be copied - * and a @user_data pointer. On common processor architectures, it's safe to - * pass %NULL as @user_data if the copy function takes only one argument. You - * may get compiler warnings from this though if compiling with GCC’s - * `-Wcast-function-type` warning. - * - * For instance, if @list holds a list of GObjects, you can do: - * |[<!-- language="C" --> - * another_list = g_list_copy_deep (list, (GCopyFunc) g_object_ref, NULL); - * ]| - * - * And, to entirely free the new list, you could do: - * |[<!-- language="C" --> - * g_list_free_full (another_list, g_object_unref); - * ]| - * - * Returns: the start of the new list that holds a full copy of @list, - * use g_list_free_full() to free it - * Since: 2.34 - */ - - -/** - * g_list_delete_link: - * @list: a #GList, this must point to the top of the list - * @link_: node to delete from @list - * - * Removes the node link_ from the list and frees it. - * Compare this to g_list_remove_link() which removes the node - * without freeing it. - * - * Returns: the (possibly changed) start of the #GList - */ - - -/** - * g_list_find: - * @list: a #GList, this must point to the top of the list - * @data: the element data to find - * - * Finds the element in a #GList which contains the given data. - * - * Returns: the found #GList element, or %NULL if it is not found - */ - - -/** - * g_list_find_custom: - * @list: a #GList, this must point to the top of the list - * @data: user data passed to the function - * @func: the function to call for each element. - * It should return 0 when the desired element is found - * - * Finds an element in a #GList, using a supplied function to - * find the desired element. It iterates over the list, calling - * the given function which should return 0 when the desired - * element is found. The function takes two #gconstpointer arguments, - * the #GList element's data as the first argument and the - * given user data. - * - * Returns: the found #GList element, or %NULL if it is not found - */ - - -/** - * g_list_first: - * @list: any #GList element - * - * Gets the first element in a #GList. - * - * Returns: the first element in the #GList, - * or %NULL if the #GList has no elements - */ - - -/** - * g_list_foreach: - * @list: a #GList, this must point to the top of the list - * @func: the function to call with each element's data - * @user_data: user data to pass to the function - * - * Calls a function for each element of a #GList. - * - * It is safe for @func to remove the element from @list, but it must - * not modify any part of the list after that element. - */ - - -/** - * g_list_free: - * @list: the first link of a #GList - * - * Frees all of the memory used by a #GList. - * The freed elements are returned to the slice allocator. - * - * If list elements contain dynamically-allocated memory, you should - * either use g_list_free_full() or free them manually first. - * - * It can be combined with g_steal_pointer() to ensure the list head pointer - * is not left dangling: - * |[<!-- language="C" --> - * GList *list_of_borrowed_things = …; /<!-- -->* (transfer container) *<!-- -->/ - * g_list_free (g_steal_pointer (&list_of_borrowed_things)); - * ]| - */ - - -/** - * g_list_free1: - * - * Another name for g_list_free_1(). - */ - - -/** - * g_list_free_1: - * @list: a #GList element - * - * Frees one #GList element, but does not update links from the next and - * previous elements in the list, so you should not call this function on an - * element that is currently part of a list. - * - * It is usually used after g_list_remove_link(). - */ - - -/** - * g_list_free_full: - * @list: the first link of a #GList - * @free_func: the function to be called to free each element's data - * - * Convenience method, which frees all the memory used by a #GList, - * and calls @free_func on every element's data. - * - * @free_func must not modify the list (eg, by removing the freed - * element from it). - * - * It can be combined with g_steal_pointer() to ensure the list head pointer - * is not left dangling — this also has the nice property that the head pointer - * is cleared before any of the list elements are freed, to prevent double frees - * from @free_func: - * |[<!-- language="C" --> - * GList *list_of_owned_things = …; /<!-- -->* (transfer full) (element-type GObject) *<!-- -->/ - * g_list_free_full (g_steal_pointer (&list_of_owned_things), g_object_unref); - * ]| - * - * Since: 2.28 - */ - - -/** - * g_list_index: - * @list: a #GList, this must point to the top of the list - * @data: the data to find - * - * Gets the position of the element containing - * the given data (starting from 0). - * - * Returns: the index of the element containing the data, - * or -1 if the data is not found - */ - - -/** - * g_list_insert: - * @list: a pointer to a #GList, this must point to the top of the list - * @data: the data for the new element - * @position: the position to insert the element. If this is - * negative, or is larger than the number of elements in the - * list, the new element is added on to the end of the list. - * - * Inserts a new element into the list at the given position. - * - * Returns: the (possibly changed) start of the #GList - */ - - -/** - * g_list_insert_before: - * @list: a pointer to a #GList, this must point to the top of the list - * @sibling: the list element before which the new element - * is inserted or %NULL to insert at the end of the list - * @data: the data for the new element - * - * Inserts a new element into the list before the given position. - * - * Returns: the (possibly changed) start of the #GList - */ - - -/** - * g_list_insert_before_link: - * @list: a pointer to a #GList, this must point to the top of the list - * @sibling: (nullable): the list element before which the new element - * is inserted or %NULL to insert at the end of the list - * @link_: the list element to be added, which must not be part of - * any other list - * - * Inserts @link_ into the list before the given position. - * - * Returns: the (possibly changed) start of the #GList - * Since: 2.62 - */ - - -/** - * g_list_insert_sorted: - * @list: a pointer to a #GList, this must point to the top of the - * already sorted list - * @data: the data for the new element - * @func: the function to compare elements in the list. It should - * return a number > 0 if the first parameter comes after the - * second parameter in the sort order. - * - * Inserts a new element into the list, using the given comparison - * function to determine its position. - * - * If you are adding many new elements to a list, and the number of - * new elements is much larger than the length of the list, use - * g_list_prepend() to add the new items and sort the list afterwards - * with g_list_sort(). - * - * Returns: the (possibly changed) start of the #GList - */ - - -/** - * g_list_insert_sorted_with_data: - * @list: a pointer to a #GList, this must point to the top of the - * already sorted list - * @data: the data for the new element - * @func: the function to compare elements in the list. It should - * return a number > 0 if the first parameter comes after the - * second parameter in the sort order. - * @user_data: user data to pass to comparison function - * - * Inserts a new element into the list, using the given comparison - * function to determine its position. - * - * If you are adding many new elements to a list, and the number of - * new elements is much larger than the length of the list, use - * g_list_prepend() to add the new items and sort the list afterwards - * with g_list_sort(). - * - * Returns: the (possibly changed) start of the #GList - * Since: 2.10 - */ - - -/** - * g_list_last: - * @list: any #GList element - * - * Gets the last element in a #GList. - * - * Returns: the last element in the #GList, - * or %NULL if the #GList has no elements - */ - - -/** - * g_list_length: - * @list: a #GList, this must point to the top of the list - * - * Gets the number of elements in a #GList. - * - * This function iterates over the whole list to count its elements. - * Use a #GQueue instead of a GList if you regularly need the number - * of items. To check whether the list is non-empty, it is faster to check - * @list against %NULL. - * - * Returns: the number of elements in the #GList - */ - - -/** - * g_list_next: - * @list: an element in a #GList - * - * A convenience macro to get the next element in a #GList. - * Note that it is considered perfectly acceptable to access - * @list->next directly. - * - * Returns: the next element, or %NULL if there are no more elements - */ - - -/** - * g_list_nth: - * @list: a #GList, this must point to the top of the list - * @n: the position of the element, counting from 0 - * - * Gets the element at the given position in a #GList. - * - * This iterates over the list until it reaches the @n-th position. If you - * intend to iterate over every element, it is better to use a for-loop as - * described in the #GList introduction. - * - * Returns: the element, or %NULL if the position is off - * the end of the #GList - */ - - -/** - * g_list_nth_data: - * @list: a #GList, this must point to the top of the list - * @n: the position of the element - * - * Gets the data of the element at the given position. - * - * This iterates over the list until it reaches the @n-th position. If you - * intend to iterate over every element, it is better to use a for-loop as - * described in the #GList introduction. - * - * Returns: the element's data, or %NULL if the position - * is off the end of the #GList - */ - - -/** - * g_list_nth_prev: - * @list: a #GList - * @n: the position of the element, counting from 0 - * - * Gets the element @n places before @list. - * - * Returns: the element, or %NULL if the position is - * off the end of the #GList - */ - - -/** - * g_list_position: - * @list: a #GList, this must point to the top of the list - * @llink: an element in the #GList - * - * Gets the position of the given element - * in the #GList (starting from 0). - * - * Returns: the position of the element in the #GList, - * or -1 if the element is not found - */ - - -/** - * g_list_prepend: - * @list: a pointer to a #GList, this must point to the top of the list - * @data: the data for the new element - * - * Prepends a new element on to the start of the list. - * - * Note that the return value is the new start of the list, - * which will have changed, so make sure you store the new value. - * - * |[<!-- language="C" --> - * // Notice that it is initialized to the empty list. - * GList *list = NULL; - * - * list = g_list_prepend (list, "last"); - * list = g_list_prepend (list, "first"); - * ]| - * - * Do not use this function to prepend a new element to a different - * element than the start of the list. Use g_list_insert_before() instead. - * - * Returns: a pointer to the newly prepended element, which is the new - * start of the #GList - */ - - -/** - * g_list_previous: - * @list: an element in a #GList - * - * A convenience macro to get the previous element in a #GList. - * Note that it is considered perfectly acceptable to access - * @list->prev directly. - * - * Returns: the previous element, or %NULL if there are no previous - * elements - */ - - -/** - * g_list_remove: - * @list: a #GList, this must point to the top of the list - * @data: the data of the element to remove - * - * Removes an element from a #GList. - * If two elements contain the same data, only the first is removed. - * If none of the elements contain the data, the #GList is unchanged. - * - * Returns: the (possibly changed) start of the #GList - */ - - -/** - * g_list_remove_all: - * @list: a #GList, this must point to the top of the list - * @data: data to remove - * - * Removes all list nodes with data equal to @data. - * Returns the new head of the list. Contrast with - * g_list_remove() which removes only the first node - * matching the given data. - * - * Returns: the (possibly changed) start of the #GList - */ - - -/** - * g_list_remove_link: - * @list: a #GList, this must point to the top of the list - * @llink: an element in the #GList - * - * Removes an element from a #GList, without freeing the element. - * The removed element's prev and next links are set to %NULL, so - * that it becomes a self-contained list with one element. - * - * This function is for example used to move an element in the list - * (see the example for g_list_concat()) or to remove an element in - * the list before freeing its data: - * |[<!-- language="C" --> - * list = g_list_remove_link (list, llink); - * free_some_data_that_may_access_the_list_again (llink->data); - * g_list_free (llink); - * ]| - * - * Returns: the (possibly changed) start of the #GList - */ - - -/** - * g_list_reverse: - * @list: a #GList, this must point to the top of the list - * - * Reverses a #GList. - * It simply switches the next and prev pointers of each element. - * - * Returns: the start of the reversed #GList - */ - - -/** - * g_list_sort: - * @list: a #GList, this must point to the top of the list - * @compare_func: the comparison function used to sort the #GList. - * This function is passed the data from 2 elements of the #GList - * and should return 0 if they are equal, a negative value if the - * first element comes before the second, or a positive value if - * the first element comes after the second. - * - * Sorts a #GList using the given comparison function. The algorithm - * used is a stable sort. - * - * Returns: the (possibly changed) start of the #GList - */ - - -/** - * g_list_sort_with_data: - * @list: a #GList, this must point to the top of the list - * @compare_func: comparison function - * @user_data: user data to pass to comparison function - * - * Like g_list_sort(), but the comparison function accepts - * a user data argument. - * - * Returns: the (possibly changed) start of the #GList - */ - - -/** - * g_listenv: - * - * Gets the names of all variables set in the environment. - * - * Programs that want to be portable to Windows should typically use - * this function and g_getenv() instead of using the environ array - * from the C library directly. On Windows, the strings in the environ - * array are in system codepage encoding, while in most of the typical - * use cases for environment variables in GLib-using programs you want - * the UTF-8 encoding that this function and g_getenv() provide. - * - * Returns: (array zero-terminated=1) (element-type filename) (transfer full): - * a %NULL-terminated list of strings which must be freed with - * g_strfreev(). - * Since: 2.8 - */ - - -/** - * g_locale_from_utf8: - * @utf8string: a UTF-8 encoded string - * @len: the length of the string, or -1 if the string is - * nul-terminated. - * @bytes_read: (out) (optional): location to store the number of bytes in the - * input string that were successfully converted, or %NULL. - * Even if the conversion was successful, this may be - * less than @len if there were partial characters - * at the end of the input. If the error - * %G_CONVERT_ERROR_ILLEGAL_SEQUENCE occurs, the value - * stored will be the byte offset after the last valid - * input sequence. - * @bytes_written: (out) (optional): the number of bytes stored in the output - * buffer (not including the terminating nul). - * @error: location to store the error occurring, or %NULL to ignore - * errors. Any of the errors in #GConvertError may occur. - * - * Converts a string from UTF-8 to the encoding used for strings by - * the C runtime (usually the same as that used by the operating - * system) in the [current locale][setlocale]. On Windows this means - * the system codepage. - * - * The input string shall not contain nul characters even if the @len - * argument is positive. A nul character found inside the string will result - * in error %G_CONVERT_ERROR_ILLEGAL_SEQUENCE. Use g_convert() to convert - * input that may contain embedded nul characters. - * - * Returns: (array length=bytes_written) (element-type guint8) (transfer full): - * A newly-allocated buffer containing the converted string, - * or %NULL on an error, and error will be set. - */ - - -/** - * g_locale_to_utf8: - * @opsysstring: (array length=len) (element-type guint8): a string in the - * encoding of the current locale. On Windows - * this means the system codepage. - * @len: the length of the string, or -1 if the string is - * nul-terminated (Note that some encodings may allow nul - * bytes to occur inside strings. In that case, using -1 - * for the @len parameter is unsafe) - * @bytes_read: (out) (optional): location to store the number of bytes in the - * input string that were successfully converted, or %NULL. - * Even if the conversion was successful, this may be - * less than @len if there were partial characters - * at the end of the input. If the error - * %G_CONVERT_ERROR_ILLEGAL_SEQUENCE occurs, the value - * stored will be the byte offset after the last valid - * input sequence. - * @bytes_written: (out) (optional): the number of bytes stored in the output - * buffer (not including the terminating nul). - * @error: location to store the error occurring, or %NULL to ignore - * errors. Any of the errors in #GConvertError may occur. - * - * Converts a string which is in the encoding used for strings by - * the C runtime (usually the same as that used by the operating - * system) in the [current locale][setlocale] into a UTF-8 string. - * - * If the source encoding is not UTF-8 and the conversion output contains a - * nul character, the error %G_CONVERT_ERROR_EMBEDDED_NUL is set and the - * function returns %NULL. - * If the source encoding is UTF-8, an embedded nul character is treated with - * the %G_CONVERT_ERROR_ILLEGAL_SEQUENCE error for backward compatibility with - * earlier versions of this library. Use g_convert() to produce output that - * may contain embedded nul characters. - * - * Returns: (type utf8): The converted string, or %NULL on an error. - */ - - -/** - * g_log: - * @log_domain: (nullable): the log domain, usually %G_LOG_DOMAIN, or %NULL - * for the default - * @log_level: the log level, either from #GLogLevelFlags - * or a user-defined level - * @format: the message format. See the `printf()` documentation - * @...: the parameters to insert into the format string - * - * Logs an error or debugging message. - * - * If the log level has been set as fatal, G_BREAKPOINT() is called - * to terminate the program. See the documentation for G_BREAKPOINT() for - * details of the debugging options this provides. - * - * If g_log_default_handler() is used as the log handler function, a new-line - * character will automatically be appended to @..., and need not be entered - * manually. - * - * If [structured logging is enabled][using-structured-logging] this will - * output via the structured log writer function (see g_log_set_writer_func()). - */ - - -/** - * g_log_default_handler: - * @log_domain: (nullable): the log domain of the message, or %NULL for the - * default "" application domain - * @log_level: the level of the message - * @message: (nullable): the message - * @unused_data: (nullable): data passed from g_log() which is unused - * - * The default log handler set up by GLib; g_log_set_default_handler() - * allows to install an alternate default log handler. - * This is used if no log handler has been set for the particular log - * domain and log level combination. It outputs the message to stderr - * or stdout and if the log level is fatal it calls G_BREAKPOINT(). It automatically - * prints a new-line character after the message, so one does not need to be - * manually included in @message. - * - * The behavior of this log handler can be influenced by a number of - * environment variables: - * - * - `G_MESSAGES_PREFIXED`: A :-separated list of log levels for which - * messages should be prefixed by the program name and PID of the - * application. - * - * - `G_MESSAGES_DEBUG`: A space-separated list of log domains for - * which debug and informational messages are printed. By default - * these messages are not printed. - * - * stderr is used for levels %G_LOG_LEVEL_ERROR, %G_LOG_LEVEL_CRITICAL, - * %G_LOG_LEVEL_WARNING and %G_LOG_LEVEL_MESSAGE. stdout is used for - * the rest, unless stderr was requested by - * g_log_writer_default_set_use_stderr(). - * - * This has no effect if structured logging is enabled; see - * [Using Structured Logging][using-structured-logging]. - */ - - -/** - * g_log_remove_handler: - * @log_domain: the log domain - * @handler_id: the id of the handler, which was returned - * in g_log_set_handler() - * - * Removes the log handler. - * - * This has no effect if structured logging is enabled; see - * [Using Structured Logging][using-structured-logging]. - */ - - -/** - * g_log_set_always_fatal: - * @fatal_mask: the mask containing bits set for each level - * of error which is to be fatal - * - * Sets the message levels which are always fatal, in any log domain. - * When a message with any of these levels is logged the program terminates. - * You can only set the levels defined by GLib to be fatal. - * %G_LOG_LEVEL_ERROR is always fatal. - * - * You can also make some message levels fatal at runtime by setting - * the `G_DEBUG` environment variable (see - * [Running GLib Applications](glib-running.html)). - * - * Libraries should not call this function, as it affects all messages logged - * by a process, including those from other libraries. - * - * Structured log messages (using g_log_structured() and - * g_log_structured_array()) are fatal only if the default log writer is used; - * otherwise it is up to the writer function to determine which log messages - * are fatal. See [Using Structured Logging][using-structured-logging]. - * - * Returns: the old fatal mask - */ - - -/** - * g_log_set_default_handler: - * @log_func: the log handler function - * @user_data: data passed to the log handler - * - * Installs a default log handler which is used if no - * log handler has been set for the particular log domain - * and log level combination. By default, GLib uses - * g_log_default_handler() as default log handler. - * - * This has no effect if structured logging is enabled; see - * [Using Structured Logging][using-structured-logging]. - * - * Returns: the previous default log handler - * Since: 2.6 - */ - - -/** - * g_log_set_fatal_mask: - * @log_domain: the log domain - * @fatal_mask: the new fatal mask - * - * Sets the log levels which are fatal in the given domain. - * %G_LOG_LEVEL_ERROR is always fatal. - * - * This has no effect on structured log messages (using g_log_structured() or - * g_log_structured_array()). To change the fatal behaviour for specific log - * messages, programs must install a custom log writer function using - * g_log_set_writer_func(). See - * [Using Structured Logging][using-structured-logging]. - * - * This function is mostly intended to be used with - * %G_LOG_LEVEL_CRITICAL. You should typically not set - * %G_LOG_LEVEL_WARNING, %G_LOG_LEVEL_MESSAGE, %G_LOG_LEVEL_INFO or - * %G_LOG_LEVEL_DEBUG as fatal except inside of test programs. - * - * Returns: the old fatal mask for the log domain - */ - - -/** - * g_log_set_handler: - * @log_domain: (nullable): the log domain, or %NULL for the default "" - * application domain - * @log_levels: the log levels to apply the log handler for. - * To handle fatal and recursive messages as well, combine - * the log levels with the %G_LOG_FLAG_FATAL and - * %G_LOG_FLAG_RECURSION bit flags. - * @log_func: the log handler function - * @user_data: data passed to the log handler - * - * Sets the log handler for a domain and a set of log levels. - * - * To handle fatal and recursive messages the @log_levels parameter - * must be combined with the %G_LOG_FLAG_FATAL and %G_LOG_FLAG_RECURSION - * bit flags. - * - * Note that since the %G_LOG_LEVEL_ERROR log level is always fatal, if - * you want to set a handler for this log level you must combine it with - * %G_LOG_FLAG_FATAL. - * - * This has no effect if structured logging is enabled; see - * [Using Structured Logging][using-structured-logging]. - * - * Here is an example for adding a log handler for all warning messages - * in the default domain: - * - * |[<!-- language="C" --> - * g_log_set_handler (NULL, G_LOG_LEVEL_WARNING | G_LOG_FLAG_FATAL - * | G_LOG_FLAG_RECURSION, my_log_handler, NULL); - * ]| - * - * This example adds a log handler for all critical messages from GTK+: - * - * |[<!-- language="C" --> - * g_log_set_handler ("Gtk", G_LOG_LEVEL_CRITICAL | G_LOG_FLAG_FATAL - * | G_LOG_FLAG_RECURSION, my_log_handler, NULL); - * ]| - * - * This example adds a log handler for all messages from GLib: - * - * |[<!-- language="C" --> - * g_log_set_handler ("GLib", G_LOG_LEVEL_MASK | G_LOG_FLAG_FATAL - * | G_LOG_FLAG_RECURSION, my_log_handler, NULL); - * ]| - * - * Returns: the id of the new handler - */ - - -/** - * g_log_set_handler_full: (rename-to g_log_set_handler) - * @log_domain: (nullable): the log domain, or %NULL for the default "" - * application domain - * @log_levels: the log levels to apply the log handler for. - * To handle fatal and recursive messages as well, combine - * the log levels with the %G_LOG_FLAG_FATAL and - * %G_LOG_FLAG_RECURSION bit flags. - * @log_func: the log handler function - * @user_data: data passed to the log handler - * @destroy: destroy notify for @user_data, or %NULL - * - * Like g_log_set_handler(), but takes a destroy notify for the @user_data. - * - * This has no effect if structured logging is enabled; see - * [Using Structured Logging][using-structured-logging]. - * - * Returns: the id of the new handler - * Since: 2.46 - */ - - -/** - * g_log_set_writer_func: - * @func: log writer function, which must not be %NULL - * @user_data: (closure func): user data to pass to @func - * @user_data_free: (destroy func): function to free @user_data once it’s - * finished with, if non-%NULL - * - * Set a writer function which will be called to format and write out each log - * message. Each program should set a writer function, or the default writer - * (g_log_writer_default()) will be used. - * - * Libraries **must not** call this function — only programs are allowed to - * install a writer function, as there must be a single, central point where - * log messages are formatted and outputted. - * - * There can only be one writer function. It is an error to set more than one. - * - * Since: 2.50 - */ - - -/** - * g_log_structured: - * @log_domain: log domain, usually %G_LOG_DOMAIN - * @log_level: log level, either from #GLogLevelFlags, or a user-defined - * level - * @...: key-value pairs of structured data to add to the log entry, followed - * by the key "MESSAGE", followed by a printf()-style message format, - * followed by parameters to insert in the format string - * - * Log a message with structured data. - * - * The message will be passed through to the log writer set by the application - * using g_log_set_writer_func(). If the message is fatal (i.e. its log level - * is %G_LOG_LEVEL_ERROR), the program will be aborted by calling - * G_BREAKPOINT() at the end of this function. If the log writer returns - * %G_LOG_WRITER_UNHANDLED (failure), no other fallback writers will be tried. - * See the documentation for #GLogWriterFunc for information on chaining - * writers. - * - * The structured data is provided as key–value pairs, where keys are UTF-8 - * strings, and values are arbitrary pointers — typically pointing to UTF-8 - * strings, but that is not a requirement. To pass binary (non-nul-terminated) - * structured data, use g_log_structured_array(). The keys for structured data - * should follow the [systemd journal - * fields](https://www.freedesktop.org/software/systemd/man/systemd.journal-fields.html) - * specification. It is suggested that custom keys are namespaced according to - * the code which sets them. For example, custom keys from GLib all have a - * `GLIB_` prefix. - * - * The @log_domain will be converted into a `GLIB_DOMAIN` field. @log_level will - * be converted into a - * [`PRIORITY`](https://www.freedesktop.org/software/systemd/man/systemd.journal-fields.html#PRIORITY=) - * field. The format string will have its placeholders substituted for the provided - * values and be converted into a - * [`MESSAGE`](https://www.freedesktop.org/software/systemd/man/systemd.journal-fields.html#MESSAGE=) - * field. - * - * Other fields you may commonly want to pass into this function: - * - * * [`MESSAGE_ID`](https://www.freedesktop.org/software/systemd/man/systemd.journal-fields.html#MESSAGE_ID=) - * * [`CODE_FILE`](https://www.freedesktop.org/software/systemd/man/systemd.journal-fields.html#CODE_FILE=) - * * [`CODE_LINE`](https://www.freedesktop.org/software/systemd/man/systemd.journal-fields.html#CODE_LINE=) - * * [`CODE_FUNC`](https://www.freedesktop.org/software/systemd/man/systemd.journal-fields.html#CODE_FUNC=) - * * [`ERRNO`](https://www.freedesktop.org/software/systemd/man/systemd.journal-fields.html#ERRNO=) - * - * Note that `CODE_FILE`, `CODE_LINE` and `CODE_FUNC` are automatically set by - * the logging macros, G_DEBUG_HERE(), g_message(), g_warning(), g_critical(), - * g_error(), etc, if the symbols `G_LOG_USE_STRUCTURED` is defined before including - * `glib.h`. - * - * For example: - * - * |[<!-- language="C" --> - * g_log_structured (G_LOG_DOMAIN, G_LOG_LEVEL_DEBUG, - * "MESSAGE_ID", "06d4df59e6c24647bfe69d2c27ef0b4e", - * "MY_APPLICATION_CUSTOM_FIELD", "some debug string", - * "MESSAGE", "This is a debug message about pointer %p and integer %u.", - * some_pointer, some_integer); - * ]| - * - * Note that each `MESSAGE_ID` must be [uniquely and randomly - * generated](https://www.freedesktop.org/software/systemd/man/systemd.journal-fields.html#MESSAGE_ID=). - * If adding a `MESSAGE_ID`, consider shipping a [message - * catalog](https://www.freedesktop.org/wiki/Software/systemd/catalog/) with - * your software. - * - * To pass a user data pointer to the log writer function which is specific to - * this logging call, you must use g_log_structured_array() and pass the pointer - * as a field with #GLogField.length set to zero, otherwise it will be - * interpreted as a string. - * - * For example: - * - * |[<!-- language="C" --> - * const GLogField fields[] = { - * { "MESSAGE", "This is a debug message.", -1 }, - * { "MESSAGE_ID", "fcfb2e1e65c3494386b74878f1abf893", -1 }, - * { "MY_APPLICATION_CUSTOM_FIELD", "some debug string", -1 }, - * { "MY_APPLICATION_STATE", state_object, 0 }, - * }; - * g_log_structured_array (G_LOG_LEVEL_DEBUG, fields, G_N_ELEMENTS (fields)); - * ]| - * - * Note also that, even if no other structured fields are specified, there - * must always be a `MESSAGE` key before the format string. The `MESSAGE`-format - * pair has to be the last of the key-value pairs, and `MESSAGE` is the only - * field for which printf()-style formatting is supported. - * - * The default writer function for `stdout` and `stderr` will automatically - * append a new-line character after the message, so you should not add one - * manually to the format string. - * - * Since: 2.50 - */ - - -/** - * g_log_structured_array: - * @log_level: log level, either from #GLogLevelFlags, or a user-defined - * level - * @fields: (array length=n_fields): key–value pairs of structured data to add - * to the log message - * @n_fields: number of elements in the @fields array - * - * Log a message with structured data. The message will be passed through to the - * log writer set by the application using g_log_set_writer_func(). If the - * message is fatal (i.e. its log level is %G_LOG_LEVEL_ERROR), the program will - * be aborted at the end of this function. - * - * See g_log_structured() for more documentation. - * - * This assumes that @log_level is already present in @fields (typically as the - * `PRIORITY` field). - * - * Since: 2.50 - */ - - -/** - * g_log_variant: - * @log_domain: (nullable): log domain, usually %G_LOG_DOMAIN - * @log_level: log level, either from #GLogLevelFlags, or a user-defined - * level - * @fields: a dictionary (#GVariant of the type %G_VARIANT_TYPE_VARDICT) - * containing the key-value pairs of message data. - * - * Log a message with structured data, accepting the data within a #GVariant. This - * version is especially useful for use in other languages, via introspection. - * - * The only mandatory item in the @fields dictionary is the "MESSAGE" which must - * contain the text shown to the user. - * - * The values in the @fields dictionary are likely to be of type String - * (#G_VARIANT_TYPE_STRING). Array of bytes (#G_VARIANT_TYPE_BYTESTRING) is also - * supported. In this case the message is handled as binary and will be forwarded - * to the log writer as such. The size of the array should not be higher than - * %G_MAXSSIZE. Otherwise it will be truncated to this size. For other types - * g_variant_print() will be used to convert the value into a string. - * - * For more details on its usage and about the parameters, see g_log_structured(). - * - * Since: 2.50 - */ - - -/** - * g_log_writer_default: - * @log_level: log level, either from #GLogLevelFlags, or a user-defined - * level - * @fields: (array length=n_fields): key–value pairs of structured data forming - * the log message - * @n_fields: number of elements in the @fields array - * @user_data: user data passed to g_log_set_writer_func() - * - * Format a structured log message and output it to the default log destination - * for the platform. On Linux, this is typically the systemd journal, falling - * back to `stdout` or `stderr` if running from the terminal or if output is - * being redirected to a file. - * - * Support for other platform-specific logging mechanisms may be added in - * future. Distributors of GLib may modify this function to impose their own - * (documented) platform-specific log writing policies. - * - * This is suitable for use as a #GLogWriterFunc, and is the default writer used - * if no other is set using g_log_set_writer_func(). - * - * As with g_log_default_handler(), this function drops debug and informational - * messages unless their log domain (or `all`) is listed in the space-separated - * `G_MESSAGES_DEBUG` environment variable. - * - * g_log_writer_default() uses the mask set by g_log_set_always_fatal() to - * determine which messages are fatal. When using a custom writer func instead it is - * up to the writer function to determine which log messages are fatal. - * - * Returns: %G_LOG_WRITER_HANDLED on success, %G_LOG_WRITER_UNHANDLED otherwise - * Since: 2.50 - */ - - -/** - * g_log_writer_default_set_use_stderr: - * @use_stderr: If %TRUE, use `stderr` for log messages that would - * normally have appeared on `stdout` - * - * Configure whether the built-in log functions - * (g_log_default_handler() for the old-style API, and both - * g_log_writer_default() and g_log_writer_standard_streams() for the - * structured API) will output all log messages to `stderr`. - * - * By default, log messages of levels %G_LOG_LEVEL_INFO and - * %G_LOG_LEVEL_DEBUG are sent to `stdout`, and other log messages are - * sent to `stderr`. This is problematic for applications that intend - * to reserve `stdout` for structured output such as JSON or XML. - * - * This function sets global state. It is not thread-aware, and should be - * called at the very start of a program, before creating any other threads - * or creating objects that could create worker threads of their own. - * - * Since: 2.68 - */ - - -/** - * g_log_writer_default_would_drop: - * @log_domain: (nullable): log domain - * @log_level: log level, either from #GLogLevelFlags, or a user-defined - * level - * - * Check whether g_log_writer_default() and g_log_default_handler() would - * ignore a message with the given domain and level. - * - * As with g_log_default_handler(), this function drops debug and informational - * messages unless their log domain (or `all`) is listed in the space-separated - * `G_MESSAGES_DEBUG` environment variable. - * - * This can be used when implementing log writers with the same filtering - * behaviour as the default, but a different destination or output format: - * - * |[<!-- language="C" --> - * if (g_log_writer_default_would_drop (log_level, log_domain)) - * return G_LOG_WRITER_HANDLED; - * ]| - * - * or to skip an expensive computation if it is only needed for a debugging - * message, and `G_MESSAGES_DEBUG` is not set: - * - * |[<!-- language="C" --> - * if (!g_log_writer_default_would_drop (G_LOG_LEVEL_DEBUG, G_LOG_DOMAIN)) - * { - * gchar *result = expensive_computation (my_object); - * - * g_debug ("my_object result: %s", result); - * g_free (result); - * } - * ]| - * - * Returns: %TRUE if the log message would be dropped by GLib's - * default log handlers - * Since: 2.68 - */ - - -/** - * g_log_writer_format_fields: - * @log_level: log level, either from #GLogLevelFlags, or a user-defined - * level - * @fields: (array length=n_fields): key–value pairs of structured data forming - * the log message - * @n_fields: number of elements in the @fields array - * @use_color: %TRUE to use ANSI color escape sequences when formatting the - * message, %FALSE to not - * - * Format a structured log message as a string suitable for outputting to the - * terminal (or elsewhere). This will include the values of all fields it knows - * how to interpret, which includes `MESSAGE` and `GLIB_DOMAIN` (see the - * documentation for g_log_structured()). It does not include values from - * unknown fields. - * - * The returned string does **not** have a trailing new-line character. It is - * encoded in the character set of the current locale, which is not necessarily - * UTF-8. - * - * Returns: (transfer full): string containing the formatted log message, in - * the character set of the current locale - * Since: 2.50 - */ - - -/** - * g_log_writer_is_journald: - * @output_fd: output file descriptor to check - * - * Check whether the given @output_fd file descriptor is a connection to the - * systemd journal, or something else (like a log file or `stdout` or - * `stderr`). - * - * Invalid file descriptors are accepted and return %FALSE, which allows for - * the following construct without needing any additional error handling: - * |[<!-- language="C" --> - * is_journald = g_log_writer_is_journald (fileno (stderr)); - * ]| - * - * Returns: %TRUE if @output_fd points to the journal, %FALSE otherwise - * Since: 2.50 - */ - - -/** - * g_log_writer_journald: - * @log_level: log level, either from #GLogLevelFlags, or a user-defined - * level - * @fields: (array length=n_fields): key–value pairs of structured data forming - * the log message - * @n_fields: number of elements in the @fields array - * @user_data: user data passed to g_log_set_writer_func() - * - * Format a structured log message and send it to the systemd journal as a set - * of key–value pairs. All fields are sent to the journal, but if a field has - * length zero (indicating program-specific data) then only its key will be - * sent. - * - * This is suitable for use as a #GLogWriterFunc. - * - * If GLib has been compiled without systemd support, this function is still - * defined, but will always return %G_LOG_WRITER_UNHANDLED. - * - * Returns: %G_LOG_WRITER_HANDLED on success, %G_LOG_WRITER_UNHANDLED otherwise - * Since: 2.50 - */ - - -/** - * g_log_writer_standard_streams: - * @log_level: log level, either from #GLogLevelFlags, or a user-defined - * level - * @fields: (array length=n_fields): key–value pairs of structured data forming - * the log message - * @n_fields: number of elements in the @fields array - * @user_data: user data passed to g_log_set_writer_func() - * - * Format a structured log message and print it to either `stdout` or `stderr`, - * depending on its log level. %G_LOG_LEVEL_INFO and %G_LOG_LEVEL_DEBUG messages - * are sent to `stdout`, or to `stderr` if requested by - * g_log_writer_default_set_use_stderr(); - * all other log levels are sent to `stderr`. Only fields - * which are understood by this function are included in the formatted string - * which is printed. - * - * If the output stream supports ANSI color escape sequences, they will be used - * in the output. - * - * A trailing new-line character is added to the log message when it is printed. - * - * This is suitable for use as a #GLogWriterFunc. - * - * Returns: %G_LOG_WRITER_HANDLED on success, %G_LOG_WRITER_UNHANDLED otherwise - * Since: 2.50 - */ - - -/** - * g_log_writer_supports_color: - * @output_fd: output file descriptor to check - * - * Check whether the given @output_fd file descriptor supports ANSI color - * escape sequences. If so, they can safely be used when formatting log - * messages. - * - * Returns: %TRUE if ANSI color escapes are supported, %FALSE otherwise - * Since: 2.50 - */ - - -/** - * g_logv: - * @log_domain: (nullable): the log domain, or %NULL for the default "" - * application domain - * @log_level: the log level - * @format: the message format. See the printf() documentation - * @args: the parameters to insert into the format string - * - * Logs an error or debugging message. - * - * If the log level has been set as fatal, G_BREAKPOINT() is called - * to terminate the program. See the documentation for G_BREAKPOINT() for - * details of the debugging options this provides. - * - * If g_log_default_handler() is used as the log handler function, a new-line - * character will automatically be appended to @..., and need not be entered - * manually. - * - * If [structured logging is enabled][using-structured-logging] this will - * output via the structured log writer function (see g_log_set_writer_func()). - */ - - -/** - * g_lstat: - * @filename: (type filename): a pathname in the GLib file name encoding - * (UTF-8 on Windows) - * @buf: a pointer to a stat struct, which will be filled with the file - * information - * - * A wrapper for the POSIX lstat() function. The lstat() function is - * like stat() except that in the case of symbolic links, it returns - * information about the symbolic link itself and not the file that it - * refers to. If the system does not support symbolic links g_lstat() - * is identical to g_stat(). - * - * See your C library manual for more details about lstat(). - * - * Returns: 0 if the information was successfully retrieved, - * -1 if an error occurred - * Since: 2.6 - */ - - -/** - * g_main_context_acquire: - * @context: a #GMainContext - * - * Tries to become the owner of the specified context. - * If some other thread is the owner of the context, - * returns %FALSE immediately. Ownership is properly - * recursive: the owner can require ownership again - * and will release ownership when g_main_context_release() - * is called as many times as g_main_context_acquire(). - * - * You must be the owner of a context before you - * can call g_main_context_prepare(), g_main_context_query(), - * g_main_context_check(), g_main_context_dispatch(). - * - * Returns: %TRUE if the operation succeeded, and - * this thread is now the owner of @context. - */ - - -/** - * g_main_context_add_poll: - * @context: (nullable): a #GMainContext (or %NULL for the default context) - * @fd: a #GPollFD structure holding information about a file - * descriptor to watch. - * @priority: the priority for this file descriptor which should be - * the same as the priority used for g_source_attach() to ensure that the - * file descriptor is polled whenever the results may be needed. - * - * Adds a file descriptor to the set of file descriptors polled for - * this context. This will very seldom be used directly. Instead - * a typical event source will use g_source_add_unix_fd() instead. - */ - - -/** - * g_main_context_check: - * @context: a #GMainContext - * @max_priority: the maximum numerical priority of sources to check - * @fds: (array length=n_fds): array of #GPollFD's that was passed to - * the last call to g_main_context_query() - * @n_fds: return value of g_main_context_query() - * - * Passes the results of polling back to the main loop. You should be - * careful to pass @fds and its length @n_fds as received from - * g_main_context_query(), as this functions relies on assumptions - * on how @fds is filled. - * - * You must have successfully acquired the context with - * g_main_context_acquire() before you may call this function. - * - * Returns: %TRUE if some sources are ready to be dispatched. - */ - - -/** - * g_main_context_default: - * - * Returns the global default main context. This is the main context - * used for main loop functions when a main loop is not explicitly - * specified, and corresponds to the "main" main loop. See also - * g_main_context_get_thread_default(). - * - * Returns: (transfer none): the global default main context. - */ - - -/** - * g_main_context_dispatch: - * @context: a #GMainContext - * - * Dispatches all pending sources. - * - * You must have successfully acquired the context with - * g_main_context_acquire() before you may call this function. - */ - - -/** - * g_main_context_find_source_by_funcs_user_data: - * @context: (nullable): a #GMainContext (if %NULL, the default context will be used). - * @funcs: the @source_funcs passed to g_source_new(). - * @user_data: the user data from the callback. - * - * Finds a source with the given source functions and user data. If - * multiple sources exist with the same source function and user data, - * the first one found will be returned. - * - * Returns: (transfer none): the source, if one was found, otherwise %NULL - */ - - -/** - * g_main_context_find_source_by_id: - * @context: (nullable): a #GMainContext (if %NULL, the default context will be used) - * @source_id: the source ID, as returned by g_source_get_id(). - * - * Finds a #GSource given a pair of context and ID. - * - * It is a programmer error to attempt to look up a non-existent source. - * - * More specifically: source IDs can be reissued after a source has been - * destroyed and therefore it is never valid to use this function with a - * source ID which may have already been removed. An example is when - * scheduling an idle to run in another thread with g_idle_add(): the - * idle may already have run and been removed by the time this function - * is called on its (now invalid) source ID. This source ID may have - * been reissued, leading to the operation being performed against the - * wrong source. - * - * Returns: (transfer none): the #GSource - */ - - -/** - * g_main_context_find_source_by_user_data: - * @context: a #GMainContext - * @user_data: the user_data for the callback. - * - * Finds a source with the given user data for the callback. If - * multiple sources exist with the same user data, the first - * one found will be returned. - * - * Returns: (transfer none): the source, if one was found, otherwise %NULL - */ - - -/** - * g_main_context_get_poll_func: - * @context: a #GMainContext - * - * Gets the poll function set by g_main_context_set_poll_func(). - * - * Returns: the poll function - */ - - -/** - * g_main_context_get_thread_default: - * - * Gets the thread-default #GMainContext for this thread. Asynchronous - * operations that want to be able to be run in contexts other than - * the default one should call this method or - * g_main_context_ref_thread_default() to get a #GMainContext to add - * their #GSources to. (Note that even in single-threaded - * programs applications may sometimes want to temporarily push a - * non-default context, so it is not safe to assume that this will - * always return %NULL if you are running in the default thread.) - * - * If you need to hold a reference on the context, use - * g_main_context_ref_thread_default() instead. - * - * Returns: (transfer none) (nullable): the thread-default #GMainContext, or - * %NULL if the thread-default context is the global default context. - * Since: 2.22 - */ - - -/** - * g_main_context_invoke: - * @context: (nullable): a #GMainContext, or %NULL - * @function: function to call - * @data: data to pass to @function - * - * Invokes a function in such a way that @context is owned during the - * invocation of @function. - * - * If @context is %NULL then the global default main context — as - * returned by g_main_context_default() — is used. - * - * If @context is owned by the current thread, @function is called - * directly. Otherwise, if @context is the thread-default main context - * of the current thread and g_main_context_acquire() succeeds, then - * @function is called and g_main_context_release() is called - * afterwards. - * - * In any other case, an idle source is created to call @function and - * that source is attached to @context (presumably to be run in another - * thread). The idle source is attached with %G_PRIORITY_DEFAULT - * priority. If you want a different priority, use - * g_main_context_invoke_full(). - * - * Note that, as with normal idle functions, @function should probably - * return %FALSE. If it returns %TRUE, it will be continuously run in a - * loop (and may prevent this call from returning). - * - * Since: 2.28 - */ - - -/** - * g_main_context_invoke_full: - * @context: (nullable): a #GMainContext, or %NULL - * @priority: the priority at which to run @function - * @function: function to call - * @data: data to pass to @function - * @notify: (nullable): a function to call when @data is no longer in use, or %NULL. - * - * Invokes a function in such a way that @context is owned during the - * invocation of @function. - * - * This function is the same as g_main_context_invoke() except that it - * lets you specify the priority in case @function ends up being - * scheduled as an idle and also lets you give a #GDestroyNotify for @data. - * - * @notify should not assume that it is called from any particular - * thread or with any particular context acquired. - * - * Since: 2.28 - */ - - -/** - * g_main_context_is_owner: - * @context: a #GMainContext - * - * Determines whether this thread holds the (recursive) - * ownership of this #GMainContext. This is useful to - * know before waiting on another thread that may be - * blocking to get ownership of @context. - * - * Returns: %TRUE if current thread is owner of @context. - * Since: 2.10 - */ - - -/** - * g_main_context_iteration: - * @context: (nullable): a #GMainContext (if %NULL, the default context will be used) - * @may_block: whether the call may block. - * - * Runs a single iteration for the given main loop. This involves - * checking to see if any event sources are ready to be processed, - * then if no events sources are ready and @may_block is %TRUE, waiting - * for a source to become ready, then dispatching the highest priority - * events sources that are ready. Otherwise, if @may_block is %FALSE - * sources are not waited to become ready, only those highest priority - * events sources will be dispatched (if any), that are ready at this - * given moment without further waiting. - * - * Note that even when @may_block is %TRUE, it is still possible for - * g_main_context_iteration() to return %FALSE, since the wait may - * be interrupted for other reasons than an event source becoming ready. - * - * Returns: %TRUE if events were dispatched. - */ - - -/** - * g_main_context_new: - * - * Creates a new #GMainContext structure. - * - * Returns: the new #GMainContext - */ - - -/** - * g_main_context_pending: - * @context: (nullable): a #GMainContext (if %NULL, the default context will be used) - * - * Checks if any sources have pending events for the given context. - * - * Returns: %TRUE if events are pending. - */ - - -/** - * g_main_context_pop_thread_default: - * @context: (nullable): a #GMainContext object, or %NULL - * - * Pops @context off the thread-default context stack (verifying that - * it was on the top of the stack). - * - * Since: 2.22 - */ - - -/** - * g_main_context_prepare: - * @context: a #GMainContext - * @priority: (out) (optional): location to store priority of highest priority - * source already ready. - * - * Prepares to poll sources within a main loop. The resulting information - * for polling is determined by calling g_main_context_query (). - * - * You must have successfully acquired the context with - * g_main_context_acquire() before you may call this function. - * - * Returns: %TRUE if some source is ready to be dispatched - * prior to polling. - */ - - -/** - * g_main_context_push_thread_default: - * @context: (nullable): a #GMainContext, or %NULL for the global default context - * - * Acquires @context and sets it as the thread-default context for the - * current thread. This will cause certain asynchronous operations - * (such as most [gio][gio]-based I/O) which are - * started in this thread to run under @context and deliver their - * results to its main loop, rather than running under the global - * default context in the main thread. Note that calling this function - * changes the context returned by g_main_context_get_thread_default(), - * not the one returned by g_main_context_default(), so it does not affect - * the context used by functions like g_idle_add(). - * - * Normally you would call this function shortly after creating a new - * thread, passing it a #GMainContext which will be run by a - * #GMainLoop in that thread, to set a new default context for all - * async operations in that thread. In this case you may not need to - * ever call g_main_context_pop_thread_default(), assuming you want the - * new #GMainContext to be the default for the whole lifecycle of the - * thread. - * - * If you don't have control over how the new thread was created (e.g. - * in the new thread isn't newly created, or if the thread life - * cycle is managed by a #GThreadPool), it is always suggested to wrap - * the logic that needs to use the new #GMainContext inside a - * g_main_context_push_thread_default() / g_main_context_pop_thread_default() - * pair, otherwise threads that are re-used will end up never explicitly - * releasing the #GMainContext reference they hold. - * - * In some cases you may want to schedule a single operation in a - * non-default context, or temporarily use a non-default context in - * the main thread. In that case, you can wrap the call to the - * asynchronous operation inside a - * g_main_context_push_thread_default() / - * g_main_context_pop_thread_default() pair, but it is up to you to - * ensure that no other asynchronous operations accidentally get - * started while the non-default context is active. - * - * Beware that libraries that predate this function may not correctly - * handle being used from a thread with a thread-default context. Eg, - * see g_file_supports_thread_contexts(). - * - * Since: 2.22 - */ - - -/** - * g_main_context_query: - * @context: a #GMainContext - * @max_priority: maximum priority source to check - * @timeout_: (out): location to store timeout to be used in polling - * @fds: (out caller-allocates) (array length=n_fds): location to - * store #GPollFD records that need to be polled. - * @n_fds: (in): length of @fds. - * - * Determines information necessary to poll this main loop. You should - * be careful to pass the resulting @fds array and its length @n_fds - * as is when calling g_main_context_check(), as this function relies - * on assumptions made when the array is filled. - * - * You must have successfully acquired the context with - * g_main_context_acquire() before you may call this function. - * - * Returns: the number of records actually stored in @fds, - * or, if more than @n_fds records need to be stored, the number - * of records that need to be stored. - */ - - -/** - * g_main_context_ref: - * @context: a #GMainContext - * - * Increases the reference count on a #GMainContext object by one. - * - * Returns: the @context that was passed in (since 2.6) - */ - - -/** - * g_main_context_ref_thread_default: - * - * Gets the thread-default #GMainContext for this thread, as with - * g_main_context_get_thread_default(), but also adds a reference to - * it with g_main_context_ref(). In addition, unlike - * g_main_context_get_thread_default(), if the thread-default context - * is the global default context, this will return that #GMainContext - * (with a ref added to it) rather than returning %NULL. - * - * Returns: (transfer full): the thread-default #GMainContext. Unref - * with g_main_context_unref() when you are done with it. - * Since: 2.32 - */ - - -/** - * g_main_context_release: - * @context: a #GMainContext - * - * Releases ownership of a context previously acquired by this thread - * with g_main_context_acquire(). If the context was acquired multiple - * times, the ownership will be released only when g_main_context_release() - * is called as many times as it was acquired. - */ - - -/** - * g_main_context_remove_poll: - * @context: a #GMainContext - * @fd: a #GPollFD descriptor previously added with g_main_context_add_poll() - * - * Removes file descriptor from the set of file descriptors to be - * polled for a particular context. - */ - - -/** - * g_main_context_set_poll_func: - * @context: a #GMainContext - * @func: the function to call to poll all file descriptors - * - * Sets the function to use to handle polling of file descriptors. It - * will be used instead of the poll() system call - * (or GLib's replacement function, which is used where - * poll() isn't available). - * - * This function could possibly be used to integrate the GLib event - * loop with an external event loop. - */ - - -/** - * g_main_context_unref: - * @context: a #GMainContext - * - * Decreases the reference count on a #GMainContext object by one. If - * the result is zero, free the context and free all associated memory. - */ - - -/** - * g_main_context_wait: - * @context: a #GMainContext - * @cond: a condition variable - * @mutex: a mutex, currently held - * - * Tries to become the owner of the specified context, - * as with g_main_context_acquire(). But if another thread - * is the owner, atomically drop @mutex and wait on @cond until - * that owner releases ownership or until @cond is signaled, then - * try again (once) to become the owner. - * - * Returns: %TRUE if the operation succeeded, and - * this thread is now the owner of @context. - * Deprecated: 2.58: Use g_main_context_is_owner() and separate locking instead. - */ - - -/** - * g_main_context_wakeup: - * @context: a #GMainContext - * - * If @context is currently blocking in g_main_context_iteration() - * waiting for a source to become ready, cause it to stop blocking - * and return. Otherwise, cause the next invocation of - * g_main_context_iteration() to return without blocking. - * - * This API is useful for low-level control over #GMainContext; for - * example, integrating it with main loop implementations such as - * #GMainLoop. - * - * Another related use for this function is when implementing a main - * loop with a termination condition, computed from multiple threads: - * - * |[<!-- language="C" --> - * #define NUM_TASKS 10 - * static gint tasks_remaining = NUM_TASKS; // (atomic) - * ... - * - * while (g_atomic_int_get (&tasks_remaining) != 0) - * g_main_context_iteration (NULL, TRUE); - * ]| - * - * Then in a thread: - * |[<!-- language="C" --> - * perform_work(); - * - * if (g_atomic_int_dec_and_test (&tasks_remaining)) - * g_main_context_wakeup (NULL); - * ]| - */ - - -/** - * g_main_current_source: - * - * Returns the currently firing source for this thread. - * - * Returns: (transfer none) (nullable): The currently firing source or %NULL. - * Since: 2.12 - */ - - -/** - * g_main_depth: - * - * Returns the depth of the stack of calls to - * g_main_context_dispatch() on any #GMainContext in the current thread. - * That is, when called from the toplevel, it gives 0. When - * called from within a callback from g_main_context_iteration() - * (or g_main_loop_run(), etc.) it returns 1. When called from within - * a callback to a recursive call to g_main_context_iteration(), - * it returns 2. And so forth. - * - * This function is useful in a situation like the following: - * Imagine an extremely simple "garbage collected" system. - * - * |[<!-- language="C" --> - * static GList *free_list; - * - * gpointer - * allocate_memory (gsize size) - * { - * gpointer result = g_malloc (size); - * free_list = g_list_prepend (free_list, result); - * return result; - * } - * - * void - * free_allocated_memory (void) - * { - * GList *l; - * for (l = free_list; l; l = l->next); - * g_free (l->data); - * g_list_free (free_list); - * free_list = NULL; - * } - * - * [...] - * - * while (TRUE); - * { - * g_main_context_iteration (NULL, TRUE); - * free_allocated_memory(); - * } - * ]| - * - * This works from an application, however, if you want to do the same - * thing from a library, it gets more difficult, since you no longer - * control the main loop. You might think you can simply use an idle - * function to make the call to free_allocated_memory(), but that - * doesn't work, since the idle function could be called from a - * recursive callback. This can be fixed by using g_main_depth() - * - * |[<!-- language="C" --> - * gpointer - * allocate_memory (gsize size) - * { - * FreeListBlock *block = g_new (FreeListBlock, 1); - * block->mem = g_malloc (size); - * block->depth = g_main_depth (); - * free_list = g_list_prepend (free_list, block); - * return block->mem; - * } - * - * void - * free_allocated_memory (void) - * { - * GList *l; - * - * int depth = g_main_depth (); - * for (l = free_list; l; ); - * { - * GList *next = l->next; - * FreeListBlock *block = l->data; - * if (block->depth > depth) - * { - * g_free (block->mem); - * g_free (block); - * free_list = g_list_delete_link (free_list, l); - * } - * - * l = next; - * } - * } - * ]| - * - * There is a temptation to use g_main_depth() to solve - * problems with reentrancy. For instance, while waiting for data - * to be received from the network in response to a menu item, - * the menu item might be selected again. It might seem that - * one could make the menu item's callback return immediately - * and do nothing if g_main_depth() returns a value greater than 1. - * However, this should be avoided since the user then sees selecting - * the menu item do nothing. Furthermore, you'll find yourself adding - * these checks all over your code, since there are doubtless many, - * many things that the user could do. Instead, you can use the - * following techniques: - * - * 1. Use gtk_widget_set_sensitive() or modal dialogs to prevent - * the user from interacting with elements while the main - * loop is recursing. - * - * 2. Avoid main loop recursion in situations where you can't handle - * arbitrary callbacks. Instead, structure your code so that you - * simply return to the main loop and then get called again when - * there is more work to do. - * - * Returns: The main loop recursion level in the current thread - */ - - -/** - * g_main_loop_get_context: - * @loop: a #GMainLoop. - * - * Returns the #GMainContext of @loop. - * - * Returns: (transfer none): the #GMainContext of @loop - */ - - -/** - * g_main_loop_is_running: - * @loop: a #GMainLoop. - * - * Checks to see if the main loop is currently being run via g_main_loop_run(). - * - * Returns: %TRUE if the mainloop is currently being run. - */ - - -/** - * g_main_loop_new: - * @context: (nullable): a #GMainContext (if %NULL, the default context will be used). - * @is_running: set to %TRUE to indicate that the loop is running. This - * is not very important since calling g_main_loop_run() will set this to - * %TRUE anyway. - * - * Creates a new #GMainLoop structure. - * - * Returns: a new #GMainLoop. - */ - - -/** - * g_main_loop_quit: - * @loop: a #GMainLoop - * - * Stops a #GMainLoop from running. Any calls to g_main_loop_run() - * for the loop will return. - * - * Note that sources that have already been dispatched when - * g_main_loop_quit() is called will still be executed. - */ - - -/** - * g_main_loop_ref: - * @loop: a #GMainLoop - * - * Increases the reference count on a #GMainLoop object by one. - * - * Returns: @loop - */ - - -/** - * g_main_loop_run: - * @loop: a #GMainLoop - * - * Runs a main loop until g_main_loop_quit() is called on the loop. - * If this is called for the thread of the loop's #GMainContext, - * it will process events from the loop, otherwise it will - * simply wait. - */ - - -/** - * g_main_loop_unref: - * @loop: a #GMainLoop - * - * Decreases the reference count on a #GMainLoop object by one. If - * the result is zero, free the loop and free all associated memory. - */ - - -/** - * g_malloc: - * @n_bytes: the number of bytes to allocate - * - * Allocates @n_bytes bytes of memory. - * If @n_bytes is 0 it returns %NULL. - * - * Returns: a pointer to the allocated memory - */ - - -/** - * g_malloc0: - * @n_bytes: the number of bytes to allocate - * - * Allocates @n_bytes bytes of memory, initialized to 0's. - * If @n_bytes is 0 it returns %NULL. - * - * Returns: a pointer to the allocated memory - */ - - -/** - * g_malloc0_n: - * @n_blocks: the number of blocks to allocate - * @n_block_bytes: the size of each block in bytes - * - * This function is similar to g_malloc0(), allocating (@n_blocks * @n_block_bytes) bytes, - * but care is taken to detect possible overflow during multiplication. - * - * Since: 2.24 - * Returns: a pointer to the allocated memory - */ - - -/** - * g_malloc_n: - * @n_blocks: the number of blocks to allocate - * @n_block_bytes: the size of each block in bytes - * - * This function is similar to g_malloc(), allocating (@n_blocks * @n_block_bytes) bytes, - * but care is taken to detect possible overflow during multiplication. - * - * Since: 2.24 - * Returns: a pointer to the allocated memory - */ - - -/** - * g_mapped_file_free: - * @file: a #GMappedFile - * - * This call existed before #GMappedFile had refcounting and is currently - * exactly the same as g_mapped_file_unref(). - * - * Since: 2.8 - * Deprecated: 2.22: Use g_mapped_file_unref() instead. - */ - - -/** - * g_mapped_file_get_bytes: - * @file: a #GMappedFile - * - * Creates a new #GBytes which references the data mapped from @file. - * The mapped contents of the file must not be modified after creating this - * bytes object, because a #GBytes should be immutable. - * - * Returns: (transfer full): A newly allocated #GBytes referencing data - * from @file - * Since: 2.34 - */ - - -/** - * g_mapped_file_get_contents: - * @file: a #GMappedFile - * - * Returns the contents of a #GMappedFile. - * - * Note that the contents may not be zero-terminated, - * even if the #GMappedFile is backed by a text file. - * - * If the file is empty then %NULL is returned. - * - * Returns: the contents of @file, or %NULL. - * Since: 2.8 - */ - - -/** - * g_mapped_file_get_length: - * @file: a #GMappedFile - * - * Returns the length of the contents of a #GMappedFile. - * - * Returns: the length of the contents of @file. - * Since: 2.8 - */ - - -/** - * g_mapped_file_new: - * @filename: (type filename): The path of the file to load, in the GLib - * filename encoding - * @writable: whether the mapping should be writable - * @error: return location for a #GError, or %NULL - * - * Maps a file into memory. On UNIX, this is using the mmap() function. - * - * If @writable is %TRUE, the mapped buffer may be modified, otherwise - * it is an error to modify the mapped buffer. Modifications to the buffer - * are not visible to other processes mapping the same file, and are not - * written back to the file. - * - * Note that modifications of the underlying file might affect the contents - * of the #GMappedFile. Therefore, mapping should only be used if the file - * will not be modified, or if all modifications of the file are done - * atomically (e.g. using g_file_set_contents()). - * - * If @filename is the name of an empty, regular file, the function - * will successfully return an empty #GMappedFile. In other cases of - * size 0 (e.g. device files such as /dev/null), @error will be set - * to the #GFileError value #G_FILE_ERROR_INVAL. - * - * Returns: a newly allocated #GMappedFile which must be unref'd - * with g_mapped_file_unref(), or %NULL if the mapping failed. - * Since: 2.8 - */ - - -/** - * g_mapped_file_new_from_fd: - * @fd: The file descriptor of the file to load - * @writable: whether the mapping should be writable - * @error: return location for a #GError, or %NULL - * - * Maps a file into memory. On UNIX, this is using the mmap() function. - * - * If @writable is %TRUE, the mapped buffer may be modified, otherwise - * it is an error to modify the mapped buffer. Modifications to the buffer - * are not visible to other processes mapping the same file, and are not - * written back to the file. - * - * Note that modifications of the underlying file might affect the contents - * of the #GMappedFile. Therefore, mapping should only be used if the file - * will not be modified, or if all modifications of the file are done - * atomically (e.g. using g_file_set_contents()). - * - * Returns: a newly allocated #GMappedFile which must be unref'd - * with g_mapped_file_unref(), or %NULL if the mapping failed. - * Since: 2.32 - */ - - -/** - * g_mapped_file_ref: - * @file: a #GMappedFile - * - * Increments the reference count of @file by one. It is safe to call - * this function from any thread. - * - * Returns: the passed in #GMappedFile. - * Since: 2.22 - */ - - -/** - * g_mapped_file_unref: - * @file: a #GMappedFile - * - * Decrements the reference count of @file by one. If the reference count - * drops to 0, unmaps the buffer of @file and frees it. - * - * It is safe to call this function from any thread. - * - * Since 2.22 - */ - - -/** - * g_markup_collect_attributes: - * @element_name: the current tag name - * @attribute_names: the attribute names - * @attribute_values: the attribute values - * @error: a pointer to a #GError or %NULL - * @first_type: the #GMarkupCollectType of the first attribute - * @first_attr: the name of the first attribute - * @...: a pointer to the storage location of the first attribute - * (or %NULL), followed by more types names and pointers, ending - * with %G_MARKUP_COLLECT_INVALID - * - * Collects the attributes of the element from the data passed to the - * #GMarkupParser start_element function, dealing with common error - * conditions and supporting boolean values. - * - * This utility function is not required to write a parser but can save - * a lot of typing. - * - * The @element_name, @attribute_names, @attribute_values and @error - * parameters passed to the start_element callback should be passed - * unmodified to this function. - * - * Following these arguments is a list of "supported" attributes to collect. - * It is an error to specify multiple attributes with the same name. If any - * attribute not in the list appears in the @attribute_names array then an - * unknown attribute error will result. - * - * The #GMarkupCollectType field allows specifying the type of collection - * to perform and if a given attribute must appear or is optional. - * - * The attribute name is simply the name of the attribute to collect. - * - * The pointer should be of the appropriate type (see the descriptions - * under #GMarkupCollectType) and may be %NULL in case a particular - * attribute is to be allowed but ignored. - * - * This function deals with issuing errors for missing attributes - * (of type %G_MARKUP_ERROR_MISSING_ATTRIBUTE), unknown attributes - * (of type %G_MARKUP_ERROR_UNKNOWN_ATTRIBUTE) and duplicate - * attributes (of type %G_MARKUP_ERROR_INVALID_CONTENT) as well - * as parse errors for boolean-valued attributes (again of type - * %G_MARKUP_ERROR_INVALID_CONTENT). In all of these cases %FALSE - * will be returned and @error will be set as appropriate. - * - * Returns: %TRUE if successful - * Since: 2.16 - */ - - -/** - * g_markup_escape_text: - * @text: some valid UTF-8 text - * @length: length of @text in bytes, or -1 if the text is nul-terminated - * - * Escapes text so that the markup parser will parse it verbatim. - * Less than, greater than, ampersand, etc. are replaced with the - * corresponding entities. This function would typically be used - * when writing out a file to be parsed with the markup parser. - * - * Note that this function doesn't protect whitespace and line endings - * from being processed according to the XML rules for normalization - * of line endings and attribute values. - * - * Note also that this function will produce character references in - * the range of  ...  for all control sequences - * except for tabstop, newline and carriage return. The character - * references in this range are not valid XML 1.0, but they are - * valid XML 1.1 and will be accepted by the GMarkup parser. - * - * Returns: a newly allocated string with the escaped text - */ - - -/** - * g_markup_parse_context_end_parse: - * @context: a #GMarkupParseContext - * @error: return location for a #GError - * - * Signals to the #GMarkupParseContext that all data has been - * fed into the parse context with g_markup_parse_context_parse(). - * - * This function reports an error if the document isn't complete, - * for example if elements are still open. - * - * Returns: %TRUE on success, %FALSE if an error was set - */ - - -/** - * g_markup_parse_context_free: - * @context: a #GMarkupParseContext - * - * Frees a #GMarkupParseContext. - * - * This function can't be called from inside one of the - * #GMarkupParser functions or while a subparser is pushed. - */ - - -/** - * g_markup_parse_context_get_element: - * @context: a #GMarkupParseContext - * - * Retrieves the name of the currently open element. - * - * If called from the start_element or end_element handlers this will - * give the element_name as passed to those functions. For the parent - * elements, see g_markup_parse_context_get_element_stack(). - * - * Returns: the name of the currently open element, or %NULL - * Since: 2.2 - */ - - -/** - * g_markup_parse_context_get_element_stack: - * @context: a #GMarkupParseContext - * - * Retrieves the element stack from the internal state of the parser. - * - * The returned #GSList is a list of strings where the first item is - * the currently open tag (as would be returned by - * g_markup_parse_context_get_element()) and the next item is its - * immediate parent. - * - * This function is intended to be used in the start_element and - * end_element handlers where g_markup_parse_context_get_element() - * would merely return the name of the element that is being - * processed. - * - * Returns: the element stack, which must not be modified - * Since: 2.16 - */ - - -/** - * g_markup_parse_context_get_position: - * @context: a #GMarkupParseContext - * @line_number: (out) (optional): return location for a line number, or %NULL - * @char_number: (out) (optional): return location for a char-on-line number, or %NULL - * - * Retrieves the current line number and the number of the character on - * that line. Intended for use in error messages; there are no strict - * semantics for what constitutes the "current" line number other than - * "the best number we could come up with for error messages." - */ - - -/** - * g_markup_parse_context_get_user_data: - * @context: a #GMarkupParseContext - * - * Returns the user_data associated with @context. - * - * This will either be the user_data that was provided to - * g_markup_parse_context_new() or to the most recent call - * of g_markup_parse_context_push(). - * - * Returns: the provided user_data. The returned data belongs to - * the markup context and will be freed when - * g_markup_parse_context_free() is called. - * Since: 2.18 - */ - - -/** - * g_markup_parse_context_new: - * @parser: a #GMarkupParser - * @flags: one or more #GMarkupParseFlags - * @user_data: user data to pass to #GMarkupParser functions - * @user_data_dnotify: user data destroy notifier called when - * the parse context is freed - * - * Creates a new parse context. A parse context is used to parse - * marked-up documents. You can feed any number of documents into - * a context, as long as no errors occur; once an error occurs, - * the parse context can't continue to parse text (you have to - * free it and create a new parse context). - * - * Returns: a new #GMarkupParseContext - */ - - -/** - * g_markup_parse_context_parse: - * @context: a #GMarkupParseContext - * @text: chunk of text to parse - * @text_len: length of @text in bytes - * @error: return location for a #GError - * - * Feed some data to the #GMarkupParseContext. - * - * The data need not be valid UTF-8; an error will be signaled if - * it's invalid. The data need not be an entire document; you can - * feed a document into the parser incrementally, via multiple calls - * to this function. Typically, as you receive data from a network - * connection or file, you feed each received chunk of data into this - * function, aborting the process if an error occurs. Once an error - * is reported, no further data may be fed to the #GMarkupParseContext; - * all errors are fatal. - * - * Returns: %FALSE if an error occurred, %TRUE on success - */ - - -/** - * g_markup_parse_context_pop: - * @context: a #GMarkupParseContext - * - * Completes the process of a temporary sub-parser redirection. - * - * This function exists to collect the user_data allocated by a - * matching call to g_markup_parse_context_push(). It must be called - * in the end_element handler corresponding to the start_element - * handler during which g_markup_parse_context_push() was called. - * You must not call this function from the error callback -- the - * @user_data is provided directly to the callback in that case. - * - * This function is not intended to be directly called by users - * interested in invoking subparsers. Instead, it is intended to - * be used by the subparsers themselves to implement a higher-level - * interface. - * - * Returns: the user data passed to g_markup_parse_context_push() - * Since: 2.18 - */ - - -/** - * g_markup_parse_context_push: - * @context: a #GMarkupParseContext - * @parser: a #GMarkupParser - * @user_data: user data to pass to #GMarkupParser functions - * - * Temporarily redirects markup data to a sub-parser. - * - * This function may only be called from the start_element handler of - * a #GMarkupParser. It must be matched with a corresponding call to - * g_markup_parse_context_pop() in the matching end_element handler - * (except in the case that the parser aborts due to an error). - * - * All tags, text and other data between the matching tags is - * redirected to the subparser given by @parser. @user_data is used - * as the user_data for that parser. @user_data is also passed to the - * error callback in the event that an error occurs. This includes - * errors that occur in subparsers of the subparser. - * - * The end tag matching the start tag for which this call was made is - * handled by the previous parser (which is given its own user_data) - * which is why g_markup_parse_context_pop() is provided to allow "one - * last access" to the @user_data provided to this function. In the - * case of error, the @user_data provided here is passed directly to - * the error callback of the subparser and g_markup_parse_context_pop() - * should not be called. In either case, if @user_data was allocated - * then it ought to be freed from both of these locations. - * - * This function is not intended to be directly called by users - * interested in invoking subparsers. Instead, it is intended to be - * used by the subparsers themselves to implement a higher-level - * interface. - * - * As an example, see the following implementation of a simple - * parser that counts the number of tags encountered. - * - * |[<!-- language="C" --> - * typedef struct - * { - * gint tag_count; - * } CounterData; - * - * static void - * counter_start_element (GMarkupParseContext *context, - * const gchar *element_name, - * const gchar **attribute_names, - * const gchar **attribute_values, - * gpointer user_data, - * GError **error) - * { - * CounterData *data = user_data; - * - * data->tag_count++; - * } - * - * static void - * counter_error (GMarkupParseContext *context, - * GError *error, - * gpointer user_data) - * { - * CounterData *data = user_data; - * - * g_slice_free (CounterData, data); - * } - * - * static GMarkupParser counter_subparser = - * { - * counter_start_element, - * NULL, - * NULL, - * NULL, - * counter_error - * }; - * ]| - * - * In order to allow this parser to be easily used as a subparser, the - * following interface is provided: - * - * |[<!-- language="C" --> - * void - * start_counting (GMarkupParseContext *context) - * { - * CounterData *data = g_slice_new (CounterData); - * - * data->tag_count = 0; - * g_markup_parse_context_push (context, &counter_subparser, data); - * } - * - * gint - * end_counting (GMarkupParseContext *context) - * { - * CounterData *data = g_markup_parse_context_pop (context); - * int result; - * - * result = data->tag_count; - * g_slice_free (CounterData, data); - * - * return result; - * } - * ]| - * - * The subparser would then be used as follows: - * - * |[<!-- language="C" --> - * static void start_element (context, element_name, ...) - * { - * if (strcmp (element_name, "count-these") == 0) - * start_counting (context); - * - * // else, handle other tags... - * } - * - * static void end_element (context, element_name, ...) - * { - * if (strcmp (element_name, "count-these") == 0) - * g_print ("Counted %d tags\n", end_counting (context)); - * - * // else, handle other tags... - * } - * ]| - * - * Since: 2.18 - */ - - -/** - * g_markup_parse_context_ref: - * @context: a #GMarkupParseContext - * - * Increases the reference count of @context. - * - * Returns: the same @context - * Since: 2.36 - */ - - -/** - * g_markup_parse_context_unref: - * @context: a #GMarkupParseContext - * - * Decreases the reference count of @context. When its reference count - * drops to 0, it is freed. - * - * Since: 2.36 - */ - - -/** - * g_markup_printf_escaped: - * @format: printf() style format string - * @...: the arguments to insert in the format string - * - * Formats arguments according to @format, escaping - * all string and character arguments in the fashion - * of g_markup_escape_text(). This is useful when you - * want to insert literal strings into XML-style markup - * output, without having to worry that the strings - * might themselves contain markup. - * - * |[<!-- language="C" --> - * const char *store = "Fortnum & Mason"; - * const char *item = "Tea"; - * char *output; - * - * output = g_markup_printf_escaped ("<purchase>" - * "<store>%s</store>" - * "<item>%s</item>" - * "</purchase>", - * store, item); - * ]| - * - * Returns: newly allocated result from formatting - * operation. Free with g_free(). - * Since: 2.4 - */ - - -/** - * g_markup_vprintf_escaped: - * @format: printf() style format string - * @args: variable argument list, similar to vprintf() - * - * Formats the data in @args according to @format, escaping - * all string and character arguments in the fashion - * of g_markup_escape_text(). See g_markup_printf_escaped(). - * - * Returns: newly allocated result from formatting - * operation. Free with g_free(). - * Since: 2.4 - */ - - -/** - * g_match_info_expand_references: - * @match_info: (nullable): a #GMatchInfo or %NULL - * @string_to_expand: the string to expand - * @error: location to store the error occurring, or %NULL to ignore errors - * - * Returns a new string containing the text in @string_to_expand with - * references and escape sequences expanded. References refer to the last - * match done with @string against @regex and have the same syntax used by - * g_regex_replace(). - * - * The @string_to_expand must be UTF-8 encoded even if #G_REGEX_RAW was - * passed to g_regex_new(). - * - * The backreferences are extracted from the string passed to the match - * function, so you cannot call this function after freeing the string. - * - * @match_info may be %NULL in which case @string_to_expand must not - * contain references. For instance "foo\n" does not refer to an actual - * pattern and '\n' merely will be replaced with \n character, - * while to expand "\0" (whole match) one needs the result of a match. - * Use g_regex_check_replacement() to find out whether @string_to_expand - * contains references. - * - * Returns: (nullable): the expanded string, or %NULL if an error occurred - * Since: 2.14 - */ - - -/** - * g_match_info_fetch: - * @match_info: #GMatchInfo structure - * @match_num: number of the sub expression - * - * Retrieves the text matching the @match_num'th capturing - * parentheses. 0 is the full text of the match, 1 is the first paren - * set, 2 the second, and so on. - * - * If @match_num is a valid sub pattern but it didn't match anything - * (e.g. sub pattern 1, matching "b" against "(a)?b") then an empty - * string is returned. - * - * If the match was obtained using the DFA algorithm, that is using - * g_regex_match_all() or g_regex_match_all_full(), the retrieved - * string is not that of a set of parentheses but that of a matched - * substring. Substrings are matched in reverse order of length, so - * 0 is the longest match. - * - * The string is fetched from the string passed to the match function, - * so you cannot call this function after freeing the string. - * - * Returns: (nullable): The matched substring, or %NULL if an error - * occurred. You have to free the string yourself - * Since: 2.14 - */ - - -/** - * g_match_info_fetch_all: - * @match_info: a #GMatchInfo structure - * - * Bundles up pointers to each of the matching substrings from a match - * and stores them in an array of gchar pointers. The first element in - * the returned array is the match number 0, i.e. the entire matched - * text. - * - * If a sub pattern didn't match anything (e.g. sub pattern 1, matching - * "b" against "(a)?b") then an empty string is inserted. - * - * If the last match was obtained using the DFA algorithm, that is using - * g_regex_match_all() or g_regex_match_all_full(), the retrieved - * strings are not that matched by sets of parentheses but that of the - * matched substring. Substrings are matched in reverse order of length, - * so the first one is the longest match. - * - * The strings are fetched from the string passed to the match function, - * so you cannot call this function after freeing the string. - * - * Returns: (transfer full): a %NULL-terminated array of gchar * - * pointers. It must be freed using g_strfreev(). If the previous - * match failed %NULL is returned - * Since: 2.14 - */ - - -/** - * g_match_info_fetch_named: - * @match_info: #GMatchInfo structure - * @name: name of the subexpression - * - * Retrieves the text matching the capturing parentheses named @name. - * - * If @name is a valid sub pattern name but it didn't match anything - * (e.g. sub pattern "X", matching "b" against "(?P<X>a)?b") - * then an empty string is returned. - * - * The string is fetched from the string passed to the match function, - * so you cannot call this function after freeing the string. - * - * Returns: (nullable): The matched substring, or %NULL if an error - * occurred. You have to free the string yourself - * Since: 2.14 - */ - - -/** - * g_match_info_fetch_named_pos: - * @match_info: #GMatchInfo structure - * @name: name of the subexpression - * @start_pos: (out) (optional): pointer to location where to store - * the start position, or %NULL - * @end_pos: (out) (optional): pointer to location where to store - * the end position, or %NULL - * - * Retrieves the position in bytes of the capturing parentheses named @name. - * - * If @name is a valid sub pattern name but it didn't match anything - * (e.g. sub pattern "X", matching "b" against "(?P<X>a)?b") - * then @start_pos and @end_pos are set to -1 and %TRUE is returned. - * - * Returns: %TRUE if the position was fetched, %FALSE otherwise. - * If the position cannot be fetched, @start_pos and @end_pos - * are left unchanged. - * Since: 2.14 - */ - - -/** - * g_match_info_fetch_pos: - * @match_info: #GMatchInfo structure - * @match_num: number of the sub expression - * @start_pos: (out) (optional): pointer to location where to store - * the start position, or %NULL - * @end_pos: (out) (optional): pointer to location where to store - * the end position, or %NULL - * - * Retrieves the position in bytes of the @match_num'th capturing - * parentheses. 0 is the full text of the match, 1 is the first - * paren set, 2 the second, and so on. - * - * If @match_num is a valid sub pattern but it didn't match anything - * (e.g. sub pattern 1, matching "b" against "(a)?b") then @start_pos - * and @end_pos are set to -1 and %TRUE is returned. - * - * If the match was obtained using the DFA algorithm, that is using - * g_regex_match_all() or g_regex_match_all_full(), the retrieved - * position is not that of a set of parentheses but that of a matched - * substring. Substrings are matched in reverse order of length, so - * 0 is the longest match. - * - * Returns: %TRUE if the position was fetched, %FALSE otherwise. If - * the position cannot be fetched, @start_pos and @end_pos are left - * unchanged - * Since: 2.14 - */ - - -/** - * g_match_info_free: - * @match_info: (nullable): a #GMatchInfo, or %NULL - * - * If @match_info is not %NULL, calls g_match_info_unref(); otherwise does - * nothing. - * - * Since: 2.14 - */ - - -/** - * g_match_info_get_match_count: - * @match_info: a #GMatchInfo structure - * - * Retrieves the number of matched substrings (including substring 0, - * that is the whole matched text), so 1 is returned if the pattern - * has no substrings in it and 0 is returned if the match failed. - * - * If the last match was obtained using the DFA algorithm, that is - * using g_regex_match_all() or g_regex_match_all_full(), the retrieved - * count is not that of the number of capturing parentheses but that of - * the number of matched substrings. - * - * Returns: Number of matched substrings, or -1 if an error occurred - * Since: 2.14 - */ - - -/** - * g_match_info_get_regex: - * @match_info: a #GMatchInfo - * - * Returns #GRegex object used in @match_info. It belongs to Glib - * and must not be freed. Use g_regex_ref() if you need to keep it - * after you free @match_info object. - * - * Returns: #GRegex object used in @match_info - * Since: 2.14 - */ - - -/** - * g_match_info_get_string: - * @match_info: a #GMatchInfo - * - * Returns the string searched with @match_info. This is the - * string passed to g_regex_match() or g_regex_replace() so - * you may not free it before calling this function. - * - * Returns: the string searched with @match_info - * Since: 2.14 - */ - - -/** - * g_match_info_is_partial_match: - * @match_info: a #GMatchInfo structure - * - * Usually if the string passed to g_regex_match*() matches as far as - * it goes, but is too short to match the entire pattern, %FALSE is - * returned. There are circumstances where it might be helpful to - * distinguish this case from other cases in which there is no match. - * - * Consider, for example, an application where a human is required to - * type in data for a field with specific formatting requirements. An - * example might be a date in the form ddmmmyy, defined by the pattern - * "^\d?\d(jan|feb|mar|apr|may|jun|jul|aug|sep|oct|nov|dec)\d\d$". - * If the application sees the user’s keystrokes one by one, and can - * check that what has been typed so far is potentially valid, it is - * able to raise an error as soon as a mistake is made. - * - * GRegex supports the concept of partial matching by means of the - * #G_REGEX_MATCH_PARTIAL_SOFT and #G_REGEX_MATCH_PARTIAL_HARD flags. - * When they are used, the return code for - * g_regex_match() or g_regex_match_full() is, as usual, %TRUE - * for a complete match, %FALSE otherwise. But, when these functions - * return %FALSE, you can check if the match was partial calling - * g_match_info_is_partial_match(). - * - * The difference between #G_REGEX_MATCH_PARTIAL_SOFT and - * #G_REGEX_MATCH_PARTIAL_HARD is that when a partial match is encountered - * with #G_REGEX_MATCH_PARTIAL_SOFT, matching continues to search for a - * possible complete match, while with #G_REGEX_MATCH_PARTIAL_HARD matching - * stops at the partial match. - * When both #G_REGEX_MATCH_PARTIAL_SOFT and #G_REGEX_MATCH_PARTIAL_HARD - * are set, the latter takes precedence. - * - * There were formerly some restrictions on the pattern for partial matching. - * The restrictions no longer apply. - * - * See pcrepartial(3) for more information on partial matching. - * - * Returns: %TRUE if the match was partial, %FALSE otherwise - * Since: 2.14 - */ - - -/** - * g_match_info_matches: - * @match_info: a #GMatchInfo structure - * - * Returns whether the previous match operation succeeded. - * - * Returns: %TRUE if the previous match operation succeeded, - * %FALSE otherwise - * Since: 2.14 - */ - - -/** - * g_match_info_next: - * @match_info: a #GMatchInfo structure - * @error: location to store the error occurring, or %NULL to ignore errors - * - * Scans for the next match using the same parameters of the previous - * call to g_regex_match_full() or g_regex_match() that returned - * @match_info. - * - * The match is done on the string passed to the match function, so you - * cannot free it before calling this function. - * - * Returns: %TRUE is the string matched, %FALSE otherwise - * Since: 2.14 - */ - - -/** - * g_match_info_ref: - * @match_info: a #GMatchInfo - * - * Increases reference count of @match_info by 1. - * - * Returns: @match_info - * Since: 2.30 - */ - - -/** - * g_match_info_unref: - * @match_info: a #GMatchInfo - * - * Decreases reference count of @match_info by 1. When reference count drops - * to zero, it frees all the memory associated with the match_info structure. - * - * Since: 2.30 - */ - - -/** - * g_mem_gc_friendly: - * - * This variable is %TRUE if the `G_DEBUG` environment variable - * includes the key `gc-friendly`. - */ - - -/** - * g_mem_is_system_malloc: - * - * Checks whether the allocator used by g_malloc() is the system's - * malloc implementation. If it returns %TRUE memory allocated with - * malloc() can be used interchangeably with memory allocated using g_malloc(). - * This function is useful for avoiding an extra copy of allocated memory returned - * by a non-GLib-based API. - * - * Returns: if %TRUE, malloc() and g_malloc() can be mixed. - * Deprecated: 2.46: GLib always uses the system malloc, so this function always - * returns %TRUE. - */ - - -/** - * g_mem_profile: - * - * GLib used to support some tools for memory profiling, but this - * no longer works. There are many other useful tools for memory - * profiling these days which can be used instead. - * - * Deprecated: 2.46: Use other memory profiling tools instead - */ - - -/** - * g_mem_set_vtable: - * @vtable: table of memory allocation routines. - * - * This function used to let you override the memory allocation function. - * However, its use was incompatible with the use of global constructors - * in GLib and GIO, because those use the GLib allocators before main is - * reached. Therefore this function is now deprecated and is just a stub. - * - * Deprecated: 2.46: This function now does nothing. Use other memory - * profiling tools instead - */ - - -/** - * g_memdup: - * @mem: the memory to copy. - * @byte_size: the number of bytes to copy. - * - * Allocates @byte_size bytes of memory, and copies @byte_size bytes into it - * from @mem. If @mem is %NULL it returns %NULL. - * - * Returns: a pointer to the newly-allocated copy of the memory, or %NULL if @mem - * is %NULL. - * Deprecated: 2.68: Use g_memdup2() instead, as it accepts a #gsize argument - * for @byte_size, avoiding the possibility of overflow in a #gsize → #guint - * conversion - */ - - -/** - * g_memdup2: - * @mem: (nullable): the memory to copy. - * @byte_size: the number of bytes to copy. - * - * Allocates @byte_size bytes of memory, and copies @byte_size bytes into it - * from @mem. If @mem is %NULL it returns %NULL. - * - * This replaces g_memdup(), which was prone to integer overflows when - * converting the argument from a #gsize to a #guint. - * - * Returns: (nullable): a pointer to the newly-allocated copy of the memory, - * or %NULL if @mem is %NULL. - * Since: 2.68 - */ - - -/** - * g_memmove: - * @dest: the destination address to copy the bytes to. - * @src: the source address to copy the bytes from. - * @len: the number of bytes to copy. - * - * Copies a block of memory @len bytes long, from @src to @dest. - * The source and destination areas may overlap. - * - * Deprecated: 2.40: Just use memmove(). - */ - - -/** - * g_message: - * @...: format string, followed by parameters to insert - * into the format string (as with printf()) - * - * A convenience function/macro to log a normal message. - * - * If g_log_default_handler() is used as the log handler function, a new-line - * character will automatically be appended to @..., and need not be entered - * manually. - * - * If structured logging is enabled, this will use g_log_structured(); - * otherwise it will use g_log(). See - * [Using Structured Logging][using-structured-logging]. - */ - - -/** - * g_mkdir: - * @filename: (type filename): a pathname in the GLib file name encoding - * (UTF-8 on Windows) - * @mode: permissions to use for the newly created directory - * - * A wrapper for the POSIX mkdir() function. The mkdir() function - * attempts to create a directory with the given name and permissions. - * The mode argument is ignored on Windows. - * - * See your C library manual for more details about mkdir(). - * - * Returns: 0 if the directory was successfully created, -1 if an error - * occurred - * Since: 2.6 - */ - - -/** - * g_mkdir_with_parents: - * @pathname: (type filename): a pathname in the GLib file name encoding - * @mode: permissions to use for newly created directories - * - * Create a directory if it doesn't already exist. Create intermediate - * parent directories as needed, too. - * - * Returns: 0 if the directory already exists, or was successfully - * created. Returns -1 if an error occurred, with errno set. - * Since: 2.8 - */ - - -/** - * g_mkdtemp: (skip) - * @tmpl: (type filename): template directory name - * - * Creates a temporary directory. See the mkdtemp() documentation - * on most UNIX-like systems. - * - * The parameter is a string that should follow the rules for - * mkdtemp() templates, i.e. contain the string "XXXXXX". - * g_mkdtemp() is slightly more flexible than mkdtemp() in that the - * sequence does not have to occur at the very end of the template. - * The X string will be modified to form the name of a directory that - * didn't exist. - * The string should be in the GLib file name encoding. Most importantly, - * on Windows it should be in UTF-8. - * - * If you are going to be creating a temporary directory inside the - * directory returned by g_get_tmp_dir(), you might want to use - * g_dir_make_tmp() instead. - * - * Returns: (nullable) (type filename): A pointer to @tmpl, which has been - * modified to hold the directory name. In case of errors, %NULL is - * returned and %errno will be set. - * Since: 2.30 - */ - - -/** - * g_mkdtemp_full: (skip) - * @tmpl: (type filename): template directory name - * @mode: permissions to create the temporary directory with - * - * Creates a temporary directory. See the mkdtemp() documentation - * on most UNIX-like systems. - * - * The parameter is a string that should follow the rules for - * mkdtemp() templates, i.e. contain the string "XXXXXX". - * g_mkdtemp_full() is slightly more flexible than mkdtemp() in that the - * sequence does not have to occur at the very end of the template - * and you can pass a @mode. The X string will be modified to form - * the name of a directory that didn't exist. The string should be - * in the GLib file name encoding. Most importantly, on Windows it - * should be in UTF-8. - * - * If you are going to be creating a temporary directory inside the - * directory returned by g_get_tmp_dir(), you might want to use - * g_dir_make_tmp() instead. - * - * Returns: (nullable) (type filename): A pointer to @tmpl, which has been - * modified to hold the directory name. In case of errors, %NULL is - * returned, and %errno will be set. - * Since: 2.30 - */ - - -/** - * g_mkstemp: (skip) - * @tmpl: (type filename): template filename - * - * Opens a temporary file. See the mkstemp() documentation - * on most UNIX-like systems. - * - * The parameter is a string that should follow the rules for - * mkstemp() templates, i.e. contain the string "XXXXXX". - * g_mkstemp() is slightly more flexible than mkstemp() in that the - * sequence does not have to occur at the very end of the template. - * The X string will be modified to form the name of a file that - * didn't exist. The string should be in the GLib file name encoding. - * Most importantly, on Windows it should be in UTF-8. - * - * Returns: A file handle (as from open()) to the file - * opened for reading and writing. The file is opened in binary - * mode on platforms where there is a difference. The file handle - * should be closed with close(). In case of errors, -1 is - * returned and %errno will be set. - */ - - -/** - * g_mkstemp_full: (skip) - * @tmpl: (type filename): template filename - * @flags: flags to pass to an open() call in addition to O_EXCL - * and O_CREAT, which are passed automatically - * @mode: permissions to create the temporary file with - * - * Opens a temporary file. See the mkstemp() documentation - * on most UNIX-like systems. - * - * The parameter is a string that should follow the rules for - * mkstemp() templates, i.e. contain the string "XXXXXX". - * g_mkstemp_full() is slightly more flexible than mkstemp() - * in that the sequence does not have to occur at the very end of the - * template and you can pass a @mode and additional @flags. The X - * string will be modified to form the name of a file that didn't exist. - * The string should be in the GLib file name encoding. Most importantly, - * on Windows it should be in UTF-8. - * - * Returns: A file handle (as from open()) to the file - * opened for reading and writing. The file handle should be - * closed with close(). In case of errors, -1 is returned - * and %errno will be set. - * Since: 2.22 - */ - - -/** - * g_mutex_clear: - * @mutex: an initialized #GMutex - * - * Frees the resources allocated to a mutex with g_mutex_init(). - * - * This function should not be used with a #GMutex that has been - * statically allocated. - * - * Calling g_mutex_clear() on a locked mutex leads to undefined - * behaviour. - * - * Sine: 2.32 - */ - - -/** - * g_mutex_init: - * @mutex: an uninitialized #GMutex - * - * Initializes a #GMutex so that it can be used. - * - * This function is useful to initialize a mutex that has been - * allocated on the stack, or as part of a larger structure. - * It is not necessary to initialize a mutex that has been - * statically allocated. - * - * |[<!-- language="C" --> - * typedef struct { - * GMutex m; - * ... - * } Blob; - * - * Blob *b; - * - * b = g_new (Blob, 1); - * g_mutex_init (&b->m); - * ]| - * - * To undo the effect of g_mutex_init() when a mutex is no longer - * needed, use g_mutex_clear(). - * - * Calling g_mutex_init() on an already initialized #GMutex leads - * to undefined behaviour. - * - * Since: 2.32 - */ - - -/** - * g_mutex_lock: - * @mutex: a #GMutex - * - * Locks @mutex. If @mutex is already locked by another thread, the - * current thread will block until @mutex is unlocked by the other - * thread. - * - * #GMutex is neither guaranteed to be recursive nor to be - * non-recursive. As such, calling g_mutex_lock() on a #GMutex that has - * already been locked by the same thread results in undefined behaviour - * (including but not limited to deadlocks). - */ - - -/** - * g_mutex_trylock: - * @mutex: a #GMutex - * - * Tries to lock @mutex. If @mutex is already locked by another thread, - * it immediately returns %FALSE. Otherwise it locks @mutex and returns - * %TRUE. - * - * #GMutex is neither guaranteed to be recursive nor to be - * non-recursive. As such, calling g_mutex_lock() on a #GMutex that has - * already been locked by the same thread results in undefined behaviour - * (including but not limited to deadlocks or arbitrary return values). - * - * Returns: %TRUE if @mutex could be locked - */ - - -/** - * g_mutex_unlock: - * @mutex: a #GMutex - * - * Unlocks @mutex. If another thread is blocked in a g_mutex_lock() - * call for @mutex, it will become unblocked and can lock @mutex itself. - * - * Calling g_mutex_unlock() on a mutex that is not locked by the - * current thread leads to undefined behaviour. - */ - - -/** - * g_node_child_index: - * @node: a #GNode - * @data: the data to find - * - * Gets the position of the first child of a #GNode - * which contains the given data. - * - * Returns: the index of the child of @node which contains - * @data, or -1 if the data is not found - */ - - -/** - * g_node_child_position: - * @node: a #GNode - * @child: a child of @node - * - * Gets the position of a #GNode with respect to its siblings. - * @child must be a child of @node. The first child is numbered 0, - * the second 1, and so on. - * - * Returns: the position of @child with respect to its siblings - */ - - -/** - * g_node_children_foreach: - * @node: a #GNode - * @flags: which types of children are to be visited, one of - * %G_TRAVERSE_ALL, %G_TRAVERSE_LEAVES and %G_TRAVERSE_NON_LEAVES - * @func: the function to call for each visited node - * @data: user data to pass to the function - * - * Calls a function for each of the children of a #GNode. Note that it - * doesn't descend beneath the child nodes. @func must not do anything - * that would modify the structure of the tree. - */ - - -/** - * g_node_copy: - * @node: a #GNode - * - * Recursively copies a #GNode (but does not deep-copy the data inside the - * nodes, see g_node_copy_deep() if you need that). - * - * Returns: a new #GNode containing the same data pointers - */ - - -/** - * g_node_copy_deep: - * @node: a #GNode - * @copy_func: the function which is called to copy the data inside each node, - * or %NULL to use the original data. - * @data: data to pass to @copy_func - * - * Recursively copies a #GNode and its data. - * - * Returns: a new #GNode containing copies of the data in @node. - * Since: 2.4 - */ - - -/** - * g_node_depth: - * @node: a #GNode - * - * Gets the depth of a #GNode. - * - * If @node is %NULL the depth is 0. The root node has a depth of 1. - * For the children of the root node the depth is 2. And so on. - * - * Returns: the depth of the #GNode - */ - - -/** - * g_node_destroy: - * @root: the root of the tree/subtree to destroy - * - * Removes @root and its children from the tree, freeing any memory - * allocated. - */ - - -/** - * g_node_find: - * @root: the root #GNode of the tree to search - * @order: the order in which nodes are visited - %G_IN_ORDER, - * %G_PRE_ORDER, %G_POST_ORDER, or %G_LEVEL_ORDER - * @flags: which types of children are to be searched, one of - * %G_TRAVERSE_ALL, %G_TRAVERSE_LEAVES and %G_TRAVERSE_NON_LEAVES - * @data: the data to find - * - * Finds a #GNode in a tree. - * - * Returns: the found #GNode, or %NULL if the data is not found - */ - - -/** - * g_node_find_child: - * @node: a #GNode - * @flags: which types of children are to be searched, one of - * %G_TRAVERSE_ALL, %G_TRAVERSE_LEAVES and %G_TRAVERSE_NON_LEAVES - * @data: the data to find - * - * Finds the first child of a #GNode with the given data. - * - * Returns: the found child #GNode, or %NULL if the data is not found - */ - - -/** - * g_node_first_sibling: - * @node: a #GNode - * - * Gets the first sibling of a #GNode. - * This could possibly be the node itself. - * - * Returns: the first sibling of @node - */ - - -/** - * g_node_get_root: - * @node: a #GNode - * - * Gets the root of a tree. - * - * Returns: the root of the tree - */ - - -/** - * g_node_insert: - * @parent: the #GNode to place @node under - * @position: the position to place @node at, with respect to its siblings - * If position is -1, @node is inserted as the last child of @parent - * @node: the #GNode to insert - * - * Inserts a #GNode beneath the parent at the given position. - * - * Returns: the inserted #GNode - */ - - -/** - * g_node_insert_after: - * @parent: the #GNode to place @node under - * @sibling: the sibling #GNode to place @node after. - * If sibling is %NULL, the node is inserted as the first child of @parent. - * @node: the #GNode to insert - * - * Inserts a #GNode beneath the parent after the given sibling. - * - * Returns: the inserted #GNode - */ - - -/** - * g_node_insert_before: - * @parent: the #GNode to place @node under - * @sibling: the sibling #GNode to place @node before. - * If sibling is %NULL, the node is inserted as the last child of @parent. - * @node: the #GNode to insert - * - * Inserts a #GNode beneath the parent before the given sibling. - * - * Returns: the inserted #GNode - */ - - -/** - * g_node_is_ancestor: - * @node: a #GNode - * @descendant: a #GNode - * - * Returns %TRUE if @node is an ancestor of @descendant. - * This is true if node is the parent of @descendant, - * or if node is the grandparent of @descendant etc. - * - * Returns: %TRUE if @node is an ancestor of @descendant - */ - - -/** - * g_node_last_child: - * @node: a #GNode (must not be %NULL) - * - * Gets the last child of a #GNode. - * - * Returns: the last child of @node, or %NULL if @node has no children - */ - - -/** - * g_node_last_sibling: - * @node: a #GNode - * - * Gets the last sibling of a #GNode. - * This could possibly be the node itself. - * - * Returns: the last sibling of @node - */ - - -/** - * g_node_max_height: - * @root: a #GNode - * - * Gets the maximum height of all branches beneath a #GNode. - * This is the maximum distance from the #GNode to all leaf nodes. - * - * If @root is %NULL, 0 is returned. If @root has no children, - * 1 is returned. If @root has children, 2 is returned. And so on. - * - * Returns: the maximum height of the tree beneath @root - */ - - -/** - * g_node_n_children: - * @node: a #GNode - * - * Gets the number of children of a #GNode. - * - * Returns: the number of children of @node - */ - - -/** - * g_node_n_nodes: - * @root: a #GNode - * @flags: which types of children are to be counted, one of - * %G_TRAVERSE_ALL, %G_TRAVERSE_LEAVES and %G_TRAVERSE_NON_LEAVES - * - * Gets the number of nodes in a tree. - * - * Returns: the number of nodes in the tree - */ - - -/** - * g_node_new: - * @data: the data of the new node - * - * Creates a new #GNode containing the given data. - * Used to create the first node in a tree. - * - * Returns: a new #GNode - */ - - -/** - * g_node_nth_child: - * @node: a #GNode - * @n: the index of the desired child - * - * Gets a child of a #GNode, using the given index. - * The first child is at index 0. If the index is - * too big, %NULL is returned. - * - * Returns: the child of @node at index @n - */ - - -/** - * g_node_prepend: - * @parent: the #GNode to place the new #GNode under - * @node: the #GNode to insert - * - * Inserts a #GNode as the first child of the given parent. - * - * Returns: the inserted #GNode - */ - - -/** - * g_node_reverse_children: - * @node: a #GNode. - * - * Reverses the order of the children of a #GNode. - * (It doesn't change the order of the grandchildren.) - */ - - -/** - * g_node_traverse: - * @root: the root #GNode of the tree to traverse - * @order: the order in which nodes are visited - %G_IN_ORDER, - * %G_PRE_ORDER, %G_POST_ORDER, or %G_LEVEL_ORDER. - * @flags: which types of children are to be visited, one of - * %G_TRAVERSE_ALL, %G_TRAVERSE_LEAVES and %G_TRAVERSE_NON_LEAVES - * @max_depth: the maximum depth of the traversal. Nodes below this - * depth will not be visited. If max_depth is -1 all nodes in - * the tree are visited. If depth is 1, only the root is visited. - * If depth is 2, the root and its children are visited. And so on. - * @func: the function to call for each visited #GNode - * @data: user data to pass to the function - * - * Traverses a tree starting at the given root #GNode. - * It calls the given function for each node visited. - * The traversal can be halted at any point by returning %TRUE from @func. - * @func must not do anything that would modify the structure of the tree. - */ - - -/** - * g_node_unlink: - * @node: the #GNode to unlink, which becomes the root of a new tree - * - * Unlinks a #GNode from a tree, resulting in two separate trees. - */ - - -/** - * g_ntohl: - * @val: a 32-bit integer value in network byte order - * - * Converts a 32-bit integer value from network to host byte order. - * - * Returns: @val converted to host byte order. - */ - - -/** - * g_ntohs: - * @val: a 16-bit integer value in network byte order - * - * Converts a 16-bit integer value from network to host byte order. - * - * Returns: @val converted to host byte order - */ - - -/** - * g_nullify_pointer: - * @nullify_location: (not nullable): the memory address of the pointer. - * - * Set the pointer at the specified location to %NULL. - */ - - -/** - * g_on_error_query: - * @prg_name: the program name, needed by gdb for the "[S]tack trace" - * option. If @prg_name is %NULL, g_get_prgname() is called to get - * the program name (which will work correctly if gdk_init() or - * gtk_init() has been called) - * - * Prompts the user with - * `[E]xit, [H]alt, show [S]tack trace or [P]roceed`. - * This function is intended to be used for debugging use only. - * The following example shows how it can be used together with - * the g_log() functions. - * - * |[<!-- language="C" --> - * #include <glib.h> - * - * static void - * log_handler (const gchar *log_domain, - * GLogLevelFlags log_level, - * const gchar *message, - * gpointer user_data) - * { - * g_log_default_handler (log_domain, log_level, message, user_data); - * - * g_on_error_query (MY_PROGRAM_NAME); - * } - * - * int - * main (int argc, char *argv[]) - * { - * g_log_set_handler (MY_LOG_DOMAIN, - * G_LOG_LEVEL_WARNING | - * G_LOG_LEVEL_ERROR | - * G_LOG_LEVEL_CRITICAL, - * log_handler, - * NULL); - * ... - * ]| - * - * If "[E]xit" is selected, the application terminates with a call - * to _exit(0). - * - * If "[S]tack" trace is selected, g_on_error_stack_trace() is called. - * This invokes gdb, which attaches to the current process and shows - * a stack trace. The prompt is then shown again. - * - * If "[P]roceed" is selected, the function returns. - * - * This function may cause different actions on non-UNIX platforms. - * - * On Windows consider using the `G_DEBUGGER` environment - * variable (see [Running GLib Applications](glib-running.html)) and - * calling g_on_error_stack_trace() instead. - */ - - -/** - * g_on_error_stack_trace: - * @prg_name: the program name, needed by gdb for the "[S]tack trace" - * option - * - * Invokes gdb, which attaches to the current process and shows a - * stack trace. Called by g_on_error_query() when the "[S]tack trace" - * option is selected. You can get the current process's program name - * with g_get_prgname(), assuming that you have called gtk_init() or - * gdk_init(). - * - * This function may cause different actions on non-UNIX platforms. - * - * When running on Windows, this function is *not* called by - * g_on_error_query(). If called directly, it will raise an - * exception, which will crash the program. If the `G_DEBUGGER` environment - * variable is set, a debugger will be invoked to attach and - * handle that exception (see [Running GLib Applications](glib-running.html)). - */ - - -/** - * g_once: - * @once: a #GOnce structure - * @func: the #GThreadFunc function associated to @once. This function - * is called only once, regardless of the number of times it and - * its associated #GOnce struct are passed to g_once(). - * @arg: data to be passed to @func - * - * The first call to this routine by a process with a given #GOnce - * struct calls @func with the given argument. Thereafter, subsequent - * calls to g_once() with the same #GOnce struct do not call @func - * again, but return the stored result of the first call. On return - * from g_once(), the status of @once will be %G_ONCE_STATUS_READY. - * - * For example, a mutex or a thread-specific data key must be created - * exactly once. In a threaded environment, calling g_once() ensures - * that the initialization is serialized across multiple threads. - * - * Calling g_once() recursively on the same #GOnce struct in - * @func will lead to a deadlock. - * - * |[<!-- language="C" --> - * gpointer - * get_debug_flags (void) - * { - * static GOnce my_once = G_ONCE_INIT; - * - * g_once (&my_once, parse_debug_flags, NULL); - * - * return my_once.retval; - * } - * ]| - * - * Since: 2.4 - */ - - -/** - * g_once_init_enter: - * @location: (not nullable): location of a static initializable variable - * containing 0 - * - * Function to be called when starting a critical initialization - * section. The argument @location must point to a static - * 0-initialized variable that will be set to a value other than 0 at - * the end of the initialization section. In combination with - * g_once_init_leave() and the unique address @value_location, it can - * be ensured that an initialization section will be executed only once - * during a program's life time, and that concurrent threads are - * blocked until initialization completed. To be used in constructs - * like this: - * - * |[<!-- language="C" --> - * static gsize initialization_value = 0; - * - * if (g_once_init_enter (&initialization_value)) - * { - * gsize setup_value = 42; // initialization code here - * - * g_once_init_leave (&initialization_value, setup_value); - * } - * - * // use initialization_value here - * ]| - * - * While @location has a `volatile` qualifier, this is a historical artifact and - * the pointer passed to it should not be `volatile`. - * - * Returns: %TRUE if the initialization section should be entered, - * %FALSE and blocks otherwise - * Since: 2.14 - */ - - -/** - * g_once_init_leave: - * @location: (not nullable): location of a static initializable variable - * containing 0 - * @result: new non-0 value for *@value_location - * - * Counterpart to g_once_init_enter(). Expects a location of a static - * 0-initialized initialization variable, and an initialization value - * other than 0. Sets the variable to the initialization value, and - * releases concurrent threads blocking in g_once_init_enter() on this - * initialization variable. - * - * While @location has a `volatile` qualifier, this is a historical artifact and - * the pointer passed to it should not be `volatile`. - * - * Since: 2.14 - */ - - -/** - * g_open: - * @filename: (type filename): a pathname in the GLib file name encoding - * (UTF-8 on Windows) - * @flags: as in open() - * @mode: as in open() - * - * A wrapper for the POSIX open() function. The open() function is - * used to convert a pathname into a file descriptor. - * - * On POSIX systems file descriptors are implemented by the operating - * system. On Windows, it's the C library that implements open() and - * file descriptors. The actual Win32 API for opening files is quite - * different, see MSDN documentation for CreateFile(). The Win32 API - * uses file handles, which are more randomish integers, not small - * integers like file descriptors. - * - * Because file descriptors are specific to the C library on Windows, - * the file descriptor returned by this function makes sense only to - * functions in the same C library. Thus if the GLib-using code uses a - * different C library than GLib does, the file descriptor returned by - * this function cannot be passed to C library functions like write() - * or read(). - * - * See your C library manual for more details about open(). - * - * Returns: a new file descriptor, or -1 if an error occurred. - * The return value can be used exactly like the return value - * from open(). - * Since: 2.6 - */ - - -/** - * g_option_context_add_group: - * @context: a #GOptionContext - * @group: (transfer full): the group to add - * - * Adds a #GOptionGroup to the @context, so that parsing with @context - * will recognize the options in the group. Note that this will take - * ownership of the @group and thus the @group should not be freed. - * - * Since: 2.6 - */ - - -/** - * g_option_context_add_main_entries: - * @context: a #GOptionContext - * @entries: (array zero-terminated=1): a %NULL-terminated array of #GOptionEntrys - * @translation_domain: (nullable): a translation domain to use for translating - * the `--help` output for the options in @entries - * with gettext(), or %NULL - * - * A convenience function which creates a main group if it doesn't - * exist, adds the @entries to it and sets the translation domain. - * - * Since: 2.6 - */ - - -/** - * g_option_context_free: - * @context: a #GOptionContext - * - * Frees context and all the groups which have been - * added to it. - * - * Please note that parsed arguments need to be freed separately (see - * #GOptionEntry). - * - * Since: 2.6 - */ - - -/** - * g_option_context_get_description: - * @context: a #GOptionContext - * - * Returns the description. See g_option_context_set_description(). - * - * Returns: the description - * Since: 2.12 - */ - - -/** - * g_option_context_get_help: - * @context: a #GOptionContext - * @main_help: if %TRUE, only include the main group - * @group: (nullable): the #GOptionGroup to create help for, or %NULL - * - * Returns a formatted, translated help text for the given context. - * To obtain the text produced by `--help`, call - * `g_option_context_get_help (context, TRUE, NULL)`. - * To obtain the text produced by `--help-all`, call - * `g_option_context_get_help (context, FALSE, NULL)`. - * To obtain the help text for an option group, call - * `g_option_context_get_help (context, FALSE, group)`. - * - * Returns: A newly allocated string containing the help text - * Since: 2.14 - */ - - -/** - * g_option_context_get_help_enabled: - * @context: a #GOptionContext - * - * Returns whether automatic `--help` generation - * is turned on for @context. See g_option_context_set_help_enabled(). - * - * Returns: %TRUE if automatic help generation is turned on. - * Since: 2.6 - */ - - -/** - * g_option_context_get_ignore_unknown_options: - * @context: a #GOptionContext - * - * Returns whether unknown options are ignored or not. See - * g_option_context_set_ignore_unknown_options(). - * - * Returns: %TRUE if unknown options are ignored. - * Since: 2.6 - */ - - -/** - * g_option_context_get_main_group: - * @context: a #GOptionContext - * - * Returns a pointer to the main group of @context. - * - * Returns: (transfer none): the main group of @context, or %NULL if - * @context doesn't have a main group. Note that group belongs to - * @context and should not be modified or freed. - * Since: 2.6 - */ - - -/** - * g_option_context_get_strict_posix: - * @context: a #GOptionContext - * - * Returns whether strict POSIX code is enabled. - * - * See g_option_context_set_strict_posix() for more information. - * - * Returns: %TRUE if strict POSIX is enabled, %FALSE otherwise. - * Since: 2.44 - */ - - -/** - * g_option_context_get_summary: - * @context: a #GOptionContext - * - * Returns the summary. See g_option_context_set_summary(). - * - * Returns: the summary - * Since: 2.12 - */ - - -/** - * g_option_context_new: - * @parameter_string: (nullable): a string which is displayed in - * the first line of `--help` output, after the usage summary - * `programname [OPTION...]` - * - * Creates a new option context. - * - * The @parameter_string can serve multiple purposes. It can be used - * to add descriptions for "rest" arguments, which are not parsed by - * the #GOptionContext, typically something like "FILES" or - * "FILE1 FILE2...". If you are using #G_OPTION_REMAINING for - * collecting "rest" arguments, GLib handles this automatically by - * using the @arg_description of the corresponding #GOptionEntry in - * the usage summary. - * - * Another usage is to give a short summary of the program - * functionality, like " - frob the strings", which will be displayed - * in the same line as the usage. For a longer description of the - * program functionality that should be displayed as a paragraph - * below the usage line, use g_option_context_set_summary(). - * - * Note that the @parameter_string is translated using the - * function set with g_option_context_set_translate_func(), so - * it should normally be passed untranslated. - * - * Returns: a newly created #GOptionContext, which must be - * freed with g_option_context_free() after use. - * Since: 2.6 - */ - - -/** - * g_option_context_parse: - * @context: a #GOptionContext - * @argc: (inout) (optional): a pointer to the number of command line arguments - * @argv: (inout) (array length=argc) (optional): a pointer to the array of command line arguments - * @error: a return location for errors - * - * Parses the command line arguments, recognizing options - * which have been added to @context. A side-effect of - * calling this function is that g_set_prgname() will be - * called. - * - * If the parsing is successful, any parsed arguments are - * removed from the array and @argc and @argv are updated - * accordingly. A '--' option is stripped from @argv - * unless there are unparsed options before and after it, - * or some of the options after it start with '-'. In case - * of an error, @argc and @argv are left unmodified. - * - * If automatic `--help` support is enabled - * (see g_option_context_set_help_enabled()), and the - * @argv array contains one of the recognized help options, - * this function will produce help output to stdout and - * call `exit (0)`. - * - * Note that function depends on the [current locale][setlocale] for - * automatic character set conversion of string and filename - * arguments. - * - * Returns: %TRUE if the parsing was successful, - * %FALSE if an error occurred - * Since: 2.6 - */ - - -/** - * g_option_context_parse_strv: - * @context: a #GOptionContext - * @arguments: (inout) (array null-terminated=1) (optional): a pointer - * to the command line arguments (which must be in UTF-8 on Windows). - * Starting with GLib 2.62, @arguments can be %NULL, which matches - * g_option_context_parse(). - * @error: a return location for errors - * - * Parses the command line arguments. - * - * This function is similar to g_option_context_parse() except that it - * respects the normal memory rules when dealing with a strv instead of - * assuming that the passed-in array is the argv of the main function. - * - * In particular, strings that are removed from the arguments list will - * be freed using g_free(). - * - * On Windows, the strings are expected to be in UTF-8. This is in - * contrast to g_option_context_parse() which expects them to be in the - * system codepage, which is how they are passed as @argv to main(). - * See g_win32_get_command_line() for a solution. - * - * This function is useful if you are trying to use #GOptionContext with - * #GApplication. - * - * Returns: %TRUE if the parsing was successful, - * %FALSE if an error occurred - * Since: 2.40 - */ - - -/** - * g_option_context_set_description: - * @context: a #GOptionContext - * @description: (nullable): a string to be shown in `--help` output - * after the list of options, or %NULL - * - * Adds a string to be displayed in `--help` output after the list - * of options. This text often includes a bug reporting address. - * - * Note that the summary is translated (see - * g_option_context_set_translate_func()). - * - * Since: 2.12 - */ - - -/** - * g_option_context_set_help_enabled: - * @context: a #GOptionContext - * @help_enabled: %TRUE to enable `--help`, %FALSE to disable it - * - * Enables or disables automatic generation of `--help` output. - * By default, g_option_context_parse() recognizes `--help`, `-h`, - * `-?`, `--help-all` and `--help-groupname` and creates suitable - * output to stdout. - * - * Since: 2.6 - */ - - -/** - * g_option_context_set_ignore_unknown_options: - * @context: a #GOptionContext - * @ignore_unknown: %TRUE to ignore unknown options, %FALSE to produce - * an error when unknown options are met - * - * Sets whether to ignore unknown options or not. If an argument is - * ignored, it is left in the @argv array after parsing. By default, - * g_option_context_parse() treats unknown options as error. - * - * This setting does not affect non-option arguments (i.e. arguments - * which don't start with a dash). But note that GOption cannot reliably - * determine whether a non-option belongs to a preceding unknown option. - * - * Since: 2.6 - */ - - -/** - * g_option_context_set_main_group: - * @context: a #GOptionContext - * @group: (transfer full): the group to set as main group - * - * Sets a #GOptionGroup as main group of the @context. - * This has the same effect as calling g_option_context_add_group(), - * the only difference is that the options in the main group are - * treated differently when generating `--help` output. - * - * Since: 2.6 - */ - - -/** - * g_option_context_set_strict_posix: - * @context: a #GOptionContext - * @strict_posix: the new value - * - * Sets strict POSIX mode. - * - * By default, this mode is disabled. - * - * In strict POSIX mode, the first non-argument parameter encountered - * (eg: filename) terminates argument processing. Remaining arguments - * are treated as non-options and are not attempted to be parsed. - * - * If strict POSIX mode is disabled then parsing is done in the GNU way - * where option arguments can be freely mixed with non-options. - * - * As an example, consider "ls foo -l". With GNU style parsing, this - * will list "foo" in long mode. In strict POSIX style, this will list - * the files named "foo" and "-l". - * - * It may be useful to force strict POSIX mode when creating "verb - * style" command line tools. For example, the "gsettings" command line - * tool supports the global option "--schemadir" as well as many - * subcommands ("get", "set", etc.) which each have their own set of - * arguments. Using strict POSIX mode will allow parsing the global - * options up to the verb name while leaving the remaining options to be - * parsed by the relevant subcommand (which can be determined by - * examining the verb name, which should be present in argv[1] after - * parsing). - * - * Since: 2.44 - */ - - -/** - * g_option_context_set_summary: - * @context: a #GOptionContext - * @summary: (nullable): a string to be shown in `--help` output - * before the list of options, or %NULL - * - * Adds a string to be displayed in `--help` output before the list - * of options. This is typically a summary of the program functionality. - * - * Note that the summary is translated (see - * g_option_context_set_translate_func() and - * g_option_context_set_translation_domain()). - * - * Since: 2.12 - */ - - -/** - * g_option_context_set_translate_func: - * @context: a #GOptionContext - * @func: (nullable): the #GTranslateFunc, or %NULL - * @data: (nullable): user data to pass to @func, or %NULL - * @destroy_notify: (nullable): a function which gets called to free @data, or %NULL - * - * Sets the function which is used to translate the contexts - * user-visible strings, for `--help` output. If @func is %NULL, - * strings are not translated. - * - * Note that option groups have their own translation functions, - * this function only affects the @parameter_string (see g_option_context_new()), - * the summary (see g_option_context_set_summary()) and the description - * (see g_option_context_set_description()). - * - * If you are using gettext(), you only need to set the translation - * domain, see g_option_context_set_translation_domain(). - * - * Since: 2.12 - */ - - -/** - * g_option_context_set_translation_domain: - * @context: a #GOptionContext - * @domain: the domain to use - * - * A convenience function to use gettext() for translating - * user-visible strings. - * - * Since: 2.12 - */ - - -/** - * g_option_group_add_entries: - * @group: a #GOptionGroup - * @entries: (array zero-terminated=1): a %NULL-terminated array of #GOptionEntrys - * - * Adds the options specified in @entries to @group. - * - * Since: 2.6 - */ - - -/** - * g_option_group_free: - * @group: a #GOptionGroup - * - * Frees a #GOptionGroup. Note that you must not free groups - * which have been added to a #GOptionContext. - * - * Since: 2.6 - * Deprecated: 2.44: Use g_option_group_unref() instead. - */ - - -/** - * g_option_group_new: - * @name: the name for the option group, this is used to provide - * help for the options in this group with `--help-`@name - * @description: a description for this group to be shown in - * `--help`. This string is translated using the translation - * domain or translation function of the group - * @help_description: a description for the `--help-`@name option. - * This string is translated using the translation domain or translation function - * of the group - * @user_data: (nullable): user data that will be passed to the pre- and post-parse hooks, - * the error hook and to callbacks of %G_OPTION_ARG_CALLBACK options, or %NULL - * @destroy: (nullable): a function that will be called to free @user_data, or %NULL - * - * Creates a new #GOptionGroup. - * - * Returns: a newly created option group. It should be added - * to a #GOptionContext or freed with g_option_group_unref(). - * Since: 2.6 - */ - - -/** - * g_option_group_ref: - * @group: a #GOptionGroup - * - * Increments the reference count of @group by one. - * - * Returns: a #GOptionGroup - * Since: 2.44 - */ - - -/** - * g_option_group_set_error_hook: - * @group: a #GOptionGroup - * @error_func: a function to call when an error occurs - * - * Associates a function with @group which will be called - * from g_option_context_parse() when an error occurs. - * - * Note that the user data to be passed to @error_func can be - * specified when constructing the group with g_option_group_new(). - * - * Since: 2.6 - */ - - -/** - * g_option_group_set_parse_hooks: - * @group: a #GOptionGroup - * @pre_parse_func: (nullable): a function to call before parsing, or %NULL - * @post_parse_func: (nullable): a function to call after parsing, or %NULL - * - * Associates two functions with @group which will be called - * from g_option_context_parse() before the first option is parsed - * and after the last option has been parsed, respectively. - * - * Note that the user data to be passed to @pre_parse_func and - * @post_parse_func can be specified when constructing the group - * with g_option_group_new(). - * - * Since: 2.6 - */ - - -/** - * g_option_group_set_translate_func: - * @group: a #GOptionGroup - * @func: (nullable): the #GTranslateFunc, or %NULL - * @data: (nullable): user data to pass to @func, or %NULL - * @destroy_notify: (nullable): a function which gets called to free @data, or %NULL - * - * Sets the function which is used to translate user-visible strings, - * for `--help` output. Different groups can use different - * #GTranslateFuncs. If @func is %NULL, strings are not translated. - * - * If you are using gettext(), you only need to set the translation - * domain, see g_option_group_set_translation_domain(). - * - * Since: 2.6 - */ - - -/** - * g_option_group_set_translation_domain: - * @group: a #GOptionGroup - * @domain: the domain to use - * - * A convenience function to use gettext() for translating - * user-visible strings. - * - * Since: 2.6 - */ - - -/** - * g_option_group_unref: - * @group: a #GOptionGroup - * - * Decrements the reference count of @group by one. - * If the reference count drops to 0, the @group will be freed. - * and all memory allocated by the @group is released. - * - * Since: 2.44 - */ - - -/** - * g_parse_debug_string: - * @string: (nullable): a list of debug options separated by colons, spaces, or - * commas, or %NULL. - * @keys: (array length=nkeys): pointer to an array of #GDebugKey which associate - * strings with bit flags. - * @nkeys: the number of #GDebugKeys in the array. - * - * Parses a string containing debugging options - * into a %guint containing bit flags. This is used - * within GDK and GTK+ to parse the debug options passed on the - * command line or through environment variables. - * - * If @string is equal to "all", all flags are set. Any flags - * specified along with "all" in @string are inverted; thus, - * "all,foo,bar" or "foo,bar,all" sets all flags except those - * corresponding to "foo" and "bar". - * - * If @string is equal to "help", all the available keys in @keys - * are printed out to standard error. - * - * Returns: the combined set of bit flags. - */ - - -/** - * g_path_get_basename: - * @file_name: (type filename): the name of the file - * - * Gets the last component of the filename. - * - * If @file_name ends with a directory separator it gets the component - * before the last slash. If @file_name consists only of directory - * separators (and on Windows, possibly a drive letter), a single - * separator is returned. If @file_name is empty, it gets ".". - * - * Returns: (type filename): a newly allocated string containing the last - * component of the filename - */ - - -/** - * g_path_get_dirname: - * @file_name: (type filename): the name of the file - * - * Gets the directory components of a file name. For example, the directory - * component of `/usr/bin/test` is `/usr/bin`. The directory component of `/` - * is `/`. - * - * If the file name has no directory components "." is returned. - * The returned string should be freed when no longer needed. - * - * Returns: (type filename): the directory components of the file - */ - - -/** - * g_path_is_absolute: - * @file_name: (type filename): a file name - * - * Returns %TRUE if the given @file_name is an absolute file name. - * Note that this is a somewhat vague concept on Windows. - * - * On POSIX systems, an absolute file name is well-defined. It always - * starts from the single root directory. For example "/usr/local". - * - * On Windows, the concepts of current drive and drive-specific - * current directory introduce vagueness. This function interprets as - * an absolute file name one that either begins with a directory - * separator such as "\Users\tml" or begins with the root on a drive, - * for example "C:\Windows". The first case also includes UNC paths - * such as "\\\\myserver\docs\foo". In all cases, either slashes or - * backslashes are accepted. - * - * Note that a file name relative to the current drive root does not - * truly specify a file uniquely over time and across processes, as - * the current drive is a per-process value and can be changed. - * - * File names relative the current directory on some specific drive, - * such as "D:foo/bar", are not interpreted as absolute by this - * function, but they obviously are not relative to the normal current - * directory as returned by getcwd() or g_get_current_dir() - * either. Such paths should be avoided, or need to be handled using - * Windows-specific code. - * - * Returns: %TRUE if @file_name is absolute - */ - - -/** - * g_path_skip_root: - * @file_name: (type filename): a file name - * - * Returns a pointer into @file_name after the root component, - * i.e. after the "/" in UNIX or "C:\" under Windows. If @file_name - * is not an absolute path it returns %NULL. - * - * Returns: (type filename) (nullable): a pointer into @file_name after the - * root component - */ - - -/** - * g_pattern_match: (skip) - * @pspec: a #GPatternSpec - * @string_length: the length of @string (in bytes, i.e. strlen(), - * not g_utf8_strlen()) - * @string: the UTF-8 encoded string to match - * @string_reversed: (nullable): the reverse of @string or %NULL - * - * Matches a string against a compiled pattern. Passing the correct - * length of the string given is mandatory. The reversed string can be - * omitted by passing %NULL, this is more efficient if the reversed - * version of the string to be matched is not at hand, as - * g_pattern_match() will only construct it if the compiled pattern - * requires reverse matches. - * - * Note that, if the user code will (possibly) match a string against a - * multitude of patterns containing wildcards, chances are high that - * some patterns will require a reversed string. In this case, it's - * more efficient to provide the reversed string to avoid multiple - * constructions thereof in the various calls to g_pattern_match(). - * - * Note also that the reverse of a UTF-8 encoded string can in general - * not be obtained by g_strreverse(). This works only if the string - * does not contain any multibyte characters. GLib offers the - * g_utf8_strreverse() function to reverse UTF-8 encoded strings. - * - * Returns: %TRUE if @string matches @pspec - * Deprecated: 2.70: Use g_pattern_spec_match() instead - */ - - -/** - * g_pattern_match_simple: - * @pattern: the UTF-8 encoded pattern - * @string: the UTF-8 encoded string to match - * - * Matches a string against a pattern given as a string. If this - * function is to be called in a loop, it's more efficient to compile - * the pattern once with g_pattern_spec_new() and call - * g_pattern_match_string() repeatedly. - * - * Returns: %TRUE if @string matches @pspec - */ - - -/** - * g_pattern_match_string: (skip) - * @pspec: a #GPatternSpec - * @string: the UTF-8 encoded string to match - * - * Matches a string against a compiled pattern. If the string is to be - * matched against more than one pattern, consider using - * g_pattern_match() instead while supplying the reversed string. - * - * Returns: %TRUE if @string matches @pspec - * Deprecated: 2.70: Use g_pattern_spec_match_string() instead - */ - - -/** - * g_pattern_spec_copy: - * @pspec: a #GPatternSpec - * - * Copies @pspec in a new #GPatternSpec. - * - * Returns: (transfer full): a copy of @pspec. - * Since: 2.70 - */ - - -/** - * g_pattern_spec_equal: - * @pspec1: a #GPatternSpec - * @pspec2: another #GPatternSpec - * - * Compares two compiled pattern specs and returns whether they will - * match the same set of strings. - * - * Returns: Whether the compiled patterns are equal - */ - - -/** - * g_pattern_spec_free: - * @pspec: a #GPatternSpec - * - * Frees the memory allocated for the #GPatternSpec. - */ - - -/** - * g_pattern_spec_match: - * @pspec: a #GPatternSpec - * @string_length: the length of @string (in bytes, i.e. strlen(), - * not g_utf8_strlen()) - * @string: the UTF-8 encoded string to match - * @string_reversed: (nullable): the reverse of @string or %NULL - * - * Matches a string against a compiled pattern. Passing the correct - * length of the string given is mandatory. The reversed string can be - * omitted by passing %NULL, this is more efficient if the reversed - * version of the string to be matched is not at hand, as - * g_pattern_match() will only construct it if the compiled pattern - * requires reverse matches. - * - * Note that, if the user code will (possibly) match a string against a - * multitude of patterns containing wildcards, chances are high that - * some patterns will require a reversed string. In this case, it's - * more efficient to provide the reversed string to avoid multiple - * constructions thereof in the various calls to g_pattern_match(). - * - * Note also that the reverse of a UTF-8 encoded string can in general - * not be obtained by g_strreverse(). This works only if the string - * does not contain any multibyte characters. GLib offers the - * g_utf8_strreverse() function to reverse UTF-8 encoded strings. - * - * Returns: %TRUE if @string matches @pspec - * Since: 2.70 - */ - - -/** - * g_pattern_spec_match_string: - * @pspec: a #GPatternSpec - * @string: the UTF-8 encoded string to match - * - * Matches a string against a compiled pattern. If the string is to be - * matched against more than one pattern, consider using - * g_pattern_match() instead while supplying the reversed string. - * - * Returns: %TRUE if @string matches @pspec - * Since: 2.70 - */ - - -/** - * g_pattern_spec_new: - * @pattern: a zero-terminated UTF-8 encoded string - * - * Compiles a pattern to a #GPatternSpec. - * - * Returns: a newly-allocated #GPatternSpec - */ - - -/** - * g_pointer_bit_lock: - * @address: (not nullable): a pointer to a #gpointer-sized value - * @lock_bit: a bit value between 0 and 31 - * - * This is equivalent to g_bit_lock, but working on pointers (or other - * pointer-sized values). - * - * For portability reasons, you may only lock on the bottom 32 bits of - * the pointer. - * - * While @address has a `volatile` qualifier, this is a historical - * artifact and the argument passed to it should not be `volatile`. - * - * Since: 2.30 - */ - - -/** - * g_pointer_bit_trylock: - * @address: (not nullable): a pointer to a #gpointer-sized value - * @lock_bit: a bit value between 0 and 31 - * - * This is equivalent to g_bit_trylock(), but working on pointers (or - * other pointer-sized values). - * - * For portability reasons, you may only lock on the bottom 32 bits of - * the pointer. - * - * While @address has a `volatile` qualifier, this is a historical - * artifact and the argument passed to it should not be `volatile`. - * - * Returns: %TRUE if the lock was acquired - * Since: 2.30 - */ - - -/** - * g_pointer_bit_unlock: - * @address: (not nullable): a pointer to a #gpointer-sized value - * @lock_bit: a bit value between 0 and 31 - * - * This is equivalent to g_bit_unlock, but working on pointers (or other - * pointer-sized values). - * - * For portability reasons, you may only lock on the bottom 32 bits of - * the pointer. - * - * While @address has a `volatile` qualifier, this is a historical - * artifact and the argument passed to it should not be `volatile`. - * - * Since: 2.30 - */ - - -/** - * g_poll: - * @fds: file descriptors to poll - * @nfds: the number of file descriptors in @fds - * @timeout: amount of time to wait, in milliseconds, or -1 to wait forever - * - * Polls @fds, as with the poll() system call, but portably. (On - * systems that don't have poll(), it is emulated using select().) - * This is used internally by #GMainContext, but it can be called - * directly if you need to block until a file descriptor is ready, but - * don't want to run the full main loop. - * - * Each element of @fds is a #GPollFD describing a single file - * descriptor to poll. The @fd field indicates the file descriptor, - * and the @events field indicates the events to poll for. On return, - * the @revents fields will be filled with the events that actually - * occurred. - * - * On POSIX systems, the file descriptors in @fds can be any sort of - * file descriptor, but the situation is much more complicated on - * Windows. If you need to use g_poll() in code that has to run on - * Windows, the easiest solution is to construct all of your - * #GPollFDs with g_io_channel_win32_make_pollfd(). - * - * Returns: the number of entries in @fds whose @revents fields - * were filled in, or 0 if the operation timed out, or -1 on error or - * if the call was interrupted. - * Since: 2.20 - */ - - -/** - * g_prefix_error: - * @err: (inout) (optional) (nullable): a return location for a #GError - * @format: printf()-style format string - * @...: arguments to @format - * - * Formats a string according to @format and prefix it to an existing - * error message. If @err is %NULL (ie: no error variable) then do - * nothing. - * - * If *@err is %NULL (ie: an error variable is present but there is no - * error condition) then also do nothing. - * - * Since: 2.16 - */ - - -/** - * g_prefix_error_literal: - * @err: (allow-none): a return location for a #GError, or %NULL - * @prefix: string to prefix @err with - * - * Prefixes @prefix to an existing error message. If @err or *@err is - * %NULL (i.e.: no error variable) then do nothing. - * - * Since: 2.70 - */ - - -/** - * g_print: - * @format: the message format. See the printf() documentation - * @...: the parameters to insert into the format string - * - * Outputs a formatted message via the print handler. - * The default print handler simply outputs the message to stdout, without - * appending a trailing new-line character. Typically, @format should end with - * its own new-line character. - * - * g_print() should not be used from within libraries for debugging - * messages, since it may be redirected by applications to special - * purpose message windows or even files. Instead, libraries should - * use g_log(), g_log_structured(), or the convenience macros g_message(), - * g_warning() and g_error(). - */ - - -/** - * g_printerr: - * @format: the message format. See the printf() documentation - * @...: the parameters to insert into the format string - * - * Outputs a formatted message via the error message handler. - * The default handler simply outputs the message to stderr, without appending - * a trailing new-line character. Typically, @format should end with its own - * new-line character. - * - * g_printerr() should not be used from within libraries. - * Instead g_log() or g_log_structured() should be used, or the convenience - * macros g_message(), g_warning() and g_error(). - */ - - -/** - * g_printf: - * @format: a standard printf() format string, but notice - * [string precision pitfalls][string-precision] - * @...: the arguments to insert in the output. - * - * An implementation of the standard printf() function which supports - * positional parameters, as specified in the Single Unix Specification. - * - * As with the standard printf(), this does not automatically append a trailing - * new-line character to the message, so typically @format should end with its - * own new-line character. - * - * `glib/gprintf.h` must be explicitly included in order to use this function. - * - * Returns: the number of bytes printed. - * Since: 2.2 - */ - - -/** - * g_printf_string_upper_bound: - * @format: the format string. See the printf() documentation - * @args: the parameters to be inserted into the format string - * - * Calculates the maximum space needed to store the output - * of the sprintf() function. - * - * Returns: the maximum space needed to store the formatted string - */ - - -/** - * g_private_get: - * @key: a #GPrivate - * - * Returns the current value of the thread local variable @key. - * - * If the value has not yet been set in this thread, %NULL is returned. - * Values are never copied between threads (when a new thread is - * created, for example). - * - * Returns: the thread-local value - */ - - -/** - * g_private_replace: - * @key: a #GPrivate - * @value: the new value - * - * Sets the thread local variable @key to have the value @value in the - * current thread. - * - * This function differs from g_private_set() in the following way: if - * the previous value was non-%NULL then the #GDestroyNotify handler for - * @key is run on it. - * - * Since: 2.32 - */ - - -/** - * g_private_set: - * @key: a #GPrivate - * @value: the new value - * - * Sets the thread local variable @key to have the value @value in the - * current thread. - * - * This function differs from g_private_replace() in the following way: - * the #GDestroyNotify for @key is not called on the old value. - */ - - -/** - * g_propagate_error: - * @dest: (out callee-allocates) (optional) (nullable): error return location - * @src: (transfer full): error to move into the return location - * - * If @dest is %NULL, free @src; otherwise, moves @src into *@dest. - * The error variable @dest points to must be %NULL. - * - * @src must be non-%NULL. - * - * Note that @src is no longer valid after this call. If you want - * to keep using the same GError*, you need to set it to %NULL - * after calling this function on it. - */ - - -/** - * g_propagate_prefixed_error: - * @dest: error return location - * @src: error to move into the return location - * @format: printf()-style format string - * @...: arguments to @format - * - * If @dest is %NULL, free @src; otherwise, moves @src into *@dest. - * *@dest must be %NULL. After the move, add a prefix as with - * g_prefix_error(). - * - * Since: 2.16 - */ - - -/** - * g_ptr_array_add: - * @array: a #GPtrArray - * @data: the pointer to add - * - * Adds a pointer to the end of the pointer array. The array will grow - * in size automatically if necessary. - */ - - -/** - * g_ptr_array_copy: - * @array: #GPtrArray to duplicate - * @func: (nullable): a copy function used to copy every element in the array - * @user_data: user data passed to the copy function @func, or %NULL - * - * Makes a full (deep) copy of a #GPtrArray. - * - * @func, as a #GCopyFunc, takes two arguments, the data to be copied - * and a @user_data pointer. On common processor architectures, it's safe to - * pass %NULL as @user_data if the copy function takes only one argument. You - * may get compiler warnings from this though if compiling with GCC’s - * `-Wcast-function-type` warning. - * - * If @func is %NULL, then only the pointers (and not what they are - * pointing to) are copied to the new #GPtrArray. - * - * The copy of @array will have the same #GDestroyNotify for its elements as - * @array. - * - * Returns: (transfer full): a deep copy of the initial #GPtrArray. - * Since: 2.62 - */ - - -/** - * g_ptr_array_extend: - * @array_to_extend: a #GPtrArray. - * @array: (transfer none): a #GPtrArray to add to the end of @array_to_extend. - * @func: (nullable): a copy function used to copy every element in the array - * @user_data: user data passed to the copy function @func, or %NULL - * - * Adds all pointers of @array to the end of the array @array_to_extend. - * The array will grow in size automatically if needed. @array_to_extend is - * modified in-place. - * - * @func, as a #GCopyFunc, takes two arguments, the data to be copied - * and a @user_data pointer. On common processor architectures, it's safe to - * pass %NULL as @user_data if the copy function takes only one argument. You - * may get compiler warnings from this though if compiling with GCC’s - * `-Wcast-function-type` warning. - * - * If @func is %NULL, then only the pointers (and not what they are - * pointing to) are copied to the new #GPtrArray. - * - * Since: 2.62 - */ - - -/** - * g_ptr_array_extend_and_steal: - * @array_to_extend: (transfer none): a #GPtrArray. - * @array: (transfer container): a #GPtrArray to add to the end of - * @array_to_extend. - * - * Adds all the pointers in @array to the end of @array_to_extend, transferring - * ownership of each element from @array to @array_to_extend and modifying - * @array_to_extend in-place. @array is then freed. - * - * As with g_ptr_array_free(), @array will be destroyed if its reference count - * is 1. If its reference count is higher, it will be decremented and the - * length of @array set to zero. - * - * Since: 2.62 - */ - - -/** - * g_ptr_array_find: (skip) - * @haystack: pointer array to be searched - * @needle: pointer to look for - * @index_: (optional) (out): return location for the index of - * the element, if found - * - * Checks whether @needle exists in @haystack. If the element is found, %TRUE is - * returned and the element’s index is returned in @index_ (if non-%NULL). - * Otherwise, %FALSE is returned and @index_ is undefined. If @needle exists - * multiple times in @haystack, the index of the first instance is returned. - * - * This does pointer comparisons only. If you want to use more complex equality - * checks, such as string comparisons, use g_ptr_array_find_with_equal_func(). - * - * Returns: %TRUE if @needle is one of the elements of @haystack - * Since: 2.54 - */ - - -/** - * g_ptr_array_find_with_equal_func: (skip) - * @haystack: pointer array to be searched - * @needle: pointer to look for - * @equal_func: (nullable): the function to call for each element, which should - * return %TRUE when the desired element is found; or %NULL to use pointer - * equality - * @index_: (optional) (out): return location for the index of - * the element, if found - * - * Checks whether @needle exists in @haystack, using the given @equal_func. - * If the element is found, %TRUE is returned and the element’s index is - * returned in @index_ (if non-%NULL). Otherwise, %FALSE is returned and @index_ - * is undefined. If @needle exists multiple times in @haystack, the index of - * the first instance is returned. - * - * @equal_func is called with the element from the array as its first parameter, - * and @needle as its second parameter. If @equal_func is %NULL, pointer - * equality is used. - * - * Returns: %TRUE if @needle is one of the elements of @haystack - * Since: 2.54 - */ - - -/** - * g_ptr_array_foreach: - * @array: a #GPtrArray - * @func: the function to call for each array element - * @user_data: user data to pass to the function - * - * Calls a function for each element of a #GPtrArray. @func must not - * add elements to or remove elements from the array. - * - * Since: 2.4 - */ - - -/** - * g_ptr_array_free: - * @array: a #GPtrArray - * @free_seg: if %TRUE the actual pointer array is freed as well - * - * Frees the memory allocated for the #GPtrArray. If @free_seg is %TRUE - * it frees the memory block holding the elements as well. Pass %FALSE - * if you want to free the #GPtrArray wrapper but preserve the - * underlying array for use elsewhere. If the reference count of @array - * is greater than one, the #GPtrArray wrapper is preserved but the - * size of @array will be set to zero. - * - * If array contents point to dynamically-allocated memory, they should - * be freed separately if @free_seg is %TRUE and no #GDestroyNotify - * function has been set for @array. - * - * This function is not thread-safe. If using a #GPtrArray from multiple - * threads, use only the atomic g_ptr_array_ref() and g_ptr_array_unref() - * functions. - * - * Returns: (transfer full) (nullable): the pointer array if @free_seg is - * %FALSE, otherwise %NULL. The pointer array should be freed using g_free(). - */ - - -/** - * g_ptr_array_index: - * @array: a #GPtrArray - * @index_: the index of the pointer to return - * - * Returns the pointer at the given index of the pointer array. - * - * This does not perform bounds checking on the given @index_, - * so you are responsible for checking it against the array length. - * - * Returns: the pointer at the given index - */ - - -/** - * g_ptr_array_insert: - * @array: a #GPtrArray - * @index_: the index to place the new element at, or -1 to append - * @data: the pointer to add. - * - * Inserts an element into the pointer array at the given index. The - * array will grow in size automatically if necessary. - * - * Since: 2.40 - */ - - -/** - * g_ptr_array_new: - * - * Creates a new #GPtrArray with a reference count of 1. - * - * Returns: the new #GPtrArray - */ - - -/** - * g_ptr_array_new_full: - * @reserved_size: number of pointers preallocated - * @element_free_func: (nullable): A function to free elements with - * destroy @array or %NULL - * - * Creates a new #GPtrArray with @reserved_size pointers preallocated - * and a reference count of 1. This avoids frequent reallocation, if - * you are going to add many pointers to the array. Note however that - * the size of the array is still 0. It also set @element_free_func - * for freeing each element when the array is destroyed either via - * g_ptr_array_unref(), when g_ptr_array_free() is called with - * @free_segment set to %TRUE or when removing elements. - * - * Returns: A new #GPtrArray - * Since: 2.30 - */ - - -/** - * g_ptr_array_new_with_free_func: - * @element_free_func: (nullable): A function to free elements with - * destroy @array or %NULL - * - * Creates a new #GPtrArray with a reference count of 1 and use - * @element_free_func for freeing each element when the array is destroyed - * either via g_ptr_array_unref(), when g_ptr_array_free() is called with - * @free_segment set to %TRUE or when removing elements. - * - * Returns: A new #GPtrArray - * Since: 2.22 - */ - - -/** - * g_ptr_array_ref: - * @array: a #GPtrArray - * - * Atomically increments the reference count of @array by one. - * This function is thread-safe and may be called from any thread. - * - * Returns: The passed in #GPtrArray - * Since: 2.22 - */ - - -/** - * g_ptr_array_remove: - * @array: a #GPtrArray - * @data: the pointer to remove - * - * Removes the first occurrence of the given pointer from the pointer - * array. The following elements are moved down one place. If @array - * has a non-%NULL #GDestroyNotify function it is called for the - * removed element. - * - * It returns %TRUE if the pointer was removed, or %FALSE if the - * pointer was not found. - * - * Returns: %TRUE if the pointer is removed, %FALSE if the pointer - * is not found in the array - */ - - -/** - * g_ptr_array_remove_fast: - * @array: a #GPtrArray - * @data: the pointer to remove - * - * Removes the first occurrence of the given pointer from the pointer - * array. The last element in the array is used to fill in the space, - * so this function does not preserve the order of the array. But it - * is faster than g_ptr_array_remove(). If @array has a non-%NULL - * #GDestroyNotify function it is called for the removed element. - * - * It returns %TRUE if the pointer was removed, or %FALSE if the - * pointer was not found. - * - * Returns: %TRUE if the pointer was found in the array - */ - - -/** - * g_ptr_array_remove_index: - * @array: a #GPtrArray - * @index_: the index of the pointer to remove - * - * Removes the pointer at the given index from the pointer array. - * The following elements are moved down one place. If @array has - * a non-%NULL #GDestroyNotify function it is called for the removed - * element. If so, the return value from this function will potentially point - * to freed memory (depending on the #GDestroyNotify implementation). - * - * Returns: (nullable): the pointer which was removed - */ - - -/** - * g_ptr_array_remove_index_fast: - * @array: a #GPtrArray - * @index_: the index of the pointer to remove - * - * Removes the pointer at the given index from the pointer array. - * The last element in the array is used to fill in the space, so - * this function does not preserve the order of the array. But it - * is faster than g_ptr_array_remove_index(). If @array has a non-%NULL - * #GDestroyNotify function it is called for the removed element. If so, the - * return value from this function will potentially point to freed memory - * (depending on the #GDestroyNotify implementation). - * - * Returns: (nullable): the pointer which was removed - */ - - -/** - * g_ptr_array_remove_range: - * @array: a @GPtrArray - * @index_: the index of the first pointer to remove - * @length: the number of pointers to remove - * - * Removes the given number of pointers starting at the given index - * from a #GPtrArray. The following elements are moved to close the - * gap. If @array has a non-%NULL #GDestroyNotify function it is - * called for the removed elements. - * - * Returns: the @array - * Since: 2.4 - */ - - -/** - * g_ptr_array_set_free_func: - * @array: A #GPtrArray - * @element_free_func: (nullable): A function to free elements with - * destroy @array or %NULL - * - * Sets a function for freeing each element when @array is destroyed - * either via g_ptr_array_unref(), when g_ptr_array_free() is called - * with @free_segment set to %TRUE or when removing elements. - * - * Since: 2.22 - */ - - -/** - * g_ptr_array_set_size: - * @array: a #GPtrArray - * @length: the new length of the pointer array - * - * Sets the size of the array. When making the array larger, - * newly-added elements will be set to %NULL. When making it smaller, - * if @array has a non-%NULL #GDestroyNotify function then it will be - * called for the removed elements. - */ - - -/** - * g_ptr_array_sized_new: - * @reserved_size: number of pointers preallocated - * - * Creates a new #GPtrArray with @reserved_size pointers preallocated - * and a reference count of 1. This avoids frequent reallocation, if - * you are going to add many pointers to the array. Note however that - * the size of the array is still 0. - * - * Returns: the new #GPtrArray - */ - - -/** - * g_ptr_array_sort: - * @array: a #GPtrArray - * @compare_func: comparison function - * - * Sorts the array, using @compare_func which should be a qsort()-style - * comparison function (returns less than zero for first arg is less - * than second arg, zero for equal, greater than zero if irst arg is - * greater than second arg). - * - * Note that the comparison function for g_ptr_array_sort() doesn't - * take the pointers from the array as arguments, it takes pointers to - * the pointers in the array. Here is a full example of usage: - * - * |[<!-- language="C" --> - * typedef struct - * { - * gchar *name; - * gint size; - * } FileListEntry; - * - * static gint - * sort_filelist (gconstpointer a, gconstpointer b) - * { - * const FileListEntry *entry1 = *((FileListEntry **) a); - * const FileListEntry *entry2 = *((FileListEntry **) b); - * - * return g_ascii_strcasecmp (entry1->name, entry2->name); - * } - * - * … - * g_autoptr (GPtrArray) file_list = NULL; - * - * // initialize file_list array and load with many FileListEntry entries - * ... - * // now sort it with - * g_ptr_array_sort (file_list, sort_filelist); - * ]| - * - * This is guaranteed to be a stable sort since version 2.32. - */ - - -/** - * g_ptr_array_sort_with_data: - * @array: a #GPtrArray - * @compare_func: comparison function - * @user_data: data to pass to @compare_func - * - * Like g_ptr_array_sort(), but the comparison function has an extra - * user data argument. - * - * Note that the comparison function for g_ptr_array_sort_with_data() - * doesn't take the pointers from the array as arguments, it takes - * pointers to the pointers in the array. Here is a full example of use: - * - * |[<!-- language="C" --> - * typedef enum { SORT_NAME, SORT_SIZE } SortMode; - * - * typedef struct - * { - * gchar *name; - * gint size; - * } FileListEntry; - * - * static gint - * sort_filelist (gconstpointer a, gconstpointer b, gpointer user_data) - * { - * gint order; - * const SortMode sort_mode = GPOINTER_TO_INT (user_data); - * const FileListEntry *entry1 = *((FileListEntry **) a); - * const FileListEntry *entry2 = *((FileListEntry **) b); - * - * switch (sort_mode) - * { - * case SORT_NAME: - * order = g_ascii_strcasecmp (entry1->name, entry2->name); - * break; - * case SORT_SIZE: - * order = entry1->size - entry2->size; - * break; - * default: - * order = 0; - * break; - * } - * return order; - * } - * - * ... - * g_autoptr (GPtrArray) file_list = NULL; - * SortMode sort_mode; - * - * // initialize file_list array and load with many FileListEntry entries - * ... - * // now sort it with - * sort_mode = SORT_NAME; - * g_ptr_array_sort_with_data (file_list, - * sort_filelist, - * GINT_TO_POINTER (sort_mode)); - * ]| - * - * This is guaranteed to be a stable sort since version 2.32. - */ - - -/** - * g_ptr_array_steal: - * @array: a #GPtrArray. - * @len: (optional) (out): pointer to retrieve the number of - * elements of the original array - * - * Frees the data in the array and resets the size to zero, while - * the underlying array is preserved for use elsewhere and returned - * to the caller. - * - * Even if set, the #GDestroyNotify function will never be called - * on the current contents of the array and the caller is - * responsible for freeing the array elements. - * - * An example of use: - * |[<!-- language="C" --> - * g_autoptr(GPtrArray) chunk_buffer = g_ptr_array_new_with_free_func (g_bytes_unref); - * - * // Some part of your application appends a number of chunks to the pointer array. - * g_ptr_array_add (chunk_buffer, g_bytes_new_static ("hello", 5)); - * g_ptr_array_add (chunk_buffer, g_bytes_new_static ("world", 5)); - * - * … - * - * // Periodically, the chunks need to be sent as an array-and-length to some - * // other part of the program. - * GBytes **chunks; - * gsize n_chunks; - * - * chunks = g_ptr_array_steal (chunk_buffer, &n_chunks); - * for (gsize i = 0; i < n_chunks; i++) - * { - * // Do something with each chunk here, and then free them, since - * // g_ptr_array_steal() transfers ownership of all the elements and the - * // array to the caller. - * … - * - * g_bytes_unref (chunks[i]); - * } - * - * g_free (chunks); - * - * // After calling g_ptr_array_steal(), the pointer array can be reused for the - * // next set of chunks. - * g_assert (chunk_buffer->len == 0); - * ]| - * - * Returns: (transfer full): the element data, which should be - * freed using g_free(). - * Since: 2.64 - */ - - -/** - * g_ptr_array_steal_index: - * @array: a #GPtrArray - * @index_: the index of the pointer to steal - * - * Removes the pointer at the given index from the pointer array. - * The following elements are moved down one place. The #GDestroyNotify for - * @array is *not* called on the removed element; ownership is transferred to - * the caller of this function. - * - * Returns: (transfer full) (nullable): the pointer which was removed - * Since: 2.58 - */ - - -/** - * g_ptr_array_steal_index_fast: - * @array: a #GPtrArray - * @index_: the index of the pointer to steal - * - * Removes the pointer at the given index from the pointer array. - * The last element in the array is used to fill in the space, so - * this function does not preserve the order of the array. But it - * is faster than g_ptr_array_steal_index(). The #GDestroyNotify for @array is - * *not* called on the removed element; ownership is transferred to the caller - * of this function. - * - * Returns: (transfer full) (nullable): the pointer which was removed - * Since: 2.58 - */ - - -/** - * g_ptr_array_unref: - * @array: A #GPtrArray - * - * Atomically decrements the reference count of @array by one. If the - * reference count drops to 0, the effect is the same as calling - * g_ptr_array_free() with @free_segment set to %TRUE. This function - * is thread-safe and may be called from any thread. - * - * Since: 2.22 - */ - - -/** - * g_qsort_with_data: - * @pbase: (not nullable): start of array to sort - * @total_elems: elements in the array - * @size: size of each element - * @compare_func: function to compare elements - * @user_data: data to pass to @compare_func - * - * This is just like the standard C qsort() function, but - * the comparison routine accepts a user data argument. - * - * This is guaranteed to be a stable sort since version 2.32. - */ - - -/** - * g_quark_from_static_string: - * @string: (nullable): a string - * - * Gets the #GQuark identifying the given (static) string. If the - * string does not currently have an associated #GQuark, a new #GQuark - * is created, linked to the given string. - * - * Note that this function is identical to g_quark_from_string() except - * that if a new #GQuark is created the string itself is used rather - * than a copy. This saves memory, but can only be used if the string - * will continue to exist until the program terminates. It can be used - * with statically allocated strings in the main program, but not with - * statically allocated memory in dynamically loaded modules, if you - * expect to ever unload the module again (e.g. do not use this - * function in GTK+ theme engines). - * - * This function must not be used before library constructors have finished - * running. In particular, this means it cannot be used to initialize global - * variables in C++. - * - * Returns: the #GQuark identifying the string, or 0 if @string is %NULL - */ - - -/** - * g_quark_from_string: - * @string: (nullable): a string - * - * Gets the #GQuark identifying the given string. If the string does - * not currently have an associated #GQuark, a new #GQuark is created, - * using a copy of the string. - * - * This function must not be used before library constructors have finished - * running. In particular, this means it cannot be used to initialize global - * variables in C++. - * - * Returns: the #GQuark identifying the string, or 0 if @string is %NULL - */ - - -/** - * g_quark_to_string: - * @quark: a #GQuark. - * - * Gets the string associated with the given #GQuark. - * - * Returns: the string associated with the #GQuark - */ - - -/** - * g_quark_try_string: - * @string: (nullable): a string - * - * Gets the #GQuark associated with the given string, or 0 if string is - * %NULL or it has no associated #GQuark. - * - * If you want the GQuark to be created if it doesn't already exist, - * use g_quark_from_string() or g_quark_from_static_string(). - * - * This function must not be used before library constructors have finished - * running. - * - * Returns: the #GQuark associated with the string, or 0 if @string is - * %NULL or there is no #GQuark associated with it - */ - - -/** - * g_queue_clear: - * @queue: a #GQueue - * - * Removes all the elements in @queue. If queue elements contain - * dynamically-allocated memory, they should be freed first. - * - * Since: 2.14 - */ - - -/** - * g_queue_clear_full: - * @queue: a pointer to a #GQueue - * @free_func: (nullable): the function to be called to free memory allocated - * - * Convenience method, which frees all the memory used by a #GQueue, - * and calls the provided @free_func on each item in the #GQueue. - * - * Since: 2.60 - */ - - -/** - * g_queue_copy: - * @queue: a #GQueue - * - * Copies a @queue. Note that is a shallow copy. If the elements in the - * queue consist of pointers to data, the pointers are copied, but the - * actual data is not. - * - * Returns: a copy of @queue - * Since: 2.4 - */ - - -/** - * g_queue_delete_link: - * @queue: a #GQueue - * @link_: a #GList link that must be part of @queue - * - * Removes @link_ from @queue and frees it. - * - * @link_ must be part of @queue. - * - * Since: 2.4 - */ - - -/** - * g_queue_find: - * @queue: a #GQueue - * @data: data to find - * - * Finds the first link in @queue which contains @data. - * - * Returns: the first link in @queue which contains @data - * Since: 2.4 - */ - - -/** - * g_queue_find_custom: - * @queue: a #GQueue - * @data: user data passed to @func - * @func: a #GCompareFunc to call for each element. It should return 0 - * when the desired element is found - * - * Finds an element in a #GQueue, using a supplied function to find the - * desired element. It iterates over the queue, calling the given function - * which should return 0 when the desired element is found. The function - * takes two gconstpointer arguments, the #GQueue element's data as the - * first argument and the given user data as the second argument. - * - * Returns: the found link, or %NULL if it wasn't found - * Since: 2.4 - */ - - -/** - * g_queue_foreach: - * @queue: a #GQueue - * @func: the function to call for each element's data - * @user_data: user data to pass to @func - * - * Calls @func for each element in the queue passing @user_data to the - * function. - * - * It is safe for @func to remove the element from @queue, but it must - * not modify any part of the queue after that element. - * - * Since: 2.4 - */ - - -/** - * g_queue_free: - * @queue: a #GQueue - * - * Frees the memory allocated for the #GQueue. Only call this function - * if @queue was created with g_queue_new(). If queue elements contain - * dynamically-allocated memory, they should be freed first. - * - * If queue elements contain dynamically-allocated memory, you should - * either use g_queue_free_full() or free them manually first. - */ - - -/** - * g_queue_free_full: - * @queue: a pointer to a #GQueue - * @free_func: the function to be called to free each element's data - * - * Convenience method, which frees all the memory used by a #GQueue, - * and calls the specified destroy function on every element's data. - * - * @free_func should not modify the queue (eg, by removing the freed - * element from it). - * - * Since: 2.32 - */ - - -/** - * g_queue_get_length: - * @queue: a #GQueue - * - * Returns the number of items in @queue. - * - * Returns: the number of items in @queue - * Since: 2.4 - */ - - -/** - * g_queue_index: - * @queue: a #GQueue - * @data: the data to find - * - * Returns the position of the first element in @queue which contains @data. - * - * Returns: the position of the first element in @queue which - * contains @data, or -1 if no element in @queue contains @data - * Since: 2.4 - */ - - -/** - * g_queue_init: - * @queue: an uninitialized #GQueue - * - * A statically-allocated #GQueue must be initialized with this function - * before it can be used. Alternatively you can initialize it with - * #G_QUEUE_INIT. It is not necessary to initialize queues created with - * g_queue_new(). - * - * Since: 2.14 - */ - - -/** - * g_queue_insert_after: - * @queue: a #GQueue - * @sibling: (nullable): a #GList link that must be part of @queue, or %NULL to - * push at the head of the queue. - * @data: the data to insert - * - * Inserts @data into @queue after @sibling. - * - * @sibling must be part of @queue. Since GLib 2.44 a %NULL sibling pushes the - * data at the head of the queue. - * - * Since: 2.4 - */ - - -/** - * g_queue_insert_after_link: - * @queue: a #GQueue - * @sibling: (nullable): a #GList link that must be part of @queue, or %NULL to - * push at the head of the queue. - * @link_: a #GList link to insert which must not be part of any other list. - * - * Inserts @link_ into @queue after @sibling. - * - * @sibling must be part of @queue. - * - * Since: 2.62 - */ - - -/** - * g_queue_insert_before: - * @queue: a #GQueue - * @sibling: (nullable): a #GList link that must be part of @queue, or %NULL to - * push at the tail of the queue. - * @data: the data to insert - * - * Inserts @data into @queue before @sibling. - * - * @sibling must be part of @queue. Since GLib 2.44 a %NULL sibling pushes the - * data at the tail of the queue. - * - * Since: 2.4 - */ - - -/** - * g_queue_insert_before_link: - * @queue: a #GQueue - * @sibling: (nullable): a #GList link that must be part of @queue, or %NULL to - * push at the tail of the queue. - * @link_: a #GList link to insert which must not be part of any other list. - * - * Inserts @link_ into @queue before @sibling. - * - * @sibling must be part of @queue. - * - * Since: 2.62 - */ - - -/** - * g_queue_insert_sorted: - * @queue: a #GQueue - * @data: the data to insert - * @func: the #GCompareDataFunc used to compare elements in the queue. It is - * called with two elements of the @queue and @user_data. It should - * return 0 if the elements are equal, a negative value if the first - * element comes before the second, and a positive value if the second - * element comes before the first. - * @user_data: user data passed to @func - * - * Inserts @data into @queue using @func to determine the new position. - * - * Since: 2.4 - */ - - -/** - * g_queue_is_empty: - * @queue: a #GQueue. - * - * Returns %TRUE if the queue is empty. - * - * Returns: %TRUE if the queue is empty - */ - - -/** - * g_queue_link_index: - * @queue: a #GQueue - * @link_: a #GList link - * - * Returns the position of @link_ in @queue. - * - * Returns: the position of @link_, or -1 if the link is - * not part of @queue - * Since: 2.4 - */ - - -/** - * g_queue_new: - * - * Creates a new #GQueue. - * - * Returns: a newly allocated #GQueue - */ - - -/** - * g_queue_peek_head: - * @queue: a #GQueue - * - * Returns the first element of the queue. - * - * Returns: the data of the first element in the queue, or %NULL - * if the queue is empty - */ - - -/** - * g_queue_peek_head_link: - * @queue: a #GQueue - * - * Returns the first link in @queue. - * - * Returns: the first link in @queue, or %NULL if @queue is empty - * Since: 2.4 - */ - - -/** - * g_queue_peek_nth: - * @queue: a #GQueue - * @n: the position of the element - * - * Returns the @n'th element of @queue. - * - * Returns: the data for the @n'th element of @queue, - * or %NULL if @n is off the end of @queue - * Since: 2.4 - */ - - -/** - * g_queue_peek_nth_link: - * @queue: a #GQueue - * @n: the position of the link - * - * Returns the link at the given position - * - * Returns: the link at the @n'th position, or %NULL - * if @n is off the end of the list - * Since: 2.4 - */ - - -/** - * g_queue_peek_tail: - * @queue: a #GQueue - * - * Returns the last element of the queue. - * - * Returns: the data of the last element in the queue, or %NULL - * if the queue is empty - */ - - -/** - * g_queue_peek_tail_link: - * @queue: a #GQueue - * - * Returns the last link in @queue. - * - * Returns: the last link in @queue, or %NULL if @queue is empty - * Since: 2.4 - */ - - -/** - * g_queue_pop_head: - * @queue: a #GQueue - * - * Removes the first element of the queue and returns its data. - * - * Returns: the data of the first element in the queue, or %NULL - * if the queue is empty - */ - - -/** - * g_queue_pop_head_link: - * @queue: a #GQueue - * - * Removes and returns the first element of the queue. - * - * Returns: the #GList element at the head of the queue, or %NULL - * if the queue is empty - */ - - -/** - * g_queue_pop_nth: - * @queue: a #GQueue - * @n: the position of the element - * - * Removes the @n'th element of @queue and returns its data. - * - * Returns: the element's data, or %NULL if @n is off the end of @queue - * Since: 2.4 - */ - - -/** - * g_queue_pop_nth_link: - * @queue: a #GQueue - * @n: the link's position - * - * Removes and returns the link at the given position. - * - * Returns: the @n'th link, or %NULL if @n is off the end of @queue - * Since: 2.4 - */ - - -/** - * g_queue_pop_tail: - * @queue: a #GQueue - * - * Removes the last element of the queue and returns its data. - * - * Returns: the data of the last element in the queue, or %NULL - * if the queue is empty - */ - - -/** - * g_queue_pop_tail_link: - * @queue: a #GQueue - * - * Removes and returns the last element of the queue. - * - * Returns: the #GList element at the tail of the queue, or %NULL - * if the queue is empty - */ - - -/** - * g_queue_push_head: - * @queue: a #GQueue. - * @data: the data for the new element. - * - * Adds a new element at the head of the queue. - */ - - -/** - * g_queue_push_head_link: - * @queue: a #GQueue - * @link_: a single #GList element, not a list with more than one element - * - * Adds a new element at the head of the queue. - */ - - -/** - * g_queue_push_nth: - * @queue: a #GQueue - * @data: the data for the new element - * @n: the position to insert the new element. If @n is negative or - * larger than the number of elements in the @queue, the element is - * added to the end of the queue. - * - * Inserts a new element into @queue at the given position. - * - * Since: 2.4 - */ - - -/** - * g_queue_push_nth_link: - * @queue: a #GQueue - * @n: the position to insert the link. If this is negative or larger than - * the number of elements in @queue, the link is added to the end of - * @queue. - * @link_: the link to add to @queue - * - * Inserts @link into @queue at the given position. - * - * Since: 2.4 - */ - - -/** - * g_queue_push_tail: - * @queue: a #GQueue - * @data: the data for the new element - * - * Adds a new element at the tail of the queue. - */ - - -/** - * g_queue_push_tail_link: - * @queue: a #GQueue - * @link_: a single #GList element, not a list with more than one element - * - * Adds a new element at the tail of the queue. - */ - - -/** - * g_queue_remove: - * @queue: a #GQueue - * @data: the data to remove - * - * Removes the first element in @queue that contains @data. - * - * Returns: %TRUE if @data was found and removed from @queue - * Since: 2.4 - */ - - -/** - * g_queue_remove_all: - * @queue: a #GQueue - * @data: the data to remove - * - * Remove all elements whose data equals @data from @queue. - * - * Returns: the number of elements removed from @queue - * Since: 2.4 - */ - - -/** - * g_queue_reverse: - * @queue: a #GQueue - * - * Reverses the order of the items in @queue. - * - * Since: 2.4 - */ - - -/** - * g_queue_sort: - * @queue: a #GQueue - * @compare_func: the #GCompareDataFunc used to sort @queue. This function - * is passed two elements of the queue and should return 0 if they are - * equal, a negative value if the first comes before the second, and - * a positive value if the second comes before the first. - * @user_data: user data passed to @compare_func - * - * Sorts @queue using @compare_func. - * - * Since: 2.4 - */ - - -/** - * g_queue_unlink: - * @queue: a #GQueue - * @link_: a #GList link that must be part of @queue - * - * Unlinks @link_ so that it will no longer be part of @queue. - * The link is not freed. - * - * @link_ must be part of @queue. - * - * Since: 2.4 - */ - - -/** - * g_rand_boolean: - * @rand_: a #GRand - * - * Returns a random #gboolean from @rand_. - * This corresponds to an unbiased coin toss. - * - * Returns: a random #gboolean - */ - - -/** - * g_rand_copy: - * @rand_: a #GRand - * - * Copies a #GRand into a new one with the same exact state as before. - * This way you can take a snapshot of the random number generator for - * replaying later. - * - * Returns: the new #GRand - * Since: 2.4 - */ - - -/** - * g_rand_double: - * @rand_: a #GRand - * - * Returns the next random #gdouble from @rand_ equally distributed over - * the range [0..1). - * - * Returns: a random number - */ - - -/** - * g_rand_double_range: - * @rand_: a #GRand - * @begin: lower closed bound of the interval - * @end: upper open bound of the interval - * - * Returns the next random #gdouble from @rand_ equally distributed over - * the range [@begin..@end). - * - * Returns: a random number - */ - - -/** - * g_rand_free: - * @rand_: a #GRand - * - * Frees the memory allocated for the #GRand. - */ - - -/** - * g_rand_int: - * @rand_: a #GRand - * - * Returns the next random #guint32 from @rand_ equally distributed over - * the range [0..2^32-1]. - * - * Returns: a random number - */ - - -/** - * g_rand_int_range: - * @rand_: a #GRand - * @begin: lower closed bound of the interval - * @end: upper open bound of the interval - * - * Returns the next random #gint32 from @rand_ equally distributed over - * the range [@begin..@end-1]. - * - * Returns: a random number - */ - - -/** - * g_rand_new: - * - * Creates a new random number generator initialized with a seed taken - * either from `/dev/urandom` (if existing) or from the current time - * (as a fallback). - * - * On Windows, the seed is taken from rand_s(). - * - * Returns: the new #GRand - */ - - -/** - * g_rand_new_with_seed: - * @seed: a value to initialize the random number generator - * - * Creates a new random number generator initialized with @seed. - * - * Returns: the new #GRand - */ - - -/** - * g_rand_new_with_seed_array: - * @seed: an array of seeds to initialize the random number generator - * @seed_length: an array of seeds to initialize the random number - * generator - * - * Creates a new random number generator initialized with @seed. - * - * Returns: the new #GRand - * Since: 2.4 - */ - - -/** - * g_rand_set_seed: - * @rand_: a #GRand - * @seed: a value to reinitialize the random number generator - * - * Sets the seed for the random number generator #GRand to @seed. - */ - - -/** - * g_rand_set_seed_array: - * @rand_: a #GRand - * @seed: array to initialize with - * @seed_length: length of array - * - * Initializes the random number generator by an array of longs. - * Array can be of arbitrary size, though only the first 624 values - * are taken. This function is useful if you have many low entropy - * seeds, or if you require more then 32 bits of actual entropy for - * your application. - * - * Since: 2.4 - */ - - -/** - * g_random_boolean: - * - * Returns a random #gboolean. - * This corresponds to an unbiased coin toss. - * - * Returns: a random #gboolean - */ - - -/** - * g_random_double: - * - * Returns a random #gdouble equally distributed over the range [0..1). - * - * Returns: a random number - */ - - -/** - * g_random_double_range: - * @begin: lower closed bound of the interval - * @end: upper open bound of the interval - * - * Returns a random #gdouble equally distributed over the range - * [@begin..@end). - * - * Returns: a random number - */ - - -/** - * g_random_int: - * - * Return a random #guint32 equally distributed over the range - * [0..2^32-1]. - * - * Returns: a random number - */ - - -/** - * g_random_int_range: - * @begin: lower closed bound of the interval - * @end: upper open bound of the interval - * - * Returns a random #gint32 equally distributed over the range - * [@begin..@end-1]. - * - * Returns: a random number - */ - - -/** - * g_random_set_seed: - * @seed: a value to reinitialize the global random number generator - * - * Sets the seed for the global random number generator, which is used - * by the g_random_* functions, to @seed. - */ - - -/** - * g_rc_box_acquire: - * @mem_block: (not nullable): a pointer to reference counted data - * - * Acquires a reference on the data pointed by @mem_block. - * - * Returns: (transfer full) (not nullable): a pointer to the data, - * with its reference count increased - * Since: 2.58 - */ - - -/** - * g_rc_box_alloc: - * @block_size: the size of the allocation, must be greater than 0 - * - * Allocates @block_size bytes of memory, and adds reference - * counting semantics to it. - * - * The data will be freed when its reference count drops to - * zero. - * - * The allocated data is guaranteed to be suitably aligned for any - * built-in type. - * - * Returns: (transfer full) (not nullable): a pointer to the allocated memory - * Since: 2.58 - */ - - -/** - * g_rc_box_alloc0: - * @block_size: the size of the allocation, must be greater than 0 - * - * Allocates @block_size bytes of memory, and adds reference - * counting semantics to it. - * - * The contents of the returned data is set to zero. - * - * The data will be freed when its reference count drops to - * zero. - * - * The allocated data is guaranteed to be suitably aligned for any - * built-in type. - * - * Returns: (transfer full) (not nullable): a pointer to the allocated memory - * Since: 2.58 - */ - - -/** - * g_rc_box_dup: - * @block_size: the number of bytes to copy, must be greater than 0 - * @mem_block: (not nullable): the memory to copy - * - * Allocates a new block of data with reference counting - * semantics, and copies @block_size bytes of @mem_block - * into it. - * - * Returns: (transfer full) (not nullable): a pointer to the allocated - * memory - * Since: 2.58 - */ - - -/** - * g_rc_box_get_size: - * @mem_block: (not nullable): a pointer to reference counted data - * - * Retrieves the size of the reference counted data pointed by @mem_block. - * - * Returns: the size of the data, in bytes - * Since: 2.58 - */ - - -/** - * g_rc_box_new: - * @type: the type to allocate, typically a structure name - * - * A convenience macro to allocate reference counted data with - * the size of the given @type. - * - * This macro calls g_rc_box_alloc() with `sizeof (@type)` and - * casts the returned pointer to a pointer of the given @type, - * avoiding a type cast in the source code. - * - * Returns: (transfer full) (not nullable): a pointer to the - * allocated memory, cast to a pointer for the given @type - * Since: 2.58 - */ - - -/** - * g_rc_box_new0: - * @type: the type to allocate, typically a structure name - * - * A convenience macro to allocate reference counted data with - * the size of the given @type, and set its contents to zero. - * - * This macro calls g_rc_box_alloc0() with `sizeof (@type)` and - * casts the returned pointer to a pointer of the given @type, - * avoiding a type cast in the source code. - * - * Returns: (transfer full) (not nullable): a pointer to the - * allocated memory, cast to a pointer for the given @type - * Since: 2.58 - */ - - -/** - * g_rc_box_release: - * @mem_block: (transfer full) (not nullable): a pointer to reference counted data - * - * Releases a reference on the data pointed by @mem_block. - * - * If the reference was the last one, it will free the - * resources allocated for @mem_block. - * - * Since: 2.58 - */ - - -/** - * g_rc_box_release_full: - * @mem_block: (transfer full) (not nullable): a pointer to reference counted data - * @clear_func: (not nullable): a function to call when clearing the data - * - * Releases a reference on the data pointed by @mem_block. - * - * If the reference was the last one, it will call @clear_func - * to clear the contents of @mem_block, and then will free the - * resources allocated for @mem_block. - * - * Since: 2.58 - */ - - -/** - * g_realloc: - * @mem: (nullable): the memory to reallocate - * @n_bytes: new size of the memory in bytes - * - * Reallocates the memory pointed to by @mem, so that it now has space for - * @n_bytes bytes of memory. It returns the new address of the memory, which may - * have been moved. @mem may be %NULL, in which case it's considered to - * have zero-length. @n_bytes may be 0, in which case %NULL will be returned - * and @mem will be freed unless it is %NULL. - * - * Returns: the new address of the allocated memory - */ - - -/** - * g_realloc_n: - * @mem: (nullable): the memory to reallocate - * @n_blocks: the number of blocks to allocate - * @n_block_bytes: the size of each block in bytes - * - * This function is similar to g_realloc(), allocating (@n_blocks * @n_block_bytes) bytes, - * but care is taken to detect possible overflow during multiplication. - * - * Since: 2.24 - * Returns: the new address of the allocated memory - */ - - -/** - * g_rec_mutex_clear: - * @rec_mutex: an initialized #GRecMutex - * - * Frees the resources allocated to a recursive mutex with - * g_rec_mutex_init(). - * - * This function should not be used with a #GRecMutex that has been - * statically allocated. - * - * Calling g_rec_mutex_clear() on a locked recursive mutex leads - * to undefined behaviour. - * - * Sine: 2.32 - */ - - -/** - * g_rec_mutex_init: - * @rec_mutex: an uninitialized #GRecMutex - * - * Initializes a #GRecMutex so that it can be used. - * - * This function is useful to initialize a recursive mutex - * that has been allocated on the stack, or as part of a larger - * structure. - * - * It is not necessary to initialise a recursive mutex that has been - * statically allocated. - * - * |[<!-- language="C" --> - * typedef struct { - * GRecMutex m; - * ... - * } Blob; - * - * Blob *b; - * - * b = g_new (Blob, 1); - * g_rec_mutex_init (&b->m); - * ]| - * - * Calling g_rec_mutex_init() on an already initialized #GRecMutex - * leads to undefined behaviour. - * - * To undo the effect of g_rec_mutex_init() when a recursive mutex - * is no longer needed, use g_rec_mutex_clear(). - * - * Since: 2.32 - */ - - -/** - * g_rec_mutex_lock: - * @rec_mutex: a #GRecMutex - * - * Locks @rec_mutex. If @rec_mutex is already locked by another - * thread, the current thread will block until @rec_mutex is - * unlocked by the other thread. If @rec_mutex is already locked - * by the current thread, the 'lock count' of @rec_mutex is increased. - * The mutex will only become available again when it is unlocked - * as many times as it has been locked. - * - * Since: 2.32 - */ - - -/** - * g_rec_mutex_trylock: - * @rec_mutex: a #GRecMutex - * - * Tries to lock @rec_mutex. If @rec_mutex is already locked - * by another thread, it immediately returns %FALSE. Otherwise - * it locks @rec_mutex and returns %TRUE. - * - * Returns: %TRUE if @rec_mutex could be locked - * Since: 2.32 - */ - - -/** - * g_rec_mutex_unlock: - * @rec_mutex: a #GRecMutex - * - * Unlocks @rec_mutex. If another thread is blocked in a - * g_rec_mutex_lock() call for @rec_mutex, it will become unblocked - * and can lock @rec_mutex itself. - * - * Calling g_rec_mutex_unlock() on a recursive mutex that is not - * locked by the current thread leads to undefined behaviour. - * - * Since: 2.32 - */ - - -/** - * g_ref_count_compare: - * @rc: the address of a reference count variable - * @val: the value to compare - * - * Compares the current value of @rc with @val. - * - * Returns: %TRUE if the reference count is the same - * as the given value - * Since: 2.58 - */ - - -/** - * g_ref_count_dec: - * @rc: the address of a reference count variable - * - * Decreases the reference count. - * - * If %TRUE is returned, the reference count reached 0. After this point, @rc - * is an undefined state and must be reinitialized with - * g_ref_count_init() to be used again. - * - * Returns: %TRUE if the reference count reached 0, and %FALSE otherwise - * Since: 2.58 - */ - - -/** - * g_ref_count_inc: - * @rc: the address of a reference count variable - * - * Increases the reference count. - * - * Since: 2.58 - */ - - -/** - * g_ref_count_init: - * @rc: the address of a reference count variable - * - * Initializes a reference count variable to 1. - * - * Since: 2.58 - */ - - -/** - * g_ref_string_acquire: - * @str: a reference counted string - * - * Acquires a reference on a string. - * - * Returns: the given string, with its reference count increased - * Since: 2.58 - */ - - -/** - * g_ref_string_length: - * @str: a reference counted string - * - * Retrieves the length of @str. - * - * Returns: the length of the given string, in bytes - * Since: 2.58 - */ - - -/** - * g_ref_string_new: - * @str: (not nullable): a NUL-terminated string - * - * Creates a new reference counted string and copies the contents of @str - * into it. - * - * Returns: (transfer full) (not nullable): the newly created reference counted string - * Since: 2.58 - */ - - -/** - * g_ref_string_new_intern: - * @str: (not nullable): a NUL-terminated string - * - * Creates a new reference counted string and copies the content of @str - * into it. - * - * If you call this function multiple times with the same @str, or with - * the same contents of @str, it will return a new reference, instead of - * creating a new string. - * - * Returns: (transfer full) (not nullable): the newly created reference - * counted string, or a new reference to an existing string - * Since: 2.58 - */ - - -/** - * g_ref_string_new_len: - * @str: (not nullable): a string - * @len: length of @str to use, or -1 if @str is nul-terminated - * - * Creates a new reference counted string and copies the contents of @str - * into it, up to @len bytes. - * - * Since this function does not stop at nul bytes, it is the caller's - * responsibility to ensure that @str has at least @len addressable bytes. - * - * Returns: (transfer full) (not nullable): the newly created reference counted string - * Since: 2.58 - */ - - -/** - * g_ref_string_release: - * @str: a reference counted string - * - * Releases a reference on a string; if it was the last reference, the - * resources allocated by the string are freed as well. - * - * Since: 2.58 - */ - - -/** - * g_regex_check_replacement: - * @replacement: the replacement string - * @has_references: (out) (optional): location to store information about - * references in @replacement or %NULL - * @error: location to store error - * - * Checks whether @replacement is a valid replacement string - * (see g_regex_replace()), i.e. that all escape sequences in - * it are valid. - * - * If @has_references is not %NULL then @replacement is checked - * for pattern references. For instance, replacement text 'foo\n' - * does not contain references and may be evaluated without information - * about actual match, but '\0\1' (whole match followed by first - * subpattern) requires valid #GMatchInfo object. - * - * Returns: whether @replacement is a valid replacement string - * Since: 2.14 - */ - - -/** - * g_regex_escape_nul: - * @string: the string to escape - * @length: the length of @string - * - * Escapes the nul characters in @string to "\x00". It can be used - * to compile a regex with embedded nul characters. - * - * For completeness, @length can be -1 for a nul-terminated string. - * In this case the output string will be of course equal to @string. - * - * Returns: a newly-allocated escaped string - * Since: 2.30 - */ - - -/** - * g_regex_escape_string: - * @string: (array length=length): the string to escape - * @length: the length of @string, in bytes, or -1 if @string is nul-terminated - * - * Escapes the special characters used for regular expressions - * in @string, for instance "a.b*c" becomes "a\.b\*c". This - * function is useful to dynamically generate regular expressions. - * - * @string can contain nul characters that are replaced with "\0", - * in this case remember to specify the correct length of @string - * in @length. - * - * Returns: a newly-allocated escaped string - * Since: 2.14 - */ - - -/** - * g_regex_get_capture_count: - * @regex: a #GRegex - * - * Returns the number of capturing subpatterns in the pattern. - * - * Returns: the number of capturing subpatterns - * Since: 2.14 - */ - - -/** - * g_regex_get_compile_flags: - * @regex: a #GRegex - * - * Returns the compile options that @regex was created with. - * - * Depending on the version of PCRE that is used, this may or may not - * include flags set by option expressions such as `(?i)` found at the - * top-level within the compiled pattern. - * - * Returns: flags from #GRegexCompileFlags - * Since: 2.26 - */ - - -/** - * g_regex_get_has_cr_or_lf: - * @regex: a #GRegex structure - * - * Checks whether the pattern contains explicit CR or LF references. - * - * Returns: %TRUE if the pattern contains explicit CR or LF references - * Since: 2.34 - */ - - -/** - * g_regex_get_match_flags: - * @regex: a #GRegex - * - * Returns the match options that @regex was created with. - * - * Returns: flags from #GRegexMatchFlags - * Since: 2.26 - */ - - -/** - * g_regex_get_max_backref: - * @regex: a #GRegex - * - * Returns the number of the highest back reference - * in the pattern, or 0 if the pattern does not contain - * back references. - * - * Returns: the number of the highest back reference - * Since: 2.14 - */ - - -/** - * g_regex_get_max_lookbehind: - * @regex: a #GRegex structure - * - * Gets the number of characters in the longest lookbehind assertion in the - * pattern. This information is useful when doing multi-segment matching using - * the partial matching facilities. - * - * Returns: the number of characters in the longest lookbehind assertion. - * Since: 2.38 - */ - - -/** - * g_regex_get_pattern: - * @regex: a #GRegex structure - * - * Gets the pattern string associated with @regex, i.e. a copy of - * the string passed to g_regex_new(). - * - * Returns: the pattern of @regex - * Since: 2.14 - */ - - -/** - * g_regex_get_string_number: - * @regex: #GRegex structure - * @name: name of the subexpression - * - * Retrieves the number of the subexpression named @name. - * - * Returns: The number of the subexpression or -1 if @name - * does not exists - * Since: 2.14 - */ - - -/** - * g_regex_match: - * @regex: a #GRegex structure from g_regex_new() - * @string: the string to scan for matches - * @match_options: match options - * @match_info: (out) (optional): pointer to location where to store - * the #GMatchInfo, or %NULL if you do not need it - * - * Scans for a match in @string for the pattern in @regex. - * The @match_options are combined with the match options specified - * when the @regex structure was created, letting you have more - * flexibility in reusing #GRegex structures. - * - * Unless %G_REGEX_RAW is specified in the options, @string must be valid UTF-8. - * - * A #GMatchInfo structure, used to get information on the match, - * is stored in @match_info if not %NULL. Note that if @match_info - * is not %NULL then it is created even if the function returns %FALSE, - * i.e. you must free it regardless if regular expression actually matched. - * - * To retrieve all the non-overlapping matches of the pattern in - * string you can use g_match_info_next(). - * - * |[<!-- language="C" --> - * static void - * print_uppercase_words (const gchar *string) - * { - * // Print all uppercase-only words. - * GRegex *regex; - * GMatchInfo *match_info; - * - * regex = g_regex_new ("[A-Z]+", 0, 0, NULL); - * g_regex_match (regex, string, 0, &match_info); - * while (g_match_info_matches (match_info)) - * { - * gchar *word = g_match_info_fetch (match_info, 0); - * g_print ("Found: %s\n", word); - * g_free (word); - * g_match_info_next (match_info, NULL); - * } - * g_match_info_free (match_info); - * g_regex_unref (regex); - * } - * ]| - * - * @string is not copied and is used in #GMatchInfo internally. If - * you use any #GMatchInfo method (except g_match_info_free()) after - * freeing or modifying @string then the behaviour is undefined. - * - * Returns: %TRUE is the string matched, %FALSE otherwise - * Since: 2.14 - */ - - -/** - * g_regex_match_all: - * @regex: a #GRegex structure from g_regex_new() - * @string: the string to scan for matches - * @match_options: match options - * @match_info: (out) (optional): pointer to location where to store - * the #GMatchInfo, or %NULL if you do not need it - * - * Using the standard algorithm for regular expression matching only - * the longest match in the string is retrieved. This function uses - * a different algorithm so it can retrieve all the possible matches. - * For more documentation see g_regex_match_all_full(). - * - * A #GMatchInfo structure, used to get information on the match, is - * stored in @match_info if not %NULL. Note that if @match_info is - * not %NULL then it is created even if the function returns %FALSE, - * i.e. you must free it regardless if regular expression actually - * matched. - * - * @string is not copied and is used in #GMatchInfo internally. If - * you use any #GMatchInfo method (except g_match_info_free()) after - * freeing or modifying @string then the behaviour is undefined. - * - * Returns: %TRUE is the string matched, %FALSE otherwise - * Since: 2.14 - */ - - -/** - * g_regex_match_all_full: - * @regex: a #GRegex structure from g_regex_new() - * @string: (array length=string_len): the string to scan for matches - * @string_len: the length of @string, in bytes, or -1 if @string is nul-terminated - * @start_position: starting index of the string to match, in bytes - * @match_options: match options - * @match_info: (out) (optional): pointer to location where to store - * the #GMatchInfo, or %NULL if you do not need it - * @error: location to store the error occurring, or %NULL to ignore errors - * - * Using the standard algorithm for regular expression matching only - * the longest match in the @string is retrieved, it is not possible - * to obtain all the available matches. For instance matching - * "<a> <b> <c>" against the pattern "<.*>" - * you get "<a> <b> <c>". - * - * This function uses a different algorithm (called DFA, i.e. deterministic - * finite automaton), so it can retrieve all the possible matches, all - * starting at the same point in the string. For instance matching - * "<a> <b> <c>" against the pattern "<.*>;" - * you would obtain three matches: "<a> <b> <c>", - * "<a> <b>" and "<a>". - * - * The number of matched strings is retrieved using - * g_match_info_get_match_count(). To obtain the matched strings and - * their position you can use, respectively, g_match_info_fetch() and - * g_match_info_fetch_pos(). Note that the strings are returned in - * reverse order of length; that is, the longest matching string is - * given first. - * - * Note that the DFA algorithm is slower than the standard one and it - * is not able to capture substrings, so backreferences do not work. - * - * Setting @start_position differs from just passing over a shortened - * string and setting #G_REGEX_MATCH_NOTBOL in the case of a pattern - * that begins with any kind of lookbehind assertion, such as "\b". - * - * Unless %G_REGEX_RAW is specified in the options, @string must be valid UTF-8. - * - * A #GMatchInfo structure, used to get information on the match, is - * stored in @match_info if not %NULL. Note that if @match_info is - * not %NULL then it is created even if the function returns %FALSE, - * i.e. you must free it regardless if regular expression actually - * matched. - * - * @string is not copied and is used in #GMatchInfo internally. If - * you use any #GMatchInfo method (except g_match_info_free()) after - * freeing or modifying @string then the behaviour is undefined. - * - * Returns: %TRUE is the string matched, %FALSE otherwise - * Since: 2.14 - */ - - -/** - * g_regex_match_full: - * @regex: a #GRegex structure from g_regex_new() - * @string: (array length=string_len): the string to scan for matches - * @string_len: the length of @string, in bytes, or -1 if @string is nul-terminated - * @start_position: starting index of the string to match, in bytes - * @match_options: match options - * @match_info: (out) (optional): pointer to location where to store - * the #GMatchInfo, or %NULL if you do not need it - * @error: location to store the error occurring, or %NULL to ignore errors - * - * Scans for a match in @string for the pattern in @regex. - * The @match_options are combined with the match options specified - * when the @regex structure was created, letting you have more - * flexibility in reusing #GRegex structures. - * - * Setting @start_position differs from just passing over a shortened - * string and setting #G_REGEX_MATCH_NOTBOL in the case of a pattern - * that begins with any kind of lookbehind assertion, such as "\b". - * - * Unless %G_REGEX_RAW is specified in the options, @string must be valid UTF-8. - * - * A #GMatchInfo structure, used to get information on the match, is - * stored in @match_info if not %NULL. Note that if @match_info is - * not %NULL then it is created even if the function returns %FALSE, - * i.e. you must free it regardless if regular expression actually - * matched. - * - * @string is not copied and is used in #GMatchInfo internally. If - * you use any #GMatchInfo method (except g_match_info_free()) after - * freeing or modifying @string then the behaviour is undefined. - * - * To retrieve all the non-overlapping matches of the pattern in - * string you can use g_match_info_next(). - * - * |[<!-- language="C" --> - * static void - * print_uppercase_words (const gchar *string) - * { - * // Print all uppercase-only words. - * GRegex *regex; - * GMatchInfo *match_info; - * GError *error = NULL; - * - * regex = g_regex_new ("[A-Z]+", 0, 0, NULL); - * g_regex_match_full (regex, string, -1, 0, 0, &match_info, &error); - * while (g_match_info_matches (match_info)) - * { - * gchar *word = g_match_info_fetch (match_info, 0); - * g_print ("Found: %s\n", word); - * g_free (word); - * g_match_info_next (match_info, &error); - * } - * g_match_info_free (match_info); - * g_regex_unref (regex); - * if (error != NULL) - * { - * g_printerr ("Error while matching: %s\n", error->message); - * g_error_free (error); - * } - * } - * ]| - * - * Returns: %TRUE is the string matched, %FALSE otherwise - * Since: 2.14 - */ - - -/** - * g_regex_match_simple: - * @pattern: the regular expression - * @string: the string to scan for matches - * @compile_options: compile options for the regular expression, or 0 - * @match_options: match options, or 0 - * - * Scans for a match in @string for @pattern. - * - * This function is equivalent to g_regex_match() but it does not - * require to compile the pattern with g_regex_new(), avoiding some - * lines of code when you need just to do a match without extracting - * substrings, capture counts, and so on. - * - * If this function is to be called on the same @pattern more than - * once, it's more efficient to compile the pattern once with - * g_regex_new() and then use g_regex_match(). - * - * Returns: %TRUE if the string matched, %FALSE otherwise - * Since: 2.14 - */ - - -/** - * g_regex_new: - * @pattern: the regular expression - * @compile_options: compile options for the regular expression, or 0 - * @match_options: match options for the regular expression, or 0 - * @error: return location for a #GError - * - * Compiles the regular expression to an internal form, and does - * the initial setup of the #GRegex structure. - * - * Returns: (nullable): a #GRegex structure or %NULL if an error occurred. Call - * g_regex_unref() when you are done with it - * Since: 2.14 - */ - - -/** - * g_regex_ref: - * @regex: a #GRegex - * - * Increases reference count of @regex by 1. - * - * Returns: @regex - * Since: 2.14 - */ - - -/** - * g_regex_replace: - * @regex: a #GRegex structure - * @string: (array length=string_len): the string to perform matches against - * @string_len: the length of @string, in bytes, or -1 if @string is nul-terminated - * @start_position: starting index of the string to match, in bytes - * @replacement: text to replace each match with - * @match_options: options for the match - * @error: location to store the error occurring, or %NULL to ignore errors - * - * Replaces all occurrences of the pattern in @regex with the - * replacement text. Backreferences of the form '\number' or - * '\g<number>' in the replacement text are interpolated by the - * number-th captured subexpression of the match, '\g<name>' refers - * to the captured subexpression with the given name. '\0' refers - * to the complete match, but '\0' followed by a number is the octal - * representation of a character. To include a literal '\' in the - * replacement, write '\\\\'. - * - * There are also escapes that changes the case of the following text: - * - * - \l: Convert to lower case the next character - * - \u: Convert to upper case the next character - * - \L: Convert to lower case till \E - * - \U: Convert to upper case till \E - * - \E: End case modification - * - * If you do not need to use backreferences use g_regex_replace_literal(). - * - * The @replacement string must be UTF-8 encoded even if #G_REGEX_RAW was - * passed to g_regex_new(). If you want to use not UTF-8 encoded strings - * you can use g_regex_replace_literal(). - * - * Setting @start_position differs from just passing over a shortened - * string and setting #G_REGEX_MATCH_NOTBOL in the case of a pattern that - * begins with any kind of lookbehind assertion, such as "\b". - * - * Returns: a newly allocated string containing the replacements - * Since: 2.14 - */ - - -/** - * g_regex_replace_eval: - * @regex: a #GRegex structure from g_regex_new() - * @string: (array length=string_len): string to perform matches against - * @string_len: the length of @string, in bytes, or -1 if @string is nul-terminated - * @start_position: starting index of the string to match, in bytes - * @match_options: options for the match - * @eval: a function to call for each match - * @user_data: user data to pass to the function - * @error: location to store the error occurring, or %NULL to ignore errors - * - * Replaces occurrences of the pattern in regex with the output of - * @eval for that occurrence. - * - * Setting @start_position differs from just passing over a shortened - * string and setting #G_REGEX_MATCH_NOTBOL in the case of a pattern - * that begins with any kind of lookbehind assertion, such as "\b". - * - * The following example uses g_regex_replace_eval() to replace multiple - * strings at once: - * |[<!-- language="C" --> - * static gboolean - * eval_cb (const GMatchInfo *info, - * GString *res, - * gpointer data) - * { - * gchar *match; - * gchar *r; - * - * match = g_match_info_fetch (info, 0); - * r = g_hash_table_lookup ((GHashTable *)data, match); - * g_string_append (res, r); - * g_free (match); - * - * return FALSE; - * } - * - * ... - * - * GRegex *reg; - * GHashTable *h; - * gchar *res; - * - * h = g_hash_table_new (g_str_hash, g_str_equal); - * - * g_hash_table_insert (h, "1", "ONE"); - * g_hash_table_insert (h, "2", "TWO"); - * g_hash_table_insert (h, "3", "THREE"); - * g_hash_table_insert (h, "4", "FOUR"); - * - * reg = g_regex_new ("1|2|3|4", 0, 0, NULL); - * res = g_regex_replace_eval (reg, text, -1, 0, 0, eval_cb, h, NULL); - * g_hash_table_destroy (h); - * - * ... - * ]| - * - * Returns: a newly allocated string containing the replacements - * Since: 2.14 - */ - - -/** - * g_regex_replace_literal: - * @regex: a #GRegex structure - * @string: (array length=string_len): the string to perform matches against - * @string_len: the length of @string, in bytes, or -1 if @string is nul-terminated - * @start_position: starting index of the string to match, in bytes - * @replacement: text to replace each match with - * @match_options: options for the match - * @error: location to store the error occurring, or %NULL to ignore errors - * - * Replaces all occurrences of the pattern in @regex with the - * replacement text. @replacement is replaced literally, to - * include backreferences use g_regex_replace(). - * - * Setting @start_position differs from just passing over a - * shortened string and setting #G_REGEX_MATCH_NOTBOL in the - * case of a pattern that begins with any kind of lookbehind - * assertion, such as "\b". - * - * Returns: a newly allocated string containing the replacements - * Since: 2.14 - */ - - -/** - * g_regex_split: - * @regex: a #GRegex structure - * @string: the string to split with the pattern - * @match_options: match time option flags - * - * Breaks the string on the pattern, and returns an array of the tokens. - * If the pattern contains capturing parentheses, then the text for each - * of the substrings will also be returned. If the pattern does not match - * anywhere in the string, then the whole string is returned as the first - * token. - * - * As a special case, the result of splitting the empty string "" is an - * empty vector, not a vector containing a single string. The reason for - * this special case is that being able to represent an empty vector is - * typically more useful than consistent handling of empty elements. If - * you do need to represent empty elements, you'll need to check for the - * empty string before calling this function. - * - * A pattern that can match empty strings splits @string into separate - * characters wherever it matches the empty string between characters. - * For example splitting "ab c" using as a separator "\s*", you will get - * "a", "b" and "c". - * - * Returns: (transfer full): a %NULL-terminated gchar ** array. Free - * it using g_strfreev() - * Since: 2.14 - */ - - -/** - * g_regex_split_full: - * @regex: a #GRegex structure - * @string: (array length=string_len): the string to split with the pattern - * @string_len: the length of @string, in bytes, or -1 if @string is nul-terminated - * @start_position: starting index of the string to match, in bytes - * @match_options: match time option flags - * @max_tokens: the maximum number of tokens to split @string into. - * If this is less than 1, the string is split completely - * @error: return location for a #GError - * - * Breaks the string on the pattern, and returns an array of the tokens. - * If the pattern contains capturing parentheses, then the text for each - * of the substrings will also be returned. If the pattern does not match - * anywhere in the string, then the whole string is returned as the first - * token. - * - * As a special case, the result of splitting the empty string "" is an - * empty vector, not a vector containing a single string. The reason for - * this special case is that being able to represent an empty vector is - * typically more useful than consistent handling of empty elements. If - * you do need to represent empty elements, you'll need to check for the - * empty string before calling this function. - * - * A pattern that can match empty strings splits @string into separate - * characters wherever it matches the empty string between characters. - * For example splitting "ab c" using as a separator "\s*", you will get - * "a", "b" and "c". - * - * Setting @start_position differs from just passing over a shortened - * string and setting #G_REGEX_MATCH_NOTBOL in the case of a pattern - * that begins with any kind of lookbehind assertion, such as "\b". - * - * Returns: (transfer full): a %NULL-terminated gchar ** array. Free - * it using g_strfreev() - * Since: 2.14 - */ - - -/** - * g_regex_split_simple: - * @pattern: the regular expression - * @string: the string to scan for matches - * @compile_options: compile options for the regular expression, or 0 - * @match_options: match options, or 0 - * - * Breaks the string on the pattern, and returns an array of - * the tokens. If the pattern contains capturing parentheses, - * then the text for each of the substrings will also be returned. - * If the pattern does not match anywhere in the string, then the - * whole string is returned as the first token. - * - * This function is equivalent to g_regex_split() but it does - * not require to compile the pattern with g_regex_new(), avoiding - * some lines of code when you need just to do a split without - * extracting substrings, capture counts, and so on. - * - * If this function is to be called on the same @pattern more than - * once, it's more efficient to compile the pattern once with - * g_regex_new() and then use g_regex_split(). - * - * As a special case, the result of splitting the empty string "" - * is an empty vector, not a vector containing a single string. - * The reason for this special case is that being able to represent - * an empty vector is typically more useful than consistent handling - * of empty elements. If you do need to represent empty elements, - * you'll need to check for the empty string before calling this - * function. - * - * A pattern that can match empty strings splits @string into - * separate characters wherever it matches the empty string between - * characters. For example splitting "ab c" using as a separator - * "\s*", you will get "a", "b" and "c". - * - * Returns: (transfer full): a %NULL-terminated array of strings. Free - * it using g_strfreev() - * Since: 2.14 - */ - - -/** - * g_regex_unref: - * @regex: a #GRegex - * - * Decreases reference count of @regex by 1. When reference count drops - * to zero, it frees all the memory associated with the regex structure. - * - * Since: 2.14 - */ - - -/** - * g_reload_user_special_dirs_cache: - * - * Resets the cache used for g_get_user_special_dir(), so - * that the latest on-disk version is used. Call this only - * if you just changed the data on disk yourself. - * - * Due to thread safety issues this may cause leaking of strings - * that were previously returned from g_get_user_special_dir() - * that can't be freed. We ensure to only leak the data for - * the directories that actually changed value though. - * - * Since: 2.22 - */ - - -/** - * g_remove: - * @filename: (type filename): a pathname in the GLib file name encoding - * (UTF-8 on Windows) - * - * A wrapper for the POSIX remove() function. The remove() function - * deletes a name from the filesystem. - * - * See your C library manual for more details about how remove() works - * on your system. On Unix, remove() removes also directories, as it - * calls unlink() for files and rmdir() for directories. On Windows, - * although remove() in the C library only works for files, this - * function tries first remove() and then if that fails rmdir(), and - * thus works for both files and directories. Note however, that on - * Windows, it is in general not possible to remove a file that is - * open to some process, or mapped into memory. - * - * If this function fails on Windows you can't infer too much from the - * errno value. rmdir() is tried regardless of what caused remove() to - * fail. Any errno value set by remove() will be overwritten by that - * set by rmdir(). - * - * Returns: 0 if the file was successfully removed, -1 if an error - * occurred - * Since: 2.6 - */ - - -/** - * g_rename: - * @oldfilename: (type filename): a pathname in the GLib file name encoding - * (UTF-8 on Windows) - * @newfilename: (type filename): a pathname in the GLib file name encoding - * - * A wrapper for the POSIX rename() function. The rename() function - * renames a file, moving it between directories if required. - * - * See your C library manual for more details about how rename() works - * on your system. It is not possible in general on Windows to rename - * a file that is open to some process. - * - * Returns: 0 if the renaming succeeded, -1 if an error occurred - * Since: 2.6 - */ - - -/** - * g_return_if_fail_warning: (skip) - * @log_domain: (nullable): log domain - * @pretty_function: function containing the assertion - * @expression: (nullable): expression which failed - * - * Internal function used to print messages from the public g_return_if_fail() - * and g_return_val_if_fail() macros. - */ - - -/** - * g_rmdir: - * @filename: (type filename): a pathname in the GLib file name encoding - * (UTF-8 on Windows) - * - * A wrapper for the POSIX rmdir() function. The rmdir() function - * deletes a directory from the filesystem. - * - * See your C library manual for more details about how rmdir() works - * on your system. - * - * Returns: 0 if the directory was successfully removed, -1 if an error - * occurred - * Since: 2.6 - */ - - -/** - * g_rw_lock_clear: - * @rw_lock: an initialized #GRWLock - * - * Frees the resources allocated to a lock with g_rw_lock_init(). - * - * This function should not be used with a #GRWLock that has been - * statically allocated. - * - * Calling g_rw_lock_clear() when any thread holds the lock - * leads to undefined behaviour. - * - * Sine: 2.32 - */ - - -/** - * g_rw_lock_init: - * @rw_lock: an uninitialized #GRWLock - * - * Initializes a #GRWLock so that it can be used. - * - * This function is useful to initialize a lock that has been - * allocated on the stack, or as part of a larger structure. It is not - * necessary to initialise a reader-writer lock that has been statically - * allocated. - * - * |[<!-- language="C" --> - * typedef struct { - * GRWLock l; - * ... - * } Blob; - * - * Blob *b; - * - * b = g_new (Blob, 1); - * g_rw_lock_init (&b->l); - * ]| - * - * To undo the effect of g_rw_lock_init() when a lock is no longer - * needed, use g_rw_lock_clear(). - * - * Calling g_rw_lock_init() on an already initialized #GRWLock leads - * to undefined behaviour. - * - * Since: 2.32 - */ - - -/** - * g_rw_lock_reader_lock: - * @rw_lock: a #GRWLock - * - * Obtain a read lock on @rw_lock. If another thread currently holds - * the write lock on @rw_lock, the current thread will block until the - * write lock was (held and) released. If another thread does not hold - * the write lock, but is waiting for it, it is implementation defined - * whether the reader or writer will block. Read locks can be taken - * recursively. - * - * Calling g_rw_lock_reader_lock() while the current thread already - * owns a write lock leads to undefined behaviour. Read locks however - * can be taken recursively, in which case you need to make sure to - * call g_rw_lock_reader_unlock() the same amount of times. - * - * It is implementation-defined how many read locks are allowed to be - * held on the same lock simultaneously. If the limit is hit, - * or if a deadlock is detected, a critical warning will be emitted. - * - * Since: 2.32 - */ - - -/** - * g_rw_lock_reader_trylock: - * @rw_lock: a #GRWLock - * - * Tries to obtain a read lock on @rw_lock and returns %TRUE if - * the read lock was successfully obtained. Otherwise it - * returns %FALSE. - * - * Returns: %TRUE if @rw_lock could be locked - * Since: 2.32 - */ - - -/** - * g_rw_lock_reader_unlock: - * @rw_lock: a #GRWLock - * - * Release a read lock on @rw_lock. - * - * Calling g_rw_lock_reader_unlock() on a lock that is not held - * by the current thread leads to undefined behaviour. - * - * Since: 2.32 - */ - - -/** - * g_rw_lock_writer_lock: - * @rw_lock: a #GRWLock - * - * Obtain a write lock on @rw_lock. If another thread currently holds - * a read or write lock on @rw_lock, the current thread will block - * until all other threads have dropped their locks on @rw_lock. - * - * Calling g_rw_lock_writer_lock() while the current thread already - * owns a read or write lock on @rw_lock leads to undefined behaviour. - * - * Since: 2.32 - */ - - -/** - * g_rw_lock_writer_trylock: - * @rw_lock: a #GRWLock - * - * Tries to obtain a write lock on @rw_lock. If another thread - * currently holds a read or write lock on @rw_lock, it immediately - * returns %FALSE. - * Otherwise it locks @rw_lock and returns %TRUE. - * - * Returns: %TRUE if @rw_lock could be locked - * Since: 2.32 - */ - - -/** - * g_rw_lock_writer_unlock: - * @rw_lock: a #GRWLock - * - * Release a write lock on @rw_lock. - * - * Calling g_rw_lock_writer_unlock() on a lock that is not held - * by the current thread leads to undefined behaviour. - * - * Since: 2.32 - */ - - -/** - * g_scanner_add_symbol: - * @scanner: a #GScanner - * @symbol: the symbol to add - * @value: the value of the symbol - * - * Adds a symbol to the default scope. - * - * Deprecated: 2.2: Use g_scanner_scope_add_symbol() instead. - */ - - -/** - * g_scanner_cur_line: - * @scanner: a #GScanner - * - * Returns the current line in the input stream (counting - * from 1). This is the line of the last token parsed via - * g_scanner_get_next_token(). - * - * Returns: the current line - */ - - -/** - * g_scanner_cur_position: - * @scanner: a #GScanner - * - * Returns the current position in the current line (counting - * from 0). This is the position of the last token parsed via - * g_scanner_get_next_token(). - * - * Returns: the current position on the line - */ - - -/** - * g_scanner_cur_token: - * @scanner: a #GScanner - * - * Gets the current token type. This is simply the @token - * field in the #GScanner structure. - * - * Returns: the current token type - */ - - -/** - * g_scanner_cur_value: - * @scanner: a #GScanner - * - * Gets the current token value. This is simply the @value - * field in the #GScanner structure. - * - * Returns: the current token value - */ - - -/** - * g_scanner_destroy: - * @scanner: a #GScanner - * - * Frees all memory used by the #GScanner. - */ - - -/** - * g_scanner_eof: - * @scanner: a #GScanner - * - * Returns %TRUE if the scanner has reached the end of - * the file or text buffer. - * - * Returns: %TRUE if the scanner has reached the end of - * the file or text buffer - */ - - -/** - * g_scanner_error: - * @scanner: a #GScanner - * @format: the message format. See the printf() documentation - * @...: the parameters to insert into the format string - * - * Outputs an error message, via the #GScanner message handler. - */ - - -/** - * g_scanner_foreach_symbol: - * @scanner: a #GScanner - * @func: the function to call with each symbol - * @data: data to pass to the function - * - * Calls a function for each symbol in the default scope. - * - * Deprecated: 2.2: Use g_scanner_scope_foreach_symbol() instead. - */ - - -/** - * g_scanner_freeze_symbol_table: - * @scanner: a #GScanner - * - * There is no reason to use this macro, since it does nothing. - * - * Deprecated: 2.2: This macro does nothing. - */ - - -/** - * g_scanner_get_next_token: - * @scanner: a #GScanner - * - * Parses the next token just like g_scanner_peek_next_token() - * and also removes it from the input stream. The token data is - * placed in the @token, @value, @line, and @position fields of - * the #GScanner structure. - * - * Returns: the type of the token - */ - - -/** - * g_scanner_input_file: - * @scanner: a #GScanner - * @input_fd: a file descriptor - * - * Prepares to scan a file. - */ - - -/** - * g_scanner_input_text: - * @scanner: a #GScanner - * @text: the text buffer to scan - * @text_len: the length of the text buffer - * - * Prepares to scan a text buffer. - */ - - -/** - * g_scanner_lookup_symbol: - * @scanner: a #GScanner - * @symbol: the symbol to look up - * - * Looks up a symbol in the current scope and return its value. - * If the symbol is not bound in the current scope, %NULL is - * returned. - * - * Returns: the value of @symbol in the current scope, or %NULL - * if @symbol is not bound in the current scope - */ - - -/** - * g_scanner_new: - * @config_templ: the initial scanner settings - * - * Creates a new #GScanner. - * - * The @config_templ structure specifies the initial settings - * of the scanner, which are copied into the #GScanner - * @config field. If you pass %NULL then the default settings - * are used. - * - * Returns: the new #GScanner - */ - - -/** - * g_scanner_peek_next_token: - * @scanner: a #GScanner - * - * Parses the next token, without removing it from the input stream. - * The token data is placed in the @next_token, @next_value, @next_line, - * and @next_position fields of the #GScanner structure. - * - * Note that, while the token is not removed from the input stream - * (i.e. the next call to g_scanner_get_next_token() will return the - * same token), it will not be reevaluated. This can lead to surprising - * results when changing scope or the scanner configuration after peeking - * the next token. Getting the next token after switching the scope or - * configuration will return whatever was peeked before, regardless of - * any symbols that may have been added or removed in the new scope. - * - * Returns: the type of the token - */ - - -/** - * g_scanner_remove_symbol: - * @scanner: a #GScanner - * @symbol: the symbol to remove - * - * Removes a symbol from the default scope. - * - * Deprecated: 2.2: Use g_scanner_scope_remove_symbol() instead. - */ - - -/** - * g_scanner_scope_add_symbol: - * @scanner: a #GScanner - * @scope_id: the scope id - * @symbol: the symbol to add - * @value: the value of the symbol - * - * Adds a symbol to the given scope. - */ - - -/** - * g_scanner_scope_foreach_symbol: - * @scanner: a #GScanner - * @scope_id: the scope id - * @func: the function to call for each symbol/value pair - * @user_data: user data to pass to the function - * - * Calls the given function for each of the symbol/value pairs - * in the given scope of the #GScanner. The function is passed - * the symbol and value of each pair, and the given @user_data - * parameter. - */ - - -/** - * g_scanner_scope_lookup_symbol: - * @scanner: a #GScanner - * @scope_id: the scope id - * @symbol: the symbol to look up - * - * Looks up a symbol in a scope and return its value. If the - * symbol is not bound in the scope, %NULL is returned. - * - * Returns: the value of @symbol in the given scope, or %NULL - * if @symbol is not bound in the given scope. - */ - - -/** - * g_scanner_scope_remove_symbol: - * @scanner: a #GScanner - * @scope_id: the scope id - * @symbol: the symbol to remove - * - * Removes a symbol from a scope. - */ - - -/** - * g_scanner_set_scope: - * @scanner: a #GScanner - * @scope_id: the new scope id - * - * Sets the current scope. - * - * Returns: the old scope id - */ - - -/** - * g_scanner_sync_file_offset: - * @scanner: a #GScanner - * - * Rewinds the filedescriptor to the current buffer position - * and blows the file read ahead buffer. This is useful for - * third party uses of the scanners filedescriptor, which hooks - * onto the current scanning position. - */ - - -/** - * g_scanner_thaw_symbol_table: - * @scanner: a #GScanner - * - * There is no reason to use this macro, since it does nothing. - * - * Deprecated: 2.2: This macro does nothing. - */ - - -/** - * g_scanner_unexp_token: - * @scanner: a #GScanner - * @expected_token: the expected token - * @identifier_spec: a string describing how the scanner's user - * refers to identifiers (%NULL defaults to "identifier"). - * This is used if @expected_token is %G_TOKEN_IDENTIFIER or - * %G_TOKEN_IDENTIFIER_NULL. - * @symbol_spec: a string describing how the scanner's user refers - * to symbols (%NULL defaults to "symbol"). This is used if - * @expected_token is %G_TOKEN_SYMBOL or any token value greater - * than %G_TOKEN_LAST. - * @symbol_name: the name of the symbol, if the scanner's current - * token is a symbol. - * @message: a message string to output at the end of the - * warning/error, or %NULL. - * @is_error: if %TRUE it is output as an error. If %FALSE it is - * output as a warning. - * - * Outputs a message through the scanner's msg_handler, - * resulting from an unexpected token in the input stream. - * Note that you should not call g_scanner_peek_next_token() - * followed by g_scanner_unexp_token() without an intermediate - * call to g_scanner_get_next_token(), as g_scanner_unexp_token() - * evaluates the scanner's current token (not the peeked token) - * to construct part of the message. - */ - - -/** - * g_scanner_warn: - * @scanner: a #GScanner - * @format: the message format. See the printf() documentation - * @...: the parameters to insert into the format string - * - * Outputs a warning message, via the #GScanner message handler. - */ - - -/** - * g_sequence_append: - * @seq: a #GSequence - * @data: the data for the new item - * - * Adds a new item to the end of @seq. - * - * Returns: (transfer none): an iterator pointing to the new item - * Since: 2.14 - */ - - -/** - * g_sequence_foreach: - * @seq: a #GSequence - * @func: the function to call for each item in @seq - * @user_data: user data passed to @func - * - * Calls @func for each item in the sequence passing @user_data - * to the function. @func must not modify the sequence itself. - * - * Since: 2.14 - */ - - -/** - * g_sequence_foreach_range: - * @begin: a #GSequenceIter - * @end: a #GSequenceIter - * @func: a #GFunc - * @user_data: user data passed to @func - * - * Calls @func for each item in the range (@begin, @end) passing - * @user_data to the function. @func must not modify the sequence - * itself. - * - * Since: 2.14 - */ - - -/** - * g_sequence_free: - * @seq: a #GSequence - * - * Frees the memory allocated for @seq. If @seq has a data destroy - * function associated with it, that function is called on all items - * in @seq. - * - * Since: 2.14 - */ - - -/** - * g_sequence_get: - * @iter: a #GSequenceIter - * - * Returns the data that @iter points to. - * - * Returns: (transfer none): the data that @iter points to - * Since: 2.14 - */ - - -/** - * g_sequence_get_begin_iter: - * @seq: a #GSequence - * - * Returns the begin iterator for @seq. - * - * Returns: (transfer none): the begin iterator for @seq. - * Since: 2.14 - */ - - -/** - * g_sequence_get_end_iter: - * @seq: a #GSequence - * - * Returns the end iterator for @seg - * - * Returns: (transfer none): the end iterator for @seq - * Since: 2.14 - */ - - -/** - * g_sequence_get_iter_at_pos: - * @seq: a #GSequence - * @pos: a position in @seq, or -1 for the end - * - * Returns the iterator at position @pos. If @pos is negative or larger - * than the number of items in @seq, the end iterator is returned. - * - * Returns: (transfer none): The #GSequenceIter at position @pos - * Since: 2.14 - */ - - -/** - * g_sequence_get_length: - * @seq: a #GSequence - * - * Returns the positive length (>= 0) of @seq. Note that this method is - * O(h) where `h' is the height of the tree. It is thus more efficient - * to use g_sequence_is_empty() when comparing the length to zero. - * - * Returns: the length of @seq - * Since: 2.14 - */ - - -/** - * g_sequence_insert_before: - * @iter: a #GSequenceIter - * @data: the data for the new item - * - * Inserts a new item just before the item pointed to by @iter. - * - * Returns: (transfer none): an iterator pointing to the new item - * Since: 2.14 - */ - - -/** - * g_sequence_insert_sorted: - * @seq: a #GSequence - * @data: the data to insert - * @cmp_func: the function used to compare items in the sequence - * @cmp_data: user data passed to @cmp_func. - * - * Inserts @data into @seq using @cmp_func to determine the new - * position. The sequence must already be sorted according to @cmp_func; - * otherwise the new position of @data is undefined. - * - * @cmp_func is called with two items of the @seq, and @cmp_data. - * It should return 0 if the items are equal, a negative value - * if the first item comes before the second, and a positive value - * if the second item comes before the first. - * - * Note that when adding a large amount of data to a #GSequence, - * it is more efficient to do unsorted insertions and then call - * g_sequence_sort() or g_sequence_sort_iter(). - * - * Returns: (transfer none): a #GSequenceIter pointing to the new item. - * Since: 2.14 - */ - - -/** - * g_sequence_insert_sorted_iter: - * @seq: a #GSequence - * @data: data for the new item - * @iter_cmp: the function used to compare iterators in the sequence - * @cmp_data: user data passed to @iter_cmp - * - * Like g_sequence_insert_sorted(), but uses - * a #GSequenceIterCompareFunc instead of a #GCompareDataFunc as - * the compare function. - * - * @iter_cmp is called with two iterators pointing into @seq. - * It should return 0 if the iterators are equal, a negative - * value if the first iterator comes before the second, and a - * positive value if the second iterator comes before the first. - * - * Note that when adding a large amount of data to a #GSequence, - * it is more efficient to do unsorted insertions and then call - * g_sequence_sort() or g_sequence_sort_iter(). - * - * Returns: (transfer none): a #GSequenceIter pointing to the new item - * Since: 2.14 - */ - - -/** - * g_sequence_is_empty: - * @seq: a #GSequence - * - * Returns %TRUE if the sequence contains zero items. - * - * This function is functionally identical to checking the result of - * g_sequence_get_length() being equal to zero. However this function is - * implemented in O(1) running time. - * - * Returns: %TRUE if the sequence is empty, otherwise %FALSE. - * Since: 2.48 - */ - - -/** - * g_sequence_iter_compare: - * @a: a #GSequenceIter - * @b: a #GSequenceIter - * - * Returns a negative number if @a comes before @b, 0 if they are equal, - * and a positive number if @a comes after @b. - * - * The @a and @b iterators must point into the same sequence. - * - * Returns: a negative number if @a comes before @b, 0 if they are - * equal, and a positive number if @a comes after @b - * Since: 2.14 - */ - - -/** - * g_sequence_iter_get_position: - * @iter: a #GSequenceIter - * - * Returns the position of @iter - * - * Returns: the position of @iter - * Since: 2.14 - */ - - -/** - * g_sequence_iter_get_sequence: - * @iter: a #GSequenceIter - * - * Returns the #GSequence that @iter points into. - * - * Returns: (transfer none): the #GSequence that @iter points into - * Since: 2.14 - */ - - -/** - * g_sequence_iter_is_begin: - * @iter: a #GSequenceIter - * - * Returns whether @iter is the begin iterator - * - * Returns: whether @iter is the begin iterator - * Since: 2.14 - */ - - -/** - * g_sequence_iter_is_end: - * @iter: a #GSequenceIter - * - * Returns whether @iter is the end iterator - * - * Returns: Whether @iter is the end iterator - * Since: 2.14 - */ - - -/** - * g_sequence_iter_move: - * @iter: a #GSequenceIter - * @delta: A positive or negative number indicating how many positions away - * from @iter the returned #GSequenceIter will be - * - * Returns the #GSequenceIter which is @delta positions away from @iter. - * If @iter is closer than -@delta positions to the beginning of the sequence, - * the begin iterator is returned. If @iter is closer than @delta positions - * to the end of the sequence, the end iterator is returned. - * - * Returns: (transfer none): a #GSequenceIter which is @delta positions away from @iter - * Since: 2.14 - */ - - -/** - * g_sequence_iter_next: - * @iter: a #GSequenceIter - * - * Returns an iterator pointing to the next position after @iter. - * If @iter is the end iterator, the end iterator is returned. - * - * Returns: (transfer none): a #GSequenceIter pointing to the next position after @iter - * Since: 2.14 - */ - - -/** - * g_sequence_iter_prev: - * @iter: a #GSequenceIter - * - * Returns an iterator pointing to the previous position before @iter. - * If @iter is the begin iterator, the begin iterator is returned. - * - * Returns: (transfer none): a #GSequenceIter pointing to the previous position - * before @iter - * Since: 2.14 - */ - - -/** - * g_sequence_lookup: - * @seq: a #GSequence - * @data: data to look up - * @cmp_func: the function used to compare items in the sequence - * @cmp_data: user data passed to @cmp_func - * - * Returns an iterator pointing to the position of the first item found - * equal to @data according to @cmp_func and @cmp_data. If more than one - * item is equal, it is not guaranteed that it is the first which is - * returned. In that case, you can use g_sequence_iter_next() and - * g_sequence_iter_prev() to get others. - * - * @cmp_func is called with two items of the @seq, and @cmp_data. - * It should return 0 if the items are equal, a negative value if - * the first item comes before the second, and a positive value if - * the second item comes before the first. - * - * This function will fail if the data contained in the sequence is - * unsorted. - * - * Returns: (transfer none) (nullable): an #GSequenceIter pointing to the position of the - * first item found equal to @data according to @cmp_func and - * @cmp_data, or %NULL if no such item exists - * Since: 2.28 - */ - - -/** - * g_sequence_lookup_iter: - * @seq: a #GSequence - * @data: data to look up - * @iter_cmp: the function used to compare iterators in the sequence - * @cmp_data: user data passed to @iter_cmp - * - * Like g_sequence_lookup(), but uses a #GSequenceIterCompareFunc - * instead of a #GCompareDataFunc as the compare function. - * - * @iter_cmp is called with two iterators pointing into @seq. - * It should return 0 if the iterators are equal, a negative value - * if the first iterator comes before the second, and a positive - * value if the second iterator comes before the first. - * - * This function will fail if the data contained in the sequence is - * unsorted. - * - * Returns: (transfer none) (nullable): an #GSequenceIter pointing to the position of - * the first item found equal to @data according to @iter_cmp - * and @cmp_data, or %NULL if no such item exists - * Since: 2.28 - */ - - -/** - * g_sequence_move: - * @src: a #GSequenceIter pointing to the item to move - * @dest: a #GSequenceIter pointing to the position to which - * the item is moved - * - * Moves the item pointed to by @src to the position indicated by @dest. - * After calling this function @dest will point to the position immediately - * after @src. It is allowed for @src and @dest to point into different - * sequences. - * - * Since: 2.14 - */ - - -/** - * g_sequence_move_range: - * @dest: a #GSequenceIter - * @begin: a #GSequenceIter - * @end: a #GSequenceIter - * - * Inserts the (@begin, @end) range at the destination pointed to by @dest. - * The @begin and @end iters must point into the same sequence. It is - * allowed for @dest to point to a different sequence than the one pointed - * into by @begin and @end. - * - * If @dest is %NULL, the range indicated by @begin and @end is - * removed from the sequence. If @dest points to a place within - * the (@begin, @end) range, the range does not move. - * - * Since: 2.14 - */ - - -/** - * g_sequence_new: - * @data_destroy: (nullable): a #GDestroyNotify function, or %NULL - * - * Creates a new GSequence. The @data_destroy function, if non-%NULL will - * be called on all items when the sequence is destroyed and on items that - * are removed from the sequence. - * - * Returns: (transfer full): a new #GSequence - * Since: 2.14 - */ - - -/** - * g_sequence_prepend: - * @seq: a #GSequence - * @data: the data for the new item - * - * Adds a new item to the front of @seq - * - * Returns: (transfer none): an iterator pointing to the new item - * Since: 2.14 - */ - - -/** - * g_sequence_range_get_midpoint: - * @begin: a #GSequenceIter - * @end: a #GSequenceIter - * - * Finds an iterator somewhere in the range (@begin, @end). This - * iterator will be close to the middle of the range, but is not - * guaranteed to be exactly in the middle. - * - * The @begin and @end iterators must both point to the same sequence - * and @begin must come before or be equal to @end in the sequence. - * - * Returns: (transfer none): a #GSequenceIter pointing somewhere in the - * (@begin, @end) range - * Since: 2.14 - */ - - -/** - * g_sequence_remove: - * @iter: a #GSequenceIter - * - * Removes the item pointed to by @iter. It is an error to pass the - * end iterator to this function. - * - * If the sequence has a data destroy function associated with it, this - * function is called on the data for the removed item. - * - * Since: 2.14 - */ - - -/** - * g_sequence_remove_range: - * @begin: a #GSequenceIter - * @end: a #GSequenceIter - * - * Removes all items in the (@begin, @end) range. - * - * If the sequence has a data destroy function associated with it, this - * function is called on the data for the removed items. - * - * Since: 2.14 - */ - - -/** - * g_sequence_search: - * @seq: a #GSequence - * @data: data for the new item - * @cmp_func: the function used to compare items in the sequence - * @cmp_data: user data passed to @cmp_func - * - * Returns an iterator pointing to the position where @data would - * be inserted according to @cmp_func and @cmp_data. - * - * @cmp_func is called with two items of the @seq, and @cmp_data. - * It should return 0 if the items are equal, a negative value if - * the first item comes before the second, and a positive value if - * the second item comes before the first. - * - * If you are simply searching for an existing element of the sequence, - * consider using g_sequence_lookup(). - * - * This function will fail if the data contained in the sequence is - * unsorted. - * - * Returns: (transfer none): an #GSequenceIter pointing to the position where @data - * would have been inserted according to @cmp_func and @cmp_data - * Since: 2.14 - */ - - -/** - * g_sequence_search_iter: - * @seq: a #GSequence - * @data: data for the new item - * @iter_cmp: the function used to compare iterators in the sequence - * @cmp_data: user data passed to @iter_cmp - * - * Like g_sequence_search(), but uses a #GSequenceIterCompareFunc - * instead of a #GCompareDataFunc as the compare function. - * - * @iter_cmp is called with two iterators pointing into @seq. - * It should return 0 if the iterators are equal, a negative value - * if the first iterator comes before the second, and a positive - * value if the second iterator comes before the first. - * - * If you are simply searching for an existing element of the sequence, - * consider using g_sequence_lookup_iter(). - * - * This function will fail if the data contained in the sequence is - * unsorted. - * - * Returns: (transfer none): a #GSequenceIter pointing to the position in @seq - * where @data would have been inserted according to @iter_cmp - * and @cmp_data - * Since: 2.14 - */ - - -/** - * g_sequence_set: - * @iter: a #GSequenceIter - * @data: new data for the item - * - * Changes the data for the item pointed to by @iter to be @data. If - * the sequence has a data destroy function associated with it, that - * function is called on the existing data that @iter pointed to. - * - * Since: 2.14 - */ - - -/** - * g_sequence_sort: - * @seq: a #GSequence - * @cmp_func: the function used to sort the sequence - * @cmp_data: user data passed to @cmp_func - * - * Sorts @seq using @cmp_func. - * - * @cmp_func is passed two items of @seq and should - * return 0 if they are equal, a negative value if the - * first comes before the second, and a positive value - * if the second comes before the first. - * - * Since: 2.14 - */ - - -/** - * g_sequence_sort_changed: - * @iter: A #GSequenceIter - * @cmp_func: the function used to compare items in the sequence - * @cmp_data: user data passed to @cmp_func. - * - * Moves the data pointed to by @iter to a new position as indicated by - * @cmp_func. This - * function should be called for items in a sequence already sorted according - * to @cmp_func whenever some aspect of an item changes so that @cmp_func - * may return different values for that item. - * - * @cmp_func is called with two items of the @seq, and @cmp_data. - * It should return 0 if the items are equal, a negative value if - * the first item comes before the second, and a positive value if - * the second item comes before the first. - * - * Since: 2.14 - */ - - -/** - * g_sequence_sort_changed_iter: - * @iter: a #GSequenceIter - * @iter_cmp: the function used to compare iterators in the sequence - * @cmp_data: user data passed to @cmp_func - * - * Like g_sequence_sort_changed(), but uses - * a #GSequenceIterCompareFunc instead of a #GCompareDataFunc as - * the compare function. - * - * @iter_cmp is called with two iterators pointing into the #GSequence that - * @iter points into. It should - * return 0 if the iterators are equal, a negative value if the first - * iterator comes before the second, and a positive value if the second - * iterator comes before the first. - * - * Since: 2.14 - */ - - -/** - * g_sequence_sort_iter: - * @seq: a #GSequence - * @cmp_func: the function used to compare iterators in the sequence - * @cmp_data: user data passed to @cmp_func - * - * Like g_sequence_sort(), but uses a #GSequenceIterCompareFunc instead - * of a #GCompareDataFunc as the compare function - * - * @cmp_func is called with two iterators pointing into @seq. It should - * return 0 if the iterators are equal, a negative value if the first - * iterator comes before the second, and a positive value if the second - * iterator comes before the first. - * - * Since: 2.14 - */ - - -/** - * g_sequence_swap: - * @a: a #GSequenceIter - * @b: a #GSequenceIter - * - * Swaps the items pointed to by @a and @b. It is allowed for @a and @b - * to point into difference sequences. - * - * Since: 2.14 - */ - - -/** - * g_set_application_name: - * @application_name: localized name of the application - * - * Sets a human-readable name for the application. This name should be - * localized if possible, and is intended for display to the user. - * Contrast with g_set_prgname(), which sets a non-localized name. - * g_set_prgname() will be called automatically by gtk_init(), - * but g_set_application_name() will not. - * - * Note that for thread safety reasons, this function can only - * be called once. - * - * The application name will be used in contexts such as error messages, - * or when displaying an application's name in the task list. - * - * Since: 2.2 - */ - - -/** - * g_set_error: - * @err: (out callee-allocates) (optional): a return location for a #GError - * @domain: error domain - * @code: error code - * @format: printf()-style format - * @...: args for @format - * - * Does nothing if @err is %NULL; if @err is non-%NULL, then *@err - * must be %NULL. A new #GError is created and assigned to *@err. - */ - - -/** - * g_set_error_literal: - * @err: (out callee-allocates) (optional): a return location for a #GError - * @domain: error domain - * @code: error code - * @message: error message - * - * Does nothing if @err is %NULL; if @err is non-%NULL, then *@err - * must be %NULL. A new #GError is created and assigned to *@err. - * Unlike g_set_error(), @message is not a printf()-style format string. - * Use this function if @message contains text you don't have control over, - * that could include printf() escape sequences. - * - * Since: 2.18 - */ - - -/** - * g_set_prgname: - * @prgname: the name of the program. - * - * Sets the name of the program. This name should not be localized, - * in contrast to g_set_application_name(). - * - * If you are using #GApplication the program name is set in - * g_application_run(). In case of GDK or GTK+ it is set in - * gdk_init(), which is called by gtk_init() and the - * #GtkApplication::startup handler. The program name is found by - * taking the last component of @argv[0]. - * - * Note that for thread-safety reasons this function can only be called once. - */ - - -/** - * g_set_print_handler: - * @func: the new print handler - * - * Sets the print handler. - * - * Any messages passed to g_print() will be output via - * the new handler. The default handler simply outputs - * the message to stdout. By providing your own handler - * you can redirect the output, to a GTK+ widget or a - * log file for example. - * - * Returns: the old print handler - */ - - -/** - * g_set_printerr_handler: - * @func: the new error message handler - * - * Sets the handler for printing error messages. - * - * Any messages passed to g_printerr() will be output via - * the new handler. The default handler simply outputs the - * message to stderr. By providing your own handler you can - * redirect the output, to a GTK+ widget or a log file for - * example. - * - * Returns: the old error message handler - */ - - -/** - * g_setenv: - * @variable: (type filename): the environment variable to set, must not - * contain '='. - * @value: (type filename): the value for to set the variable to. - * @overwrite: whether to change the variable if it already exists. - * - * Sets an environment variable. On UNIX, both the variable's name and - * value can be arbitrary byte strings, except that the variable's name - * cannot contain '='. On Windows, they should be in UTF-8. - * - * Note that on some systems, when variables are overwritten, the memory - * used for the previous variables and its value isn't reclaimed. - * - * You should be mindful of the fact that environment variable handling - * in UNIX is not thread-safe, and your program may crash if one thread - * calls g_setenv() while another thread is calling getenv(). (And note - * that many functions, such as gettext(), call getenv() internally.) - * This function is only safe to use at the very start of your program, - * before creating any other threads (or creating objects that create - * worker threads of their own). - * - * If you need to set up the environment for a child process, you can - * use g_get_environ() to get an environment array, modify that with - * g_environ_setenv() and g_environ_unsetenv(), and then pass that - * array directly to execvpe(), g_spawn_async(), or the like. - * - * Returns: %FALSE if the environment variable couldn't be set. - * Since: 2.4 - */ - - -/** - * g_shell_parse_argv: - * @command_line: (type filename): command line to parse - * @argcp: (out) (optional): return location for number of args - * @argvp: (out) (optional) (array length=argcp zero-terminated=1) (element-type filename): - * return location for array of args - * @error: (optional): return location for error - * - * Parses a command line into an argument vector, in much the same way - * the shell would, but without many of the expansions the shell would - * perform (variable expansion, globs, operators, filename expansion, - * etc. are not supported). - * - * The results are defined to be the same as those you would get from - * a UNIX98 `/bin/sh`, as long as the input contains none of the - * unsupported shell expansions. If the input does contain such expansions, - * they are passed through literally. - * - * Possible errors are those from the %G_SHELL_ERROR domain. - * - * Free the returned vector with g_strfreev(). - * - * Returns: %TRUE on success, %FALSE if error set - */ - - -/** - * g_shell_quote: - * @unquoted_string: (type filename): a literal string - * - * Quotes a string so that the shell (/bin/sh) will interpret the - * quoted string to mean @unquoted_string. - * - * If you pass a filename to the shell, for example, you should first - * quote it with this function. - * - * The return value must be freed with g_free(). - * - * The quoting style used is undefined (single or double quotes may be - * used). - * - * Returns: (type filename) (transfer full): quoted string - */ - - -/** - * g_shell_unquote: - * @quoted_string: (type filename): shell-quoted string - * @error: error return location or NULL - * - * Unquotes a string as the shell (/bin/sh) would. - * - * This function only handles quotes; if a string contains file globs, - * arithmetic operators, variables, backticks, redirections, or other - * special-to-the-shell features, the result will be different from the - * result a real shell would produce (the variables, backticks, etc. - * will be passed through literally instead of being expanded). - * - * This function is guaranteed to succeed if applied to the result of - * g_shell_quote(). If it fails, it returns %NULL and sets the - * error. - * - * The @quoted_string need not actually contain quoted or escaped text; - * g_shell_unquote() simply goes through the string and unquotes/unescapes - * anything that the shell would. Both single and double quotes are - * handled, as are escapes including escaped newlines. - * - * The return value must be freed with g_free(). - * - * Possible errors are in the %G_SHELL_ERROR domain. - * - * Shell quoting rules are a bit strange. Single quotes preserve the - * literal string exactly. escape sequences are not allowed; not even - * `\'` - if you want a `'` in the quoted text, you have to do something - * like `'foo'\''bar'`. Double quotes allow `$`, ```, `"`, `\`, and - * newline to be escaped with backslash. Otherwise double quotes - * preserve things literally. - * - * Returns: (type filename): an unquoted string - */ - - -/** - * g_size_checked_add: - * @dest: a pointer to the #gsize destination - * @a: the #gsize left operand - * @b: the #gsize right operand - * - * Performs a checked addition of @a and @b, storing the result in - * @dest. - * - * If the operation is successful, %TRUE is returned. If the operation - * overflows then the state of @dest is undefined and %FALSE is - * returned. - * - * Returns: %TRUE if there was no overflow - * Since: 2.48 - */ - - -/** - * g_size_checked_mul: - * @dest: a pointer to the #gsize destination - * @a: the #gsize left operand - * @b: the #gsize right operand - * - * Performs a checked multiplication of @a and @b, storing the result in - * @dest. - * - * If the operation is successful, %TRUE is returned. If the operation - * overflows then the state of @dest is undefined and %FALSE is - * returned. - * - * Returns: %TRUE if there was no overflow - * Since: 2.48 - */ - - -/** - * g_slice_alloc: - * @block_size: the number of bytes to allocate - * - * Allocates a block of memory from the slice allocator. - * - * The block address handed out can be expected to be aligned - * to at least `1 * sizeof (void*)`, though in general slices - * are `2 * sizeof (void*)` bytes aligned; if a `malloc()` - * fallback implementation is used instead, the alignment may - * be reduced in a libc dependent fashion. - * - * Note that the underlying slice allocation mechanism can - * be changed with the [`G_SLICE=always-malloc`][G_SLICE] - * environment variable. - * - * Returns: a pointer to the allocated memory block, which will - * be %NULL if and only if @mem_size is 0 - * Since: 2.10 - */ - - -/** - * g_slice_alloc0: - * @block_size: the number of bytes to allocate - * - * Allocates a block of memory via g_slice_alloc() and initializes - * the returned memory to 0. Note that the underlying slice allocation - * mechanism can be changed with the [`G_SLICE=always-malloc`][G_SLICE] - * environment variable. - * - * Returns: a pointer to the allocated block, which will be %NULL if and only - * if @mem_size is 0 - * Since: 2.10 - */ - - -/** - * g_slice_copy: - * @block_size: the number of bytes to allocate - * @mem_block: the memory to copy - * - * Allocates a block of memory from the slice allocator - * and copies @block_size bytes into it from @mem_block. - * - * @mem_block must be non-%NULL if @block_size is non-zero. - * - * Returns: a pointer to the allocated memory block, which will be %NULL if and - * only if @mem_size is 0 - * Since: 2.14 - */ - - -/** - * g_slice_dup: - * @type: the type to duplicate, typically a structure name - * @mem: (not nullable): the memory to copy into the allocated block - * - * A convenience macro to duplicate a block of memory using - * the slice allocator. - * - * It calls g_slice_copy() with `sizeof (@type)` - * and casts the returned pointer to a pointer of the given type, - * avoiding a type cast in the source code. - * Note that the underlying slice allocation mechanism can - * be changed with the [`G_SLICE=always-malloc`][G_SLICE] - * environment variable. - * - * This can never return %NULL. - * - * Returns: (not nullable): a pointer to the allocated block, cast to a pointer - * to @type - * Since: 2.14 - */ - - -/** - * g_slice_free: - * @type: the type of the block to free, typically a structure name - * @mem: a pointer to the block to free - * - * A convenience macro to free a block of memory that has - * been allocated from the slice allocator. - * - * It calls g_slice_free1() using `sizeof (type)` - * as the block size. - * Note that the exact release behaviour can be changed with the - * [`G_DEBUG=gc-friendly`][G_DEBUG] environment variable, also see - * [`G_SLICE`][G_SLICE] for related debugging options. - * - * If @mem is %NULL, this macro does nothing. - * - * Since: 2.10 - */ - - -/** - * g_slice_free1: - * @block_size: the size of the block - * @mem_block: a pointer to the block to free - * - * Frees a block of memory. - * - * The memory must have been allocated via g_slice_alloc() or - * g_slice_alloc0() and the @block_size has to match the size - * specified upon allocation. Note that the exact release behaviour - * can be changed with the [`G_DEBUG=gc-friendly`][G_DEBUG] environment - * variable, also see [`G_SLICE`][G_SLICE] for related debugging options. - * - * If @mem_block is %NULL, this function does nothing. - * - * Since: 2.10 - */ - - -/** - * g_slice_free_chain: - * @type: the type of the @mem_chain blocks - * @mem_chain: a pointer to the first block of the chain - * @next: the field name of the next pointer in @type - * - * Frees a linked list of memory blocks of structure type @type. - * - * The memory blocks must be equal-sized, allocated via - * g_slice_alloc() or g_slice_alloc0() and linked together by - * a @next pointer (similar to #GSList). The name of the - * @next field in @type is passed as third argument. - * Note that the exact release behaviour can be changed with the - * [`G_DEBUG=gc-friendly`][G_DEBUG] environment variable, also see - * [`G_SLICE`][G_SLICE] for related debugging options. - * - * If @mem_chain is %NULL, this function does nothing. - * - * Since: 2.10 - */ - - -/** - * g_slice_free_chain_with_offset: - * @block_size: the size of the blocks - * @mem_chain: a pointer to the first block of the chain - * @next_offset: the offset of the @next field in the blocks - * - * Frees a linked list of memory blocks of structure type @type. - * - * The memory blocks must be equal-sized, allocated via - * g_slice_alloc() or g_slice_alloc0() and linked together by a - * @next pointer (similar to #GSList). The offset of the @next - * field in each block is passed as third argument. - * Note that the exact release behaviour can be changed with the - * [`G_DEBUG=gc-friendly`][G_DEBUG] environment variable, also see - * [`G_SLICE`][G_SLICE] for related debugging options. - * - * If @mem_chain is %NULL, this function does nothing. - * - * Since: 2.10 - */ - - -/** - * g_slice_new: - * @type: the type to allocate, typically a structure name - * - * A convenience macro to allocate a block of memory from the - * slice allocator. - * - * It calls g_slice_alloc() with `sizeof (@type)` and casts the - * returned pointer to a pointer of the given type, avoiding a type - * cast in the source code. Note that the underlying slice allocation - * mechanism can be changed with the [`G_SLICE=always-malloc`][G_SLICE] - * environment variable. - * - * This can never return %NULL as the minimum allocation size from - * `sizeof (@type)` is 1 byte. - * - * Returns: (not nullable): a pointer to the allocated block, cast to a pointer - * to @type - * Since: 2.10 - */ - - -/** - * g_slice_new0: - * @type: the type to allocate, typically a structure name - * - * A convenience macro to allocate a block of memory from the - * slice allocator and set the memory to 0. - * - * It calls g_slice_alloc0() with `sizeof (@type)` - * and casts the returned pointer to a pointer of the given type, - * avoiding a type cast in the source code. - * Note that the underlying slice allocation mechanism can - * be changed with the [`G_SLICE=always-malloc`][G_SLICE] - * environment variable. - * - * This can never return %NULL as the minimum allocation size from - * `sizeof (@type)` is 1 byte. - * - * Returns: (not nullable): a pointer to the allocated block, cast to a pointer - * to @type - * Since: 2.10 - */ - - -/** - * g_slist_alloc: - * - * Allocates space for one #GSList element. It is called by the - * g_slist_append(), g_slist_prepend(), g_slist_insert() and - * g_slist_insert_sorted() functions and so is rarely used on its own. - * - * Returns: a pointer to the newly-allocated #GSList element. - */ - - -/** - * g_slist_append: - * @list: a #GSList - * @data: the data for the new element - * - * Adds a new element on to the end of the list. - * - * The return value is the new start of the list, which may - * have changed, so make sure you store the new value. - * - * Note that g_slist_append() has to traverse the entire list - * to find the end, which is inefficient when adding multiple - * elements. A common idiom to avoid the inefficiency is to prepend - * the elements and reverse the list when all elements have been added. - * - * |[<!-- language="C" --> - * // Notice that these are initialized to the empty list. - * GSList *list = NULL, *number_list = NULL; - * - * // This is a list of strings. - * list = g_slist_append (list, "first"); - * list = g_slist_append (list, "second"); - * - * // 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 (14)); - * ]| - * - * Returns: the new start of the #GSList - */ - - -/** - * g_slist_concat: - * @list1: a #GSList - * @list2: the #GSList to add to the end of the first #GSList - * - * Adds the second #GSList onto the end of the first #GSList. - * Note that the elements of the second #GSList are not copied. - * They are used directly. - * - * Returns: the start of the new #GSList - */ - - -/** - * g_slist_copy: - * @list: a #GSList - * - * Copies a #GSList. - * - * Note that this is a "shallow" copy. If the list elements - * consist of pointers to data, the pointers are copied but - * the actual data isn't. See g_slist_copy_deep() if you need - * to copy the data as well. - * - * Returns: a copy of @list - */ - - -/** - * g_slist_copy_deep: - * @list: a #GSList - * @func: a copy function used to copy every element in the list - * @user_data: user data passed to the copy function @func, or #NULL - * - * Makes a full (deep) copy of a #GSList. - * - * In contrast with g_slist_copy(), this function uses @func to make a copy of - * each list element, in addition to copying the list container itself. - * - * @func, as a #GCopyFunc, takes two arguments, the data to be copied - * and a @user_data pointer. On common processor architectures, it's safe to - * pass %NULL as @user_data if the copy function takes only one argument. You - * may get compiler warnings from this though if compiling with GCC’s - * `-Wcast-function-type` warning. - * - * For instance, if @list holds a list of GObjects, you can do: - * |[<!-- language="C" --> - * another_list = g_slist_copy_deep (list, (GCopyFunc) g_object_ref, NULL); - * ]| - * - * And, to entirely free the new list, you could do: - * |[<!-- language="C" --> - * g_slist_free_full (another_list, g_object_unref); - * ]| - * - * Returns: a full copy of @list, use g_slist_free_full() to free it - * Since: 2.34 - */ - - -/** - * g_slist_delete_link: - * @list: a #GSList - * @link_: node to delete - * - * Removes the node link_ from the list and frees it. - * Compare this to g_slist_remove_link() which removes the node - * without freeing it. - * - * Removing arbitrary nodes from a singly-linked list requires time - * that is proportional to the length of the list (ie. O(n)). If you - * find yourself using g_slist_delete_link() frequently, you should - * consider a different data structure, such as the doubly-linked - * #GList. - * - * Returns: the new head of @list - */ - - -/** - * g_slist_find: - * @list: a #GSList - * @data: the element data to find - * - * Finds the element in a #GSList which - * contains the given data. - * - * Returns: the found #GSList element, - * or %NULL if it is not found - */ - - -/** - * g_slist_find_custom: - * @list: a #GSList - * @data: user data passed to the function - * @func: the function to call for each element. - * It should return 0 when the desired element is found - * - * Finds an element in a #GSList, using a supplied function to - * find the desired element. It iterates over the list, calling - * the given function which should return 0 when the desired - * element is found. The function takes two #gconstpointer arguments, - * the #GSList element's data as the first argument and the - * given user data. - * - * Returns: the found #GSList element, or %NULL if it is not found - */ - - -/** - * g_slist_foreach: - * @list: a #GSList - * @func: the function to call with each element's data - * @user_data: user data to pass to the function - * - * Calls a function for each element of a #GSList. - * - * It is safe for @func to remove the element from @list, but it must - * not modify any part of the list after that element. - */ - - -/** - * g_slist_free: - * @list: the first link of a #GSList - * - * Frees all of the memory used by a #GSList. - * The freed elements are returned to the slice allocator. - * - * If list elements contain dynamically-allocated memory, - * you should either use g_slist_free_full() or free them manually - * first. - * - * It can be combined with g_steal_pointer() to ensure the list head pointer - * is not left dangling: - * |[<!-- language="C" --> - * GSList *list_of_borrowed_things = …; /<!-- -->* (transfer container) *<!-- -->/ - * g_slist_free (g_steal_pointer (&list_of_borrowed_things)); - * ]| - */ - - -/** - * g_slist_free1: - * - * A macro which does the same as g_slist_free_1(). - * - * Since: 2.10 - */ - - -/** - * g_slist_free_1: - * @list: a #GSList element - * - * Frees one #GSList element. - * It is usually used after g_slist_remove_link(). - */ - - -/** - * g_slist_free_full: - * @list: the first link of a #GSList - * @free_func: the function to be called to free each element's data - * - * Convenience method, which frees all the memory used by a #GSList, and - * calls the specified destroy function on every element's data. - * - * @free_func must not modify the list (eg, by removing the freed - * element from it). - * - * It can be combined with g_steal_pointer() to ensure the list head pointer - * is not left dangling — this also has the nice property that the head pointer - * is cleared before any of the list elements are freed, to prevent double frees - * from @free_func: - * |[<!-- language="C" --> - * GSList *list_of_owned_things = …; /<!-- -->* (transfer full) (element-type GObject) *<!-- -->/ - * g_slist_free_full (g_steal_pointer (&list_of_owned_things), g_object_unref); - * ]| - * - * Since: 2.28 - */ - - -/** - * g_slist_index: - * @list: a #GSList - * @data: the data to find - * - * Gets the position of the element containing - * the given data (starting from 0). - * - * Returns: the index of the element containing the data, - * or -1 if the data is not found - */ - - -/** - * g_slist_insert: - * @list: a #GSList - * @data: the data for the new element - * @position: the position to insert the element. - * If this is negative, or is larger than the number - * of elements in the list, the new element is added on - * to the end of the list. - * - * Inserts a new element into the list at the given position. - * - * Returns: the new start of the #GSList - */ - - -/** - * g_slist_insert_before: - * @slist: a #GSList - * @sibling: node to insert @data before - * @data: data to put in the newly-inserted node - * - * Inserts a node before @sibling containing @data. - * - * Returns: the new head of the list. - */ - - -/** - * g_slist_insert_sorted: - * @list: a #GSList - * @data: the data for the new element - * @func: the function to compare elements in the list. - * It should return a number > 0 if the first parameter - * comes after the second parameter in the sort order. - * - * Inserts a new element into the list, using the given - * comparison function to determine its position. - * - * Returns: the new start of the #GSList - */ - - -/** - * g_slist_insert_sorted_with_data: - * @list: a #GSList - * @data: the data for the new element - * @func: the function to compare elements in the list. - * It should return a number > 0 if the first parameter - * comes after the second parameter in the sort order. - * @user_data: data to pass to comparison function - * - * Inserts a new element into the list, using the given - * comparison function to determine its position. - * - * Returns: the new start of the #GSList - * Since: 2.10 - */ - - -/** - * g_slist_last: - * @list: a #GSList - * - * Gets the last element in a #GSList. - * - * This function iterates over the whole list. - * - * Returns: the last element in the #GSList, - * or %NULL if the #GSList has no elements - */ - - -/** - * g_slist_length: - * @list: a #GSList - * - * Gets the number of elements in a #GSList. - * - * This function iterates over the whole list to - * count its elements. To check whether the list is non-empty, it is faster to - * check @list against %NULL. - * - * Returns: the number of elements in the #GSList - */ - - -/** - * g_slist_next: - * @slist: an element in a #GSList. - * - * A convenience macro to get the next element in a #GSList. - * Note that it is considered perfectly acceptable to access - * @slist->next directly. - * - * Returns: the next element, or %NULL if there are no more elements. - */ - - -/** - * g_slist_nth: - * @list: a #GSList - * @n: the position of the element, counting from 0 - * - * Gets the element at the given position in a #GSList. - * - * Returns: the element, or %NULL if the position is off - * the end of the #GSList - */ - - -/** - * g_slist_nth_data: - * @list: a #GSList - * @n: the position of the element - * - * Gets the data of the element at the given position. - * - * Returns: the element's data, or %NULL if the position - * is off the end of the #GSList - */ - - -/** - * g_slist_position: - * @list: a #GSList - * @llink: an element in the #GSList - * - * Gets the position of the given element - * in the #GSList (starting from 0). - * - * Returns: the position of the element in the #GSList, - * or -1 if the element is not found - */ - - -/** - * g_slist_prepend: - * @list: a #GSList - * @data: the data for the new element - * - * Adds a new element on to the start of the list. - * - * The return value is the new start of the list, which - * may have changed, so make sure you store the new value. - * - * |[<!-- language="C" --> - * // Notice that it is initialized to the empty list. - * GSList *list = NULL; - * list = g_slist_prepend (list, "last"); - * list = g_slist_prepend (list, "first"); - * ]| - * - * Returns: the new start of the #GSList - */ - - -/** - * g_slist_remove: - * @list: a #GSList - * @data: the data of the element to remove - * - * Removes an element from a #GSList. - * If two elements contain the same data, only the first is removed. - * If none of the elements contain the data, the #GSList is unchanged. - * - * Returns: the new start of the #GSList - */ - - -/** - * g_slist_remove_all: - * @list: a #GSList - * @data: data to remove - * - * Removes all list nodes with data equal to @data. - * Returns the new head of the list. Contrast with - * g_slist_remove() which removes only the first node - * matching the given data. - * - * Returns: new head of @list - */ - - -/** - * g_slist_remove_link: - * @list: a #GSList - * @link_: an element in the #GSList - * - * Removes an element from a #GSList, without - * freeing the element. The removed element's next - * link is set to %NULL, so that it becomes a - * self-contained list with one element. - * - * Removing arbitrary nodes from a singly-linked list - * requires time that is proportional to the length of the list - * (ie. O(n)). If you find yourself using g_slist_remove_link() - * frequently, you should consider a different data structure, - * such as the doubly-linked #GList. - * - * Returns: the new start of the #GSList, without the element - */ - - -/** - * g_slist_reverse: - * @list: a #GSList - * - * Reverses a #GSList. - * - * Returns: the start of the reversed #GSList - */ - - -/** - * g_slist_sort: - * @list: a #GSList - * @compare_func: the comparison function used to sort the #GSList. - * This function is passed the data from 2 elements of the #GSList - * and should return 0 if they are equal, a negative value if the - * first element comes before the second, or a positive value if - * the first element comes after the second. - * - * Sorts a #GSList using the given comparison function. The algorithm - * used is a stable sort. - * - * Returns: the start of the sorted #GSList - */ - - -/** - * g_slist_sort_with_data: - * @list: a #GSList - * @compare_func: comparison function - * @user_data: data to pass to comparison function - * - * Like g_slist_sort(), but the sort function accepts a user data argument. - * - * Returns: new head of the list - */ - - -/** - * g_snprintf: - * @string: the buffer to hold the output. - * @n: the maximum number of bytes to produce (including the - * terminating nul character). - * @format: a standard printf() format string, but notice - * [string precision pitfalls][string-precision] - * @...: the arguments to insert in the output. - * - * A safer form of the standard sprintf() function. The output is guaranteed - * to not exceed @n characters (including the terminating nul character), so - * it is easy to ensure that a buffer overflow cannot occur. - * - * See also g_strdup_printf(). - * - * In versions of GLib prior to 1.2.3, this function may return -1 if the - * output was truncated, and the truncated string may not be nul-terminated. - * In versions prior to 1.3.12, this function returns the length of the output - * string. - * - * The return value of g_snprintf() conforms to the snprintf() - * function as standardized in ISO C99. Note that this is different from - * traditional snprintf(), which returns the length of the output string. - * - * The format string may contain positional parameters, as specified in - * the Single Unix Specification. - * - * Returns: the number of bytes which would be produced if the buffer - * was large enough. - */ - - -/** - * g_source_add_child_source: - * @source: a #GSource - * @child_source: a second #GSource that @source should "poll" - * - * Adds @child_source to @source as a "polled" source; when @source is - * added to a #GMainContext, @child_source will be automatically added - * with the same priority, when @child_source is triggered, it will - * cause @source to dispatch (in addition to calling its own - * callback), and when @source is destroyed, it will destroy - * @child_source as well. (@source will also still be dispatched if - * its own prepare/check functions indicate that it is ready.) - * - * If you don't need @child_source to do anything on its own when it - * triggers, you can call g_source_set_dummy_callback() on it to set a - * callback that does nothing (except return %TRUE if appropriate). - * - * @source will hold a reference on @child_source while @child_source - * is attached to it. - * - * This API is only intended to be used by implementations of #GSource. - * Do not call this API on a #GSource that you did not create. - * - * Since: 2.28 - */ - - -/** - * g_source_add_poll: - * @source: a #GSource - * @fd: a #GPollFD structure holding information about a file - * descriptor to watch. - * - * Adds a file descriptor to the set of file descriptors polled for - * this source. This is usually combined with g_source_new() to add an - * event source. The event source's check function will typically test - * the @revents field in the #GPollFD struct and return %TRUE if events need - * to be processed. - * - * This API is only intended to be used by implementations of #GSource. - * Do not call this API on a #GSource that you did not create. - * - * Using this API forces the linear scanning of event sources on each - * main loop iteration. Newly-written event sources should try to use - * g_source_add_unix_fd() instead of this API. - */ - - -/** - * g_source_add_unix_fd: - * @source: a #GSource - * @fd: the fd to monitor - * @events: an event mask - * - * Monitors @fd for the IO events in @events. - * - * The tag returned by this function can be used to remove or modify the - * monitoring of the fd using g_source_remove_unix_fd() or - * g_source_modify_unix_fd(). - * - * It is not necessary to remove the fd before destroying the source; it - * will be cleaned up automatically. - * - * This API is only intended to be used by implementations of #GSource. - * Do not call this API on a #GSource that you did not create. - * - * As the name suggests, this function is not available on Windows. - * - * Returns: (not nullable): an opaque tag - * Since: 2.36 - */ - - -/** - * g_source_attach: - * @source: a #GSource - * @context: (nullable): a #GMainContext (if %NULL, the default context will be used) - * - * Adds a #GSource to a @context so that it will be executed within - * that context. Remove it by calling g_source_destroy(). - * - * This function is safe to call from any thread, regardless of which thread - * the @context is running in. - * - * Returns: the ID (greater than 0) for the source within the - * #GMainContext. - */ - - -/** - * g_source_destroy: - * @source: a #GSource - * - * Removes a source from its #GMainContext, if any, and mark it as - * destroyed. The source cannot be subsequently added to another - * context. It is safe to call this on sources which have already been - * removed from their context. - * - * This does not unref the #GSource: if you still hold a reference, use - * g_source_unref() to drop it. - * - * This function is safe to call from any thread, regardless of which thread - * the #GMainContext is running in. - * - * If the source is currently attached to a #GMainContext, destroying it - * will effectively unset the callback similar to calling g_source_set_callback(). - * This can mean, that the data's #GDestroyNotify gets called right away. - */ - - -/** - * g_source_get_can_recurse: - * @source: a #GSource - * - * Checks whether a source is allowed to be called recursively. - * see g_source_set_can_recurse(). - * - * Returns: whether recursion is allowed. - */ - - -/** - * g_source_get_context: - * @source: a #GSource - * - * Gets the #GMainContext with which the source is associated. - * - * You can call this on a source that has been destroyed, provided - * that the #GMainContext it was attached to still exists (in which - * case it will return that #GMainContext). In particular, you can - * always call this function on the source returned from - * g_main_current_source(). But calling this function on a source - * whose #GMainContext has been destroyed is an error. - * - * Returns: (transfer none) (nullable): the #GMainContext with which the - * source is associated, or %NULL if the context has not - * yet been added to a source. - */ - - -/** - * g_source_get_current_time: - * @source: a #GSource - * @timeval: #GTimeVal structure in which to store current time. - * - * This function ignores @source and is otherwise the same as - * g_get_current_time(). - * - * Deprecated: 2.28: use g_source_get_time() instead - */ - - -/** - * g_source_get_id: - * @source: a #GSource - * - * Returns the numeric ID for a particular source. The ID of a source - * is a positive integer which is unique within a particular main loop - * context. The reverse - * mapping from ID to source is done by g_main_context_find_source_by_id(). - * - * You can only call this function while the source is associated to a - * #GMainContext instance; calling this function before g_source_attach() - * or after g_source_destroy() yields undefined behavior. The ID returned - * is unique within the #GMainContext instance passed to g_source_attach(). - * - * Returns: the ID (greater than 0) for the source - */ - - -/** - * g_source_get_name: - * @source: a #GSource - * - * Gets a name for the source, used in debugging and profiling. The - * name may be #NULL if it has never been set with g_source_set_name(). - * - * Returns: (nullable): the name of the source - * Since: 2.26 - */ - - -/** - * g_source_get_priority: - * @source: a #GSource - * - * Gets the priority of a source. - * - * Returns: the priority of the source - */ - - -/** - * g_source_get_ready_time: - * @source: a #GSource - * - * Gets the "ready time" of @source, as set by - * g_source_set_ready_time(). - * - * Any time before the current monotonic time (including 0) is an - * indication that the source will fire immediately. - * - * Returns: the monotonic ready time, -1 for "never" - */ - - -/** - * g_source_get_time: - * @source: a #GSource - * - * Gets the time to be used when checking this source. The advantage of - * calling this function over calling g_get_monotonic_time() directly is - * that when checking multiple sources, GLib can cache a single value - * instead of having to repeatedly get the system monotonic time. - * - * The time here is the system monotonic time, if available, or some - * other reasonable alternative otherwise. See g_get_monotonic_time(). - * - * Returns: the monotonic time in microseconds - * Since: 2.28 - */ - - -/** - * g_source_is_destroyed: - * @source: a #GSource - * - * Returns whether @source has been destroyed. - * - * This is important when you operate upon your objects - * from within idle handlers, but may have freed the object - * before the dispatch of your idle handler. - * - * |[<!-- language="C" --> - * static gboolean - * idle_callback (gpointer data) - * { - * SomeWidget *self = data; - * - * g_mutex_lock (&self->idle_id_mutex); - * // do stuff with self - * self->idle_id = 0; - * g_mutex_unlock (&self->idle_id_mutex); - * - * return G_SOURCE_REMOVE; - * } - * - * static void - * some_widget_do_stuff_later (SomeWidget *self) - * { - * g_mutex_lock (&self->idle_id_mutex); - * self->idle_id = g_idle_add (idle_callback, self); - * g_mutex_unlock (&self->idle_id_mutex); - * } - * - * static void - * some_widget_init (SomeWidget *self) - * { - * g_mutex_init (&self->idle_id_mutex); - * - * // ... - * } - * - * static void - * some_widget_finalize (GObject *object) - * { - * SomeWidget *self = SOME_WIDGET (object); - * - * if (self->idle_id) - * g_source_remove (self->idle_id); - * - * g_mutex_clear (&self->idle_id_mutex); - * - * G_OBJECT_CLASS (parent_class)->finalize (object); - * } - * ]| - * - * This will fail in a multi-threaded application if the - * widget is destroyed before the idle handler fires due - * to the use after free in the callback. A solution, to - * this particular problem, is to check to if the source - * has already been destroy within the callback. - * - * |[<!-- language="C" --> - * static gboolean - * idle_callback (gpointer data) - * { - * SomeWidget *self = data; - * - * g_mutex_lock (&self->idle_id_mutex); - * if (!g_source_is_destroyed (g_main_current_source ())) - * { - * // do stuff with self - * } - * g_mutex_unlock (&self->idle_id_mutex); - * - * return FALSE; - * } - * ]| - * - * Calls to this function from a thread other than the one acquired by the - * #GMainContext the #GSource is attached to are typically redundant, as the - * source could be destroyed immediately after this function returns. However, - * once a source is destroyed it cannot be un-destroyed, so this function can be - * used for opportunistic checks from any thread. - * - * Returns: %TRUE if the source has been destroyed - * Since: 2.12 - */ - - -/** - * g_source_modify_unix_fd: - * @source: a #GSource - * @tag: (not nullable): the tag from g_source_add_unix_fd() - * @new_events: the new event mask to watch - * - * Updates the event mask to watch for the fd identified by @tag. - * - * @tag is the tag returned from g_source_add_unix_fd(). - * - * If you want to remove a fd, don't set its event mask to zero. - * Instead, call g_source_remove_unix_fd(). - * - * This API is only intended to be used by implementations of #GSource. - * Do not call this API on a #GSource that you did not create. - * - * As the name suggests, this function is not available on Windows. - * - * Since: 2.36 - */ - - -/** - * g_source_new: - * @source_funcs: structure containing functions that implement - * the sources behavior. - * @struct_size: size of the #GSource structure to create. - * - * Creates a new #GSource structure. The size is specified to - * allow creating structures derived from #GSource that contain - * additional data. The size passed in must be at least - * `sizeof (GSource)`. - * - * The source will not initially be associated with any #GMainContext - * and must be added to one with g_source_attach() before it will be - * executed. - * - * Returns: the newly-created #GSource. - */ - - -/** - * g_source_query_unix_fd: - * @source: a #GSource - * @tag: (not nullable): the tag from g_source_add_unix_fd() - * - * Queries the events reported for the fd corresponding to @tag on - * @source during the last poll. - * - * The return value of this function is only defined when the function - * is called from the check or dispatch functions for @source. - * - * This API is only intended to be used by implementations of #GSource. - * Do not call this API on a #GSource that you did not create. - * - * As the name suggests, this function is not available on Windows. - * - * Returns: the conditions reported on the fd - * Since: 2.36 - */ - - -/** - * g_source_ref: - * @source: a #GSource - * - * Increases the reference count on a source by one. - * - * Returns: @source - */ - - -/** - * g_source_remove: - * @tag: the ID of the source to remove. - * - * Removes the source with the given ID from the default main context. You must - * use g_source_destroy() for sources added to a non-default main context. - * - * The ID of a #GSource is given by g_source_get_id(), or will be - * returned by the functions g_source_attach(), g_idle_add(), - * g_idle_add_full(), g_timeout_add(), g_timeout_add_full(), - * g_child_watch_add(), g_child_watch_add_full(), g_io_add_watch(), and - * g_io_add_watch_full(). - * - * It is a programmer error to attempt to remove a non-existent source. - * - * More specifically: source IDs can be reissued after a source has been - * destroyed and therefore it is never valid to use this function with a - * source ID which may have already been removed. An example is when - * scheduling an idle to run in another thread with g_idle_add(): the - * idle may already have run and been removed by the time this function - * is called on its (now invalid) source ID. This source ID may have - * been reissued, leading to the operation being performed against the - * wrong source. - * - * Returns: For historical reasons, this function always returns %TRUE - */ - - -/** - * g_source_remove_by_funcs_user_data: - * @funcs: The @source_funcs passed to g_source_new() - * @user_data: the user data for the callback - * - * Removes a source from the default main loop context given the - * source functions and user data. If multiple sources exist with the - * same source functions and user data, only one will be destroyed. - * - * Returns: %TRUE if a source was found and removed. - */ - - -/** - * g_source_remove_by_user_data: - * @user_data: the user_data for the callback. - * - * Removes a source from the default main loop context given the user - * data for the callback. If multiple sources exist with the same user - * data, only one will be destroyed. - * - * Returns: %TRUE if a source was found and removed. - */ - - -/** - * g_source_remove_child_source: - * @source: a #GSource - * @child_source: a #GSource previously passed to - * g_source_add_child_source(). - * - * Detaches @child_source from @source and destroys it. - * - * This API is only intended to be used by implementations of #GSource. - * Do not call this API on a #GSource that you did not create. - * - * Since: 2.28 - */ - - -/** - * g_source_remove_poll: - * @source: a #GSource - * @fd: a #GPollFD structure previously passed to g_source_add_poll(). - * - * Removes a file descriptor from the set of file descriptors polled for - * this source. - * - * This API is only intended to be used by implementations of #GSource. - * Do not call this API on a #GSource that you did not create. - */ - - -/** - * g_source_remove_unix_fd: - * @source: a #GSource - * @tag: (not nullable): the tag from g_source_add_unix_fd() - * - * Reverses the effect of a previous call to g_source_add_unix_fd(). - * - * You only need to call this if you want to remove an fd from being - * watched while keeping the same source around. In the normal case you - * will just want to destroy the source. - * - * This API is only intended to be used by implementations of #GSource. - * Do not call this API on a #GSource that you did not create. - * - * As the name suggests, this function is not available on Windows. - * - * Since: 2.36 - */ - - -/** - * g_source_set_callback: - * @source: the source - * @func: a callback function - * @data: the data to pass to callback function - * @notify: (nullable): a function to call when @data is no longer in use, or %NULL. - * - * Sets the callback function for a source. The callback for a source is - * called from the source's dispatch function. - * - * The exact type of @func depends on the type of source; ie. you - * should not count on @func being called with @data as its first - * parameter. Cast @func with G_SOURCE_FUNC() to avoid warnings about - * incompatible function types. - * - * See [memory management of sources][mainloop-memory-management] for details - * on how to handle memory management of @data. - * - * Typically, you won't use this function. Instead use functions specific - * to the type of source you are using, such as g_idle_add() or g_timeout_add(). - * - * It is safe to call this function multiple times on a source which has already - * been attached to a context. The changes will take effect for the next time - * the source is dispatched after this call returns. - * - * Note that g_source_destroy() for a currently attached source has the effect - * of also unsetting the callback. - */ - - -/** - * g_source_set_callback_indirect: - * @source: the source - * @callback_data: pointer to callback data "object" - * @callback_funcs: functions for reference counting @callback_data - * and getting the callback and data - * - * Sets the callback function storing the data as a refcounted callback - * "object". This is used internally. Note that calling - * g_source_set_callback_indirect() assumes - * an initial reference count on @callback_data, and thus - * @callback_funcs->unref will eventually be called once more - * than @callback_funcs->ref. - * - * It is safe to call this function multiple times on a source which has already - * been attached to a context. The changes will take effect for the next time - * the source is dispatched after this call returns. - */ - - -/** - * g_source_set_can_recurse: - * @source: a #GSource - * @can_recurse: whether recursion is allowed for this source - * - * Sets whether a source can be called recursively. If @can_recurse is - * %TRUE, then while the source is being dispatched then this source - * will be processed normally. Otherwise, all processing of this - * source is blocked until the dispatch function returns. - */ - - -/** - * g_source_set_dispose_function: - * @source: A #GSource to set the dispose function on - * @dispose: #GSourceDisposeFunc to set on the source - * - * Set @dispose as dispose function on @source. @dispose will be called once - * the reference count of @source reaches 0 but before any of the state of the - * source is freed, especially before the finalize function is called. - * - * This means that at this point @source is still a valid #GSource and it is - * allow for the reference count to increase again until @dispose returns. - * - * The dispose function can be used to clear any "weak" references to the - * @source in other data structures in a thread-safe way where it is possible - * for another thread to increase the reference count of @source again while - * it is being freed. - * - * The finalize function can not be used for this purpose as at that point - * @source is already partially freed and not valid anymore. - * - * This should only ever be called from #GSource implementations. - * - * Since: 2.64 - */ - - -/** - * g_source_set_funcs: - * @source: a #GSource - * @funcs: the new #GSourceFuncs - * - * Sets the source functions (can be used to override - * default implementations) of an unattached source. - * - * Since: 2.12 - */ - - -/** - * g_source_set_name: - * @source: a #GSource - * @name: debug name for the source - * - * Sets a name for the source, used in debugging and profiling. - * The name defaults to #NULL. - * - * The source name should describe in a human-readable way - * what the source does. For example, "X11 event queue" - * or "GTK+ repaint idle handler" or whatever it is. - * - * It is permitted to call this function multiple times, but is not - * recommended due to the potential performance impact. For example, - * one could change the name in the "check" function of a #GSourceFuncs - * to include details like the event type in the source name. - * - * Use caution if changing the name while another thread may be - * accessing it with g_source_get_name(); that function does not copy - * the value, and changing the value will free it while the other thread - * may be attempting to use it. - * - * Also see g_source_set_static_name(). - * - * Since: 2.26 - */ - - -/** - * g_source_set_name_by_id: - * @tag: a #GSource ID - * @name: debug name for the source - * - * Sets the name of a source using its ID. - * - * This is a convenience utility to set source names from the return - * value of g_idle_add(), g_timeout_add(), etc. - * - * It is a programmer error to attempt to set the name of a non-existent - * source. - * - * More specifically: source IDs can be reissued after a source has been - * destroyed and therefore it is never valid to use this function with a - * source ID which may have already been removed. An example is when - * scheduling an idle to run in another thread with g_idle_add(): the - * idle may already have run and been removed by the time this function - * is called on its (now invalid) source ID. This source ID may have - * been reissued, leading to the operation being performed against the - * wrong source. - * - * Since: 2.26 - */ - - -/** - * g_source_set_priority: - * @source: a #GSource - * @priority: the new priority. - * - * Sets the priority of a source. While the main loop is being run, a - * source will be dispatched if it is ready to be dispatched and no - * sources at a higher (numerically smaller) priority are ready to be - * dispatched. - * - * A child source always has the same priority as its parent. It is not - * permitted to change the priority of a source once it has been added - * as a child of another source. - */ - - -/** - * g_source_set_ready_time: - * @source: a #GSource - * @ready_time: the monotonic time at which the source will be ready, - * 0 for "immediately", -1 for "never" - * - * Sets a #GSource to be dispatched when the given monotonic time is - * reached (or passed). If the monotonic time is in the past (as it - * always will be if @ready_time is 0) then the source will be - * dispatched immediately. - * - * If @ready_time is -1 then the source is never woken up on the basis - * of the passage of time. - * - * Dispatching the source does not reset the ready time. You should do - * so yourself, from the source dispatch function. - * - * Note that if you have a pair of sources where the ready time of one - * suggests that it will be delivered first but the priority for the - * other suggests that it would be delivered first, and the ready time - * for both sources is reached during the same main context iteration, - * then the order of dispatch is undefined. - * - * It is a no-op to call this function on a #GSource which has already been - * destroyed with g_source_destroy(). - * - * This API is only intended to be used by implementations of #GSource. - * Do not call this API on a #GSource that you did not create. - * - * Since: 2.36 - */ - - -/** - * g_source_set_static_name: - * @source: a #GSource - * @name: debug name for the source - * - * A variant of g_source_set_name() that does not - * duplicate the @name, and can only be used with - * string literals. - * - * Since: 2.70 - */ - - -/** - * g_source_unref: - * @source: a #GSource - * - * Decreases the reference count of a source by one. If the - * resulting reference count is zero the source and associated - * memory will be destroyed. - */ - - -/** - * g_spaced_primes_closest: - * @num: a #guint - * - * Gets the smallest prime number from a built-in array of primes which - * is larger than @num. This is used within GLib to calculate the optimum - * size of a #GHashTable. - * - * The built-in array of primes ranges from 11 to 13845163 such that - * each prime is approximately 1.5-2 times the previous prime. - * - * Returns: the smallest prime number from a built-in array of primes - * which is larger than @num - */ - - -/** - * g_spawn_async: - * @working_directory: (type filename) (nullable): child's current working - * directory, or %NULL to inherit parent's - * @argv: (array zero-terminated=1) (element-type filename): - * child's argument vector - * @envp: (array zero-terminated=1) (element-type filename) (nullable): - * child's environment, or %NULL to inherit parent's - * @flags: flags from #GSpawnFlags - * @child_setup: (scope async) (nullable): function to run in the child just before exec() - * @user_data: (closure): user data for @child_setup - * @child_pid: (out) (optional): return location for child process reference, or %NULL - * @error: return location for error - * - * Executes a child program asynchronously. - * - * See g_spawn_async_with_pipes() for a full description; this function - * simply calls the g_spawn_async_with_pipes() without any pipes. - * - * You should call g_spawn_close_pid() on the returned child process - * reference when you don't need it any more. - * - * If you are writing a GTK application, and the program you are spawning is a - * graphical application too, then to ensure that the spawned program opens its - * windows on the right screen, you may want to use #GdkAppLaunchContext, - * #GAppLaunchContext, or set the %DISPLAY environment variable. - * - * Note that the returned @child_pid on Windows is a handle to the child - * process and not its identifier. Process handles and process identifiers - * are different concepts on Windows. - * - * Returns: %TRUE on success, %FALSE if error is set - */ - - -/** - * g_spawn_async_with_fds: - * @working_directory: (type filename) (nullable): child's current working directory, or %NULL to inherit parent's, in the GLib file name encoding - * @argv: (array zero-terminated=1): child's argument vector, in the GLib file name encoding - * @envp: (array zero-terminated=1) (nullable): child's environment, or %NULL to inherit parent's, in the GLib file name encoding - * @flags: flags from #GSpawnFlags - * @child_setup: (scope async) (nullable): function to run in the child just before exec() - * @user_data: (closure): user data for @child_setup - * @child_pid: (out) (optional): return location for child process ID, or %NULL - * @stdin_fd: file descriptor to use for child's stdin, or `-1` - * @stdout_fd: file descriptor to use for child's stdout, or `-1` - * @stderr_fd: file descriptor to use for child's stderr, or `-1` - * @error: return location for error - * - * Executes a child program asynchronously. - * - * Identical to g_spawn_async_with_pipes_and_fds() but with `n_fds` set to zero, - * so no FD assignments are used. - * - * Returns: %TRUE on success, %FALSE if an error was set - * Since: 2.58 - */ - - -/** - * g_spawn_async_with_pipes: - * @working_directory: (type filename) (nullable): child's current working - * directory, or %NULL to inherit parent's, in the GLib file name encoding - * @argv: (array zero-terminated=1) (element-type filename): child's argument - * vector, in the GLib file name encoding - * @envp: (array zero-terminated=1) (element-type filename) (nullable): - * child's environment, or %NULL to inherit parent's, in the GLib file - * name encoding - * @flags: flags from #GSpawnFlags - * @child_setup: (scope async) (nullable): function to run in the child just before exec() - * @user_data: (closure): user data for @child_setup - * @child_pid: (out) (optional): return location for child process ID, or %NULL - * @standard_input: (out) (optional): return location for file descriptor to write to child's stdin, or %NULL - * @standard_output: (out) (optional): return location for file descriptor to read child's stdout, or %NULL - * @standard_error: (out) (optional): return location for file descriptor to read child's stderr, or %NULL - * @error: return location for error - * - * Identical to g_spawn_async_with_pipes_and_fds() but with `n_fds` set to zero, - * so no FD assignments are used. - * - * Returns: %TRUE on success, %FALSE if an error was set - */ - - -/** - * g_spawn_async_with_pipes_and_fds: - * @working_directory: (type filename) (nullable): child's current working - * directory, or %NULL to inherit parent's, in the GLib file name encoding - * @argv: (array zero-terminated=1) (element-type filename): child's argument - * vector, in the GLib file name encoding - * @envp: (array zero-terminated=1) (element-type filename) (nullable): - * child's environment, or %NULL to inherit parent's, in the GLib file - * name encoding - * @flags: flags from #GSpawnFlags - * @child_setup: (scope async) (nullable): function to run in the child just before `exec()` - * @user_data: (closure): user data for @child_setup - * @stdin_fd: file descriptor to use for child's stdin, or `-1` - * @stdout_fd: file descriptor to use for child's stdout, or `-1` - * @stderr_fd: file descriptor to use for child's stderr, or `-1` - * @source_fds: (array length=n_fds) (nullable): array of FDs from the parent - * process to make available in the child process - * @target_fds: (array length=n_fds) (nullable): array of FDs to remap - * @source_fds to in the child process - * @n_fds: number of FDs in @source_fds and @target_fds - * @child_pid_out: (out) (optional): return location for child process ID, or %NULL - * @stdin_pipe_out: (out) (optional): return location for file descriptor to write to child's stdin, or %NULL - * @stdout_pipe_out: (out) (optional): return location for file descriptor to read child's stdout, or %NULL - * @stderr_pipe_out: (out) (optional): return location for file descriptor to read child's stderr, or %NULL - * @error: return location for error - * - * Executes a child program asynchronously (your program will not - * block waiting for the child to exit). - * - * The child program is specified by the only argument that must be - * provided, @argv. @argv should be a %NULL-terminated array of strings, - * to be passed as the argument vector for the child. The first string - * in @argv is of course the name of the program to execute. By default, - * the name of the program must be a full path. If @flags contains the - * %G_SPAWN_SEARCH_PATH flag, the `PATH` environment variable is used to - * search for the executable. If @flags contains the - * %G_SPAWN_SEARCH_PATH_FROM_ENVP flag, the `PATH` variable from @envp - * is used to search for the executable. If both the - * %G_SPAWN_SEARCH_PATH and %G_SPAWN_SEARCH_PATH_FROM_ENVP flags are - * set, the `PATH` variable from @envp takes precedence over the - * environment variable. - * - * If the program name is not a full path and %G_SPAWN_SEARCH_PATH flag - * is not used, then the program will be run from the current directory - * (or @working_directory, if specified); this might be unexpected or even - * dangerous in some cases when the current directory is world-writable. - * - * On Windows, note that all the string or string vector arguments to - * this function and the other `g_spawn*()` functions are in UTF-8, the - * GLib file name encoding. Unicode characters that are not part of - * the system codepage passed in these arguments will be correctly - * available in the spawned program only if it uses wide character API - * to retrieve its command line. For C programs built with Microsoft's - * tools it is enough to make the program have a `wmain()` instead of - * `main()`. `wmain()` has a wide character argument vector as parameter. - * - * At least currently, mingw doesn't support `wmain()`, so if you use - * mingw to develop the spawned program, it should call - * g_win32_get_command_line() to get arguments in UTF-8. - * - * On Windows the low-level child process creation API `CreateProcess()` - * doesn't use argument vectors, but a command line. The C runtime - * library's `spawn*()` family of functions (which g_spawn_async_with_pipes() - * eventually calls) paste the argument vector elements together into - * a command line, and the C runtime startup code does a corresponding - * reconstruction of an argument vector from the command line, to be - * passed to `main()`. Complications arise when you have argument vector - * elements that contain spaces or double quotes. The `spawn*()` functions - * don't do any quoting or escaping, but on the other hand the startup - * code does do unquoting and unescaping in order to enable receiving - * arguments with embedded spaces or double quotes. To work around this - * asymmetry, g_spawn_async_with_pipes() will do quoting and escaping on - * argument vector elements that need it before calling the C runtime - * `spawn()` function. - * - * The returned @child_pid on Windows is a handle to the child - * process, not its identifier. Process handles and process - * identifiers are different concepts on Windows. - * - * @envp is a %NULL-terminated array of strings, where each string - * has the form `KEY=VALUE`. This will become the child's environment. - * If @envp is %NULL, the child inherits its parent's environment. - * - * @flags should be the bitwise OR of any flags you want to affect the - * function's behaviour. The %G_SPAWN_DO_NOT_REAP_CHILD means that the - * child will not automatically be reaped; you must use a child watch - * (g_child_watch_add()) to be notified about the death of the child process, - * otherwise it will stay around as a zombie process until this process exits. - * Eventually you must call g_spawn_close_pid() on the @child_pid, in order to - * free resources which may be associated with the child process. (On Unix, - * using a child watch is equivalent to calling waitpid() or handling - * the `SIGCHLD` signal manually. On Windows, calling g_spawn_close_pid() - * is equivalent to calling `CloseHandle()` on the process handle returned - * in @child_pid). See g_child_watch_add(). - * - * Open UNIX file descriptors marked as `FD_CLOEXEC` will be automatically - * closed in the child process. %G_SPAWN_LEAVE_DESCRIPTORS_OPEN means that - * other open file descriptors will be inherited by the child; otherwise all - * descriptors except stdin/stdout/stderr will be closed before calling `exec()` - * in the child. %G_SPAWN_SEARCH_PATH means that @argv[0] need not be an - * absolute path, it will be looked for in the `PATH` environment - * variable. %G_SPAWN_SEARCH_PATH_FROM_ENVP means need not be an - * absolute path, it will be looked for in the `PATH` variable from - * @envp. If both %G_SPAWN_SEARCH_PATH and %G_SPAWN_SEARCH_PATH_FROM_ENVP - * are used, the value from @envp takes precedence over the environment. - * - * %G_SPAWN_STDOUT_TO_DEV_NULL means that the child's standard output - * will be discarded, instead of going to the same location as the parent's - * standard output. If you use this flag, @stdout_pipe_out must be %NULL. - * - * %G_SPAWN_STDERR_TO_DEV_NULL means that the child's standard error - * will be discarded, instead of going to the same location as the parent's - * standard error. If you use this flag, @stderr_pipe_out must be %NULL. - * - * %G_SPAWN_CHILD_INHERITS_STDIN means that the child will inherit the parent's - * standard input (by default, the child's standard input is attached to - * `/dev/null`). If you use this flag, @stdin_pipe_out must be %NULL. - * - * It is valid to pass the same FD in multiple parameters (e.g. you can pass - * a single FD for both @stdout_fd and @stderr_fd, and include it in - * @source_fds too). - * - * @source_fds and @target_fds allow zero or more FDs from this process to be - * remapped to different FDs in the spawned process. If @n_fds is greater than - * zero, @source_fds and @target_fds must both be non-%NULL and the same length. - * Each FD in @source_fds is remapped to the FD number at the same index in - * @target_fds. The source and target FD may be equal to simply propagate an FD - * to the spawned process. FD remappings are processed after standard FDs, so - * any target FDs which equal @stdin_fd, @stdout_fd or @stderr_fd will overwrite - * them in the spawned process. - * - * %G_SPAWN_FILE_AND_ARGV_ZERO means that the first element of @argv is - * the file to execute, while the remaining elements are the actual - * argument vector to pass to the file. Normally g_spawn_async_with_pipes() - * uses @argv[0] as the file to execute, and passes all of @argv to the child. - * - * @child_setup and @user_data are a function and user data. On POSIX - * platforms, the function is called in the child after GLib has - * performed all the setup it plans to perform (including creating - * pipes, closing file descriptors, etc.) but before calling `exec()`. - * That is, @child_setup is called just before calling `exec()` in the - * child. Obviously actions taken in this function will only affect - * the child, not the parent. - * - * On Windows, there is no separate `fork()` and `exec()` functionality. - * Child processes are created and run with a single API call, - * `CreateProcess()`. There is no sensible thing @child_setup - * could be used for on Windows so it is ignored and not called. - * - * If non-%NULL, @child_pid will on Unix be filled with the child's - * process ID. You can use the process ID to send signals to the child, - * or to use g_child_watch_add() (or `waitpid()`) if you specified the - * %G_SPAWN_DO_NOT_REAP_CHILD flag. On Windows, @child_pid will be - * filled with a handle to the child process only if you specified the - * %G_SPAWN_DO_NOT_REAP_CHILD flag. You can then access the child - * process using the Win32 API, for example wait for its termination - * with the `WaitFor*()` functions, or examine its exit code with - * `GetExitCodeProcess()`. You should close the handle with `CloseHandle()` - * or g_spawn_close_pid() when you no longer need it. - * - * If non-%NULL, the @stdin_pipe_out, @stdout_pipe_out, @stderr_pipe_out - * locations will be filled with file descriptors for writing to the child's - * standard input or reading from its standard output or standard error. - * The caller of g_spawn_async_with_pipes() must close these file descriptors - * when they are no longer in use. If these parameters are %NULL, the - * corresponding pipe won't be created. - * - * If @stdin_pipe_out is %NULL, the child's standard input is attached to - * `/dev/null` unless %G_SPAWN_CHILD_INHERITS_STDIN is set. - * - * If @stderr_pipe_out is NULL, the child's standard error goes to the same - * location as the parent's standard error unless %G_SPAWN_STDERR_TO_DEV_NULL - * is set. - * - * If @stdout_pipe_out is NULL, the child's standard output goes to the same - * location as the parent's standard output unless %G_SPAWN_STDOUT_TO_DEV_NULL - * is set. - * - * @error can be %NULL to ignore errors, or non-%NULL to report errors. - * If an error is set, the function returns %FALSE. Errors are reported - * even if they occur in the child (for example if the executable in - * `@argv[0]` is not found). Typically the `message` field of returned - * errors should be displayed to users. Possible errors are those from - * the #G_SPAWN_ERROR domain. - * - * If an error occurs, @child_pid, @stdin_pipe_out, @stdout_pipe_out, - * and @stderr_pipe_out will not be filled with valid values. - * - * If @child_pid is not %NULL and an error does not occur then the returned - * process reference must be closed using g_spawn_close_pid(). - * - * On modern UNIX platforms, GLib can use an efficient process launching - * codepath driven internally by `posix_spawn()`. This has the advantage of - * avoiding the fork-time performance costs of cloning the parent process - * address space, and avoiding associated memory overcommit checks that are - * not relevant in the context of immediately executing a distinct process. - * This optimized codepath will be used provided that the following conditions - * are met: - * - * 1. %G_SPAWN_DO_NOT_REAP_CHILD is set - * 2. %G_SPAWN_LEAVE_DESCRIPTORS_OPEN is set - * 3. %G_SPAWN_SEARCH_PATH_FROM_ENVP is not set - * 4. @working_directory is %NULL - * 5. @child_setup is %NULL - * 6. The program is of a recognised binary format, or has a shebang. - * Otherwise, GLib will have to execute the program through the - * shell, which is not done using the optimized codepath. - * - * If you are writing a GTK application, and the program you are spawning is a - * graphical application too, then to ensure that the spawned program opens its - * windows on the right screen, you may want to use #GdkAppLaunchContext, - * #GAppLaunchContext, or set the `DISPLAY` environment variable. - * - * Returns: %TRUE on success, %FALSE if an error was set - * Since: 2.68 - */ - - -/** - * g_spawn_check_exit_status: - * @wait_status: A status as returned from g_spawn_sync() - * @error: a #GError - * - * An old name for g_spawn_check_wait_status(), deprecated because its - * name is misleading. - * - * Despite the name of the function, @wait_status must be the wait status - * as returned by g_spawn_sync(), g_subprocess_get_status(), `waitpid()`, - * etc. On Unix platforms, it is incorrect for it to be the exit status - * as passed to `exit()` or returned by g_subprocess_get_exit_status() or - * `WEXITSTATUS()`. - * - * Returns: %TRUE if child exited successfully, %FALSE otherwise (and - * @error will be set) - * Since: 2.34 - * Deprecated: 2.70: Use g_spawn_check_wait_status() instead, and check whether your code is conflating wait and exit statuses. - */ - - -/** - * g_spawn_check_wait_status: - * @wait_status: A platform-specific wait status as returned from g_spawn_sync() - * @error: a #GError - * - * Set @error if @wait_status indicates the child exited abnormally - * (e.g. with a nonzero exit code, or via a fatal signal). - * - * The g_spawn_sync() and g_child_watch_add() family of APIs return the - * status of subprocesses encoded in a platform-specific way. - * On Unix, this is guaranteed to be in the same format waitpid() returns, - * and on Windows it is guaranteed to be the result of GetExitCodeProcess(). - * - * Prior to the introduction of this function in GLib 2.34, interpreting - * @wait_status required use of platform-specific APIs, which is problematic - * for software using GLib as a cross-platform layer. - * - * Additionally, many programs simply want to determine whether or not - * the child exited successfully, and either propagate a #GError or - * print a message to standard error. In that common case, this function - * can be used. Note that the error message in @error will contain - * human-readable information about the wait status. - * - * The @domain and @code of @error have special semantics in the case - * where the process has an "exit code", as opposed to being killed by - * a signal. On Unix, this happens if WIFEXITED() would be true of - * @wait_status. On Windows, it is always the case. - * - * The special semantics are that the actual exit code will be the - * code set in @error, and the domain will be %G_SPAWN_EXIT_ERROR. - * This allows you to differentiate between different exit codes. - * - * If the process was terminated by some means other than an exit - * status (for example if it was killed by a signal), the domain will be - * %G_SPAWN_ERROR and the code will be %G_SPAWN_ERROR_FAILED. - * - * This function just offers convenience; you can of course also check - * the available platform via a macro such as %G_OS_UNIX, and use - * WIFEXITED() and WEXITSTATUS() on @wait_status directly. Do not attempt - * to scan or parse the error message string; it may be translated and/or - * change in future versions of GLib. - * - * Prior to version 2.70, g_spawn_check_exit_status() provides the same - * functionality, although under a misleading name. - * - * Returns: %TRUE if child exited successfully, %FALSE otherwise (and - * @error will be set) - * Since: 2.70 - */ - - -/** - * g_spawn_close_pid: - * @pid: The process reference to close - * - * On some platforms, notably Windows, the #GPid type represents a resource - * which must be closed to prevent resource leaking. g_spawn_close_pid() - * is provided for this purpose. It should be used on all platforms, even - * though it doesn't do anything under UNIX. - */ - - -/** - * g_spawn_command_line_async: - * @command_line: (type filename): a command line - * @error: return location for errors - * - * A simple version of g_spawn_async() that parses a command line with - * g_shell_parse_argv() and passes it to g_spawn_async(). - * - * Runs a command line in the background. Unlike g_spawn_async(), the - * %G_SPAWN_SEARCH_PATH flag is enabled, other flags are not. Note - * that %G_SPAWN_SEARCH_PATH can have security implications, so - * consider using g_spawn_async() directly if appropriate. Possible - * errors are those from g_shell_parse_argv() and g_spawn_async(). - * - * The same concerns on Windows apply as for g_spawn_command_line_sync(). - * - * Returns: %TRUE on success, %FALSE if error is set - */ - - -/** - * g_spawn_command_line_sync: - * @command_line: (type filename): a command line - * @standard_output: (out) (array zero-terminated=1) (element-type guint8) (optional): return location for child output - * @standard_error: (out) (array zero-terminated=1) (element-type guint8) (optional): return location for child errors - * @wait_status: (out) (optional): return location for child wait status, as returned by waitpid() - * @error: return location for errors - * - * A simple version of g_spawn_sync() with little-used parameters - * removed, taking a command line instead of an argument vector. - * - * See g_spawn_sync() for full details. - * - * The @command_line argument will be parsed by g_shell_parse_argv(). - * - * Unlike g_spawn_sync(), the %G_SPAWN_SEARCH_PATH flag is enabled. - * Note that %G_SPAWN_SEARCH_PATH can have security implications, so - * consider using g_spawn_sync() directly if appropriate. - * - * Possible errors are those from g_spawn_sync() and those - * from g_shell_parse_argv(). - * - * If @wait_status is non-%NULL, the platform-specific status of - * the child is stored there; see the documentation of - * g_spawn_check_wait_status() for how to use and interpret this. - * On Unix platforms, note that it is usually not equal - * to the integer passed to `exit()` or returned from `main()`. - * - * On Windows, please note the implications of g_shell_parse_argv() - * parsing @command_line. Parsing is done according to Unix shell rules, not - * Windows command interpreter rules. - * Space is a separator, and backslashes are - * special. Thus you cannot simply pass a @command_line containing - * canonical Windows paths, like "c:\\program files\\app\\app.exe", as - * the backslashes will be eaten, and the space will act as a - * separator. You need to enclose such paths with single quotes, like - * "'c:\\program files\\app\\app.exe' 'e:\\folder\\argument.txt'". - * - * Returns: %TRUE on success, %FALSE if an error was set - */ - - -/** - * g_spawn_sync: - * @working_directory: (type filename) (nullable): child's current working - * directory, or %NULL to inherit parent's - * @argv: (array zero-terminated=1) (element-type filename): - * child's argument vector - * @envp: (array zero-terminated=1) (element-type filename) (nullable): - * child's environment, or %NULL to inherit parent's - * @flags: flags from #GSpawnFlags - * @child_setup: (scope async) (nullable): function to run in the child just before exec() - * @user_data: (closure): user data for @child_setup - * @standard_output: (out) (array zero-terminated=1) (element-type guint8) (optional): return location for child output, or %NULL - * @standard_error: (out) (array zero-terminated=1) (element-type guint8) (optional): return location for child error messages, or %NULL - * @wait_status: (out) (optional): return location for child wait status, as returned by waitpid(), or %NULL - * @error: return location for error, or %NULL - * - * Executes a child synchronously (waits for the child to exit before returning). - * - * All output from the child is stored in @standard_output and @standard_error, - * if those parameters are non-%NULL. Note that you must set the - * %G_SPAWN_STDOUT_TO_DEV_NULL and %G_SPAWN_STDERR_TO_DEV_NULL flags when - * passing %NULL for @standard_output and @standard_error. - * - * If @wait_status is non-%NULL, the platform-specific status of - * the child is stored there; see the documentation of - * g_spawn_check_wait_status() for how to use and interpret this. - * On Unix platforms, note that it is usually not equal - * to the integer passed to `exit()` or returned from `main()`. - * - * Note that it is invalid to pass %G_SPAWN_DO_NOT_REAP_CHILD in - * @flags, and on POSIX platforms, the same restrictions as for - * g_child_watch_source_new() apply. - * - * If an error occurs, no data is returned in @standard_output, - * @standard_error, or @wait_status. - * - * This function calls g_spawn_async_with_pipes() internally; see that - * function for full details on the other parameters and details on - * how these functions work on Windows. - * - * Returns: %TRUE on success, %FALSE if an error was set - */ - - -/** - * g_sprintf: - * @string: A pointer to a memory buffer to contain the resulting string. It - * is up to the caller to ensure that the allocated buffer is large - * enough to hold the formatted result - * @format: a standard printf() format string, but notice - * [string precision pitfalls][string-precision] - * @...: the arguments to insert in the output. - * - * An implementation of the standard sprintf() function which supports - * positional parameters, as specified in the Single Unix Specification. - * - * Note that it is usually better to use g_snprintf(), to avoid the - * risk of buffer overflow. - * - * `glib/gprintf.h` must be explicitly included in order to use this function. - * - * See also g_strdup_printf(). - * - * Returns: the number of bytes printed. - * Since: 2.2 - */ - - -/** - * g_stat: - * @filename: (type filename): a pathname in the GLib file name encoding - * (UTF-8 on Windows) - * @buf: a pointer to a stat struct, which will be filled with the file - * information - * - * A wrapper for the POSIX stat() function. The stat() function - * returns information about a file. On Windows the stat() function in - * the C library checks only the FAT-style READONLY attribute and does - * not look at the ACL at all. Thus on Windows the protection bits in - * the @st_mode field are a fabrication of little use. - * - * On Windows the Microsoft C libraries have several variants of the - * stat struct and stat() function with names like _stat(), _stat32(), - * _stat32i64() and _stat64i32(). The one used here is for 32-bit code - * the one with 32-bit size and time fields, specifically called _stat32(). - * - * In Microsoft's compiler, by default struct stat means one with - * 64-bit time fields while in MinGW struct stat is the legacy one - * with 32-bit fields. To hopefully clear up this messs, the gstdio.h - * header defines a type #GStatBuf which is the appropriate struct type - * depending on the platform and/or compiler being used. On POSIX it - * is just struct stat, but note that even on POSIX platforms, stat() - * might be a macro. - * - * See your C library manual for more details about stat(). - * - * Returns: 0 if the information was successfully retrieved, - * -1 if an error occurred - * Since: 2.6 - */ - - -/** - * g_steal_fd: - * @fd_ptr: (not optional) (inout): A pointer to a file descriptor - * - * Sets @fd_ptr to `-1`, returning the value that was there before. - * - * Conceptually, this transfers the ownership of the file descriptor - * from the referenced variable to the caller of the function (i.e. - * ‘steals’ the reference). This is very similar to g_steal_pointer(), - * but for file descriptors. - * - * On POSIX platforms, this function is async-signal safe - * (see [`signal(7)`](man:signal(7)) and - * [`signal-safety(7)`](man:signal-safety(7))), making it safe to call from a - * signal handler or a #GSpawnChildSetupFunc. - * - * Returns: the value that @fd_ptr previously had - * Since: 2.70 - */ - - -/** - * g_stpcpy: - * @dest: destination buffer. - * @src: source string. - * - * Copies a nul-terminated string into the dest buffer, include the - * trailing nul, and return a pointer to the trailing nul byte. - * This is useful for concatenating multiple strings together - * without having to repeatedly scan for the end. - * - * Returns: a pointer to trailing nul byte. - */ - - -/** - * g_str_equal: - * @v1: (not nullable): a key - * @v2: (not nullable): a key to compare with @v1 - * - * Compares two strings for byte-by-byte equality and returns %TRUE - * if they are equal. It can be passed to g_hash_table_new() as the - * @key_equal_func parameter, when using non-%NULL strings as keys in a - * #GHashTable. - * - * This function is typically used for hash table comparisons, but can be used - * for general purpose comparisons of non-%NULL strings. For a %NULL-safe string - * comparison function, see g_strcmp0(). - * - * Returns: %TRUE if the two keys match - */ - - -/** - * g_str_has_prefix: - * @str: a nul-terminated string - * @prefix: the nul-terminated prefix to look for - * - * Looks whether the string @str begins with @prefix. - * - * Returns: %TRUE if @str begins with @prefix, %FALSE otherwise. - * Since: 2.2 - */ - - -/** - * g_str_has_suffix: - * @str: a nul-terminated string - * @suffix: the nul-terminated suffix to look for - * - * Looks whether the string @str ends with @suffix. - * - * Returns: %TRUE if @str end with @suffix, %FALSE otherwise. - * Since: 2.2 - */ - - -/** - * g_str_hash: - * @v: (not nullable): a string key - * - * Converts a string to a hash value. - * - * This function implements the widely used "djb" hash apparently - * posted by Daniel Bernstein to comp.lang.c some time ago. The 32 - * bit unsigned hash value starts at 5381 and for each byte 'c' in - * the string, is updated: `hash = hash * 33 + c`. This function - * uses the signed value of each byte. - * - * It can be passed to g_hash_table_new() as the @hash_func parameter, - * when using non-%NULL strings as keys in a #GHashTable. - * - * Note that this function may not be a perfect fit for all use cases. - * For example, it produces some hash collisions with strings as short - * as 2. - * - * Returns: a hash value corresponding to the key - */ - - -/** - * g_str_is_ascii: - * @str: a string - * - * Determines if a string is pure ASCII. A string is pure ASCII if it - * contains no bytes with the high bit set. - * - * Returns: %TRUE if @str is ASCII - * Since: 2.40 - */ - - -/** - * g_str_match_string: - * @search_term: the search term from the user - * @potential_hit: the text that may be a hit - * @accept_alternates: %TRUE to accept ASCII alternates - * - * Checks if a search conducted for @search_term should match - * @potential_hit. - * - * This function calls g_str_tokenize_and_fold() on both - * @search_term and @potential_hit. ASCII alternates are never taken - * for @search_term but will be taken for @potential_hit according to - * the value of @accept_alternates. - * - * A hit occurs when each folded token in @search_term is a prefix of a - * folded token from @potential_hit. - * - * Depending on how you're performing the search, it will typically be - * faster to call g_str_tokenize_and_fold() on each string in - * your corpus and build an index on the returned folded tokens, then - * call g_str_tokenize_and_fold() on the search term and - * perform lookups into that index. - * - * As some examples, searching for ‘fred’ would match the potential hit - * ‘Smith, Fred’ and also ‘Frédéric’. Searching for ‘Fréd’ would match - * ‘Frédéric’ but not ‘Frederic’ (due to the one-directional nature of - * accent matching). Searching ‘fo’ would match ‘Foo’ and ‘Bar Foo - * Baz’, but not ‘SFO’ (because no word has ‘fo’ as a prefix). - * - * Returns: %TRUE if @potential_hit is a hit - * Since: 2.40 - */ - - -/** - * g_str_to_ascii: - * @str: a string, in UTF-8 - * @from_locale: (nullable): the source locale, if known - * - * Transliterate @str to plain ASCII. - * - * For best results, @str should be in composed normalised form. - * - * This function performs a reasonably good set of character - * replacements. The particular set of replacements that is done may - * change by version or even by runtime environment. - * - * If the source language of @str is known, it can used to improve the - * accuracy of the translation by passing it as @from_locale. It should - * be a valid POSIX locale string (of the form - * `language[_territory][.codeset][@modifier]`). - * - * If @from_locale is %NULL then the current locale is used. - * - * If you want to do translation for no specific locale, and you want it - * to be done independently of the currently locale, specify `"C"` for - * @from_locale. - * - * Returns: a string in plain ASCII - * Since: 2.40 - */ - - -/** - * g_str_tokenize_and_fold: - * @string: a string - * @translit_locale: (nullable): the language code (like 'de' or - * 'en_GB') from which @string originates - * @ascii_alternates: (out) (transfer full) (array zero-terminated=1): a - * return location for ASCII alternates - * - * Tokenises @string and performs folding on each token. - * - * A token is a non-empty sequence of alphanumeric characters in the - * source string, separated by non-alphanumeric characters. An - * "alphanumeric" character for this purpose is one that matches - * g_unichar_isalnum() or g_unichar_ismark(). - * - * Each token is then (Unicode) normalised and case-folded. If - * @ascii_alternates is non-%NULL and some of the returned tokens - * contain non-ASCII characters, ASCII alternatives will be generated. - * - * The number of ASCII alternatives that are generated and the method - * for doing so is unspecified, but @translit_locale (if specified) may - * improve the transliteration if the language of the source string is - * known. - * - * Returns: (transfer full) (array zero-terminated=1): the folded tokens - * Since: 2.40 - */ - - -/** - * g_strcanon: - * @string: a nul-terminated array of bytes - * @valid_chars: bytes permitted in @string - * @substitutor: replacement character for disallowed bytes - * - * For each character in @string, if the character is not in @valid_chars, - * replaces the character with @substitutor. - * - * Modifies @string in place, and return @string itself, not a copy. The - * return value is to allow nesting such as: - * - * |[<!-- language="C" --> - * g_ascii_strup (g_strcanon (str, "abc", '?')) - * ]| - * - * In order to modify a copy, you may use g_strdup(): - * - * |[<!-- language="C" --> - * reformatted = g_strcanon (g_strdup (const_str), "abc", '?'); - * ... - * g_free (reformatted); - * ]| - * - * Returns: the modified @string - */ - - -/** - * g_strcasecmp: - * @s1: a string - * @s2: a string to compare with @s1 - * - * A case-insensitive string comparison, corresponding to the standard - * strcasecmp() function on platforms which support it. - * - * Returns: 0 if the strings match, a negative value if @s1 < @s2, - * or a positive value if @s1 > @s2. - * Deprecated: 2.2: See g_strncasecmp() for a discussion of why this - * function is deprecated and how to replace it. - */ - - -/** - * g_strchomp: - * @string: a string to remove the trailing whitespace from - * - * Removes trailing whitespace from a string. - * - * This function doesn't allocate or reallocate any memory; - * it modifies @string in place. Therefore, it cannot be used - * on statically allocated strings. - * - * The pointer to @string is returned to allow the nesting of functions. - * - * Also see g_strchug() and g_strstrip(). - * - * Returns: @string - */ - - -/** - * g_strchug: - * @string: a string to remove the leading whitespace from - * - * Removes leading whitespace from a string, by moving the rest - * of the characters forward. - * - * This function doesn't allocate or reallocate any memory; - * it modifies @string in place. Therefore, it cannot be used on - * statically allocated strings. - * - * The pointer to @string is returned to allow the nesting of functions. - * - * Also see g_strchomp() and g_strstrip(). - * - * Returns: @string - */ - - -/** - * g_strcmp0: - * @str1: (nullable): a C string or %NULL - * @str2: (nullable): another C string or %NULL - * - * Compares @str1 and @str2 like strcmp(). Handles %NULL - * gracefully by sorting it before non-%NULL strings. - * Comparing two %NULL pointers returns 0. - * - * Returns: an integer less than, equal to, or greater than zero, if @str1 is <, == or > than @str2. - * Since: 2.16 - */ - - -/** - * g_strcompress: - * @source: a string to compress - * - * Replaces all escaped characters with their one byte equivalent. - * - * This function does the reverse conversion of g_strescape(). - * - * Returns: a newly-allocated copy of @source with all escaped - * character compressed - */ - - -/** - * g_strconcat: - * @string1: the first string to add, which must not be %NULL - * @...: a %NULL-terminated list of strings to append to the string - * - * Concatenates all of the given strings into one long string. The - * returned string should be freed with g_free() when no longer needed. - * - * The variable argument list must end with %NULL. If you forget the %NULL, - * g_strconcat() will start appending random memory junk to your string. - * - * Note that this function is usually not the right function to use to - * assemble a translated message from pieces, since proper translation - * often requires the pieces to be reordered. - * - * Returns: a newly-allocated string containing all the string arguments - */ - - -/** - * g_strdelimit: - * @string: the string to convert - * @delimiters: (nullable): a string containing the current delimiters, - * or %NULL to use the standard delimiters defined in #G_STR_DELIMITERS - * @new_delimiter: the new delimiter character - * - * Converts any delimiter characters in @string to @new_delimiter. - * - * Any characters in @string which are found in @delimiters are - * changed to the @new_delimiter character. Modifies @string in place, - * and returns @string itself, not a copy. - * - * The return value is to allow nesting such as: - * - * |[<!-- language="C" --> - * g_ascii_strup (g_strdelimit (str, "abc", '?')) - * ]| - * - * In order to modify a copy, you may use g_strdup(): - * - * |[<!-- language="C" --> - * reformatted = g_strdelimit (g_strdup (const_str), "abc", '?'); - * ... - * g_free (reformatted); - * ]| - * - * Returns: the modified @string - */ - - -/** - * g_strdown: - * @string: the string to convert. - * - * Converts a string to lower case. - * - * Returns: the string - * Deprecated: 2.2: This function is totally broken for the reasons discussed - * in the g_strncasecmp() docs - use g_ascii_strdown() or g_utf8_strdown() - * instead. - */ - - -/** - * g_strdup: - * @str: (nullable): the string to duplicate - * - * Duplicates a string. If @str is %NULL it returns %NULL. - * The returned string should be freed with g_free() - * when no longer needed. - * - * Returns: a newly-allocated copy of @str - */ - - -/** - * g_strdup_printf: - * @format: (not nullable): a standard printf() format string, but notice - * [string precision pitfalls][string-precision] - * @...: the parameters to insert into the format string - * - * Similar to the standard C sprintf() function but safer, since it - * calculates the maximum space required and allocates memory to hold - * the result. The returned string should be freed with g_free() when no - * longer needed. - * - * The returned string is guaranteed to be non-NULL, unless @format - * contains `%lc` or `%ls` conversions, which can fail if no multibyte - * representation is available for the given character. - * - * Returns: a newly-allocated string holding the result - */ - - -/** - * g_strdup_vprintf: - * @format: (not nullable): a standard printf() format string, but notice - * [string precision pitfalls][string-precision] - * @args: the list of parameters to insert into the format string - * - * Similar to the standard C vsprintf() function but safer, since it - * calculates the maximum space required and allocates memory to hold - * the result. The returned string should be freed with g_free() when - * no longer needed. - * - * The returned string is guaranteed to be non-NULL, unless @format - * contains `%lc` or `%ls` conversions, which can fail if no multibyte - * representation is available for the given character. - * - * See also g_vasprintf(), which offers the same functionality, but - * additionally returns the length of the allocated string. - * - * Returns: a newly-allocated string holding the result - */ - - -/** - * g_strdupv: - * @str_array: (nullable): a %NULL-terminated array of strings - * - * Copies %NULL-terminated array of strings. The copy is a deep copy; - * the new array should be freed by first freeing each string, then - * the array itself. g_strfreev() does this for you. If called - * on a %NULL value, g_strdupv() simply returns %NULL. - * - * Returns: (nullable): a new %NULL-terminated array of strings. - */ - - -/** - * g_strerror: - * @errnum: the system error number. See the standard C %errno - * documentation - * - * Returns a string corresponding to the given error code, e.g. "no - * such process". Unlike strerror(), this always returns a string in - * UTF-8 encoding, and the pointer is guaranteed to remain valid for - * the lifetime of the process. - * - * Note that the string may be translated according to the current locale. - * - * The value of %errno will not be changed by this function. However, it may - * be changed by intermediate function calls, so you should save its value - * as soon as the call returns: - * |[ - * int saved_errno; - * - * ret = read (blah); - * saved_errno = errno; - * - * g_strerror (saved_errno); - * ]| - * - * Returns: a UTF-8 string describing the error code. If the error code - * is unknown, it returns a string like "unknown error (<code>)". - */ - - -/** - * g_strescape: - * @source: a string to escape - * @exceptions: (nullable): a string of characters not to escape in @source - * - * Escapes the special characters '\b', '\f', '\n', '\r', '\t', '\v', '\' - * and '"' in the string @source by inserting a '\' before - * them. Additionally all characters in the range 0x01-0x1F (everything - * below SPACE) and in the range 0x7F-0xFF (all non-ASCII chars) are - * replaced with a '\' followed by their octal representation. - * Characters supplied in @exceptions are not escaped. - * - * g_strcompress() does the reverse conversion. - * - * Returns: a newly-allocated copy of @source with certain - * characters escaped. See above. - */ - - -/** - * g_strfreev: - * @str_array: (nullable): a %NULL-terminated array of strings to free - * - * Frees a %NULL-terminated array of strings, as well as each - * string it contains. - * - * If @str_array is %NULL, this function simply returns. - */ - - -/** - * g_string_append: - * @string: a #GString - * @val: the string to append onto the end of @string - * - * Adds a string onto the end of a #GString, expanding - * it if necessary. - * - * Returns: (transfer none): @string - */ - - -/** - * g_string_append_c: - * @string: a #GString - * @c: the byte to append onto the end of @string - * - * Adds a byte onto the end of a #GString, expanding - * it if necessary. - * - * Returns: (transfer none): @string - */ - - -/** - * g_string_append_len: - * @string: a #GString - * @val: bytes to append - * @len: number of bytes of @val to use, or -1 for all of @val - * - * Appends @len bytes of @val to @string. - * - * If @len is positive, @val may contain embedded nuls and need - * not be nul-terminated. It is the caller's responsibility to - * ensure that @val has at least @len addressable bytes. - * - * If @len is negative, @val must be nul-terminated and @len - * is considered to request the entire string length. This - * makes g_string_append_len() equivalent to g_string_append(). - * - * Returns: (transfer none): @string - */ - - -/** - * g_string_append_printf: - * @string: a #GString - * @format: the string format. See the printf() documentation - * @...: the parameters to insert into the format string - * - * Appends a formatted string onto the end of a #GString. - * This function is similar to g_string_printf() except - * that the text is appended to the #GString. - */ - - -/** - * g_string_append_unichar: - * @string: a #GString - * @wc: a Unicode character - * - * Converts a Unicode character into UTF-8, and appends it - * to the string. - * - * Returns: (transfer none): @string - */ - - -/** - * g_string_append_uri_escaped: - * @string: a #GString - * @unescaped: a string - * @reserved_chars_allowed: a string of reserved characters allowed - * to be used, or %NULL - * @allow_utf8: set %TRUE if the escaped string may include UTF8 characters - * - * Appends @unescaped to @string, escaping any characters that - * are reserved in URIs using URI-style escape sequences. - * - * Returns: (transfer none): @string - * Since: 2.16 - */ - - -/** - * g_string_append_vprintf: - * @string: a #GString - * @format: (not nullable): the string format. See the printf() documentation - * @args: the list of arguments to insert in the output - * - * Appends a formatted string onto the end of a #GString. - * This function is similar to g_string_append_printf() - * except that the arguments to the format string are passed - * as a va_list. - * - * Since: 2.14 - */ - - -/** - * g_string_ascii_down: - * @string: a GString - * - * Converts all uppercase ASCII letters to lowercase ASCII letters. - * - * Returns: (transfer none): passed-in @string pointer, with all the - * uppercase characters converted to lowercase in place, - * with semantics that exactly match g_ascii_tolower(). - */ - - -/** - * g_string_ascii_up: - * @string: a GString - * - * Converts all lowercase ASCII letters to uppercase ASCII letters. - * - * Returns: (transfer none): passed-in @string pointer, with all the - * lowercase characters converted to uppercase in place, - * with semantics that exactly match g_ascii_toupper(). - */ - - -/** - * g_string_assign: - * @string: the destination #GString. Its current contents - * are destroyed. - * @rval: the string to copy into @string - * - * Copies the bytes from a string into a #GString, - * destroying any previous contents. It is rather like - * the standard strcpy() function, except that you do not - * have to worry about having enough space to copy the string. - * - * Returns: (transfer none): @string - */ - - -/** - * g_string_chunk_clear: - * @chunk: a #GStringChunk - * - * Frees all strings contained within the #GStringChunk. - * After calling g_string_chunk_clear() it is not safe to - * access any of the strings which were contained within it. - * - * Since: 2.14 - */ - - -/** - * g_string_chunk_free: - * @chunk: a #GStringChunk - * - * Frees all memory allocated by the #GStringChunk. - * After calling g_string_chunk_free() it is not safe to - * access any of the strings which were contained within it. - */ - - -/** - * g_string_chunk_insert: - * @chunk: a #GStringChunk - * @string: the string to add - * - * Adds a copy of @string to the #GStringChunk. - * It returns a pointer to the new copy of the string - * in the #GStringChunk. The characters in the string - * can be changed, if necessary, though you should not - * change anything after the end of the string. - * - * Unlike g_string_chunk_insert_const(), this function - * does not check for duplicates. Also strings added - * with g_string_chunk_insert() will not be searched - * by g_string_chunk_insert_const() when looking for - * duplicates. - * - * Returns: a pointer to the copy of @string within - * the #GStringChunk - */ - - -/** - * g_string_chunk_insert_const: - * @chunk: a #GStringChunk - * @string: the string to add - * - * Adds a copy of @string to the #GStringChunk, unless the same - * string has already been added to the #GStringChunk with - * g_string_chunk_insert_const(). - * - * This function is useful if you need to copy a large number - * of strings but do not want to waste space storing duplicates. - * But you must remember that there may be several pointers to - * the same string, and so any changes made to the strings - * should be done very carefully. - * - * Note that g_string_chunk_insert_const() will not return a - * pointer to a string added with g_string_chunk_insert(), even - * if they do match. - * - * Returns: a pointer to the new or existing copy of @string - * within the #GStringChunk - */ - - -/** - * g_string_chunk_insert_len: - * @chunk: a #GStringChunk - * @string: bytes to insert - * @len: number of bytes of @string to insert, or -1 to insert a - * nul-terminated string - * - * Adds a copy of the first @len bytes of @string to the #GStringChunk. - * The copy is nul-terminated. - * - * Since this function does not stop at nul bytes, it is the caller's - * responsibility to ensure that @string has at least @len addressable - * bytes. - * - * The characters in the returned string can be changed, if necessary, - * though you should not change anything after the end of the string. - * - * Returns: a pointer to the copy of @string within the #GStringChunk - * Since: 2.4 - */ - - -/** - * g_string_chunk_new: - * @size: the default size of the blocks of memory which are - * allocated to store the strings. If a particular string - * is larger than this default size, a larger block of - * memory will be allocated for it. - * - * Creates a new #GStringChunk. - * - * Returns: a new #GStringChunk - */ - - -/** - * g_string_down: - * @string: a #GString - * - * Converts a #GString to lowercase. - * - * Returns: (transfer none): the #GString - * Deprecated: 2.2: This function uses the locale-specific - * tolower() function, which is almost never the right thing. - * Use g_string_ascii_down() or g_utf8_strdown() instead. - */ - - -/** - * g_string_equal: - * @v: a #GString - * @v2: another #GString - * - * Compares two strings for equality, returning %TRUE if they are equal. - * For use with #GHashTable. - * - * Returns: %TRUE if the strings are the same length and contain the - * same bytes - */ - - -/** - * g_string_erase: - * @string: a #GString - * @pos: the position of the content to remove - * @len: the number of bytes to remove, or -1 to remove all - * following bytes - * - * Removes @len bytes from a #GString, starting at position @pos. - * The rest of the #GString is shifted down to fill the gap. - * - * Returns: (transfer none): @string - */ - - -/** - * g_string_free: - * @string: (transfer full): a #GString - * @free_segment: if %TRUE, the actual character data is freed as well - * - * Frees the memory allocated for the #GString. - * If @free_segment is %TRUE it also frees the character data. If - * it's %FALSE, the caller gains ownership of the buffer and must - * free it after use with g_free(). - * - * Returns: (nullable): the character data of @string - * (i.e. %NULL if @free_segment is %TRUE) - */ - - -/** - * g_string_free_to_bytes: - * @string: (transfer full): a #GString - * - * Transfers ownership of the contents of @string to a newly allocated - * #GBytes. The #GString structure itself is deallocated, and it is - * therefore invalid to use @string after invoking this function. - * - * Note that while #GString ensures that its buffer always has a - * trailing nul character (not reflected in its "len"), the returned - * #GBytes does not include this extra nul; i.e. it has length exactly - * equal to the "len" member. - * - * Returns: (transfer full): A newly allocated #GBytes containing contents of @string; @string itself is freed - * Since: 2.34 - */ - - -/** - * g_string_hash: - * @str: a string to hash - * - * Creates a hash code for @str; for use with #GHashTable. - * - * Returns: hash code for @str - */ - - -/** - * g_string_insert: - * @string: a #GString - * @pos: the position to insert the copy of the string - * @val: the string to insert - * - * Inserts a copy of a string into a #GString, - * expanding it if necessary. - * - * Returns: (transfer none): @string - */ - - -/** - * g_string_insert_c: - * @string: a #GString - * @pos: the position to insert the byte - * @c: the byte to insert - * - * Inserts a byte into a #GString, expanding it if necessary. - * - * Returns: (transfer none): @string - */ - - -/** - * g_string_insert_len: - * @string: a #GString - * @pos: position in @string where insertion should - * happen, or -1 for at the end - * @val: bytes to insert - * @len: number of bytes of @val to insert, or -1 for all of @val - * - * Inserts @len bytes of @val into @string at @pos. - * - * If @len is positive, @val may contain embedded nuls and need - * not be nul-terminated. It is the caller's responsibility to - * ensure that @val has at least @len addressable bytes. - * - * If @len is negative, @val must be nul-terminated and @len - * is considered to request the entire string length. - * - * If @pos is -1, bytes are inserted at the end of the string. - * - * Returns: (transfer none): @string - */ - - -/** - * g_string_insert_unichar: - * @string: a #GString - * @pos: the position at which to insert character, or -1 - * to append at the end of the string - * @wc: a Unicode character - * - * Converts a Unicode character into UTF-8, and insert it - * into the string at the given position. - * - * Returns: (transfer none): @string - */ - - -/** - * g_string_new: (constructor) - * @init: (nullable): the initial text to copy into the string, or %NULL to - * start with an empty string - * - * Creates a new #GString, initialized with the given string. - * - * Returns: (transfer full): the new #GString - */ - - -/** - * g_string_new_len: (constructor) - * @init: initial contents of the string - * @len: length of @init to use - * - * Creates a new #GString with @len bytes of the @init buffer. - * Because a length is provided, @init need not be nul-terminated, - * and can contain embedded nul bytes. - * - * Since this function does not stop at nul bytes, it is the caller's - * responsibility to ensure that @init has at least @len addressable - * bytes. - * - * Returns: (transfer full): a new #GString - */ - - -/** - * g_string_overwrite: - * @string: a #GString - * @pos: the position at which to start overwriting - * @val: the string that will overwrite the @string starting at @pos - * - * Overwrites part of a string, lengthening it if necessary. - * - * Returns: (transfer none): @string - * Since: 2.14 - */ - - -/** - * g_string_overwrite_len: - * @string: a #GString - * @pos: the position at which to start overwriting - * @val: the string that will overwrite the @string starting at @pos - * @len: the number of bytes to write from @val - * - * Overwrites part of a string, lengthening it if necessary. - * This function will work with embedded nuls. - * - * Returns: (transfer none): @string - * Since: 2.14 - */ - - -/** - * g_string_prepend: - * @string: a #GString - * @val: the string to prepend on the start of @string - * - * Adds a string on to the start of a #GString, - * expanding it if necessary. - * - * Returns: (transfer none): @string - */ - - -/** - * g_string_prepend_c: - * @string: a #GString - * @c: the byte to prepend on the start of the #GString - * - * Adds a byte onto the start of a #GString, - * expanding it if necessary. - * - * Returns: (transfer none): @string - */ - - -/** - * g_string_prepend_len: - * @string: a #GString - * @val: bytes to prepend - * @len: number of bytes in @val to prepend, or -1 for all of @val - * - * Prepends @len bytes of @val to @string. - * - * If @len is positive, @val may contain embedded nuls and need - * not be nul-terminated. It is the caller's responsibility to - * ensure that @val has at least @len addressable bytes. - * - * If @len is negative, @val must be nul-terminated and @len - * is considered to request the entire string length. This - * makes g_string_prepend_len() equivalent to g_string_prepend(). - * - * Returns: (transfer none): @string - */ - - -/** - * g_string_prepend_unichar: - * @string: a #GString - * @wc: a Unicode character - * - * Converts a Unicode character into UTF-8, and prepends it - * to the string. - * - * Returns: (transfer none): @string - */ - - -/** - * g_string_printf: - * @string: a #GString - * @format: the string format. See the printf() documentation - * @...: the parameters to insert into the format string - * - * Writes a formatted string into a #GString. - * This is similar to the standard sprintf() function, - * except that the #GString buffer automatically expands - * to contain the results. The previous contents of the - * #GString are destroyed. - */ - - -/** - * g_string_replace: - * @string: a #GString - * @find: the string to find in @string - * @replace: the string to insert in place of @find - * @limit: the maximum instances of @find to replace with @replace, or `0` for - * no limit - * - * Replaces the string @find with the string @replace in a #GString up to - * @limit times. If the number of instances of @find in the #GString is - * less than @limit, all instances are replaced. If @limit is `0`, - * all instances of @find are replaced. - * - * If @find is the empty string, since versions 2.69.1 and 2.68.4 the - * replacement will be inserted no more than once per possible position - * (beginning of string, end of string and between characters). This did - * not work correctly in earlier versions. - * - * Returns: the number of find and replace operations performed. - * Since: 2.68 - */ - - -/** - * g_string_set_size: - * @string: a #GString - * @len: the new length - * - * Sets the length of a #GString. If the length is less than - * the current length, the string will be truncated. If the - * length is greater than the current length, the contents - * of the newly added area are undefined. (However, as - * always, string->str[string->len] will be a nul byte.) - * - * Returns: (transfer none): @string - */ - - -/** - * g_string_sized_new: (constructor) - * @dfl_size: the default size of the space allocated to hold the string - * - * Creates a new #GString, with enough space for @dfl_size - * bytes. This is useful if you are going to add a lot of - * text to the string and don't want it to be reallocated - * too often. - * - * Returns: (transfer full): the new #GString - */ - - -/** - * g_string_sprintf: - * @string: a #GString - * @format: the string format. See the sprintf() documentation - * @...: the parameters to insert into the format string - * - * Writes a formatted string into a #GString. - * This is similar to the standard sprintf() function, - * except that the #GString buffer automatically expands - * to contain the results. The previous contents of the - * #GString are destroyed. - * - * Deprecated: This function has been renamed to g_string_printf(). - */ - - -/** - * g_string_sprintfa: - * @string: a #GString - * @format: the string format. See the sprintf() documentation - * @...: the parameters to insert into the format string - * - * Appends a formatted string onto the end of a #GString. - * This function is similar to g_string_sprintf() except that - * the text is appended to the #GString. - * - * Deprecated: This function has been renamed to g_string_append_printf() - */ - - -/** - * g_string_truncate: - * @string: a #GString - * @len: the new size of @string - * - * Cuts off the end of the GString, leaving the first @len bytes. - * - * Returns: (transfer none): @string - */ - - -/** - * g_string_up: - * @string: a #GString - * - * Converts a #GString to uppercase. - * - * Returns: (transfer none): @string - * Deprecated: 2.2: This function uses the locale-specific - * toupper() function, which is almost never the right thing. - * Use g_string_ascii_up() or g_utf8_strup() instead. - */ - - -/** - * g_string_vprintf: - * @string: a #GString - * @format: (not nullable): the string format. See the printf() documentation - * @args: the parameters to insert into the format string - * - * Writes a formatted string into a #GString. - * This function is similar to g_string_printf() except that - * the arguments to the format string are passed as a va_list. - * - * Since: 2.14 - */ - - -/** - * g_strip_context: - * @msgid: a string - * @msgval: another string - * - * An auxiliary function for gettext() support (see Q_()). - * - * Returns: @msgval, unless @msgval is identical to @msgid - * and contains a '|' character, in which case a pointer to - * the substring of msgid after the first '|' character is returned. - * Since: 2.4 - */ - - -/** - * g_strjoin: - * @separator: (nullable): a string to insert between each of the - * strings, or %NULL - * @...: a %NULL-terminated list of strings to join - * - * Joins a number of strings together to form one long string, with the - * optional @separator inserted between each of them. The returned string - * should be freed with g_free(). - * - * Returns: a newly-allocated string containing all of the strings joined - * together, with @separator between them - */ - - -/** - * g_strjoinv: - * @separator: (nullable): a string to insert between each of the - * strings, or %NULL - * @str_array: a %NULL-terminated array of strings to join - * - * Joins a number of strings together to form one long string, with the - * optional @separator inserted between each of them. The returned string - * should be freed with g_free(). - * - * If @str_array has no items, the return value will be an - * empty string. If @str_array contains a single item, @separator will not - * appear in the resulting string. - * - * Returns: a newly-allocated string containing all of the strings joined - * together, with @separator between them - */ - - -/** - * g_strlcat: - * @dest: destination buffer, already containing one nul-terminated string - * @src: source buffer - * @dest_size: length of @dest buffer in bytes (not length of existing string - * inside @dest) - * - * Portability wrapper that calls strlcat() on systems which have it, - * and emulates it otherwise. Appends nul-terminated @src string to @dest, - * guaranteeing nul-termination for @dest. The total size of @dest won't - * exceed @dest_size. - * - * At most @dest_size - 1 characters will be copied. Unlike strncat(), - * @dest_size is the full size of dest, not the space left over. This - * function does not allocate memory. It always nul-terminates (unless - * @dest_size == 0 or there were no nul characters in the @dest_size - * characters of dest to start with). - * - * Caveat: this is supposedly a more secure alternative to strcat() or - * strncat(), but for real security g_strconcat() is harder to mess up. - * - * Returns: size of attempted result, which is MIN (dest_size, strlen - * (original dest)) + strlen (src), so if retval >= dest_size, - * truncation occurred. - */ - - -/** - * g_strlcpy: - * @dest: destination buffer - * @src: source buffer - * @dest_size: length of @dest in bytes - * - * Portability wrapper that calls strlcpy() on systems which have it, - * and emulates strlcpy() otherwise. Copies @src to @dest; @dest is - * guaranteed to be nul-terminated; @src must be nul-terminated; - * @dest_size is the buffer size, not the number of bytes to copy. - * - * At most @dest_size - 1 characters will be copied. Always nul-terminates - * (unless @dest_size is 0). This function does not allocate memory. Unlike - * strncpy(), this function doesn't pad @dest (so it's often faster). It - * returns the size of the attempted result, strlen (src), so if - * @retval >= @dest_size, truncation occurred. - * - * Caveat: strlcpy() is supposedly more secure than strcpy() or strncpy(), - * but if you really want to avoid screwups, g_strdup() is an even better - * idea. - * - * Returns: length of @src - */ - - -/** - * g_strncasecmp: - * @s1: a string - * @s2: a string to compare with @s1 - * @n: the maximum number of characters to compare - * - * A case-insensitive string comparison, corresponding to the standard - * strncasecmp() function on platforms which support it. It is similar - * to g_strcasecmp() except it only compares the first @n characters of - * the strings. - * - * Returns: 0 if the strings match, a negative value if @s1 < @s2, - * or a positive value if @s1 > @s2. - * Deprecated: 2.2: The problem with g_strncasecmp() is that it does - * the comparison by calling toupper()/tolower(). These functions - * are locale-specific and operate on single bytes. However, it is - * impossible to handle things correctly from an internationalization - * standpoint by operating on bytes, since characters may be multibyte. - * Thus g_strncasecmp() is broken if your string is guaranteed to be - * ASCII, since it is locale-sensitive, and it's broken if your string - * is localized, since it doesn't work on many encodings at all, - * including UTF-8, EUC-JP, etc. - * - * There are therefore two replacement techniques: g_ascii_strncasecmp(), - * which only works on ASCII and is not locale-sensitive, and - * g_utf8_casefold() followed by strcmp() on the resulting strings, - * which is good for case-insensitive sorting of UTF-8. - */ - - -/** - * g_strndup: - * @str: the string to duplicate - * @n: the maximum number of bytes to copy from @str - * - * Duplicates the first @n bytes of a string, returning a newly-allocated - * buffer @n + 1 bytes long which will always be nul-terminated. If @str - * is less than @n bytes long the buffer is padded with nuls. If @str is - * %NULL it returns %NULL. The returned value should be freed when no longer - * needed. - * - * To copy a number of characters from a UTF-8 encoded string, - * use g_utf8_strncpy() instead. - * - * Returns: a newly-allocated buffer containing the first @n bytes - * of @str, nul-terminated - */ - - -/** - * g_strnfill: - * @length: the length of the new string - * @fill_char: the byte to fill the string with - * - * Creates a new string @length bytes long filled with @fill_char. - * The returned string should be freed when no longer needed. - * - * Returns: a newly-allocated string filled the @fill_char - */ - - -/** - * g_strreverse: - * @string: the string to reverse - * - * Reverses all of the bytes in a string. For example, - * `g_strreverse ("abcdef")` will result in "fedcba". - * - * Note that g_strreverse() doesn't work on UTF-8 strings - * containing multibyte characters. For that purpose, use - * g_utf8_strreverse(). - * - * Returns: the same pointer passed in as @string - */ - - -/** - * g_strrstr: - * @haystack: a nul-terminated string - * @needle: the nul-terminated string to search for - * - * Searches the string @haystack for the last occurrence - * of the string @needle. - * - * Returns: a pointer to the found occurrence, or - * %NULL if not found. - */ - - -/** - * g_strrstr_len: - * @haystack: a nul-terminated string - * @haystack_len: the maximum length of @haystack in bytes. A length of -1 - * can be used to mean "search the entire string", like g_strrstr(). - * @needle: the nul-terminated string to search for - * - * Searches the string @haystack for the last occurrence - * of the string @needle, limiting the length of the search - * to @haystack_len. - * - * Returns: a pointer to the found occurrence, or - * %NULL if not found. - */ - - -/** - * g_strsignal: - * @signum: the signal number. See the `signal` documentation - * - * Returns a string describing the given signal, e.g. "Segmentation fault". - * You should use this function in preference to strsignal(), because it - * returns a string in UTF-8 encoding, and since not all platforms support - * the strsignal() function. - * - * Returns: a UTF-8 string describing the signal. If the signal is unknown, - * it returns "unknown signal (<signum>)". - */ - - -/** - * g_strsplit: - * @string: a string to split - * @delimiter: a string which specifies the places at which to split - * the string. The delimiter is not included in any of the resulting - * strings, unless @max_tokens is reached. - * @max_tokens: the maximum number of pieces to split @string into. - * If this is less than 1, the string is split completely. - * - * Splits a string into a maximum of @max_tokens pieces, using the given - * @delimiter. If @max_tokens is reached, the remainder of @string is - * appended to the last token. - * - * As an example, the result of g_strsplit (":a:bc::d:", ":", -1) is a - * %NULL-terminated vector containing the six strings "", "a", "bc", "", "d" - * and "". - * - * As a special case, the result of splitting the empty string "" is an empty - * vector, not a vector containing a single string. The reason for this - * special case is that being able to represent an empty vector is typically - * more useful than consistent handling of empty elements. If you do need - * to represent empty elements, you'll need to check for the empty string - * before calling g_strsplit(). - * - * Returns: a newly-allocated %NULL-terminated array of strings. Use - * g_strfreev() to free it. - */ - - -/** - * g_strsplit_set: - * @string: The string to be tokenized - * @delimiters: A nul-terminated string containing bytes that are used - * to split the string (it can accept an empty string, which will result - * in no string splitting). - * @max_tokens: The maximum number of tokens to split @string into. - * If this is less than 1, the string is split completely - * - * Splits @string into a number of tokens not containing any of the characters - * in @delimiter. A token is the (possibly empty) longest string that does not - * contain any of the characters in @delimiters. If @max_tokens is reached, the - * remainder is appended to the last token. - * - * For example the result of g_strsplit_set ("abc:def/ghi", ":/", -1) is a - * %NULL-terminated vector containing the three strings "abc", "def", - * and "ghi". - * - * The result of g_strsplit_set (":def/ghi:", ":/", -1) is a %NULL-terminated - * vector containing the four strings "", "def", "ghi", and "". - * - * As a special case, the result of splitting the empty string "" is an empty - * vector, not a vector containing a single string. The reason for this - * special case is that being able to represent an empty vector is typically - * more useful than consistent handling of empty elements. If you do need - * to represent empty elements, you'll need to check for the empty string - * before calling g_strsplit_set(). - * - * Note that this function works on bytes not characters, so it can't be used - * to delimit UTF-8 strings for anything but ASCII characters. - * - * Returns: a newly-allocated %NULL-terminated array of strings. Use - * g_strfreev() to free it. - * Since: 2.4 - */ - - -/** - * g_strstr_len: - * @haystack: a nul-terminated string - * @haystack_len: the maximum length of @haystack in bytes. A length of -1 - * can be used to mean "search the entire string", like `strstr()`. - * @needle: the string to search for - * - * Searches the string @haystack for the first occurrence - * of the string @needle, limiting the length of the search - * to @haystack_len. - * - * Returns: a pointer to the found occurrence, or - * %NULL if not found. - */ - - -/** - * g_strstrip: - * @string: a string to remove the leading and trailing whitespace from - * - * Removes leading and trailing whitespace from a string. - * See g_strchomp() and g_strchug(). - * - * Returns: @string - */ - - -/** - * g_strtod: - * @nptr: the string to convert to a numeric value. - * @endptr: (out) (transfer none) (optional): if non-%NULL, it returns the - * character after the last character used in the conversion. - * - * Converts a string to a #gdouble value. - * It calls the standard strtod() function to handle the conversion, but - * if the string is not completely converted it attempts the conversion - * again with g_ascii_strtod(), and returns the best match. - * - * This function should seldom be used. The normal situation when reading - * numbers not for human consumption is to use g_ascii_strtod(). Only when - * you know that you must expect both locale formatted and C formatted numbers - * should you use this. Make sure that you don't pass strings such as comma - * separated lists of values, since the commas may be interpreted as a decimal - * point in some locales, causing unexpected results. - * - * Returns: the #gdouble value. - */ - - -/** - * g_strup: - * @string: the string to convert - * - * Converts a string to upper case. - * - * Returns: the string - * Deprecated: 2.2: This function is totally broken for the reasons - * discussed in the g_strncasecmp() docs - use g_ascii_strup() - * or g_utf8_strup() instead. - */ - - -/** - * g_strv_builder_add: - * @builder: a #GStrvBuilder - * @value: a string. - * - * Add a string to the end of the array. - * - * Since 2.68 - */ - - -/** - * g_strv_builder_add_many: - * @builder: a #GStrvBuilder - * @...: one or more strings followed by %NULL - * - * Appends all the given strings to the builder. - * - * Since 2.70 - */ - - -/** - * g_strv_builder_addv: - * @builder: a #GStrvBuilder - * @value: (array zero-terminated=1): the vector of strings to add - * - * Appends all the strings in the given vector to the builder. - * - * Since 2.70 - */ - - -/** - * g_strv_builder_end: - * @builder: a #GStrvBuilder - * - * Ends the builder process and returns the constructed NULL-terminated string - * array. The returned value should be freed with g_strfreev() when no longer - * needed. - * - * Returns: (transfer full): the constructed string array. - * - * Since 2.68 - */ - - -/** - * g_strv_builder_new: - * - * Creates a new #GStrvBuilder with a reference count of 1. - * Use g_strv_builder_unref() on the returned value when no longer needed. - * - * Returns: (transfer full): the new #GStrvBuilder - * Since: 2.68 - */ - - -/** - * g_strv_builder_ref: - * @builder: (transfer none): a #GStrvBuilder - * - * Atomically increments the reference count of @builder by one. - * This function is thread-safe and may be called from any thread. - * - * Returns: (transfer full): The passed in #GStrvBuilder - * Since: 2.68 - */ - - -/** - * g_strv_builder_unref: - * @builder: (transfer full): a #GStrvBuilder allocated by g_strv_builder_new() - * - * Decreases the reference count on @builder. - * - * In the event that there are no more references, releases all memory - * associated with the #GStrvBuilder. - * - * Since: 2.68 - */ - - -/** - * g_strv_contains: - * @strv: a %NULL-terminated array of strings - * @str: a string - * - * Checks if @strv contains @str. @strv must not be %NULL. - * - * Returns: %TRUE if @str is an element of @strv, according to g_str_equal(). - * Since: 2.44 - */ - - -/** - * g_strv_equal: - * @strv1: a %NULL-terminated array of strings - * @strv2: another %NULL-terminated array of strings - * - * Checks if @strv1 and @strv2 contain exactly the same elements in exactly the - * same order. Elements are compared using g_str_equal(). To match independently - * of order, sort the arrays first (using g_qsort_with_data() or similar). - * - * Two empty arrays are considered equal. Neither @strv1 not @strv2 may be - * %NULL. - * - * Returns: %TRUE if @strv1 and @strv2 are equal - * Since: 2.60 - */ - - -/** - * g_strv_length: - * @str_array: a %NULL-terminated array of strings - * - * Returns the length of the given %NULL-terminated - * string array @str_array. @str_array must not be %NULL. - * - * Returns: length of @str_array. - * Since: 2.6 - */ - - -/** - * g_test_add_data_func: - * @testpath: /-separated test case path name for the test. - * @test_data: Test data argument for the test function. - * @test_func: (scope async): The test function to invoke for this test. - * - * Create a new test case, similar to g_test_create_case(). However - * the test is assumed to use no fixture, and test suites are automatically - * created on the fly and added to the root fixture, based on the - * slash-separated portions of @testpath. The @test_data argument - * will be passed as first argument to @test_func. - * - * If @testpath includes the component "subprocess" anywhere in it, - * the test will be skipped by default, and only run if explicitly - * required via the `-p` command-line option or g_test_trap_subprocess(). - * - * No component of @testpath may start with a dot (`.`) if the - * %G_TEST_OPTION_ISOLATE_DIRS option is being used; and it is recommended to - * do so even if it isn’t. - * - * Since: 2.16 - */ - - -/** - * g_test_add_data_func_full: - * @testpath: /-separated test case path name for the test. - * @test_data: Test data argument for the test function. - * @test_func: The test function to invoke for this test. - * @data_free_func: #GDestroyNotify for @test_data. - * - * Create a new test case, as with g_test_add_data_func(), but freeing - * @test_data after the test run is complete. - * - * Since: 2.34 - */ - - -/** - * g_test_add_func: - * @testpath: /-separated test case path name for the test. - * @test_func: (scope async): The test function to invoke for this test. - * - * Create a new test case, similar to g_test_create_case(). However - * the test is assumed to use no fixture, and test suites are automatically - * created on the fly and added to the root fixture, based on the - * slash-separated portions of @testpath. - * - * If @testpath includes the component "subprocess" anywhere in it, - * the test will be skipped by default, and only run if explicitly - * required via the `-p` command-line option or g_test_trap_subprocess(). - * - * No component of @testpath may start with a dot (`.`) if the - * %G_TEST_OPTION_ISOLATE_DIRS option is being used; and it is recommended to - * do so even if it isn’t. - * - * Since: 2.16 - */ - - -/** - * g_test_assert_expected_messages: - * - * Asserts that all messages previously indicated via - * g_test_expect_message() have been seen and suppressed. - * - * This API may only be used with the old logging API (g_log() without - * %G_LOG_USE_STRUCTURED defined). It will not work with the structured logging - * API. See [Testing for Messages][testing-for-messages]. - * - * If messages at %G_LOG_LEVEL_DEBUG are emitted, but not explicitly - * expected via g_test_expect_message() then they will be ignored. - * - * Since: 2.34 - */ - - -/** - * g_test_bug: - * @bug_uri_snippet: Bug specific bug tracker URI or URI portion. - * - * This function adds a message to test reports that - * associates a bug URI with a test case. - * - * Bug URIs are constructed from a base URI set with g_test_bug_base() - * and @bug_uri_snippet. If g_test_bug_base() has not been called, it is - * assumed to be the empty string, so a full URI can be provided to - * g_test_bug() instead. - * - * Since GLib 2.70, the base URI is not prepended to @bug_uri_snippet if it - * is already a valid URI. - * - * Since: 2.16: - * See also: g_test_summary() - */ - - -/** - * g_test_bug_base: - * @uri_pattern: the base pattern for bug URIs - * - * Specify the base URI for bug reports. - * - * The base URI is used to construct bug report messages for - * g_test_message() when g_test_bug() is called. - * Calling this function outside of a test case sets the - * default base URI for all test cases. Calling it from within - * a test case changes the base URI for the scope of the test - * case only. - * Bug URIs are constructed by appending a bug specific URI - * portion to @uri_pattern, or by replacing the special string - * `%s` within @uri_pattern if that is present. - * - * If g_test_bug_base() is not called, bug URIs are formed solely - * from the value provided by g_test_bug(). - * - * Since: 2.16 - */ - - -/** - * g_test_build_filename: - * @file_type: the type of file (built vs. distributed) - * @first_path: the first segment of the pathname - * @...: %NULL-terminated additional path segments - * - * Creates the pathname to a data file that is required for a test. - * - * This function is conceptually similar to g_build_filename() except - * that the first argument has been replaced with a #GTestFileType - * argument. - * - * The data file should either have been distributed with the module - * containing the test (%G_TEST_DIST) or built as part of the build - * system of that module (%G_TEST_BUILT). - * - * In order for this function to work in srcdir != builddir situations, - * the G_TEST_SRCDIR and G_TEST_BUILDDIR environment variables need to - * have been defined. As of 2.38, this is done by the glib.mk - * included in GLib. Please ensure that your copy is up to date before - * using this function. - * - * In case neither variable is set, this function will fall back to - * using the dirname portion of argv[0], possibly removing ".libs". - * This allows for casual running of tests directly from the commandline - * in the srcdir == builddir case and should also support running of - * installed tests, assuming the data files have been installed in the - * same relative path as the test binary. - * - * Returns: the path of the file, to be freed using g_free() - * Since: 2.38 - */ - - -/** - * g_test_case_free: - * @test_case: a #GTestCase - * - * Free the @test_case. - * - * Since: 2.70 - */ - - -/** - * g_test_create_case: - * @test_name: the name for the test case - * @data_size: the size of the fixture data structure - * @test_data: test data argument for the test functions - * @data_setup: (scope async): the function to set up the fixture data - * @data_test: (scope async): the actual test function - * @data_teardown: (scope async): the function to teardown the fixture data - * - * Create a new #GTestCase, named @test_name. - * - * This API is fairly low level, and calling g_test_add() or g_test_add_func() - * is preferable. - * - * When this test is executed, a fixture structure of size @data_size - * will be automatically allocated and filled with zeros. Then @data_setup is - * called to initialize the fixture. After fixture setup, the actual test - * function @data_test is called. Once the test run completes, the - * fixture structure is torn down by calling @data_teardown and - * after that the memory is automatically released by the test framework. - * - * Splitting up a test run into fixture setup, test function and - * fixture teardown is most useful if the same fixture type is used for - * multiple tests. In this cases, g_test_create_case() will be - * called with the same type of fixture (the @data_size argument), but varying - * @test_name and @data_test arguments. - * - * Returns: a newly allocated #GTestCase. - * Since: 2.16 - */ - - -/** - * g_test_create_suite: - * @suite_name: a name for the suite - * - * Create a new test suite with the name @suite_name. - * - * Returns: A newly allocated #GTestSuite instance. - * Since: 2.16 - */ - - -/** - * g_test_expect_message: - * @log_domain: (nullable): the log domain of the message - * @log_level: the log level of the message - * @pattern: a glob-style [pattern][glib-Glob-style-pattern-matching] - * - * Indicates that a message with the given @log_domain and @log_level, - * with text matching @pattern, is expected to be logged. When this - * message is logged, it will not be printed, and the test case will - * not abort. - * - * This API may only be used with the old logging API (g_log() without - * %G_LOG_USE_STRUCTURED defined). It will not work with the structured logging - * API. See [Testing for Messages][testing-for-messages]. - * - * Use g_test_assert_expected_messages() to assert that all - * previously-expected messages have been seen and suppressed. - * - * You can call this multiple times in a row, if multiple messages are - * expected as a result of a single call. (The messages must appear in - * the same order as the calls to g_test_expect_message().) - * - * For example: - * - * |[<!-- language="C" --> - * // g_main_context_push_thread_default() should fail if the - * // context is already owned by another thread. - * g_test_expect_message (G_LOG_DOMAIN, - * G_LOG_LEVEL_CRITICAL, - * "assertion*acquired_context*failed"); - * g_main_context_push_thread_default (bad_context); - * g_test_assert_expected_messages (); - * ]| - * - * Note that you cannot use this to test g_error() messages, since - * g_error() intentionally never returns even if the program doesn't - * abort; use g_test_trap_subprocess() in this case. - * - * If messages at %G_LOG_LEVEL_DEBUG are emitted, but not explicitly - * expected via g_test_expect_message() then they will be ignored. - * - * Since: 2.34 - */ - - -/** - * g_test_fail: - * - * Indicates that a test failed. This function can be called - * multiple times from the same test. You can use this function - * if your test failed in a recoverable way. - * - * Do not use this function if the failure of a test could cause - * other tests to malfunction. - * - * Calling this function will not stop the test from running, you - * need to return from the test function yourself. So you can - * produce additional diagnostic messages or even continue running - * the test. - * - * If not called from inside a test, this function does nothing. - * - * Note that unlike g_test_skip() and g_test_incomplete(), this - * function does not log a message alongside the test failure. - * If details of the test failure are available, either log them with - * g_test_message() before g_test_fail(), or use g_test_fail_printf() - * instead. - * - * Since: 2.30 - */ - - -/** - * g_test_fail_printf: - * @format: the format string - * @...: printf-like arguments to @format - * - * Equivalent to g_test_fail(), but also record a message like - * g_test_skip_printf(). - * - * Since: 2.70 - */ - - -/** - * g_test_failed: - * - * Returns whether a test has already failed. This will - * be the case when g_test_fail(), g_test_incomplete() - * or g_test_skip() have been called, but also if an - * assertion has failed. - * - * This can be useful to return early from a test if - * continuing after a failed assertion might be harmful. - * - * The return value of this function is only meaningful - * if it is called from inside a test function. - * - * Returns: %TRUE if the test has failed - * Since: 2.38 - */ - - -/** - * g_test_get_dir: - * @file_type: the type of file (built vs. distributed) - * - * Gets the pathname of the directory containing test files of the type - * specified by @file_type. - * - * This is approximately the same as calling g_test_build_filename("."), - * but you don't need to free the return value. - * - * Returns: (type filename): the path of the directory, owned by GLib - * Since: 2.38 - */ - - -/** - * g_test_get_filename: - * @file_type: the type of file (built vs. distributed) - * @first_path: the first segment of the pathname - * @...: %NULL-terminated additional path segments - * - * Gets the pathname to a data file that is required for a test. - * - * This is the same as g_test_build_filename() with two differences. - * The first difference is that must only use this function from within - * a testcase function. The second difference is that you need not free - * the return value -- it will be automatically freed when the testcase - * finishes running. - * - * It is safe to use this function from a thread inside of a testcase - * but you must ensure that all such uses occur before the main testcase - * function returns (ie: it is best to ensure that all threads have been - * joined). - * - * Returns: the path, automatically freed at the end of the testcase - * Since: 2.38 - */ - - -/** - * g_test_get_path: - * - * Gets the test path for the test currently being run. - * - * In essence, it will be the same string passed as the first argument to - * e.g. g_test_add() when the test was added. - * - * This function returns a valid string only within a test function. - * - * Returns: the test path for the test currently being run - * Since: 2.68 - */ - - -/** - * g_test_get_root: - * - * Get the toplevel test suite for the test path API. - * - * Returns: the toplevel #GTestSuite - * Since: 2.16 - */ - - -/** - * g_test_incomplete: - * @msg: (nullable): explanation - * - * Indicates that a test failed because of some incomplete - * functionality. This function can be called multiple times - * from the same test. - * - * Calling this function will not stop the test from running, you - * need to return from the test function yourself. So you can - * produce additional diagnostic messages or even continue running - * the test. - * - * If not called from inside a test, this function does nothing. - * - * Since: 2.38 - */ - - -/** - * g_test_incomplete_printf: - * @format: the format string - * @...: printf-like arguments to @format - * - * Equivalent to g_test_incomplete(), but the explanation is formatted - * as if by g_strdup_printf(). - * - * Since: 2.70 - */ - - -/** - * g_test_init: - * @argc: Address of the @argc parameter of the main() function. - * Changed if any arguments were handled. - * @argv: Address of the @argv parameter of main(). - * Any parameters understood by g_test_init() stripped before return. - * @...: %NULL-terminated list of special options, documented below. - * - * Initialize the GLib testing framework, e.g. by seeding the - * test random number generator, the name for g_get_prgname() - * and parsing test related command line args. - * - * So far, the following arguments are understood: - * - * - `-l`: List test cases available in a test executable. - * - `--seed=SEED`: Provide a random seed to reproduce test - * runs using random numbers. - * - `--verbose`: Run tests verbosely. - * - `-q`, `--quiet`: Run tests quietly. - * - `-p PATH`: Execute all tests matching the given path. - * - `-s PATH`: Skip all tests matching the given path. - * This can also be used to force a test to run that would otherwise - * be skipped (ie, a test whose name contains "/subprocess"). - * - `-m {perf|slow|thorough|quick|undefined|no-undefined}`: Execute tests according to these test modes: - * - * `perf`: Performance tests, may take long and report results (off by default). - * - * `slow`, `thorough`: Slow and thorough tests, may take quite long and maximize coverage - * (off by default). - * - * `quick`: Quick tests, should run really quickly and give good coverage (the default). - * - * `undefined`: Tests for undefined behaviour, may provoke programming errors - * under g_test_trap_subprocess() or g_test_expect_message() to check - * that appropriate assertions or warnings are given (the default). - * - * `no-undefined`: Avoid tests for undefined behaviour - * - * - `--debug-log`: Debug test logging output. - * - * Options which can be passed to @... are: - * - * - `"no_g_set_prgname"`: Causes g_test_init() to not call g_set_prgname(). - * - %G_TEST_OPTION_ISOLATE_DIRS: Creates a unique temporary directory for each - * unit test and uses g_set_user_dirs() to set XDG directories to point into - * that temporary directory for the duration of the unit test. See the - * documentation for %G_TEST_OPTION_ISOLATE_DIRS. - * - * Since 2.58, if tests are compiled with `G_DISABLE_ASSERT` defined, - * g_test_init() will print an error and exit. This is to prevent no-op tests - * from being executed, as g_assert() is commonly (erroneously) used in unit - * tests, and is a no-op when compiled with `G_DISABLE_ASSERT`. Ensure your - * tests are compiled without `G_DISABLE_ASSERT` defined. - * - * Since: 2.16 - */ - - -/** - * g_test_initialized: - * - * Returns %TRUE if g_test_init() has been called. - * - * Returns: %TRUE if g_test_init() has been called. - * Since: 2.36 - */ - - -/** - * g_test_log_buffer_free: - * - * Internal function for gtester to free test log messages, no ABI guarantees provided. - */ - - -/** - * g_test_log_buffer_new: - * - * Internal function for gtester to decode test log messages, no ABI guarantees provided. - */ - - -/** - * g_test_log_buffer_pop: - * - * Internal function for gtester to retrieve test log messages, no ABI guarantees provided. - */ - - -/** - * g_test_log_buffer_push: - * - * Internal function for gtester to decode test log messages, no ABI guarantees provided. - */ - - -/** - * g_test_log_msg_free: - * - * Internal function for gtester to free test log messages, no ABI guarantees provided. - */ - - -/** - * g_test_log_set_fatal_handler: - * @log_func: the log handler function. - * @user_data: data passed to the log handler. - * - * Installs a non-error fatal log handler which can be - * used to decide whether log messages which are counted - * as fatal abort the program. - * - * The use case here is that you are running a test case - * that depends on particular libraries or circumstances - * and cannot prevent certain known critical or warning - * messages. So you install a handler that compares the - * domain and message to precisely not abort in such a case. - * - * Note that the handler is reset at the beginning of - * any test case, so you have to set it inside each test - * function which needs the special behavior. - * - * This handler has no effect on g_error messages. - * - * This handler also has no effect on structured log messages (using - * g_log_structured() or g_log_structured_array()). To change the fatal - * behaviour for specific log messages, programs must install a custom log - * writer function using g_log_set_writer_func().See - * [Using Structured Logging][using-structured-logging]. - * - * Since: 2.22 - */ - - -/** - * g_test_maximized_result: - * @maximized_quantity: the reported value - * @format: the format string of the report message - * @...: arguments to pass to the printf() function - * - * Report the result of a performance or measurement test. - * The test should generally strive to maximize the reported - * quantities (larger values are better than smaller ones), - * this and @maximized_quantity can determine sorting - * order for test result reports. - * - * Since: 2.16 - */ - - -/** - * g_test_message: - * @format: the format string - * @...: printf-like arguments to @format - * - * Add a message to the test report. - * - * Since: 2.16 - */ - - -/** - * g_test_minimized_result: - * @minimized_quantity: the reported value - * @format: the format string of the report message - * @...: arguments to pass to the printf() function - * - * Report the result of a performance or measurement test. - * The test should generally strive to minimize the reported - * quantities (smaller values are better than larger ones), - * this and @minimized_quantity can determine sorting - * order for test result reports. - * - * Since: 2.16 - */ - - -/** - * g_test_perf: - * - * Returns %TRUE if tests are run in performance mode. - * - * By default, tests are run in quick mode. In tests that use - * g_test_init(), the option `-m perf` enables performance tests, while - * `-m quick` disables them. - * - * Returns: %TRUE if in performance mode - */ - - -/** - * g_test_queue_destroy: - * @destroy_func: Destroy callback for teardown phase. - * @destroy_data: Destroy callback data. - * - * This function enqueus a callback @destroy_func to be executed - * during the next test case teardown phase. This is most useful - * to auto destruct allocated test resources at the end of a test run. - * Resources are released in reverse queue order, that means enqueueing - * callback A before callback B will cause B() to be called before - * A() during teardown. - * - * Since: 2.16 - */ - - -/** - * g_test_queue_free: - * @gfree_pointer: the pointer to be stored. - * - * Enqueue a pointer to be released with g_free() during the next - * teardown phase. This is equivalent to calling g_test_queue_destroy() - * with a destroy callback of g_free(). - * - * Since: 2.16 - */ - - -/** - * g_test_queue_unref: - * @gobject: the object to unref - * - * Enqueue an object to be released with g_object_unref() during - * the next teardown phase. This is equivalent to calling - * g_test_queue_destroy() with a destroy callback of g_object_unref(). - * - * Since: 2.16 - */ - - -/** - * g_test_quick: - * - * Returns %TRUE if tests are run in quick mode. - * Exactly one of g_test_quick() and g_test_slow() is active in any run; - * there is no "medium speed". - * - * By default, tests are run in quick mode. In tests that use - * g_test_init(), the options `-m quick`, `-m slow` and `-m thorough` - * can be used to change this. - * - * Returns: %TRUE if in quick mode - */ - - -/** - * g_test_quiet: - * - * Returns %TRUE if tests are run in quiet mode. - * In tests that use g_test_init(), the option `-q` or `--quiet` enables - * this, while `--verbose` disables it. - * The default is neither g_test_verbose() nor g_test_quiet(). - * - * Returns: %TRUE if in quiet mode - */ - - -/** - * g_test_rand_bit: - * - * Get a reproducible random bit (0 or 1), see g_test_rand_int() - * for details on test case random numbers. - * - * Since: 2.16 - */ - - -/** - * g_test_rand_double: - * - * Get a reproducible random floating point number, - * see g_test_rand_int() for details on test case random numbers. - * - * Returns: a random number from the seeded random number generator. - * Since: 2.16 - */ - - -/** - * g_test_rand_double_range: - * @range_start: the minimum value returned by this function - * @range_end: the minimum value not returned by this function - * - * Get a reproducible random floating pointer number out of a specified range, - * see g_test_rand_int() for details on test case random numbers. - * - * Returns: a number with @range_start <= number < @range_end. - * Since: 2.16 - */ - - -/** - * g_test_rand_int: - * - * Get a reproducible random integer number. - * - * The random numbers generated by the g_test_rand_*() family of functions - * change with every new test program start, unless the --seed option is - * given when starting test programs. - * - * For individual test cases however, the random number generator is - * reseeded, to avoid dependencies between tests and to make --seed - * effective for all test cases. - * - * Returns: a random number from the seeded random number generator. - * Since: 2.16 - */ - - -/** - * g_test_rand_int_range: - * @begin: the minimum value returned by this function - * @end: the smallest value not to be returned by this function - * - * Get a reproducible random integer number out of a specified range, - * see g_test_rand_int() for details on test case random numbers. - * - * Returns: a number with @begin <= number < @end. - * Since: 2.16 - */ - - -/** - * g_test_run: - * - * Runs all tests under the toplevel suite which can be retrieved - * with g_test_get_root(). Similar to g_test_run_suite(), the test - * cases to be run are filtered according to test path arguments - * (`-p testpath` and `-s testpath`) as parsed by g_test_init(). - * g_test_run_suite() or g_test_run() may only be called once in a - * program. - * - * In general, the tests and sub-suites within each suite are run in - * the order in which they are defined. However, note that prior to - * GLib 2.36, there was a bug in the `g_test_add_*` - * functions which caused them to create multiple suites with the same - * name, meaning that if you created tests "/foo/simple", - * "/bar/simple", and "/foo/using-bar" in that order, they would get - * run in that order (since g_test_run() would run the first "/foo" - * suite, then the "/bar" suite, then the second "/foo" suite). As of - * 2.36, this bug is fixed, and adding the tests in that order would - * result in a running order of "/foo/simple", "/foo/using-bar", - * "/bar/simple". If this new ordering is sub-optimal (because it puts - * more-complicated tests before simpler ones, making it harder to - * figure out exactly what has failed), you can fix it by changing the - * test paths to group tests by suite in a way that will result in the - * desired running order. Eg, "/simple/foo", "/simple/bar", - * "/complex/foo-using-bar". - * - * However, you should never make the actual result of a test depend - * on the order that tests are run in. If you need to ensure that some - * particular code runs before or after a given test case, use - * g_test_add(), which lets you specify setup and teardown functions. - * - * If all tests are skipped or marked as incomplete (expected failures), - * this function will return 0 if producing TAP output, or 77 (treated - * as "skip test" by Automake) otherwise. - * - * Returns: 0 on success, 1 on failure (assuming it returns at all), - * 0 or 77 if all tests were skipped with g_test_skip() and/or - * g_test_incomplete() - * Since: 2.16 - */ - - -/** - * g_test_run_suite: - * @suite: a #GTestSuite - * - * Execute the tests within @suite and all nested #GTestSuites. - * The test suites to be executed are filtered according to - * test path arguments (`-p testpath` and `-s testpath`) as parsed by - * g_test_init(). See the g_test_run() documentation for more - * information on the order that tests are run in. - * - * g_test_run_suite() or g_test_run() may only be called once - * in a program. - * - * Returns: 0 on success - * Since: 2.16 - */ - - -/** - * g_test_set_nonfatal_assertions: - * - * Changes the behaviour of the various `g_assert_*()` macros, - * g_test_assert_expected_messages() and the various - * `g_test_trap_assert_*()` macros to not abort to program, but instead - * call g_test_fail() and continue. (This also changes the behavior of - * g_test_fail() so that it will not cause the test program to abort - * after completing the failed test.) - * - * Note that the g_assert_not_reached() and g_assert() macros are not - * affected by this. - * - * This function can only be called after g_test_init(). - * - * Since: 2.38 - */ - - -/** - * g_test_skip: - * @msg: (nullable): explanation - * - * Indicates that a test was skipped. - * - * Calling this function will not stop the test from running, you - * need to return from the test function yourself. So you can - * produce additional diagnostic messages or even continue running - * the test. - * - * If not called from inside a test, this function does nothing. - * - * Since: 2.38 - */ - - -/** - * g_test_skip_printf: - * @format: the format string - * @...: printf-like arguments to @format - * - * Equivalent to g_test_skip(), but the explanation is formatted - * as if by g_strdup_printf(). - * - * Since: 2.70 - */ - - -/** - * g_test_slow: - * - * Returns %TRUE if tests are run in slow mode. - * Exactly one of g_test_quick() and g_test_slow() is active in any run; - * there is no "medium speed". - * - * By default, tests are run in quick mode. In tests that use - * g_test_init(), the options `-m quick`, `-m slow` and `-m thorough` - * can be used to change this. - * - * Returns: the opposite of g_test_quick() - */ - - -/** - * g_test_subprocess: - * - * Returns %TRUE (after g_test_init() has been called) if the test - * program is running under g_test_trap_subprocess(). - * - * Returns: %TRUE if the test program is running under - * g_test_trap_subprocess(). - * Since: 2.38 - */ - - -/** - * g_test_suite_add: - * @suite: a #GTestSuite - * @test_case: a #GTestCase - * - * Adds @test_case to @suite. - * - * Since: 2.16 - */ - - -/** - * g_test_suite_add_suite: - * @suite: a #GTestSuite - * @nestedsuite: another #GTestSuite - * - * Adds @nestedsuite to @suite. - * - * Since: 2.16 - */ - - -/** - * g_test_suite_free: - * @suite: a #GTestSuite - * - * Free the @suite and all nested #GTestSuites. - * - * Since: 2.70 - */ - - -/** - * g_test_summary: - * @summary: One or two sentences summarising what the test checks, and how it - * checks it. - * - * Set the summary for a test, which describes what the test checks, and how it - * goes about checking it. This may be included in test report output, and is - * useful documentation for anyone reading the source code or modifying a test - * in future. It must be a single line. - * - * This should be called at the top of a test function. - * - * For example: - * |[<!-- language="C" --> - * static void - * test_array_sort (void) - * { - * g_test_summary ("Test my_array_sort() sorts the array correctly and stably, " - * "including testing zero length and one-element arrays."); - * - * … - * } - * ]| - * - * Since: 2.62: - * See also: g_test_bug() - */ - - -/** - * g_test_thorough: - * - * Returns %TRUE if tests are run in thorough mode, equivalent to - * g_test_slow(). - * - * By default, tests are run in quick mode. In tests that use - * g_test_init(), the options `-m quick`, `-m slow` and `-m thorough` - * can be used to change this. - * - * Returns: the same thing as g_test_slow() - */ - - -/** - * g_test_timer_elapsed: - * - * Get the time since the last start of the timer with g_test_timer_start(). - * - * Returns: the time since the last start of the timer, as a double - * Since: 2.16 - */ - - -/** - * g_test_timer_last: - * - * Report the last result of g_test_timer_elapsed(). - * - * Returns: the last result of g_test_timer_elapsed(), as a double - * Since: 2.16 - */ - - -/** - * g_test_timer_start: - * - * Start a timing test. Call g_test_timer_elapsed() when the task is supposed - * to be done. Call this function again to restart the timer. - * - * Since: 2.16 - */ - - -/** - * g_test_trap_assert_failed: - * - * Assert that the last test subprocess failed. - * See g_test_trap_subprocess(). - * - * This is sometimes used to test situations that are formally considered to - * be undefined behaviour, like inputs that fail a g_return_if_fail() - * check. In these situations you should skip the entire test, including the - * call to g_test_trap_subprocess(), unless g_test_undefined() returns %TRUE - * to indicate that undefined behaviour may be tested. - * - * Since: 2.16 - */ - - -/** - * g_test_trap_assert_passed: - * - * Assert that the last test subprocess passed. - * See g_test_trap_subprocess(). - * - * Since: 2.16 - */ - - -/** - * g_test_trap_assert_stderr: - * @serrpattern: a glob-style [pattern][glib-Glob-style-pattern-matching] - * - * Assert that the stderr output of the last test subprocess - * matches @serrpattern. See g_test_trap_subprocess(). - * - * This is sometimes used to test situations that are formally - * considered to be undefined behaviour, like code that hits a - * g_assert() or g_error(). In these situations you should skip the - * entire test, including the call to g_test_trap_subprocess(), unless - * g_test_undefined() returns %TRUE to indicate that undefined - * behaviour may be tested. - * - * Since: 2.16 - */ - - -/** - * g_test_trap_assert_stderr_unmatched: - * @serrpattern: a glob-style [pattern][glib-Glob-style-pattern-matching] - * - * Assert that the stderr output of the last test subprocess - * does not match @serrpattern. See g_test_trap_subprocess(). - * - * Since: 2.16 - */ - - -/** - * g_test_trap_assert_stdout: - * @soutpattern: a glob-style [pattern][glib-Glob-style-pattern-matching] - * - * Assert that the stdout output of the last test subprocess matches - * @soutpattern. See g_test_trap_subprocess(). - * - * Since: 2.16 - */ - - -/** - * g_test_trap_assert_stdout_unmatched: - * @soutpattern: a glob-style [pattern][glib-Glob-style-pattern-matching] - * - * Assert that the stdout output of the last test subprocess - * does not match @soutpattern. See g_test_trap_subprocess(). - * - * Since: 2.16 - */ - - -/** - * g_test_trap_fork: - * @usec_timeout: Timeout for the forked test in micro seconds. - * @test_trap_flags: Flags to modify forking behaviour. - * - * Fork the current test program to execute a test case that might - * not return or that might abort. - * - * If @usec_timeout is non-0, the forked test case is aborted and - * considered failing if its run time exceeds it. - * - * The forking behavior can be configured with the #GTestTrapFlags flags. - * - * In the following example, the test code forks, the forked child - * process produces some sample output and exits successfully. - * The forking parent process then asserts successful child program - * termination and validates child program outputs. - * - * |[<!-- language="C" --> - * static void - * test_fork_patterns (void) - * { - * if (g_test_trap_fork (0, G_TEST_TRAP_SILENCE_STDOUT | G_TEST_TRAP_SILENCE_STDERR)) - * { - * g_print ("some stdout text: somagic17\n"); - * g_printerr ("some stderr text: semagic43\n"); - * exit (0); // successful test run - * } - * g_test_trap_assert_passed (); - * g_test_trap_assert_stdout ("*somagic17*"); - * g_test_trap_assert_stderr ("*semagic43*"); - * } - * ]| - * - * Returns: %TRUE for the forked child and %FALSE for the executing parent process. - * Since: 2.16 - * Deprecated: This function is implemented only on Unix platforms, - * and is not always reliable due to problems inherent in - * fork-without-exec. Use g_test_trap_subprocess() instead. - */ - - -/** - * g_test_trap_has_passed: - * - * Check the result of the last g_test_trap_subprocess() call. - * - * Returns: %TRUE if the last test subprocess terminated successfully. - * Since: 2.16 - */ - - -/** - * g_test_trap_reached_timeout: - * - * Check the result of the last g_test_trap_subprocess() call. - * - * Returns: %TRUE if the last test subprocess got killed due to a timeout. - * Since: 2.16 - */ - - -/** - * g_test_trap_subprocess: - * @test_path: (nullable): Test to run in a subprocess - * @usec_timeout: Timeout for the subprocess test in micro seconds. - * @test_flags: Flags to modify subprocess behaviour. - * - * Respawns the test program to run only @test_path in a subprocess. - * This can be used for a test case that might not return, or that - * might abort. - * - * If @test_path is %NULL then the same test is re-run in a subprocess. - * You can use g_test_subprocess() to determine whether the test is in - * a subprocess or not. - * - * @test_path can also be the name of the parent test, followed by - * "`/subprocess/`" and then a name for the specific subtest (or just - * ending with "`/subprocess`" if the test only has one child test); - * tests with names of this form will automatically be skipped in the - * parent process. - * - * If @usec_timeout is non-0, the test subprocess is aborted and - * considered failing if its run time exceeds it. - * - * The subprocess behavior can be configured with the - * #GTestSubprocessFlags flags. - * - * You can use methods such as g_test_trap_assert_passed(), - * g_test_trap_assert_failed(), and g_test_trap_assert_stderr() to - * check the results of the subprocess. (But note that - * g_test_trap_assert_stdout() and g_test_trap_assert_stderr() - * cannot be used if @test_flags specifies that the child should - * inherit the parent stdout/stderr.) - * - * If your `main ()` needs to behave differently in - * the subprocess, you can call g_test_subprocess() (after calling - * g_test_init()) to see whether you are in a subprocess. - * - * The following example tests that calling - * `my_object_new(1000000)` will abort with an error - * message. - * - * |[<!-- language="C" --> - * static void - * test_create_large_object (void) - * { - * if (g_test_subprocess ()) - * { - * my_object_new (1000000); - * return; - * } - * - * // Reruns this same test in a subprocess - * g_test_trap_subprocess (NULL, 0, 0); - * g_test_trap_assert_failed (); - * g_test_trap_assert_stderr ("*ERROR*too large*"); - * } - * - * int - * main (int argc, char **argv) - * { - * g_test_init (&argc, &argv, NULL); - * - * g_test_add_func ("/myobject/create_large_object", - * test_create_large_object); - * return g_test_run (); - * } - * ]| - * - * Since: 2.38 - */ - - -/** - * g_test_undefined: - * - * Returns %TRUE if tests may provoke assertions and other formally-undefined - * behaviour, to verify that appropriate warnings are given. It might, in some - * cases, be useful to turn this off with if running tests under valgrind; - * in tests that use g_test_init(), the option `-m no-undefined` disables - * those tests, while `-m undefined` explicitly enables them (normally - * the default behaviour). - * - * Since GLib 2.68, if GLib was compiled with gcc or clang and - * [AddressSanitizer](https://github.com/google/sanitizers/wiki/AddressSanitizer) - * is enabled, the default changes to not exercising undefined behaviour. - * - * Returns: %TRUE if tests may provoke programming errors - */ - - -/** - * g_test_verbose: - * - * Returns %TRUE if tests are run in verbose mode. - * In tests that use g_test_init(), the option `--verbose` enables this, - * while `-q` or `--quiet` disables it. - * The default is neither g_test_verbose() nor g_test_quiet(). - * - * Returns: %TRUE if in verbose mode - */ - - -/** - * g_thread_exit: - * @retval: the return value of this thread - * - * Terminates the current thread. - * - * If another thread is waiting for us using g_thread_join() then the - * waiting thread will be woken up and get @retval as the return value - * of g_thread_join(). - * - * Calling g_thread_exit() with a parameter @retval is equivalent to - * returning @retval from the function @func, as given to g_thread_new(). - * - * You must only call g_thread_exit() from a thread that you created - * yourself with g_thread_new() or related APIs. You must not call - * this function from a thread created with another threading library - * or or from within a #GThreadPool. - */ - - -/** - * g_thread_join: - * @thread: (transfer full): a #GThread - * - * Waits until @thread finishes, i.e. the function @func, as - * given to g_thread_new(), returns or g_thread_exit() is called. - * If @thread has already terminated, then g_thread_join() - * returns immediately. - * - * Any thread can wait for any other thread by calling g_thread_join(), - * not just its 'creator'. Calling g_thread_join() from multiple threads - * for the same @thread leads to undefined behaviour. - * - * The value returned by @func or given to g_thread_exit() is - * returned by this function. - * - * g_thread_join() consumes the reference to the passed-in @thread. - * This will usually cause the #GThread struct and associated resources - * to be freed. Use g_thread_ref() to obtain an extra reference if you - * want to keep the GThread alive beyond the g_thread_join() call. - * - * Returns: (transfer full): the return value of the thread - */ - - -/** - * g_thread_new: - * @name: (nullable): an (optional) name for the new thread - * @func: (closure data) (scope async): a function to execute in the new thread - * @data: (nullable): an argument to supply to the new thread - * - * This function creates a new thread. The new thread starts by invoking - * @func with the argument data. The thread will run until @func returns - * or until g_thread_exit() is called from the new thread. The return value - * of @func becomes the return value of the thread, which can be obtained - * with g_thread_join(). - * - * The @name can be useful for discriminating threads in a debugger. - * It is not used for other purposes and does not have to be unique. - * Some systems restrict the length of @name to 16 bytes. - * - * If the thread can not be created the program aborts. See - * g_thread_try_new() if you want to attempt to deal with failures. - * - * If you are using threads to offload (potentially many) short-lived tasks, - * #GThreadPool may be more appropriate than manually spawning and tracking - * multiple #GThreads. - * - * To free the struct returned by this function, use g_thread_unref(). - * Note that g_thread_join() implicitly unrefs the #GThread as well. - * - * New threads by default inherit their scheduler policy (POSIX) or thread - * priority (Windows) of the thread creating the new thread. - * - * This behaviour changed in GLib 2.64: before threads on Windows were not - * inheriting the thread priority but were spawned with the default priority. - * Starting with GLib 2.64 the behaviour is now consistent between Windows and - * POSIX and all threads inherit their parent thread's priority. - * - * Returns: (transfer full): the new #GThread - * Since: 2.32 - */ - - -/** - * g_thread_pool_free: - * @pool: a #GThreadPool - * @immediate: should @pool shut down immediately? - * @wait_: should the function wait for all tasks to be finished? - * - * Frees all resources allocated for @pool. - * - * If @immediate is %TRUE, no new task is processed for @pool. - * Otherwise @pool is not freed before the last task is processed. - * Note however, that no thread of this pool is interrupted while - * processing a task. Instead at least all still running threads - * can finish their tasks before the @pool is freed. - * - * If @wait_ is %TRUE, this function does not return before all - * tasks to be processed (dependent on @immediate, whether all - * or only the currently running) are ready. - * Otherwise this function returns immediately. - * - * After calling this function @pool must not be used anymore. - */ - - -/** - * g_thread_pool_get_max_idle_time: - * - * This function will return the maximum @interval that a - * thread will wait in the thread pool for new tasks before - * being stopped. - * - * If this function returns 0, threads waiting in the thread - * pool for new work are not stopped. - * - * Returns: the maximum @interval (milliseconds) to wait - * for new tasks in the thread pool before stopping the - * thread - * Since: 2.10 - */ - - -/** - * g_thread_pool_get_max_threads: - * @pool: a #GThreadPool - * - * Returns the maximal number of threads for @pool. - * - * Returns: the maximal number of threads - */ - - -/** - * g_thread_pool_get_max_unused_threads: - * - * Returns the maximal allowed number of unused threads. - * - * Returns: the maximal number of unused threads - */ - - -/** - * g_thread_pool_get_num_threads: - * @pool: a #GThreadPool - * - * Returns the number of threads currently running in @pool. - * - * Returns: the number of threads currently running - */ - - -/** - * g_thread_pool_get_num_unused_threads: - * - * Returns the number of currently unused threads. - * - * Returns: the number of currently unused threads - */ - - -/** - * g_thread_pool_move_to_front: - * @pool: a #GThreadPool - * @data: an unprocessed item in the pool - * - * Moves the item to the front of the queue of unprocessed - * items, so that it will be processed next. - * - * Returns: %TRUE if the item was found and moved - * Since: 2.46 - */ - - -/** - * g_thread_pool_new: - * @func: a function to execute in the threads of the new thread pool - * @user_data: user data that is handed over to @func every time it - * is called - * @max_threads: the maximal number of threads to execute concurrently - * in the new thread pool, -1 means no limit - * @exclusive: should this thread pool be exclusive? - * @error: return location for error, or %NULL - * - * This function creates a new thread pool. - * - * Whenever you call g_thread_pool_push(), either a new thread is - * created or an unused one is reused. At most @max_threads threads - * are running concurrently for this thread pool. @max_threads = -1 - * allows unlimited threads to be created for this thread pool. The - * newly created or reused thread now executes the function @func - * with the two arguments. The first one is the parameter to - * g_thread_pool_push() and the second one is @user_data. - * - * Pass g_get_num_processors() to @max_threads to create as many threads as - * there are logical processors on the system. This will not pin each thread to - * a specific processor. - * - * The parameter @exclusive determines whether the thread pool owns - * all threads exclusive or shares them with other thread pools. - * If @exclusive is %TRUE, @max_threads threads are started - * immediately and they will run exclusively for this thread pool - * until it is destroyed by g_thread_pool_free(). If @exclusive is - * %FALSE, threads are created when needed and shared between all - * non-exclusive thread pools. This implies that @max_threads may - * not be -1 for exclusive thread pools. Besides, exclusive thread - * pools are not affected by g_thread_pool_set_max_idle_time() - * since their threads are never considered idle and returned to the - * global pool. - * - * @error can be %NULL to ignore errors, or non-%NULL to report - * errors. An error can only occur when @exclusive is set to %TRUE - * and not all @max_threads threads could be created. - * See #GThreadError for possible errors that may occur. - * Note, even in case of error a valid #GThreadPool is returned. - * - * Returns: the new #GThreadPool - */ - - -/** - * g_thread_pool_new_full: - * @func: a function to execute in the threads of the new thread pool - * @user_data: user data that is handed over to @func every time it - * is called - * @item_free_func: (nullable): used to pass as a free function to - * g_async_queue_new_full() - * @max_threads: the maximal number of threads to execute concurrently - * in the new thread pool, `-1` means no limit - * @exclusive: should this thread pool be exclusive? - * @error: return location for error, or %NULL - * - * This function creates a new thread pool similar to g_thread_pool_new() - * but allowing @item_free_func to be specified to free the data passed - * to g_thread_pool_push() in the case that the #GThreadPool is stopped - * and freed before all tasks have been executed. - * - * Returns: (transfer full): the new #GThreadPool - * Since: 2.70 - */ - - -/** - * g_thread_pool_push: - * @pool: a #GThreadPool - * @data: a new task for @pool - * @error: return location for error, or %NULL - * - * Inserts @data into the list of tasks to be executed by @pool. - * - * When the number of currently running threads is lower than the - * maximal allowed number of threads, a new thread is started (or - * reused) with the properties given to g_thread_pool_new(). - * Otherwise, @data stays in the queue until a thread in this pool - * finishes its previous task and processes @data. - * - * @error can be %NULL to ignore errors, or non-%NULL to report - * errors. An error can only occur when a new thread couldn't be - * created. In that case @data is simply appended to the queue of - * work to do. - * - * Before version 2.32, this function did not return a success status. - * - * Returns: %TRUE on success, %FALSE if an error occurred - */ - - -/** - * g_thread_pool_set_max_idle_time: - * @interval: the maximum @interval (in milliseconds) - * a thread can be idle - * - * This function will set the maximum @interval that a thread - * waiting in the pool for new tasks can be idle for before - * being stopped. This function is similar to calling - * g_thread_pool_stop_unused_threads() on a regular timeout, - * except this is done on a per thread basis. - * - * By setting @interval to 0, idle threads will not be stopped. - * - * The default value is 15000 (15 seconds). - * - * Since: 2.10 - */ - - -/** - * g_thread_pool_set_max_threads: - * @pool: a #GThreadPool - * @max_threads: a new maximal number of threads for @pool, - * or -1 for unlimited - * @error: return location for error, or %NULL - * - * Sets the maximal allowed number of threads for @pool. - * A value of -1 means that the maximal number of threads - * is unlimited. If @pool is an exclusive thread pool, setting - * the maximal number of threads to -1 is not allowed. - * - * Setting @max_threads to 0 means stopping all work for @pool. - * It is effectively frozen until @max_threads is set to a non-zero - * value again. - * - * A thread is never terminated while calling @func, as supplied by - * g_thread_pool_new(). Instead the maximal number of threads only - * has effect for the allocation of new threads in g_thread_pool_push(). - * A new thread is allocated, whenever the number of currently - * running threads in @pool is smaller than the maximal number. - * - * @error can be %NULL to ignore errors, or non-%NULL to report - * errors. An error can only occur when a new thread couldn't be - * created. - * - * Before version 2.32, this function did not return a success status. - * - * Returns: %TRUE on success, %FALSE if an error occurred - */ - - -/** - * g_thread_pool_set_max_unused_threads: - * @max_threads: maximal number of unused threads - * - * Sets the maximal number of unused threads to @max_threads. - * If @max_threads is -1, no limit is imposed on the number - * of unused threads. - * - * The default value is 2. - */ - - -/** - * g_thread_pool_set_sort_function: - * @pool: a #GThreadPool - * @func: the #GCompareDataFunc used to sort the list of tasks. - * This function is passed two tasks. It should return - * 0 if the order in which they are handled does not matter, - * a negative value if the first task should be processed before - * the second or a positive value if the second task should be - * processed first. - * @user_data: user data passed to @func - * - * Sets the function used to sort the list of tasks. This allows the - * tasks to be processed by a priority determined by @func, and not - * just in the order in which they were added to the pool. - * - * Note, if the maximum number of threads is more than 1, the order - * that threads are executed cannot be guaranteed 100%. Threads are - * scheduled by the operating system and are executed at random. It - * cannot be assumed that threads are executed in the order they are - * created. - * - * Since: 2.10 - */ - - -/** - * g_thread_pool_stop_unused_threads: - * - * Stops all currently unused threads. This does not change the - * maximal number of unused threads. This function can be used to - * regularly stop all unused threads e.g. from g_timeout_add(). - */ - - -/** - * g_thread_pool_unprocessed: - * @pool: a #GThreadPool - * - * Returns the number of tasks still unprocessed in @pool. - * - * Returns: the number of unprocessed tasks - */ - - -/** - * g_thread_ref: - * @thread: a #GThread - * - * Increase the reference count on @thread. - * - * Returns: (transfer full): a new reference to @thread - * Since: 2.32 - */ - - -/** - * g_thread_self: - * - * This function returns the #GThread corresponding to the - * current thread. Note that this function does not increase - * the reference count of the returned struct. - * - * This function will return a #GThread even for threads that - * were not created by GLib (i.e. those created by other threading - * APIs). This may be useful for thread identification purposes - * (i.e. comparisons) but you must not use GLib functions (such - * as g_thread_join()) on these threads. - * - * Returns: (transfer none): the #GThread representing the current thread - */ - - -/** - * g_thread_supported: - * - * This macro returns %TRUE if the thread system is initialized, - * and %FALSE if it is not. - * - * For language bindings, g_thread_get_initialized() provides - * the same functionality as a function. - * - * Returns: %TRUE, if the thread system is initialized - */ - - -/** - * g_thread_try_new: - * @name: (nullable): an (optional) name for the new thread - * @func: (closure data) (scope async): a function to execute in the new thread - * @data: (nullable): an argument to supply to the new thread - * @error: return location for error, or %NULL - * - * This function is the same as g_thread_new() except that - * it allows for the possibility of failure. - * - * If a thread can not be created (due to resource limits), - * @error is set and %NULL is returned. - * - * Returns: (transfer full): the new #GThread, or %NULL if an error occurred - * Since: 2.32 - */ - - -/** - * g_thread_unref: - * @thread: (transfer full): a #GThread - * - * Decrease the reference count on @thread, possibly freeing all - * resources associated with it. - * - * Note that each thread holds a reference to its #GThread while - * it is running, so it is safe to drop your own reference to it - * if you don't need it anymore. - * - * Since: 2.32 - */ - - -/** - * g_thread_yield: - * - * Causes the calling thread to voluntarily relinquish the CPU, so - * that other threads can run. - * - * This function is often used as a method to make busy wait less evil. - */ - - -/** - * g_time_val_add: - * @time_: a #GTimeVal - * @microseconds: number of microseconds to add to @time - * - * Adds the given number of microseconds to @time_. @microseconds can - * also be negative to decrease the value of @time_. - * - * Deprecated: 2.62: #GTimeVal is not year-2038-safe. Use `guint64` for - * representing microseconds since the epoch, or use #GDateTime. - */ - - -/** - * g_time_val_from_iso8601: - * @iso_date: an ISO 8601 encoded date string - * @time_: (out): a #GTimeVal - * - * Converts a string containing an ISO 8601 encoded date and time - * to a #GTimeVal and puts it into @time_. - * - * @iso_date must include year, month, day, hours, minutes, and - * seconds. It can optionally include fractions of a second and a time - * zone indicator. (In the absence of any time zone indication, the - * timestamp is assumed to be in local time.) - * - * Any leading or trailing space in @iso_date is ignored. - * - * This function was deprecated, along with #GTimeVal itself, in GLib 2.62. - * Equivalent functionality is available using code like: - * |[ - * GDateTime *dt = g_date_time_new_from_iso8601 (iso8601_string, NULL); - * gint64 time_val = g_date_time_to_unix (dt); - * g_date_time_unref (dt); - * ]| - * - * Returns: %TRUE if the conversion was successful. - * Since: 2.12 - * Deprecated: 2.62: #GTimeVal is not year-2038-safe. Use - * g_date_time_new_from_iso8601() instead. - */ - - -/** - * g_time_val_to_iso8601: - * @time_: a #GTimeVal - * - * Converts @time_ into an RFC 3339 encoded string, relative to the - * Coordinated Universal Time (UTC). This is one of the many formats - * allowed by ISO 8601. - * - * ISO 8601 allows a large number of date/time formats, with or without - * punctuation and optional elements. The format returned by this function - * is a complete date and time, with optional punctuation included, the - * UTC time zone represented as "Z", and the @tv_usec part included if - * and only if it is nonzero, i.e. either - * "YYYY-MM-DDTHH:MM:SSZ" or "YYYY-MM-DDTHH:MM:SS.fffffZ". - * - * This corresponds to the Internet date/time format defined by - * [RFC 3339](https://www.ietf.org/rfc/rfc3339.txt), - * and to either of the two most-precise formats defined by - * the W3C Note - * [Date and Time Formats](http://www.w3.org/TR/NOTE-datetime-19980827). - * Both of these documents are profiles of ISO 8601. - * - * Use g_date_time_format() or g_strdup_printf() if a different - * variation of ISO 8601 format is required. - * - * If @time_ represents a date which is too large to fit into a `struct tm`, - * %NULL will be returned. This is platform dependent. Note also that since - * `GTimeVal` stores the number of seconds as a `glong`, on 32-bit systems it - * is subject to the year 2038 problem. Accordingly, since GLib 2.62, this - * function has been deprecated. Equivalent functionality is available using: - * |[ - * GDateTime *dt = g_date_time_new_from_unix_utc (time_val); - * iso8601_string = g_date_time_format_iso8601 (dt); - * g_date_time_unref (dt); - * ]| - * - * The return value of g_time_val_to_iso8601() has been nullable since GLib - * 2.54; before then, GLib would crash under the same conditions. - * - * Returns: (nullable): a newly allocated string containing an ISO 8601 date, - * or %NULL if @time_ was too large - * Since: 2.12 - * Deprecated: 2.62: #GTimeVal is not year-2038-safe. Use - * g_date_time_format_iso8601(dt) instead. - */ - - -/** - * g_time_zone_adjust_time: - * @tz: a #GTimeZone - * @type: the #GTimeType of @time_ - * @time_: a pointer to a number of seconds since January 1, 1970 - * - * Finds an interval within @tz that corresponds to the given @time_, - * possibly adjusting @time_ if required to fit into an interval. - * The meaning of @time_ depends on @type. - * - * This function is similar to g_time_zone_find_interval(), with the - * difference that it always succeeds (by making the adjustments - * described below). - * - * In any of the cases where g_time_zone_find_interval() succeeds then - * this function returns the same value, without modifying @time_. - * - * This function may, however, modify @time_ in order to deal with - * non-existent times. If the non-existent local @time_ of 02:30 were - * requested on March 14th 2010 in Toronto then this function would - * adjust @time_ to be 03:00 and return the interval containing the - * adjusted time. - * - * Returns: the interval containing @time_, never -1 - * Since: 2.26 - */ - - -/** - * g_time_zone_find_interval: - * @tz: a #GTimeZone - * @type: the #GTimeType of @time_ - * @time_: a number of seconds since January 1, 1970 - * - * Finds an interval within @tz that corresponds to the given @time_. - * The meaning of @time_ depends on @type. - * - * If @type is %G_TIME_TYPE_UNIVERSAL then this function will always - * succeed (since universal time is monotonic and continuous). - * - * Otherwise @time_ is treated as local time. The distinction between - * %G_TIME_TYPE_STANDARD and %G_TIME_TYPE_DAYLIGHT is ignored except in - * the case that the given @time_ is ambiguous. In Toronto, for example, - * 01:30 on November 7th 2010 occurred twice (once inside of daylight - * savings time and the next, an hour later, outside of daylight savings - * time). In this case, the different value of @type would result in a - * different interval being returned. - * - * It is still possible for this function to fail. In Toronto, for - * example, 02:00 on March 14th 2010 does not exist (due to the leap - * forward to begin daylight savings time). -1 is returned in that - * case. - * - * Returns: the interval containing @time_, or -1 in case of failure - * Since: 2.26 - */ - - -/** - * g_time_zone_get_abbreviation: - * @tz: a #GTimeZone - * @interval: an interval within the timezone - * - * Determines the time zone abbreviation to be used during a particular - * @interval of time in the time zone @tz. - * - * For example, in Toronto this is currently "EST" during the winter - * months and "EDT" during the summer months when daylight savings time - * is in effect. - * - * Returns: the time zone abbreviation, which belongs to @tz - * Since: 2.26 - */ - - -/** - * g_time_zone_get_identifier: - * @tz: a #GTimeZone - * - * Get the identifier of this #GTimeZone, as passed to g_time_zone_new(). - * If the identifier passed at construction time was not recognised, `UTC` will - * be returned. If it was %NULL, the identifier of the local timezone at - * construction time will be returned. - * - * The identifier will be returned in the same format as provided at - * construction time: if provided as a time offset, that will be returned by - * this function. - * - * Returns: identifier for this timezone - * Since: 2.58 - */ - - -/** - * g_time_zone_get_offset: - * @tz: a #GTimeZone - * @interval: an interval within the timezone - * - * Determines the offset to UTC in effect during a particular @interval - * of time in the time zone @tz. - * - * The offset is the number of seconds that you add to UTC time to - * arrive at local time for @tz (ie: negative numbers for time zones - * west of GMT, positive numbers for east). - * - * Returns: the number of seconds that should be added to UTC to get the - * local time in @tz - * Since: 2.26 - */ - - -/** - * g_time_zone_is_dst: - * @tz: a #GTimeZone - * @interval: an interval within the timezone - * - * Determines if daylight savings time is in effect during a particular - * @interval of time in the time zone @tz. - * - * Returns: %TRUE if daylight savings time is in effect - * Since: 2.26 - */ - - -/** - * g_time_zone_new: - * @identifier: (nullable): a timezone identifier - * - * A version of g_time_zone_new_identifier() which returns the UTC time zone - * if @identifier could not be parsed or loaded. - * - * If you need to check whether @identifier was loaded successfully, use - * g_time_zone_new_identifier(). - * - * Returns: (transfer full) (not nullable): the requested timezone - * Deprecated: 2.68: Use g_time_zone_new_identifier() instead, as it provides - * error reporting. Change your code to handle a potentially %NULL return - * value. - * Since: 2.26 - */ - - -/** - * g_time_zone_new_identifier: - * @identifier: (nullable): a timezone identifier - * - * Creates a #GTimeZone corresponding to @identifier. If @identifier cannot be - * parsed or loaded, %NULL is returned. - * - * @identifier can either be an RFC3339/ISO 8601 time offset or - * something that would pass as a valid value for the `TZ` environment - * variable (including %NULL). - * - * In Windows, @identifier can also be the unlocalized name of a time - * zone for standard time, for example "Pacific Standard Time". - * - * Valid RFC3339 time offsets are `"Z"` (for UTC) or - * `"±hh:mm"`. ISO 8601 additionally specifies - * `"±hhmm"` and `"±hh"`. Offsets are - * time values to be added to Coordinated Universal Time (UTC) to get - * the local time. - * - * In UNIX, the `TZ` environment variable typically corresponds - * to the name of a file in the zoneinfo database, an absolute path to a file - * somewhere else, or a string in - * "std offset [dst [offset],start[/time],end[/time]]" (POSIX) format. - * There are no spaces in the specification. The name of standard - * and daylight savings time zone must be three or more alphabetic - * characters. Offsets are time values to be added to local time to - * get Coordinated Universal Time (UTC) and should be - * `"[±]hh[[:]mm[:ss]]"`. Dates are either - * `"Jn"` (Julian day with n between 1 and 365, leap - * years not counted), `"n"` (zero-based Julian day - * with n between 0 and 365) or `"Mm.w.d"` (day d - * (0 <= d <= 6) of week w (1 <= w <= 5) of month m (1 <= m <= 12), day - * 0 is a Sunday). Times are in local wall clock time, the default is - * 02:00:00. - * - * In Windows, the "tzn[+|–]hh[:mm[:ss]][dzn]" format is used, but also - * accepts POSIX format. The Windows format uses US rules for all time - * zones; daylight savings time is 60 minutes behind the standard time - * with date and time of change taken from Pacific Standard Time. - * Offsets are time values to be added to the local time to get - * Coordinated Universal Time (UTC). - * - * g_time_zone_new_local() calls this function with the value of the - * `TZ` environment variable. This function itself is independent of - * the value of `TZ`, but if @identifier is %NULL then `/etc/localtime` - * will be consulted to discover the correct time zone on UNIX and the - * registry will be consulted or GetTimeZoneInformation() will be used - * to get the local time zone on Windows. - * - * If intervals are not available, only time zone rules from `TZ` - * environment variable or other means, then they will be computed - * from year 1900 to 2037. If the maximum year for the rules is - * available and it is greater than 2037, then it will followed - * instead. - * - * See - * [RFC3339 §5.6](http://tools.ietf.org/html/rfc3339#section-5.6) - * for a precise definition of valid RFC3339 time offsets - * (the `time-offset` expansion) and ISO 8601 for the - * full list of valid time offsets. See - * [The GNU C Library manual](http://www.gnu.org/s/libc/manual/html_node/TZ-Variable.html) - * for an explanation of the possible - * values of the `TZ` environment variable. See - * [Microsoft Time Zone Index Values](http://msdn.microsoft.com/en-us/library/ms912391%28v=winembedded.11%29.aspx) - * for the list of time zones on Windows. - * - * You should release the return value by calling g_time_zone_unref() - * when you are done with it. - * - * Returns: (transfer full) (nullable): the requested timezone, or %NULL on - * failure - * Since: 2.68 - */ - - -/** - * g_time_zone_new_local: - * - * Creates a #GTimeZone corresponding to local time. The local time - * zone may change between invocations to this function; for example, - * if the system administrator changes it. - * - * This is equivalent to calling g_time_zone_new() with the value of - * the `TZ` environment variable (including the possibility of %NULL). - * - * You should release the return value by calling g_time_zone_unref() - * when you are done with it. - * - * Returns: the local timezone - * Since: 2.26 - */ - - -/** - * g_time_zone_new_offset: - * @seconds: offset to UTC, in seconds - * - * Creates a #GTimeZone corresponding to the given constant offset from UTC, - * in seconds. - * - * This is equivalent to calling g_time_zone_new() with a string in the form - * `[+|-]hh[:mm[:ss]]`. - * - * Returns: (transfer full): a timezone at the given offset from UTC - * Since: 2.58 - */ - - -/** - * g_time_zone_new_utc: - * - * Creates a #GTimeZone corresponding to UTC. - * - * This is equivalent to calling g_time_zone_new() with a value like - * "Z", "UTC", "+00", etc. - * - * You should release the return value by calling g_time_zone_unref() - * when you are done with it. - * - * Returns: the universal timezone - * Since: 2.26 - */ - - -/** - * g_time_zone_ref: - * @tz: a #GTimeZone - * - * Increases the reference count on @tz. - * - * Returns: a new reference to @tz. - * Since: 2.26 - */ - - -/** - * g_time_zone_unref: - * @tz: a #GTimeZone - * - * Decreases the reference count on @tz. - * - * Since: 2.26 - */ - - -/** - * g_timeout_add: - * @interval: the time between calls to the function, in milliseconds - * (1/1000ths of a second) - * @function: function to call - * @data: data to pass to @function - * - * Sets a function to be called at regular intervals, with the default - * priority, %G_PRIORITY_DEFAULT. - * - * The given @function is called repeatedly until it returns %G_SOURCE_REMOVE - * or %FALSE, at which point the timeout is automatically destroyed and the - * function will not be called again. The first call to the function will be - * at the end of the first @interval. - * - * Note that timeout functions may be delayed, due to the processing of other - * event sources. Thus they should not be relied on for precise timing. - * After each call to the timeout function, the time of the next - * timeout is recalculated based on the current time and the given interval - * (it does not try to 'catch up' time lost in delays). - * - * See [memory management of sources][mainloop-memory-management] for details - * on how to handle the return value and memory management of @data. - * - * If you want to have a timer in the "seconds" range and do not care - * about the exact time of the first call of the timer, use the - * g_timeout_add_seconds() function; this function allows for more - * optimizations and more efficient system power usage. - * - * This internally creates a main loop source using g_timeout_source_new() - * and attaches it to the global #GMainContext using g_source_attach(), so - * the callback will be invoked in whichever thread is running that main - * context. You can do these steps manually if you need greater control or to - * use a custom main context. - * - * It is safe to call this function from any thread. - * - * The interval given is in terms of monotonic time, not wall clock - * time. See g_get_monotonic_time(). - * - * Returns: the ID (greater than 0) of the event source. - */ - - -/** - * g_timeout_add_full: (rename-to g_timeout_add) - * @priority: the priority of the timeout source. Typically this will be in - * the range between %G_PRIORITY_DEFAULT and %G_PRIORITY_HIGH. - * @interval: the time between calls to the function, in milliseconds - * (1/1000ths of a second) - * @function: function to call - * @data: data to pass to @function - * @notify: (nullable): function to call when the timeout is removed, or %NULL - * - * Sets a function to be called at regular intervals, with the given - * priority. The function is called repeatedly until it returns - * %FALSE, at which point the timeout is automatically destroyed and - * the function will not be called again. The @notify function is - * called when the timeout is destroyed. The first call to the - * function will be at the end of the first @interval. - * - * Note that timeout functions may be delayed, due to the processing of other - * event sources. Thus they should not be relied on for precise timing. - * After each call to the timeout function, the time of the next - * timeout is recalculated based on the current time and the given interval - * (it does not try to 'catch up' time lost in delays). - * - * See [memory management of sources][mainloop-memory-management] for details - * on how to handle the return value and memory management of @data. - * - * This internally creates a main loop source using g_timeout_source_new() - * and attaches it to the global #GMainContext using g_source_attach(), so - * the callback will be invoked in whichever thread is running that main - * context. You can do these steps manually if you need greater control or to - * use a custom main context. - * - * The interval given is in terms of monotonic time, not wall clock time. - * See g_get_monotonic_time(). - * - * Returns: the ID (greater than 0) of the event source. - */ - - -/** - * g_timeout_add_seconds: - * @interval: the time between calls to the function, in seconds - * @function: function to call - * @data: data to pass to @function - * - * Sets a function to be called at regular intervals with the default - * priority, %G_PRIORITY_DEFAULT. - * - * The function is called repeatedly until it returns %G_SOURCE_REMOVE - * or %FALSE, at which point the timeout is automatically destroyed - * and the function will not be called again. - * - * This internally creates a main loop source using - * g_timeout_source_new_seconds() and attaches it to the main loop context - * using g_source_attach(). You can do these steps manually if you need - * greater control. Also see g_timeout_add_seconds_full(). - * - * It is safe to call this function from any thread. - * - * Note that the first call of the timer may not be precise for timeouts - * of one second. If you need finer precision and have such a timeout, - * you may want to use g_timeout_add() instead. - * - * See [memory management of sources][mainloop-memory-management] for details - * on how to handle the return value and memory management of @data. - * - * The interval given is in terms of monotonic time, not wall clock - * time. See g_get_monotonic_time(). - * - * Returns: the ID (greater than 0) of the event source. - * Since: 2.14 - */ - - -/** - * g_timeout_add_seconds_full: (rename-to g_timeout_add_seconds) - * @priority: the priority of the timeout source. Typically this will be in - * the range between %G_PRIORITY_DEFAULT and %G_PRIORITY_HIGH. - * @interval: the time between calls to the function, in seconds - * @function: function to call - * @data: data to pass to @function - * @notify: (nullable): function to call when the timeout is removed, or %NULL - * - * Sets a function to be called at regular intervals, with @priority. - * - * The function is called repeatedly until it returns %G_SOURCE_REMOVE - * or %FALSE, at which point the timeout is automatically destroyed and - * the function will not be called again. - * - * Unlike g_timeout_add(), this function operates at whole second granularity. - * The initial starting point of the timer is determined by the implementation - * and the implementation is expected to group multiple timers together so that - * they fire all at the same time. To allow this grouping, the @interval to the - * first timer is rounded and can deviate up to one second from the specified - * interval. Subsequent timer iterations will generally run at the specified - * interval. - * - * Note that timeout functions may be delayed, due to the processing of other - * event sources. Thus they should not be relied on for precise timing. - * After each call to the timeout function, the time of the next - * timeout is recalculated based on the current time and the given @interval - * - * See [memory management of sources][mainloop-memory-management] for details - * on how to handle the return value and memory management of @data. - * - * If you want timing more precise than whole seconds, use g_timeout_add() - * instead. - * - * The grouping of timers to fire at the same time results in a more power - * and CPU efficient behavior so if your timer is in multiples of seconds - * and you don't require the first timer exactly one second from now, the - * use of g_timeout_add_seconds() is preferred over g_timeout_add(). - * - * This internally creates a main loop source using - * g_timeout_source_new_seconds() and attaches it to the main loop context - * using g_source_attach(). You can do these steps manually if you need - * greater control. - * - * It is safe to call this function from any thread. - * - * The interval given is in terms of monotonic time, not wall clock - * time. See g_get_monotonic_time(). - * - * Returns: the ID (greater than 0) of the event source. - * Since: 2.14 - */ - - -/** - * g_timeout_source_new: - * @interval: the timeout interval in milliseconds. - * - * Creates a new timeout source. - * - * The source will not initially be associated with any #GMainContext - * and must be added to one with g_source_attach() before it will be - * executed. - * - * The interval given is in terms of monotonic time, not wall clock - * time. See g_get_monotonic_time(). - * - * Returns: the newly-created timeout source - */ - - -/** - * g_timeout_source_new_seconds: - * @interval: the timeout interval in seconds - * - * Creates a new timeout source. - * - * The source will not initially be associated with any #GMainContext - * and must be added to one with g_source_attach() before it will be - * executed. - * - * The scheduling granularity/accuracy of this timeout source will be - * in seconds. - * - * The interval given is in terms of monotonic time, not wall clock time. - * See g_get_monotonic_time(). - * - * Returns: the newly-created timeout source - * Since: 2.14 - */ - - -/** - * g_timer_continue: - * @timer: a #GTimer. - * - * Resumes a timer that has previously been stopped with - * g_timer_stop(). g_timer_stop() must be called before using this - * function. - * - * Since: 2.4 - */ - - -/** - * g_timer_destroy: - * @timer: a #GTimer to destroy. - * - * Destroys a timer, freeing associated resources. - */ - - -/** - * g_timer_elapsed: - * @timer: a #GTimer. - * @microseconds: return location for the fractional part of seconds - * elapsed, in microseconds (that is, the total number - * of microseconds elapsed, modulo 1000000), or %NULL - * - * If @timer has been started but not stopped, obtains the time since - * the timer was started. If @timer has been stopped, obtains the - * elapsed time between the time it was started and the time it was - * stopped. The return value is the number of seconds elapsed, - * including any fractional part. The @microseconds out parameter is - * essentially useless. - * - * Returns: seconds elapsed as a floating point value, including any - * fractional part. - */ - - -/** - * g_timer_is_active: - * @timer: a #GTimer. - * - * Exposes whether the timer is currently active. - * - * Returns: %TRUE if the timer is running, %FALSE otherwise - * Since: 2.62 - */ - - -/** - * g_timer_new: - * - * Creates a new timer, and starts timing (i.e. g_timer_start() is - * implicitly called for you). - * - * Returns: a new #GTimer. - */ - - -/** - * g_timer_reset: - * @timer: a #GTimer. - * - * This function is useless; it's fine to call g_timer_start() on an - * already-started timer to reset the start time, so g_timer_reset() - * serves no purpose. - */ - - -/** - * g_timer_start: - * @timer: a #GTimer. - * - * Marks a start time, so that future calls to g_timer_elapsed() will - * report the time since g_timer_start() was called. g_timer_new() - * automatically marks the start time, so no need to call - * g_timer_start() immediately after creating the timer. - */ - - -/** - * g_timer_stop: - * @timer: a #GTimer. - * - * Marks an end time, so calls to g_timer_elapsed() will return the - * difference between this end time and the start time. - */ - - -/** - * g_trash_stack_height: - * @stack_p: a #GTrashStack - * - * Returns the height of a #GTrashStack. - * - * Note that execution of this function is of O(N) complexity - * where N denotes the number of items on the stack. - * - * Returns: the height of the stack - * Deprecated: 2.48: #GTrashStack is deprecated without replacement - */ - - -/** - * g_trash_stack_peek: - * @stack_p: a #GTrashStack - * - * Returns the element at the top of a #GTrashStack - * which may be %NULL. - * - * Returns: the element at the top of the stack - * Deprecated: 2.48: #GTrashStack is deprecated without replacement - */ - - -/** - * g_trash_stack_pop: - * @stack_p: a #GTrashStack - * - * Pops a piece of memory off a #GTrashStack. - * - * Returns: the element at the top of the stack - * Deprecated: 2.48: #GTrashStack is deprecated without replacement - */ - - -/** - * g_trash_stack_push: - * @stack_p: a #GTrashStack - * @data_p: (not nullable): the piece of memory to push on the stack - * - * Pushes a piece of memory onto a #GTrashStack. - * - * Deprecated: 2.48: #GTrashStack is deprecated without replacement - */ - - -/** - * g_tree_destroy: - * @tree: a #GTree - * - * Removes all keys and values from the #GTree and decreases its - * reference count by one. If keys and/or values are dynamically - * allocated, you should either free them first or create the #GTree - * using g_tree_new_full(). In the latter case the destroy functions - * you supplied will be called on all keys and values before destroying - * the #GTree. - */ - - -/** - * g_tree_foreach: - * @tree: a #GTree - * @func: the function to call for each node visited. - * If this function returns %TRUE, the traversal is stopped. - * @user_data: user data to pass to the function - * - * Calls the given function for each of the key/value pairs in the #GTree. - * The function is passed the key and value of each pair, and the given - * @data parameter. The tree is traversed in sorted order. - * - * The tree may not be modified while iterating over it (you can't - * add/remove items). To remove all items matching a predicate, you need - * to add each item to a list in your #GTraverseFunc as you walk over - * the tree, then walk the list and remove each item. - */ - - -/** - * g_tree_foreach_node: - * @tree: a #GTree - * @func: the function to call for each node visited. - * If this function returns %TRUE, the traversal is stopped. - * @user_data: user data to pass to the function - * - * Calls the given function for each of the nodes in the #GTree. - * The function is passed the pointer to the particular node, and the given - * @data parameter. The tree traversal happens in-order. - * - * The tree may not be modified while iterating over it (you can't - * add/remove items). To remove all items matching a predicate, you need - * to add each item to a list in your #GTraverseFunc as you walk over - * the tree, then walk the list and remove each item. - * - * Since: 2.68 - */ - - -/** - * g_tree_height: - * @tree: a #GTree - * - * Gets the height of a #GTree. - * - * If the #GTree contains no nodes, the height is 0. - * If the #GTree contains only one root node the height is 1. - * If the root node has children the height is 2, etc. - * - * Returns: the height of @tree - */ - - -/** - * g_tree_insert: - * @tree: a #GTree - * @key: the key to insert - * @value: the value corresponding to the key - * - * Inserts a key/value pair into a #GTree. - * - * Inserts a new key and value into a #GTree as g_tree_insert_node() does, - * only this function does not return the inserted or set node. - */ - - -/** - * g_tree_insert_node: - * @tree: a #GTree - * @key: the key to insert - * @value: the value corresponding to the key - * - * Inserts a key/value pair into a #GTree. - * - * If the given key already exists in the #GTree its corresponding value - * is set to the new value. If you supplied a @value_destroy_func when - * creating the #GTree, the old value is freed using that function. If - * you supplied a @key_destroy_func when creating the #GTree, the passed - * key is freed using that function. - * - * The tree is automatically 'balanced' as new key/value pairs are added, - * so that the distance from the root to every leaf is as small as possible. - * The cost of maintaining a balanced tree while inserting new key/value - * result in a O(n log(n)) operation where most of the other operations - * are O(log(n)). - * - * Returns: (transfer none): the inserted (or set) node. - * Since: 2.68 - */ - - -/** - * g_tree_lookup: - * @tree: a #GTree - * @key: the key to look up - * - * Gets the value corresponding to the given key. Since a #GTree is - * automatically balanced as key/value pairs are added, key lookup - * is O(log n) (where n is the number of key/value pairs in the tree). - * - * Returns: the value corresponding to the key, or %NULL - * if the key was not found - */ - - -/** - * g_tree_lookup_extended: - * @tree: a #GTree - * @lookup_key: the key to look up - * @orig_key: (out) (optional) (nullable): returns the original key - * @value: (out) (optional) (nullable): returns the value associated with the key - * - * Looks up a key in the #GTree, returning the original key and the - * associated value. This is useful if you need to free the memory - * allocated for the original key, for example before calling - * g_tree_remove(). - * - * Returns: %TRUE if the key was found in the #GTree - */ - - -/** - * g_tree_lookup_node: - * @tree: a #GTree - * @key: the key to look up - * - * Gets the tree node corresponding to the given key. Since a #GTree is - * automatically balanced as key/value pairs are added, key lookup - * is O(log n) (where n is the number of key/value pairs in the tree). - * - * Returns: (nullable) (transfer none): the tree node corresponding to - * the key, or %NULL if the key was not found - * Since: 2.68 - */ - - -/** - * g_tree_lower_bound: - * @tree: a #GTree - * @key: the key to calculate the lower bound for - * - * Gets the lower bound node corresponding to the given key, - * or %NULL if the tree is empty or all the nodes in the tree - * have keys that are strictly lower than the searched key. - * - * The lower bound is the first node that has its key greater - * than or equal to the searched key. - * - * Returns: (nullable) (transfer none): the tree node corresponding to - * the lower bound, or %NULL if the tree is empty or has only - * keys strictly lower than the searched key. - * Since: 2.68 - */ - - -/** - * g_tree_new: - * @key_compare_func: the function used to order the nodes in the #GTree. - * It should return values similar to the standard strcmp() function - - * 0 if the two arguments are equal, a negative value if the first argument - * comes before the second, or a positive value if the first argument comes - * after the second. - * - * Creates a new #GTree. - * - * Returns: a newly allocated #GTree - */ - - -/** - * g_tree_new_full: - * @key_compare_func: qsort()-style comparison function - * @key_compare_data: data to pass to comparison function - * @key_destroy_func: a function to free the memory allocated for the key - * used when removing the entry from the #GTree or %NULL if you don't - * want to supply such a function - * @value_destroy_func: a function to free the memory allocated for the - * value used when removing the entry from the #GTree or %NULL if you - * don't want to supply such a function - * - * Creates a new #GTree like g_tree_new() and allows to specify functions - * to free the memory allocated for the key and value that get called when - * removing the entry from the #GTree. - * - * Returns: a newly allocated #GTree - */ - - -/** - * g_tree_new_with_data: - * @key_compare_func: qsort()-style comparison function - * @key_compare_data: data to pass to comparison function - * - * Creates a new #GTree with a comparison function that accepts user data. - * See g_tree_new() for more details. - * - * Returns: a newly allocated #GTree - */ - - -/** - * g_tree_nnodes: - * @tree: a #GTree - * - * Gets the number of nodes in a #GTree. - * - * Returns: the number of nodes in @tree - */ - - -/** - * g_tree_node_first: - * @tree: a #GTree - * - * Returns the first in-order node of the tree, or %NULL - * for an empty tree. - * - * Returns: (nullable) (transfer none): the first node in the tree - * Since: 2.68 - */ - - -/** - * g_tree_node_key: - * @node: a #GTree node - * - * Gets the key stored at a particular tree node. - * - * Returns: (nullable) (transfer none): the key at the node. - * Since: 2.68 - */ - - -/** - * g_tree_node_last: - * @tree: a #GTree - * - * Returns the last in-order node of the tree, or %NULL - * for an empty tree. - * - * Returns: (nullable) (transfer none): the last node in the tree - * Since: 2.68 - */ - - -/** - * g_tree_node_next: - * @node: a #GTree node - * - * Returns the next in-order node of the tree, or %NULL - * if the passed node was already the last one. - * - * Returns: (nullable) (transfer none): the next node in the tree - * Since: 2.68 - */ - - -/** - * g_tree_node_previous: - * @node: a #GTree node - * - * Returns the previous in-order node of the tree, or %NULL - * if the passed node was already the first one. - * - * Returns: (nullable) (transfer none): the previous node in the tree - * Since: 2.68 - */ - - -/** - * g_tree_node_value: - * @node: a #GTree node - * - * Gets the value stored at a particular tree node. - * - * Returns: (nullable) (transfer none): the value at the node. - * Since: 2.68 - */ - - -/** - * g_tree_ref: - * @tree: a #GTree - * - * Increments the reference count of @tree by one. - * - * It is safe to call this function from any thread. - * - * Returns: the passed in #GTree - * Since: 2.22 - */ - - -/** - * g_tree_remove: - * @tree: a #GTree - * @key: the key to remove - * - * Removes a key/value pair from a #GTree. - * - * If the #GTree was created using g_tree_new_full(), the key and value - * are freed using the supplied destroy functions, otherwise you have to - * make sure that any dynamically allocated values are freed yourself. - * If the key does not exist in the #GTree, the function does nothing. - * - * The cost of maintaining a balanced tree while removing a key/value - * result in a O(n log(n)) operation where most of the other operations - * are O(log(n)). - * - * Returns: %TRUE if the key was found (prior to 2.8, this function - * returned nothing) - */ - - -/** - * g_tree_remove_all: - * @tree: a #GTree - * - * Removes all nodes from a #GTree and destroys their keys and values, - * then resets the #GTree’s root to %NULL. - * - * Since: 2.70 - */ - - -/** - * g_tree_replace: - * @tree: a #GTree - * @key: the key to insert - * @value: the value corresponding to the key - * - * Inserts a new key and value into a #GTree as g_tree_replace_node() does, - * only this function does not return the inserted or set node. - */ - - -/** - * g_tree_replace_node: - * @tree: a #GTree - * @key: the key to insert - * @value: the value corresponding to the key - * - * Inserts a new key and value into a #GTree similar to g_tree_insert_node(). - * The difference is that if the key already exists in the #GTree, it gets - * replaced by the new key. If you supplied a @value_destroy_func when - * creating the #GTree, the old value is freed using that function. If you - * supplied a @key_destroy_func when creating the #GTree, the old key is - * freed using that function. - * - * The tree is automatically 'balanced' as new key/value pairs are added, - * so that the distance from the root to every leaf is as small as possible. - * - * Returns: (transfer none): the inserted (or set) node. - * Since: 2.68 - */ - - -/** - * g_tree_search: - * @tree: a #GTree - * @search_func: a function used to search the #GTree - * @user_data: the data passed as the second argument to @search_func - * - * Searches a #GTree using @search_func. - * - * The @search_func is called with a pointer to the key of a key/value - * pair in the tree, and the passed in @user_data. If @search_func returns - * 0 for a key/value pair, then the corresponding value is returned as - * the result of g_tree_search(). If @search_func returns -1, searching - * will proceed among the key/value pairs that have a smaller key; if - * @search_func returns 1, searching will proceed among the key/value - * pairs that have a larger key. - * - * Returns: the value corresponding to the found key, or %NULL - * if the key was not found - */ - - -/** - * g_tree_search_node: - * @tree: a #GTree - * @search_func: a function used to search the #GTree - * @user_data: the data passed as the second argument to @search_func - * - * Searches a #GTree using @search_func. - * - * The @search_func is called with a pointer to the key of a key/value - * pair in the tree, and the passed in @user_data. If @search_func returns - * 0 for a key/value pair, then the corresponding node is returned as - * the result of g_tree_search(). If @search_func returns -1, searching - * will proceed among the key/value pairs that have a smaller key; if - * @search_func returns 1, searching will proceed among the key/value - * pairs that have a larger key. - * - * Returns: (nullable) (transfer none): the node corresponding to the - * found key, or %NULL if the key was not found - * Since: 2.68 - */ - - -/** - * g_tree_steal: - * @tree: a #GTree - * @key: the key to remove - * - * Removes a key and its associated value from a #GTree without calling - * the key and value destroy functions. - * - * If the key does not exist in the #GTree, the function does nothing. - * - * Returns: %TRUE if the key was found (prior to 2.8, this function - * returned nothing) - */ - - -/** - * g_tree_traverse: - * @tree: a #GTree - * @traverse_func: the function to call for each node visited. If this - * function returns %TRUE, the traversal is stopped. - * @traverse_type: the order in which nodes are visited, one of %G_IN_ORDER, - * %G_PRE_ORDER and %G_POST_ORDER - * @user_data: user data to pass to the function - * - * Calls the given function for each node in the #GTree. - * - * Deprecated: 2.2: The order of a balanced tree is somewhat arbitrary. - * If you just want to visit all nodes in sorted order, use - * g_tree_foreach() instead. If you really need to visit nodes in - * a different order, consider using an [n-ary tree][glib-N-ary-Trees]. - */ - - -/** - * g_tree_unref: - * @tree: a #GTree - * - * Decrements the reference count of @tree by one. - * If the reference count drops to 0, all keys and values will - * be destroyed (if destroy functions were specified) and all - * memory allocated by @tree will be released. - * - * It is safe to call this function from any thread. - * - * Since: 2.22 - */ - - -/** - * g_tree_upper_bound: - * @tree: a #GTree - * @key: the key to calculate the upper bound for - * - * Gets the upper bound node corresponding to the given key, - * or %NULL if the tree is empty or all the nodes in the tree - * have keys that are lower than or equal to the searched key. - * - * The upper bound is the first node that has its key strictly greater - * than the searched key. - * - * Returns: (nullable) (transfer none): the tree node corresponding to the - * upper bound, or %NULL if the tree is empty or has only keys - * lower than or equal to the searched key. - * Since: 2.68 - */ - - -/** - * g_try_malloc: - * @n_bytes: number of bytes to allocate. - * - * Attempts to allocate @n_bytes, and returns %NULL on failure. - * Contrast with g_malloc(), which aborts the program on failure. - * - * Returns: the allocated memory, or %NULL. - */ - - -/** - * g_try_malloc0: - * @n_bytes: number of bytes to allocate - * - * Attempts to allocate @n_bytes, initialized to 0's, and returns %NULL on - * failure. Contrast with g_malloc0(), which aborts the program on failure. - * - * Since: 2.8 - * Returns: the allocated memory, or %NULL - */ - - -/** - * g_try_malloc0_n: - * @n_blocks: the number of blocks to allocate - * @n_block_bytes: the size of each block in bytes - * - * This function is similar to g_try_malloc0(), allocating (@n_blocks * @n_block_bytes) bytes, - * but care is taken to detect possible overflow during multiplication. - * - * Since: 2.24 - * Returns: the allocated memory, or %NULL - */ - - -/** - * g_try_malloc_n: - * @n_blocks: the number of blocks to allocate - * @n_block_bytes: the size of each block in bytes - * - * This function is similar to g_try_malloc(), allocating (@n_blocks * @n_block_bytes) bytes, - * but care is taken to detect possible overflow during multiplication. - * - * Since: 2.24 - * Returns: the allocated memory, or %NULL. - */ - - -/** - * g_try_realloc: - * @mem: (nullable): previously-allocated memory, or %NULL. - * @n_bytes: number of bytes to allocate. - * - * Attempts to realloc @mem to a new size, @n_bytes, and returns %NULL - * on failure. Contrast with g_realloc(), which aborts the program - * on failure. - * - * If @mem is %NULL, behaves the same as g_try_malloc(). - * - * Returns: the allocated memory, or %NULL. - */ - - -/** - * g_try_realloc_n: - * @mem: (nullable): previously-allocated memory, or %NULL. - * @n_blocks: the number of blocks to allocate - * @n_block_bytes: the size of each block in bytes - * - * This function is similar to g_try_realloc(), allocating (@n_blocks * @n_block_bytes) bytes, - * but care is taken to detect possible overflow during multiplication. - * - * Since: 2.24 - * Returns: the allocated memory, or %NULL. - */ - - -/** - * g_ucs4_to_utf16: - * @str: a UCS-4 encoded string - * @len: the maximum length (number of characters) of @str to use. - * If @len < 0, then the string is nul-terminated. - * @items_read: (out) (optional): location to store number of - * bytes read, or %NULL. If an error occurs then the index of the invalid - * input is stored here. - * @items_written: (out) (optional): location to store number - * of #gunichar2 written, or %NULL. The value stored here does not include - * the trailing 0. - * @error: location to store the error occurring, or %NULL to ignore - * errors. Any of the errors in #GConvertError other than - * %G_CONVERT_ERROR_NO_CONVERSION may occur. - * - * Convert a string from UCS-4 to UTF-16. A 0 character will be - * added to the result after the converted text. - * - * Returns: (transfer full): a pointer to a newly allocated UTF-16 string. - * This value must be freed with g_free(). If an error occurs, - * %NULL will be returned and @error set. - */ - - -/** - * g_ucs4_to_utf8: - * @str: a UCS-4 encoded string - * @len: the maximum length (number of characters) of @str to use. - * If @len < 0, then the string is nul-terminated. - * @items_read: (out) (optional): location to store number of - * characters read, or %NULL. - * @items_written: (out) (optional): location to store number - * of bytes written or %NULL. The value here stored does not include the - * trailing 0 byte. - * @error: location to store the error occurring, or %NULL to ignore - * errors. Any of the errors in #GConvertError other than - * %G_CONVERT_ERROR_NO_CONVERSION may occur. - * - * Convert a string from a 32-bit fixed width representation as UCS-4. - * to UTF-8. The result will be terminated with a 0 byte. - * - * Returns: (transfer full): a pointer to a newly allocated UTF-8 string. - * This value must be freed with g_free(). If an error occurs, - * %NULL will be returned and @error set. In that case, @items_read - * will be set to the position of the first invalid input character. - */ - - -/** - * g_uint64_checked_add: - * @dest: a pointer to the #guint64 destination - * @a: the #guint64 left operand - * @b: the #guint64 right operand - * - * Performs a checked addition of @a and @b, storing the result in - * @dest. - * - * If the operation is successful, %TRUE is returned. If the operation - * overflows then the state of @dest is undefined and %FALSE is - * returned. - * - * Returns: %TRUE if there was no overflow - * Since: 2.48 - */ - - -/** - * g_uint64_checked_mul: - * @dest: a pointer to the #guint64 destination - * @a: the #guint64 left operand - * @b: the #guint64 right operand - * - * Performs a checked multiplication of @a and @b, storing the result in - * @dest. - * - * If the operation is successful, %TRUE is returned. If the operation - * overflows then the state of @dest is undefined and %FALSE is - * returned. - * - * Returns: %TRUE if there was no overflow - * Since: 2.48 - */ - - -/** - * g_uint_checked_add: - * @dest: a pointer to the #guint destination - * @a: the #guint left operand - * @b: the #guint right operand - * - * Performs a checked addition of @a and @b, storing the result in - * @dest. - * - * If the operation is successful, %TRUE is returned. If the operation - * overflows then the state of @dest is undefined and %FALSE is - * returned. - * - * Returns: %TRUE if there was no overflow - * Since: 2.48 - */ - - -/** - * g_uint_checked_mul: - * @dest: a pointer to the #guint destination - * @a: the #guint left operand - * @b: the #guint right operand - * - * Performs a checked multiplication of @a and @b, storing the result in - * @dest. - * - * If the operation is successful, %TRUE is returned. If the operation - * overflows then the state of @dest is undefined and %FALSE is - * returned. - * - * Returns: %TRUE if there was no overflow - * Since: 2.48 - */ - - -/** - * g_unichar_break_type: - * @c: a Unicode character - * - * Determines the break type of @c. @c should be a Unicode character - * (to derive a character from UTF-8 encoded text, use - * g_utf8_get_char()). The break type is used to find word and line - * breaks ("text boundaries"), Pango implements the Unicode boundary - * resolution algorithms and normally you would use a function such - * as pango_break() instead of caring about break types yourself. - * - * Returns: the break type of @c - */ - - -/** - * g_unichar_combining_class: - * @uc: a Unicode character - * - * Determines the canonical combining class of a Unicode character. - * - * Returns: the combining class of the character - * Since: 2.14 - */ - - -/** - * g_unichar_compose: - * @a: a Unicode character - * @b: a Unicode character - * @ch: (out) (not optional): return location for the composed character - * - * Performs a single composition step of the - * Unicode canonical composition algorithm. - * - * This function includes algorithmic Hangul Jamo composition, - * but it is not exactly the inverse of g_unichar_decompose(). - * No composition can have either of @a or @b equal to zero. - * To be precise, this function composes if and only if - * there exists a Primary Composite P which is canonically - * equivalent to the sequence <@a,@b>. See the Unicode - * Standard for the definition of Primary Composite. - * - * If @a and @b do not compose a new character, @ch is set to zero. - * - * See - * [UAX#15](http://unicode.org/reports/tr15/) - * for details. - * - * Returns: %TRUE if the characters could be composed - * Since: 2.30 - */ - - -/** - * g_unichar_decompose: - * @ch: a Unicode character - * @a: (out) (not optional): return location for the first component of @ch - * @b: (out) (not optional): return location for the second component of @ch - * - * Performs a single decomposition step of the - * Unicode canonical decomposition algorithm. - * - * This function does not include compatibility - * decompositions. It does, however, include algorithmic - * Hangul Jamo decomposition, as well as 'singleton' - * decompositions which replace a character by a single - * other character. In the case of singletons *@b will - * be set to zero. - * - * If @ch is not decomposable, *@a is set to @ch and *@b - * is set to zero. - * - * Note that the way Unicode decomposition pairs are - * defined, it is guaranteed that @b would not decompose - * further, but @a may itself decompose. To get the full - * canonical decomposition for @ch, one would need to - * recursively call this function on @a. Or use - * g_unichar_fully_decompose(). - * - * See - * [UAX#15](http://unicode.org/reports/tr15/) - * for details. - * - * Returns: %TRUE if the character could be decomposed - * Since: 2.30 - */ - - -/** - * g_unichar_digit_value: - * @c: a Unicode character - * - * Determines the numeric value of a character as a decimal - * digit. - * - * Returns: If @c is a decimal digit (according to - * g_unichar_isdigit()), its numeric value. Otherwise, -1. - */ - - -/** - * g_unichar_fully_decompose: - * @ch: a Unicode character. - * @compat: whether perform canonical or compatibility decomposition - * @result: (optional) (out caller-allocates): location to store decomposed result, or %NULL - * @result_len: length of @result - * - * Computes the canonical or compatibility decomposition of a - * Unicode character. For compatibility decomposition, - * pass %TRUE for @compat; for canonical decomposition - * pass %FALSE for @compat. - * - * The decomposed sequence is placed in @result. Only up to - * @result_len characters are written into @result. The length - * of the full decomposition (irrespective of @result_len) is - * returned by the function. For canonical decomposition, - * currently all decompositions are of length at most 4, but - * this may change in the future (very unlikely though). - * At any rate, Unicode does guarantee that a buffer of length - * 18 is always enough for both compatibility and canonical - * decompositions, so that is the size recommended. This is provided - * as %G_UNICHAR_MAX_DECOMPOSITION_LENGTH. - * - * See - * [UAX#15](http://unicode.org/reports/tr15/) - * for details. - * - * Returns: the length of the full decomposition. - * Since: 2.30 - */ - - -/** - * g_unichar_get_mirror_char: - * @ch: a Unicode character - * @mirrored_ch: location to store the mirrored character - * - * In Unicode, some characters are "mirrored". This means that their - * images are mirrored horizontally in text that is laid out from right - * to left. For instance, "(" would become its mirror image, ")", in - * right-to-left text. - * - * If @ch has the Unicode mirrored property and there is another unicode - * character that typically has a glyph that is the mirror image of @ch's - * glyph and @mirrored_ch is set, it puts that character in the address - * pointed to by @mirrored_ch. Otherwise the original character is put. - * - * Returns: %TRUE if @ch has a mirrored character, %FALSE otherwise - * Since: 2.4 - */ - - -/** - * g_unichar_get_script: - * @ch: a Unicode character - * - * Looks up the #GUnicodeScript for a particular character (as defined - * by Unicode Standard Annex \#24). No check is made for @ch being a - * valid Unicode character; if you pass in invalid character, the - * result is undefined. - * - * This function is equivalent to pango_script_for_unichar() and the - * two are interchangeable. - * - * Returns: the #GUnicodeScript for the character. - * Since: 2.14 - */ - - -/** - * g_unichar_isalnum: - * @c: a Unicode character - * - * Determines whether a character is alphanumeric. - * Given some UTF-8 text, obtain a character value - * with g_utf8_get_char(). - * - * Returns: %TRUE if @c is an alphanumeric character - */ - - -/** - * g_unichar_isalpha: - * @c: a Unicode character - * - * Determines whether a character is alphabetic (i.e. a letter). - * Given some UTF-8 text, obtain a character value with - * g_utf8_get_char(). - * - * Returns: %TRUE if @c is an alphabetic character - */ - - -/** - * g_unichar_iscntrl: - * @c: a Unicode character - * - * Determines whether a character is a control character. - * Given some UTF-8 text, obtain a character value with - * g_utf8_get_char(). - * - * Returns: %TRUE if @c is a control character - */ - - -/** - * g_unichar_isdefined: - * @c: a Unicode character - * - * Determines if a given character is assigned in the Unicode - * standard. - * - * Returns: %TRUE if the character has an assigned value - */ - - -/** - * g_unichar_isdigit: - * @c: a Unicode character - * - * Determines whether a character is numeric (i.e. a digit). This - * covers ASCII 0-9 and also digits in other languages/scripts. Given - * some UTF-8 text, obtain a character value with g_utf8_get_char(). - * - * Returns: %TRUE if @c is a digit - */ - - -/** - * g_unichar_isgraph: - * @c: a Unicode character - * - * Determines whether a character is printable and not a space - * (returns %FALSE for control characters, format characters, and - * spaces). g_unichar_isprint() is similar, but returns %TRUE for - * spaces. Given some UTF-8 text, obtain a character value with - * g_utf8_get_char(). - * - * Returns: %TRUE if @c is printable unless it's a space - */ - - -/** - * g_unichar_islower: - * @c: a Unicode character - * - * Determines whether a character is a lowercase letter. - * Given some UTF-8 text, obtain a character value with - * g_utf8_get_char(). - * - * Returns: %TRUE if @c is a lowercase letter - */ - - -/** - * g_unichar_ismark: - * @c: a Unicode character - * - * Determines whether a character is a mark (non-spacing mark, - * combining mark, or enclosing mark in Unicode speak). - * Given some UTF-8 text, obtain a character value - * with g_utf8_get_char(). - * - * Note: in most cases where isalpha characters are allowed, - * ismark characters should be allowed to as they are essential - * for writing most European languages as well as many non-Latin - * scripts. - * - * Returns: %TRUE if @c is a mark character - * Since: 2.14 - */ - - -/** - * g_unichar_isprint: - * @c: a Unicode character - * - * Determines whether a character is printable. - * Unlike g_unichar_isgraph(), returns %TRUE for spaces. - * Given some UTF-8 text, obtain a character value with - * g_utf8_get_char(). - * - * Returns: %TRUE if @c is printable - */ - - -/** - * g_unichar_ispunct: - * @c: a Unicode character - * - * Determines whether a character is punctuation or a symbol. - * Given some UTF-8 text, obtain a character value with - * g_utf8_get_char(). - * - * Returns: %TRUE if @c is a punctuation or symbol character - */ - - -/** - * g_unichar_isspace: - * @c: a Unicode character - * - * Determines whether a character is a space, tab, or line separator - * (newline, carriage return, etc.). Given some UTF-8 text, obtain a - * character value with g_utf8_get_char(). - * - * (Note: don't use this to do word breaking; you have to use - * Pango or equivalent to get word breaking right, the algorithm - * is fairly complex.) - * - * Returns: %TRUE if @c is a space character - */ - - -/** - * g_unichar_istitle: - * @c: a Unicode character - * - * Determines if a character is titlecase. Some characters in - * Unicode which are composites, such as the DZ digraph - * have three case variants instead of just two. The titlecase - * form is used at the beginning of a word where only the - * first letter is capitalized. The titlecase form of the DZ - * digraph is U+01F2 LATIN CAPITAL LETTTER D WITH SMALL LETTER Z. - * - * Returns: %TRUE if the character is titlecase - */ - - -/** - * g_unichar_isupper: - * @c: a Unicode character - * - * Determines if a character is uppercase. - * - * Returns: %TRUE if @c is an uppercase character - */ - - -/** - * g_unichar_iswide: - * @c: a Unicode character - * - * Determines if a character is typically rendered in a double-width - * cell. - * - * Returns: %TRUE if the character is wide - */ - - -/** - * g_unichar_iswide_cjk: - * @c: a Unicode character - * - * Determines if a character is typically rendered in a double-width - * cell under legacy East Asian locales. If a character is wide according to - * g_unichar_iswide(), then it is also reported wide with this function, but - * the converse is not necessarily true. See the - * [Unicode Standard Annex #11](http://www.unicode.org/reports/tr11/) - * for details. - * - * If a character passes the g_unichar_iswide() test then it will also pass - * this test, but not the other way around. Note that some characters may - * pass both this test and g_unichar_iszerowidth(). - * - * Returns: %TRUE if the character is wide in legacy East Asian locales - * Since: 2.12 - */ - - -/** - * g_unichar_isxdigit: - * @c: a Unicode character. - * - * Determines if a character is a hexadecimal digit. - * - * Returns: %TRUE if the character is a hexadecimal digit - */ - - -/** - * g_unichar_iszerowidth: - * @c: a Unicode character - * - * Determines if a given character typically takes zero width when rendered. - * The return value is %TRUE for all non-spacing and enclosing marks - * (e.g., combining accents), format characters, zero-width - * space, but not U+00AD SOFT HYPHEN. - * - * A typical use of this function is with one of g_unichar_iswide() or - * g_unichar_iswide_cjk() to determine the number of cells a string occupies - * when displayed on a grid display (terminals). However, note that not all - * terminals support zero-width rendering of zero-width marks. - * - * Returns: %TRUE if the character has zero width - * Since: 2.14 - */ - - -/** - * g_unichar_to_utf8: - * @c: a Unicode character code - * @outbuf: (out caller-allocates) (optional): output buffer, must have at - * least 6 bytes of space. If %NULL, the length will be computed and - * returned and nothing will be written to @outbuf. - * - * Converts a single character to UTF-8. - * - * Returns: number of bytes written - */ - - -/** - * g_unichar_tolower: - * @c: a Unicode character. - * - * Converts a character to lower case. - * - * Returns: the result of converting @c to lower case. - * If @c is not an upperlower or titlecase character, - * or has no lowercase equivalent @c is returned unchanged. - */ - - -/** - * g_unichar_totitle: - * @c: a Unicode character - * - * Converts a character to the titlecase. - * - * Returns: the result of converting @c to titlecase. - * If @c is not an uppercase or lowercase character, - * @c is returned unchanged. - */ - - -/** - * g_unichar_toupper: - * @c: a Unicode character - * - * Converts a character to uppercase. - * - * Returns: the result of converting @c to uppercase. - * If @c is not a lowercase or titlecase character, - * or has no upper case equivalent @c is returned unchanged. - */ - - -/** - * g_unichar_type: - * @c: a Unicode character - * - * Classifies a Unicode character by type. - * - * Returns: the type of the character. - */ - - -/** - * g_unichar_validate: - * @ch: a Unicode character - * - * Checks whether @ch is a valid Unicode character. Some possible - * integer values of @ch will not be valid. 0 is considered a valid - * character, though it's normally a string terminator. - * - * Returns: %TRUE if @ch is a valid Unicode character - */ - - -/** - * g_unichar_xdigit_value: - * @c: a Unicode character - * - * Determines the numeric value of a character as a hexadecimal - * digit. - * - * Returns: If @c is a hex digit (according to - * g_unichar_isxdigit()), its numeric value. Otherwise, -1. - */ - - -/** - * g_unicode_canonical_decomposition: - * @ch: a Unicode character. - * @result_len: location to store the length of the return value. - * - * Computes the canonical decomposition of a Unicode character. - * - * Returns: a newly allocated string of Unicode characters. - * @result_len is set to the resulting length of the string. - * Deprecated: 2.30: Use the more flexible g_unichar_fully_decompose() - * instead. - */ - - -/** - * g_unicode_canonical_ordering: - * @string: a UCS-4 encoded string. - * @len: the maximum length of @string to use. - * - * Computes the canonical ordering of a string in-place. - * This rearranges decomposed characters in the string - * according to their combining classes. See the Unicode - * manual for more information. - */ - - -/** - * g_unicode_script_from_iso15924: - * @iso15924: a Unicode script - * - * Looks up the Unicode script for @iso15924. ISO 15924 assigns four-letter - * codes to scripts. For example, the code for Arabic is 'Arab'. - * This function accepts four letter codes encoded as a @guint32 in a - * big-endian fashion. That is, the code expected for Arabic is - * 0x41726162 (0x41 is ASCII code for 'A', 0x72 is ASCII code for 'r', etc). - * - * See - * [Codes for the representation of names of scripts](http://unicode.org/iso15924/codelists.html) - * for details. - * - * Returns: the Unicode script for @iso15924, or - * of %G_UNICODE_SCRIPT_INVALID_CODE if @iso15924 is zero and - * %G_UNICODE_SCRIPT_UNKNOWN if @iso15924 is unknown. - * Since: 2.30 - */ - - -/** - * g_unicode_script_to_iso15924: - * @script: a Unicode script - * - * Looks up the ISO 15924 code for @script. ISO 15924 assigns four-letter - * codes to scripts. For example, the code for Arabic is 'Arab'. The - * four letter codes are encoded as a @guint32 by this function in a - * big-endian fashion. That is, the code returned for Arabic is - * 0x41726162 (0x41 is ASCII code for 'A', 0x72 is ASCII code for 'r', etc). - * - * See - * [Codes for the representation of names of scripts](http://unicode.org/iso15924/codelists.html) - * for details. - * - * Returns: the ISO 15924 code for @script, encoded as an integer, - * of zero if @script is %G_UNICODE_SCRIPT_INVALID_CODE or - * ISO 15924 code 'Zzzz' (script code for UNKNOWN) if @script is not understood. - * Since: 2.30 - */ - - -/** - * g_unix_fd_add: - * @fd: a file descriptor - * @condition: IO conditions to watch for on @fd - * @function: a #GUnixFDSourceFunc - * @user_data: data to pass to @function - * - * Sets a function to be called when the IO condition, as specified by - * @condition becomes true for @fd. - * - * @function will be called when the specified IO condition becomes - * %TRUE. The function is expected to clear whatever event caused the - * IO condition to become true and return %TRUE in order to be notified - * when it happens again. If @function returns %FALSE then the watch - * will be cancelled. - * - * The return value of this function can be passed to g_source_remove() - * to cancel the watch at any time that it exists. - * - * The source will never close the fd -- you must do it yourself. - * - * Returns: the ID (greater than 0) of the event source - * Since: 2.36 - */ - - -/** - * g_unix_fd_add_full: - * @priority: the priority of the source - * @fd: a file descriptor - * @condition: IO conditions to watch for on @fd - * @function: a #GUnixFDSourceFunc - * @user_data: data to pass to @function - * @notify: function to call when the idle is removed, or %NULL - * - * Sets a function to be called when the IO condition, as specified by - * @condition becomes true for @fd. - * - * This is the same as g_unix_fd_add(), except that it allows you to - * specify a non-default priority and a provide a #GDestroyNotify for - * @user_data. - * - * Returns: the ID (greater than 0) of the event source - * Since: 2.36 - */ - - -/** - * g_unix_fd_source_new: - * @fd: a file descriptor - * @condition: IO conditions to watch for on @fd - * - * Creates a #GSource to watch for a particular IO condition on a file - * descriptor. - * - * The source will never close the fd -- you must do it yourself. - * - * Returns: the newly created #GSource - * Since: 2.36 - */ - - -/** - * g_unix_get_passwd_entry: - * @user_name: the username to get the passwd file entry for - * @error: return location for a #GError, or %NULL - * - * Get the `passwd` file entry for the given @user_name using `getpwnam_r()`. - * This can fail if the given @user_name doesn’t exist. - * - * The returned `struct passwd` has been allocated using g_malloc() and should - * be freed using g_free(). The strings referenced by the returned struct are - * included in the same allocation, so are valid until the `struct passwd` is - * freed. - * - * This function is safe to call from multiple threads concurrently. - * - * You will need to include `pwd.h` to get the definition of `struct passwd`. - * - * Returns: (transfer full): passwd entry, or %NULL on error; free the returned - * value with g_free() - * Since: 2.64 - */ - - -/** - * g_unix_open_pipe: - * @fds: Array of two integers - * @flags: Bitfield of file descriptor flags, as for fcntl() - * @error: a #GError - * - * Similar to the UNIX pipe() call, but on modern systems like Linux - * uses the pipe2() system call, which atomically creates a pipe with - * the configured flags. The only supported flag currently is - * %FD_CLOEXEC. If for example you want to configure %O_NONBLOCK, that - * must still be done separately with fcntl(). - * - * This function does not take %O_CLOEXEC, it takes %FD_CLOEXEC as if - * for fcntl(); these are different on Linux/glibc. - * - * Returns: %TRUE on success, %FALSE if not (and errno will be set). - * Since: 2.30 - */ - - -/** - * g_unix_set_fd_nonblocking: - * @fd: A file descriptor - * @nonblock: If %TRUE, set the descriptor to be non-blocking - * @error: a #GError - * - * Control the non-blocking state of the given file descriptor, - * according to @nonblock. On most systems this uses %O_NONBLOCK, but - * on some older ones may use %O_NDELAY. - * - * Returns: %TRUE if successful - * Since: 2.30 - */ - - -/** - * g_unix_signal_add: - * @signum: Signal number - * @handler: Callback - * @user_data: Data for @handler - * - * A convenience function for g_unix_signal_source_new(), which - * attaches to the default #GMainContext. You can remove the watch - * using g_source_remove(). - * - * Returns: An ID (greater than 0) for the event source - * Since: 2.30 - */ - - -/** - * g_unix_signal_add_full: (rename-to g_unix_signal_add) - * @priority: the priority of the signal source. Typically this will be in - * the range between #G_PRIORITY_DEFAULT and #G_PRIORITY_HIGH. - * @signum: Signal number - * @handler: Callback - * @user_data: Data for @handler - * @notify: #GDestroyNotify for @handler - * - * A convenience function for g_unix_signal_source_new(), which - * attaches to the default #GMainContext. You can remove the watch - * using g_source_remove(). - * - * Returns: An ID (greater than 0) for the event source - * Since: 2.30 - */ - - -/** - * g_unix_signal_source_new: - * @signum: A signal number - * - * Create a #GSource that will be dispatched upon delivery of the UNIX - * signal @signum. In GLib versions before 2.36, only `SIGHUP`, `SIGINT`, - * `SIGTERM` can be monitored. In GLib 2.36, `SIGUSR1` and `SIGUSR2` - * were added. In GLib 2.54, `SIGWINCH` was added. - * - * Note that unlike the UNIX default, all sources which have created a - * watch will be dispatched, regardless of which underlying thread - * invoked g_unix_signal_source_new(). - * - * For example, an effective use of this function is to handle `SIGTERM` - * cleanly; flushing any outstanding files, and then calling - * g_main_loop_quit (). It is not safe to do any of this a regular - * UNIX signal handler; your handler may be invoked while malloc() or - * another library function is running, causing reentrancy if you - * attempt to use it from the handler. None of the GLib/GObject API - * is safe against this kind of reentrancy. - * - * The interaction of this source when combined with native UNIX - * functions like sigprocmask() is not defined. - * - * The source will not initially be associated with any #GMainContext - * and must be added to one with g_source_attach() before it will be - * executed. - * - * Returns: A newly created #GSource - * Since: 2.30 - */ - - -/** - * g_unlink: - * @filename: (type filename): a pathname in the GLib file name encoding - * (UTF-8 on Windows) - * - * A wrapper for the POSIX unlink() function. The unlink() function - * deletes a name from the filesystem. If this was the last link to the - * file and no processes have it opened, the diskspace occupied by the - * file is freed. - * - * See your C library manual for more details about unlink(). Note - * that on Windows, it is in general not possible to delete files that - * are open to some process, or mapped into memory. - * - * Returns: 0 if the name was successfully deleted, -1 if an error - * occurred - * Since: 2.6 - */ - - -/** - * g_unsetenv: - * @variable: (type filename): the environment variable to remove, must - * not contain '=' - * - * Removes an environment variable from the environment. - * - * Note that on some systems, when variables are overwritten, the - * memory used for the previous variables and its value isn't reclaimed. - * - * You should be mindful of the fact that environment variable handling - * in UNIX is not thread-safe, and your program may crash if one thread - * calls g_unsetenv() while another thread is calling getenv(). (And note - * that many functions, such as gettext(), call getenv() internally.) This - * function is only safe to use at the very start of your program, before - * creating any other threads (or creating objects that create worker - * threads of their own). - * - * If you need to set up the environment for a child process, you can - * use g_get_environ() to get an environment array, modify that with - * g_environ_setenv() and g_environ_unsetenv(), and then pass that - * array directly to execvpe(), g_spawn_async(), or the like. - * - * Since: 2.4 - */ - - -/** - * g_uri_build: - * @flags: flags describing how to build the #GUri - * @scheme: (not nullable): the URI scheme - * @userinfo: (nullable): the userinfo component, or %NULL - * @host: (nullable): the host component, or %NULL - * @port: the port, or `-1` - * @path: (not nullable): the path component - * @query: (nullable): the query component, or %NULL - * @fragment: (nullable): the fragment, or %NULL - * - * Creates a new #GUri from the given components according to @flags. - * - * See also g_uri_build_with_user(), which allows specifying the - * components of the "userinfo" separately. - * - * Returns: (not nullable) (transfer full): a new #GUri - * Since: 2.66 - */ - - -/** - * g_uri_build_with_user: - * @flags: flags describing how to build the #GUri - * @scheme: (not nullable): the URI scheme - * @user: (nullable): the user component of the userinfo, or %NULL - * @password: (nullable): the password component of the userinfo, or %NULL - * @auth_params: (nullable): the auth params of the userinfo, or %NULL - * @host: (nullable): the host component, or %NULL - * @port: the port, or `-1` - * @path: (not nullable): the path component - * @query: (nullable): the query component, or %NULL - * @fragment: (nullable): the fragment, or %NULL - * - * Creates a new #GUri from the given components according to @flags - * (%G_URI_FLAGS_HAS_PASSWORD is added unconditionally). The @flags must be - * coherent with the passed values, in particular use `%`-encoded values with - * %G_URI_FLAGS_ENCODED. - * - * In contrast to g_uri_build(), this allows specifying the components - * of the ‘userinfo’ field separately. Note that @user must be non-%NULL - * if either @password or @auth_params is non-%NULL. - * - * Returns: (not nullable) (transfer full): a new #GUri - * Since: 2.66 - */ - - -/** - * g_uri_escape_bytes: - * @unescaped: (array length=length): the unescaped input data. - * @length: the length of @unescaped - * @reserved_chars_allowed: (nullable): a string of reserved - * characters that are allowed to be used, or %NULL. - * - * Escapes arbitrary data for use in a URI. - * - * Normally all characters that are not ‘unreserved’ (i.e. ASCII - * alphanumerical characters plus dash, dot, underscore and tilde) are - * escaped. But if you specify characters in @reserved_chars_allowed - * they are not escaped. This is useful for the ‘reserved’ characters - * in the URI specification, since those are allowed unescaped in some - * portions of a URI. - * - * Though technically incorrect, this will also allow escaping nul - * bytes as `%``00`. - * - * Returns: (not nullable) (transfer full): an escaped version of @unescaped. - * The returned string should be freed when no longer needed. - * Since: 2.66 - */ - - -/** - * g_uri_escape_string: - * @unescaped: the unescaped input string. - * @reserved_chars_allowed: (nullable): a string of reserved - * characters that are allowed to be used, or %NULL. - * @allow_utf8: %TRUE if the result can include UTF-8 characters. - * - * Escapes a string for use in a URI. - * - * Normally all characters that are not "unreserved" (i.e. ASCII - * alphanumerical characters plus dash, dot, underscore and tilde) are - * escaped. But if you specify characters in @reserved_chars_allowed - * they are not escaped. This is useful for the "reserved" characters - * in the URI specification, since those are allowed unescaped in some - * portions of a URI. - * - * Returns: (not nullable): an escaped version of @unescaped. The - * returned string should be freed when no longer needed. - * Since: 2.16 - */ - - -/** - * g_uri_get_auth_params: - * @uri: a #GUri - * - * Gets @uri's authentication parameters, which may contain - * `%`-encoding, depending on the flags with which @uri was created. - * (If @uri was not created with %G_URI_FLAGS_HAS_AUTH_PARAMS then this will - * be %NULL.) - * - * Depending on the URI scheme, g_uri_parse_params() may be useful for - * further parsing this information. - * - * Returns: (nullable): @uri's authentication parameters. - * Since: 2.66 - */ - - -/** - * g_uri_get_flags: - * @uri: a #GUri - * - * Gets @uri's flags set upon construction. - * - * Returns: @uri's flags. - * Since: 2.66 - */ - - -/** - * g_uri_get_fragment: - * @uri: a #GUri - * - * Gets @uri's fragment, which may contain `%`-encoding, depending on - * the flags with which @uri was created. - * - * Returns: (nullable): @uri's fragment. - * Since: 2.66 - */ - - -/** - * g_uri_get_host: - * @uri: a #GUri - * - * Gets @uri's host. This will never have `%`-encoded characters, - * unless it is non-UTF-8 (which can only be the case if @uri was - * created with %G_URI_FLAGS_NON_DNS). - * - * If @uri contained an IPv6 address literal, this value will be just - * that address, without the brackets around it that are necessary in - * the string form of the URI. Note that in this case there may also - * be a scope ID attached to the address. Eg, `fe80::1234%``em1` (or - * `fe80::1234%``25em1` if the string is still encoded). - * - * Returns: (nullable): @uri's host. - * Since: 2.66 - */ - - -/** - * g_uri_get_password: - * @uri: a #GUri - * - * Gets @uri's password, which may contain `%`-encoding, depending on - * the flags with which @uri was created. (If @uri was not created - * with %G_URI_FLAGS_HAS_PASSWORD then this will be %NULL.) - * - * Returns: (nullable): @uri's password. - * Since: 2.66 - */ - - -/** - * g_uri_get_path: - * @uri: a #GUri - * - * Gets @uri's path, which may contain `%`-encoding, depending on the - * flags with which @uri was created. - * - * Returns: (not nullable): @uri's path. - * Since: 2.66 - */ - - -/** - * g_uri_get_port: - * @uri: a #GUri - * - * Gets @uri's port. - * - * Returns: @uri's port, or `-1` if no port was specified. - * Since: 2.66 - */ - - -/** - * g_uri_get_query: - * @uri: a #GUri - * - * Gets @uri's query, which may contain `%`-encoding, depending on the - * flags with which @uri was created. - * - * For queries consisting of a series of `name=value` parameters, - * #GUriParamsIter or g_uri_parse_params() may be useful. - * - * Returns: (nullable): @uri's query. - * Since: 2.66 - */ - - -/** - * g_uri_get_scheme: - * @uri: a #GUri - * - * Gets @uri's scheme. Note that this will always be all-lowercase, - * regardless of the string or strings that @uri was created from. - * - * Returns: (not nullable): @uri's scheme. - * Since: 2.66 - */ - - -/** - * g_uri_get_user: - * @uri: a #GUri - * - * Gets the ‘username’ component of @uri's userinfo, which may contain - * `%`-encoding, depending on the flags with which @uri was created. - * If @uri was not created with %G_URI_FLAGS_HAS_PASSWORD or - * %G_URI_FLAGS_HAS_AUTH_PARAMS, this is the same as g_uri_get_userinfo(). - * - * Returns: (nullable): @uri's user. - * Since: 2.66 - */ - - -/** - * g_uri_get_userinfo: - * @uri: a #GUri - * - * Gets @uri's userinfo, which may contain `%`-encoding, depending on - * the flags with which @uri was created. - * - * Returns: (nullable): @uri's userinfo. - * Since: 2.66 - */ - - -/** - * g_uri_is_valid: - * @uri_string: a string containing an absolute URI - * @flags: flags for parsing @uri_string - * @error: #GError for error reporting, or %NULL to ignore. - * - * Parses @uri_string according to @flags, to determine whether it is a valid - * [absolute URI][relative-absolute-uris], i.e. it does not need to be resolved - * relative to another URI using g_uri_parse_relative(). - * - * If it’s not a valid URI, an error is returned explaining how it’s invalid. - * - * See g_uri_split(), and the definition of #GUriFlags, for more - * information on the effect of @flags. - * - * Returns: %TRUE if @uri_string is a valid absolute URI, %FALSE on error. - * Since: 2.66 - */ - - -/** - * g_uri_join: - * @flags: flags describing how to build the URI string - * @scheme: (nullable): the URI scheme, or %NULL - * @userinfo: (nullable): the userinfo component, or %NULL - * @host: (nullable): the host component, or %NULL - * @port: the port, or `-1` - * @path: (not nullable): the path component - * @query: (nullable): the query component, or %NULL - * @fragment: (nullable): the fragment, or %NULL - * - * Joins the given components together according to @flags to create - * an absolute URI string. @path may not be %NULL (though it may be the empty - * string). - * - * When @host is present, @path must either be empty or begin with a slash (`/`) - * character. When @host is not present, @path cannot begin with two slash - * characters (`//`). See - * [RFC 3986, section 3](https://tools.ietf.org/html/rfc3986#section-3). - * - * See also g_uri_join_with_user(), which allows specifying the - * components of the ‘userinfo’ separately. - * - * %G_URI_FLAGS_HAS_PASSWORD and %G_URI_FLAGS_HAS_AUTH_PARAMS are ignored if set - * in @flags. - * - * Returns: (not nullable) (transfer full): an absolute URI string - * Since: 2.66 - */ - - -/** - * g_uri_join_with_user: - * @flags: flags describing how to build the URI string - * @scheme: (nullable): the URI scheme, or %NULL - * @user: (nullable): the user component of the userinfo, or %NULL - * @password: (nullable): the password component of the userinfo, or - * %NULL - * @auth_params: (nullable): the auth params of the userinfo, or - * %NULL - * @host: (nullable): the host component, or %NULL - * @port: the port, or `-1` - * @path: (not nullable): the path component - * @query: (nullable): the query component, or %NULL - * @fragment: (nullable): the fragment, or %NULL - * - * Joins the given components together according to @flags to create - * an absolute URI string. @path may not be %NULL (though it may be the empty - * string). - * - * In contrast to g_uri_join(), this allows specifying the components - * of the ‘userinfo’ separately. It otherwise behaves the same. - * - * %G_URI_FLAGS_HAS_PASSWORD and %G_URI_FLAGS_HAS_AUTH_PARAMS are ignored if set - * in @flags. - * - * Returns: (not nullable) (transfer full): an absolute URI string - * Since: 2.66 - */ - - -/** - * g_uri_list_extract_uris: - * @uri_list: an URI list - * - * Splits an URI list conforming to the text/uri-list - * mime type defined in RFC 2483 into individual URIs, - * discarding any comments. The URIs are not validated. - * - * Returns: (transfer full): a newly allocated %NULL-terminated list - * of strings holding the individual URIs. The array should be freed - * with g_strfreev(). - * Since: 2.6 - */ - - -/** - * g_uri_params_iter_init: - * @iter: an uninitialized #GUriParamsIter - * @params: a `%`-encoded string containing `attribute=value` - * parameters - * @length: the length of @params, or `-1` if it is nul-terminated - * @separators: the separator byte character set between parameters. (usually - * `&`, but sometimes `;` or both `&;`). Note that this function works on - * bytes not characters, so it can't be used to delimit UTF-8 strings for - * anything but ASCII characters. You may pass an empty set, in which case - * no splitting will occur. - * @flags: flags to modify the way the parameters are handled. - * - * Initializes an attribute/value pair iterator. - * - * The iterator keeps pointers to the @params and @separators arguments, those - * variables must thus outlive the iterator and not be modified during the - * iteration. - * - * If %G_URI_PARAMS_WWW_FORM is passed in @flags, `+` characters in the param - * string will be replaced with spaces in the output. For example, `foo=bar+baz` - * will give attribute `foo` with value `bar baz`. This is commonly used on the - * web (the `https` and `http` schemes only), but is deprecated in favour of - * the equivalent of encoding spaces as `%20`. - * - * Unlike with g_uri_parse_params(), %G_URI_PARAMS_CASE_INSENSITIVE has no - * effect if passed to @flags for g_uri_params_iter_init(). The caller is - * responsible for doing their own case-insensitive comparisons. - * - * |[<!-- language="C" --> - * GUriParamsIter iter; - * GError *error = NULL; - * gchar *unowned_attr, *unowned_value; - * - * g_uri_params_iter_init (&iter, "foo=bar&baz=bar&Foo=frob&baz=bar2", -1, "&", G_URI_PARAMS_NONE); - * while (g_uri_params_iter_next (&iter, &unowned_attr, &unowned_value, &error)) - * { - * g_autofree gchar *attr = g_steal_pointer (&unowned_attr); - * g_autofree gchar *value = g_steal_pointer (&unowned_value); - * // do something with attr and value; this code will be called 4 times - * // for the params string in this example: once with attr=foo and value=bar, - * // then with baz/bar, then Foo/frob, then baz/bar2. - * } - * if (error) - * // handle parsing error - * ]| - * - * Since: 2.66 - */ - - -/** - * g_uri_params_iter_next: - * @iter: an initialized #GUriParamsIter - * @attribute: (out) (nullable) (optional) (transfer full): on return, contains - * the attribute, or %NULL. - * @value: (out) (nullable) (optional) (transfer full): on return, contains - * the value, or %NULL. - * @error: #GError for error reporting, or %NULL to ignore. - * - * Advances @iter and retrieves the next attribute/value. %FALSE is returned if - * an error has occurred (in which case @error is set), or if the end of the - * iteration is reached (in which case @attribute and @value are set to %NULL - * and the iterator becomes invalid). If %TRUE is returned, - * g_uri_params_iter_next() may be called again to receive another - * attribute/value pair. - * - * Note that the same @attribute may be returned multiple times, since URIs - * allow repeated attributes. - * - * Returns: %FALSE if the end of the parameters has been reached or an error was - * encountered. %TRUE otherwise. - * Since: 2.66 - */ - - -/** - * g_uri_parse: - * @uri_string: a string representing an absolute URI - * @flags: flags describing how to parse @uri_string - * @error: #GError for error reporting, or %NULL to ignore. - * - * Parses @uri_string according to @flags. If the result is not a - * valid [absolute URI][relative-absolute-uris], it will be discarded, and an - * error returned. - * - * Returns: (transfer full): a new #GUri, or NULL on error. - * Since: 2.66 - */ - - -/** - * g_uri_parse_params: - * @params: a `%`-encoded string containing `attribute=value` - * parameters - * @length: the length of @params, or `-1` if it is nul-terminated - * @separators: the separator byte character set between parameters. (usually - * `&`, but sometimes `;` or both `&;`). Note that this function works on - * bytes not characters, so it can't be used to delimit UTF-8 strings for - * anything but ASCII characters. You may pass an empty set, in which case - * no splitting will occur. - * @flags: flags to modify the way the parameters are handled. - * @error: #GError for error reporting, or %NULL to ignore. - * - * Many URI schemes include one or more attribute/value pairs as part of the URI - * value. This method can be used to parse them into a hash table. When an - * attribute has multiple occurrences, the last value is the final returned - * value. If you need to handle repeated attributes differently, use - * #GUriParamsIter. - * - * The @params string is assumed to still be `%`-encoded, but the returned - * values will be fully decoded. (Thus it is possible that the returned values - * may contain `=` or @separators, if the value was encoded in the input.) - * Invalid `%`-encoding is treated as with the %G_URI_FLAGS_PARSE_RELAXED - * rules for g_uri_parse(). (However, if @params is the path or query string - * from a #GUri that was parsed without %G_URI_FLAGS_PARSE_RELAXED and - * %G_URI_FLAGS_ENCODED, then you already know that it does not contain any - * invalid encoding.) - * - * %G_URI_PARAMS_WWW_FORM is handled as documented for g_uri_params_iter_init(). - * - * If %G_URI_PARAMS_CASE_INSENSITIVE is passed to @flags, attributes will be - * compared case-insensitively, so a params string `attr=123&Attr=456` will only - * return a single attribute–value pair, `Attr=456`. Case will be preserved in - * the returned attributes. - * - * If @params cannot be parsed (for example, it contains two @separators - * characters in a row), then @error is set and %NULL is returned. - * - * Returns: (transfer full) (element-type utf8 utf8): - * A hash table of attribute/value pairs, with both names and values - * fully-decoded; or %NULL on error. - * Since: 2.66 - */ - - -/** - * g_uri_parse_relative: - * @base_uri: (nullable) (transfer none): a base absolute URI - * @uri_ref: a string representing a relative or absolute URI - * @flags: flags describing how to parse @uri_ref - * @error: #GError for error reporting, or %NULL to ignore. - * - * Parses @uri_ref according to @flags and, if it is a - * [relative URI][relative-absolute-uris], resolves it relative to @base_uri. - * If the result is not a valid absolute URI, it will be discarded, and an error - * returned. - * - * Returns: (transfer full): a new #GUri, or NULL on error. - * Since: 2.66 - */ - - -/** - * g_uri_parse_scheme: - * @uri: a valid URI. - * - * Gets the scheme portion of a URI string. - * [RFC 3986](https://tools.ietf.org/html/rfc3986#section-3) decodes the scheme - * as: - * |[ - * URI = scheme ":" hier-part [ "?" query ] [ "#" fragment ] - * ]| - * Common schemes include `file`, `https`, `svn+ssh`, etc. - * - * Returns: (transfer full) (nullable): The ‘scheme’ component of the URI, or - * %NULL on error. The returned string should be freed when no longer needed. - * Since: 2.16 - */ - - -/** - * g_uri_peek_scheme: - * @uri: a valid URI. - * - * Gets the scheme portion of a URI string. - * [RFC 3986](https://tools.ietf.org/html/rfc3986#section-3) decodes the scheme - * as: - * |[ - * URI = scheme ":" hier-part [ "?" query ] [ "#" fragment ] - * ]| - * Common schemes include `file`, `https`, `svn+ssh`, etc. - * - * Unlike g_uri_parse_scheme(), the returned scheme is normalized to - * all-lowercase and does not need to be freed. - * - * Returns: (transfer none) (nullable): The ‘scheme’ component of the URI, or - * %NULL on error. The returned string is normalized to all-lowercase, and - * interned via g_intern_string(), so it does not need to be freed. - * Since: 2.66 - */ - - -/** - * g_uri_ref: (skip) - * @uri: a #GUri - * - * Increments the reference count of @uri by one. - * - * Returns: @uri - * Since: 2.66 - */ - - -/** - * g_uri_resolve_relative: - * @base_uri_string: (nullable): a string representing a base URI - * @uri_ref: a string representing a relative or absolute URI - * @flags: flags describing how to parse @uri_ref - * @error: #GError for error reporting, or %NULL to ignore. - * - * Parses @uri_ref according to @flags and, if it is a - * [relative URI][relative-absolute-uris], resolves it relative to - * @base_uri_string. If the result is not a valid absolute URI, it will be - * discarded, and an error returned. - * - * (If @base_uri_string is %NULL, this just returns @uri_ref, or - * %NULL if @uri_ref is invalid or not absolute.) - * - * Returns: (transfer full): the resolved URI string, - * or NULL on error. - * Since: 2.66 - */ - - -/** - * g_uri_split: - * @uri_ref: a string containing a relative or absolute URI - * @flags: flags for parsing @uri_ref - * @scheme: (out) (nullable) (optional) (transfer full): on return, contains - * the scheme (converted to lowercase), or %NULL - * @userinfo: (out) (nullable) (optional) (transfer full): on return, contains - * the userinfo, or %NULL - * @host: (out) (nullable) (optional) (transfer full): on return, contains the - * host, or %NULL - * @port: (out) (optional) (transfer full): on return, contains the - * port, or `-1` - * @path: (out) (not nullable) (optional) (transfer full): on return, contains the - * path - * @query: (out) (nullable) (optional) (transfer full): on return, contains the - * query, or %NULL - * @fragment: (out) (nullable) (optional) (transfer full): on return, contains - * the fragment, or %NULL - * @error: #GError for error reporting, or %NULL to ignore. - * - * Parses @uri_ref (which can be an - * [absolute or relative URI][relative-absolute-uris]) according to @flags, and - * returns the pieces. Any component that doesn't appear in @uri_ref will be - * returned as %NULL (but note that all URIs always have a path component, - * though it may be the empty string). - * - * If @flags contains %G_URI_FLAGS_ENCODED, then `%`-encoded characters in - * @uri_ref will remain encoded in the output strings. (If not, - * then all such characters will be decoded.) Note that decoding will - * only work if the URI components are ASCII or UTF-8, so you will - * need to use %G_URI_FLAGS_ENCODED if they are not. - * - * Note that the %G_URI_FLAGS_HAS_PASSWORD and - * %G_URI_FLAGS_HAS_AUTH_PARAMS @flags are ignored by g_uri_split(), - * since it always returns only the full userinfo; use - * g_uri_split_with_user() if you want it split up. - * - * Returns: (skip): %TRUE if @uri_ref parsed successfully, %FALSE - * on error. - * Since: 2.66 - */ - - -/** - * g_uri_split_network: - * @uri_string: a string containing an absolute URI - * @flags: flags for parsing @uri_string - * @scheme: (out) (nullable) (optional) (transfer full): on return, contains - * the scheme (converted to lowercase), or %NULL - * @host: (out) (nullable) (optional) (transfer full): on return, contains the - * host, or %NULL - * @port: (out) (optional) (transfer full): on return, contains the - * port, or `-1` - * @error: #GError for error reporting, or %NULL to ignore. - * - * Parses @uri_string (which must be an [absolute URI][relative-absolute-uris]) - * according to @flags, and returns the pieces relevant to connecting to a host. - * See the documentation for g_uri_split() for more details; this is - * mostly a wrapper around that function with simpler arguments. - * However, it will return an error if @uri_string is a relative URI, - * or does not contain a hostname component. - * - * Returns: (skip): %TRUE if @uri_string parsed successfully, - * %FALSE on error. - * Since: 2.66 - */ - - -/** - * g_uri_split_with_user: - * @uri_ref: a string containing a relative or absolute URI - * @flags: flags for parsing @uri_ref - * @scheme: (out) (nullable) (optional) (transfer full): on return, contains - * the scheme (converted to lowercase), or %NULL - * @user: (out) (nullable) (optional) (transfer full): on return, contains - * the user, or %NULL - * @password: (out) (nullable) (optional) (transfer full): on return, contains - * the password, or %NULL - * @auth_params: (out) (nullable) (optional) (transfer full): on return, contains - * the auth_params, or %NULL - * @host: (out) (nullable) (optional) (transfer full): on return, contains the - * host, or %NULL - * @port: (out) (optional) (transfer full): on return, contains the - * port, or `-1` - * @path: (out) (not nullable) (optional) (transfer full): on return, contains the - * path - * @query: (out) (nullable) (optional) (transfer full): on return, contains the - * query, or %NULL - * @fragment: (out) (nullable) (optional) (transfer full): on return, contains - * the fragment, or %NULL - * @error: #GError for error reporting, or %NULL to ignore. - * - * Parses @uri_ref (which can be an - * [absolute or relative URI][relative-absolute-uris]) according to @flags, and - * returns the pieces. Any component that doesn't appear in @uri_ref will be - * returned as %NULL (but note that all URIs always have a path component, - * though it may be the empty string). - * - * See g_uri_split(), and the definition of #GUriFlags, for more - * information on the effect of @flags. Note that @password will only - * be parsed out if @flags contains %G_URI_FLAGS_HAS_PASSWORD, and - * @auth_params will only be parsed out if @flags contains - * %G_URI_FLAGS_HAS_AUTH_PARAMS. - * - * Returns: (skip): %TRUE if @uri_ref parsed successfully, %FALSE - * on error. - * Since: 2.66 - */ - - -/** - * g_uri_to_string: - * @uri: a #GUri - * - * Returns a string representing @uri. - * - * This is not guaranteed to return a string which is identical to the - * string that @uri was parsed from. However, if the source URI was - * syntactically correct (according to RFC 3986), and it was parsed - * with %G_URI_FLAGS_ENCODED, then g_uri_to_string() is guaranteed to return - * a string which is at least semantically equivalent to the source - * URI (according to RFC 3986). - * - * If @uri might contain sensitive details, such as authentication parameters, - * or private data in its query string, and the returned string is going to be - * logged, then consider using g_uri_to_string_partial() to redact parts. - * - * Returns: (not nullable) (transfer full): a string representing @uri, - * which the caller must free. - * Since: 2.66 - */ - - -/** - * g_uri_to_string_partial: - * @uri: a #GUri - * @flags: flags describing what parts of @uri to hide - * - * Returns a string representing @uri, subject to the options in - * @flags. See g_uri_to_string() and #GUriHideFlags for more details. - * - * Returns: (not nullable) (transfer full): a string representing - * @uri, which the caller must free. - * Since: 2.66 - */ - - -/** - * g_uri_unescape_bytes: - * @escaped_string: A URI-escaped string - * @length: the length (in bytes) of @escaped_string to escape, or `-1` if it - * is nul-terminated. - * @illegal_characters: (nullable): a string of illegal characters - * not to be allowed, or %NULL. - * @error: #GError for error reporting, or %NULL to ignore. - * - * Unescapes a segment of an escaped string as binary data. - * - * Note that in contrast to g_uri_unescape_string(), this does allow - * nul bytes to appear in the output. - * - * If any of the characters in @illegal_characters appears as an escaped - * character in @escaped_string, then that is an error and %NULL will be - * returned. This is useful if you want to avoid for instance having a slash - * being expanded in an escaped path element, which might confuse pathname - * handling. - * - * Returns: (transfer full): an unescaped version of @escaped_string - * or %NULL on error (if decoding failed, using %G_URI_ERROR_FAILED error - * code). The returned #GBytes should be unreffed when no longer needed. - * Since: 2.66 - */ - - -/** - * g_uri_unescape_segment: - * @escaped_string: (nullable): A string, may be %NULL - * @escaped_string_end: (nullable): Pointer to end of @escaped_string, - * may be %NULL - * @illegal_characters: (nullable): An optional string of illegal - * characters not to be allowed, may be %NULL - * - * Unescapes a segment of an escaped string. - * - * If any of the characters in @illegal_characters or the NUL - * character appears as an escaped character in @escaped_string, then - * that is an error and %NULL will be returned. This is useful if you - * want to avoid for instance having a slash being expanded in an - * escaped path element, which might confuse pathname handling. - * - * Note: `NUL` byte is not accepted in the output, in contrast to - * g_uri_unescape_bytes(). - * - * Returns: (nullable): an unescaped version of @escaped_string, - * or %NULL on error. The returned string should be freed when no longer - * needed. As a special case if %NULL is given for @escaped_string, this - * function will return %NULL. - * Since: 2.16 - */ - - -/** - * g_uri_unescape_string: - * @escaped_string: an escaped string to be unescaped. - * @illegal_characters: (nullable): a string of illegal characters - * not to be allowed, or %NULL. - * - * Unescapes a whole escaped string. - * - * If any of the characters in @illegal_characters or the NUL - * character appears as an escaped character in @escaped_string, then - * that is an error and %NULL will be returned. This is useful if you - * want to avoid for instance having a slash being expanded in an - * escaped path element, which might confuse pathname handling. - * - * Returns: (nullable): an unescaped version of @escaped_string. - * The returned string should be freed when no longer needed. - * Since: 2.16 - */ - - -/** - * g_uri_unref: (skip) - * @uri: a #GUri - * - * Atomically decrements the reference count of @uri by one. - * - * When the reference count reaches zero, the resources allocated by - * @uri are freed - * - * Since: 2.66 - */ - - -/** - * g_usleep: - * @microseconds: number of microseconds to pause - * - * Pauses the current thread for the given number of microseconds. - * - * There are 1 million microseconds per second (represented by the - * #G_USEC_PER_SEC macro). g_usleep() may have limited precision, - * depending on hardware and operating system; don't rely on the exact - * length of the sleep. - */ - - -/** - * g_utf16_to_ucs4: - * @str: a UTF-16 encoded string - * @len: the maximum length (number of #gunichar2) of @str to use. - * If @len < 0, then the string is nul-terminated. - * @items_read: (out) (optional): location to store number of - * words read, or %NULL. If %NULL, then %G_CONVERT_ERROR_PARTIAL_INPUT will - * be returned in case @str contains a trailing partial character. If - * an error occurs then the index of the invalid input is stored here. - * @items_written: (out) (optional): location to store number - * of characters written, or %NULL. The value stored here does not include - * the trailing 0 character. - * @error: location to store the error occurring, or %NULL to ignore - * errors. Any of the errors in #GConvertError other than - * %G_CONVERT_ERROR_NO_CONVERSION may occur. - * - * Convert a string from UTF-16 to UCS-4. The result will be - * nul-terminated. - * - * Returns: (transfer full): a pointer to a newly allocated UCS-4 string. - * This value must be freed with g_free(). If an error occurs, - * %NULL will be returned and @error set. - */ - - -/** - * g_utf16_to_utf8: - * @str: a UTF-16 encoded string - * @len: the maximum length (number of #gunichar2) of @str to use. - * If @len < 0, then the string is nul-terminated. - * @items_read: (out) (optional): location to store number of - * words read, or %NULL. If %NULL, then %G_CONVERT_ERROR_PARTIAL_INPUT will - * be returned in case @str contains a trailing partial character. If - * an error occurs then the index of the invalid input is stored here. - * @items_written: (out) (optional): location to store number - * of bytes written, or %NULL. The value stored here does not include the - * trailing 0 byte. - * @error: location to store the error occurring, or %NULL to ignore - * errors. Any of the errors in #GConvertError other than - * %G_CONVERT_ERROR_NO_CONVERSION may occur. - * - * Convert a string from UTF-16 to UTF-8. The result will be - * terminated with a 0 byte. - * - * Note that the input is expected to be already in native endianness, - * an initial byte-order-mark character is not handled specially. - * g_convert() can be used to convert a byte buffer of UTF-16 data of - * ambiguous endianness. - * - * Further note that this function does not validate the result - * string; it may e.g. include embedded NUL characters. The only - * validation done by this function is to ensure that the input can - * be correctly interpreted as UTF-16, i.e. it doesn't contain - * unpaired surrogates or partial character sequences. - * - * Returns: (transfer full): a pointer to a newly allocated UTF-8 string. - * This value must be freed with g_free(). If an error occurs, - * %NULL will be returned and @error set. - */ - - -/** - * g_utf8_casefold: - * @str: a UTF-8 encoded string - * @len: length of @str, in bytes, or -1 if @str is nul-terminated. - * - * Converts a string into a form that is independent of case. The - * result will not correspond to any particular case, but can be - * compared for equality or ordered with the results of calling - * g_utf8_casefold() on other strings. - * - * Note that calling g_utf8_casefold() followed by g_utf8_collate() is - * only an approximation to the correct linguistic case insensitive - * ordering, though it is a fairly good one. Getting this exactly - * right would require a more sophisticated collation function that - * takes case sensitivity into account. GLib does not currently - * provide such a function. - * - * Returns: a newly allocated string, that is a - * case independent form of @str. - */ - - -/** - * g_utf8_collate: - * @str1: a UTF-8 encoded string - * @str2: a UTF-8 encoded string - * - * Compares two strings for ordering using the linguistically - * correct rules for the [current locale][setlocale]. - * When sorting a large number of strings, it will be significantly - * faster to obtain collation keys with g_utf8_collate_key() and - * compare the keys with strcmp() when sorting instead of sorting - * the original strings. - * - * Returns: < 0 if @str1 compares before @str2, - * 0 if they compare equal, > 0 if @str1 compares after @str2. - */ - - -/** - * g_utf8_collate_key: - * @str: a UTF-8 encoded string. - * @len: length of @str, in bytes, or -1 if @str is nul-terminated. - * - * Converts a string into a collation key that can be compared - * with other collation keys produced by the same function using - * strcmp(). - * - * The results of comparing the collation keys of two strings - * with strcmp() will always be the same as comparing the two - * original keys with g_utf8_collate(). - * - * Note that this function depends on the [current locale][setlocale]. - * - * Returns: a newly allocated string. This string should - * be freed with g_free() when you are done with it. - */ - - -/** - * g_utf8_collate_key_for_filename: - * @str: a UTF-8 encoded string. - * @len: length of @str, in bytes, or -1 if @str is nul-terminated. - * - * Converts a string into a collation key that can be compared - * with other collation keys produced by the same function using strcmp(). - * - * In order to sort filenames correctly, this function treats the dot '.' - * as a special case. Most dictionary orderings seem to consider it - * insignificant, thus producing the ordering "event.c" "eventgenerator.c" - * "event.h" instead of "event.c" "event.h" "eventgenerator.c". Also, we - * would like to treat numbers intelligently so that "file1" "file10" "file5" - * is sorted as "file1" "file5" "file10". - * - * Note that this function depends on the [current locale][setlocale]. - * - * Returns: a newly allocated string. This string should - * be freed with g_free() when you are done with it. - * Since: 2.8 - */ - - -/** - * g_utf8_find_next_char: - * @p: a pointer to a position within a UTF-8 encoded string - * @end: (nullable): a pointer to the byte following the end of the string, - * or %NULL to indicate that the string is nul-terminated - * - * Finds the start of the next UTF-8 character in the string after @p. - * - * @p does not have to be at the beginning of a UTF-8 character. No check - * is made to see if the character found is actually valid other than - * it starts with an appropriate byte. - * - * If @end is %NULL, the return value will never be %NULL: if the end of the - * string is reached, a pointer to the terminating nul byte is returned. If - * @end is non-%NULL, the return value will be %NULL if the end of the string - * is reached. - * - * Returns: (transfer none) (nullable): a pointer to the found character or %NULL if @end is - * set and is reached - */ - - -/** - * g_utf8_find_prev_char: - * @str: pointer to the beginning of a UTF-8 encoded string - * @p: pointer to some position within @str - * - * Given a position @p with a UTF-8 encoded string @str, find the start - * of the previous UTF-8 character starting before @p. Returns %NULL if no - * UTF-8 characters are present in @str before @p. - * - * @p does not have to be at the beginning of a UTF-8 character. No check - * is made to see if the character found is actually valid other than - * it starts with an appropriate byte. - * - * Returns: (transfer none) (nullable): a pointer to the found character or %NULL. - */ - - -/** - * g_utf8_get_char: - * @p: a pointer to Unicode character encoded as UTF-8 - * - * Converts a sequence of bytes encoded as UTF-8 to a Unicode character. - * - * If @p does not point to a valid UTF-8 encoded character, results - * are undefined. If you are not sure that the bytes are complete - * valid Unicode characters, you should use g_utf8_get_char_validated() - * instead. - * - * Returns: the resulting character - */ - - -/** - * g_utf8_get_char_validated: - * @p: a pointer to Unicode character encoded as UTF-8 - * @max_len: the maximum number of bytes to read, or -1 if @p is nul-terminated - * - * Convert a sequence of bytes encoded as UTF-8 to a Unicode character. - * This function checks for incomplete characters, for invalid characters - * such as characters that are out of the range of Unicode, and for - * overlong encodings of valid characters. - * - * Note that g_utf8_get_char_validated() returns (gunichar)-2 if - * @max_len is positive and any of the bytes in the first UTF-8 character - * sequence are nul. - * - * Returns: the resulting character. If @p points to a partial - * sequence at the end of a string that could begin a valid - * character (or if @max_len is zero), returns (gunichar)-2; - * otherwise, if @p does not point to a valid UTF-8 encoded - * Unicode character, returns (gunichar)-1. - */ - - -/** - * g_utf8_make_valid: - * @str: string to coerce into UTF-8 - * @len: the maximum length of @str to use, in bytes. If @len < 0, - * then the string is nul-terminated. - * - * If the provided string is valid UTF-8, return a copy of it. If not, - * return a copy in which bytes that could not be interpreted as valid Unicode - * are replaced with the Unicode replacement character (U+FFFD). - * - * For example, this is an appropriate function to use if you have received - * a string that was incorrectly declared to be UTF-8, and you need a valid - * UTF-8 version of it that can be logged or displayed to the user, with the - * assumption that it is close enough to ASCII or UTF-8 to be mostly - * readable as-is. - * - * Returns: (transfer full): a valid UTF-8 string whose content resembles @str - * Since: 2.52 - */ - - -/** - * g_utf8_normalize: - * @str: a UTF-8 encoded string. - * @len: length of @str, in bytes, or -1 if @str is nul-terminated. - * @mode: the type of normalization to perform. - * - * Converts a string into canonical form, standardizing - * such issues as whether a character with an accent - * is represented as a base character and combining - * accent or as a single precomposed character. The - * string has to be valid UTF-8, otherwise %NULL is - * returned. You should generally call g_utf8_normalize() - * before comparing two Unicode strings. - * - * The normalization mode %G_NORMALIZE_DEFAULT only - * standardizes differences that do not affect the - * text content, such as the above-mentioned accent - * representation. %G_NORMALIZE_ALL also standardizes - * the "compatibility" characters in Unicode, such - * as SUPERSCRIPT THREE to the standard forms - * (in this case DIGIT THREE). Formatting information - * may be lost but for most text operations such - * characters should be considered the same. - * - * %G_NORMALIZE_DEFAULT_COMPOSE and %G_NORMALIZE_ALL_COMPOSE - * are like %G_NORMALIZE_DEFAULT and %G_NORMALIZE_ALL, - * but returned a result with composed forms rather - * than a maximally decomposed form. This is often - * useful if you intend to convert the string to - * a legacy encoding or pass it to a system with - * less capable Unicode handling. - * - * Returns: (nullable): a newly allocated string, that - * is the normalized form of @str, or %NULL if @str - * is not valid UTF-8. - */ - - -/** - * g_utf8_offset_to_pointer: - * @str: a UTF-8 encoded string - * @offset: a character offset within @str - * - * Converts from an integer character offset to a pointer to a position - * within the string. - * - * Since 2.10, this function allows to pass a negative @offset to - * step backwards. It is usually worth stepping backwards from the end - * instead of forwards if @offset is in the last fourth of the string, - * since moving forward is about 3 times faster than moving backward. - * - * Note that this function doesn't abort when reaching the end of @str. - * Therefore you should be sure that @offset is within string boundaries - * before calling that function. Call g_utf8_strlen() when unsure. - * This limitation exists as this function is called frequently during - * text rendering and therefore has to be as fast as possible. - * - * Returns: (transfer none): the resulting pointer - */ - - -/** - * g_utf8_pointer_to_offset: - * @str: a UTF-8 encoded string - * @pos: a pointer to a position within @str - * - * Converts from a pointer to position within a string to an integer - * character offset. - * - * Since 2.10, this function allows @pos to be before @str, and returns - * a negative offset in this case. - * - * Returns: the resulting character offset - */ - - -/** - * g_utf8_prev_char: - * @p: a pointer to a position within a UTF-8 encoded string - * - * Finds the previous UTF-8 character in the string before @p. - * - * @p does not have to be at the beginning of a UTF-8 character. No check - * is made to see if the character found is actually valid other than - * it starts with an appropriate byte. If @p might be the first - * character of the string, you must use g_utf8_find_prev_char() instead. - * - * Returns: (transfer none) (not nullable): a pointer to the found character - */ - - -/** - * g_utf8_strchr: - * @p: a nul-terminated UTF-8 encoded string - * @len: the maximum length of @p - * @c: a Unicode character - * - * Finds the leftmost occurrence of the given Unicode character - * in a UTF-8 encoded string, while limiting the search to @len bytes. - * If @len is -1, allow unbounded search. - * - * Returns: (transfer none) (nullable): %NULL if the string does not contain the character, - * otherwise, a pointer to the start of the leftmost occurrence - * of the character in the string. - */ - - -/** - * g_utf8_strdown: - * @str: a UTF-8 encoded string - * @len: length of @str, in bytes, or -1 if @str is nul-terminated. - * - * Converts all Unicode characters in the string that have a case - * to lowercase. The exact manner that this is done depends - * on the current locale, and may result in the number of - * characters in the string changing. - * - * Returns: a newly allocated string, with all characters - * converted to lowercase. - */ - - -/** - * g_utf8_strlen: - * @p: pointer to the start of a UTF-8 encoded string - * @max: the maximum number of bytes to examine. If @max - * is less than 0, then the string is assumed to be - * nul-terminated. If @max is 0, @p will not be examined and - * may be %NULL. If @max is greater than 0, up to @max - * bytes are examined - * - * Computes the length of the string in characters, not including - * the terminating nul character. If the @max'th byte falls in the - * middle of a character, the last (partial) character is not counted. - * - * Returns: the length of the string in characters - */ - - -/** - * g_utf8_strncpy: - * @dest: (transfer none): buffer to fill with characters from @src - * @src: UTF-8 encoded string - * @n: character count - * - * Like the standard C strncpy() function, but copies a given number - * of characters instead of a given number of bytes. The @src string - * must be valid UTF-8 encoded text. (Use g_utf8_validate() on all - * text before trying to use UTF-8 utility functions with it.) - * - * Note you must ensure @dest is at least 4 * @n to fit the - * largest possible UTF-8 characters - * - * Returns: (transfer none): @dest - */ - - -/** - * g_utf8_strrchr: - * @p: a nul-terminated UTF-8 encoded string - * @len: the maximum length of @p - * @c: a Unicode character - * - * Find the rightmost occurrence of the given Unicode character - * in a UTF-8 encoded string, while limiting the search to @len bytes. - * If @len is -1, allow unbounded search. - * - * Returns: (transfer none) (nullable): %NULL if the string does not contain the character, - * otherwise, a pointer to the start of the rightmost occurrence - * of the character in the string. - */ - - -/** - * g_utf8_strreverse: - * @str: a UTF-8 encoded string - * @len: the maximum length of @str to use, in bytes. If @len < 0, - * then the string is nul-terminated. - * - * Reverses a UTF-8 string. @str must be valid UTF-8 encoded text. - * (Use g_utf8_validate() on all text before trying to use UTF-8 - * utility functions with it.) - * - * This function is intended for programmatic uses of reversed strings. - * It pays no attention to decomposed characters, combining marks, byte - * order marks, directional indicators (LRM, LRO, etc) and similar - * characters which might need special handling when reversing a string - * for display purposes. - * - * Note that unlike g_strreverse(), this function returns - * newly-allocated memory, which should be freed with g_free() when - * no longer needed. - * - * Returns: (transfer full): a newly-allocated string which is the reverse of @str - * Since: 2.2 - */ - - -/** - * g_utf8_strup: - * @str: a UTF-8 encoded string - * @len: length of @str, in bytes, or -1 if @str is nul-terminated. - * - * Converts all Unicode characters in the string that have a case - * to uppercase. The exact manner that this is done depends - * on the current locale, and may result in the number of - * characters in the string increasing. (For instance, the - * German ess-zet will be changed to SS.) - * - * Returns: a newly allocated string, with all characters - * converted to uppercase. - */ - - -/** - * g_utf8_substring: - * @str: a UTF-8 encoded string - * @start_pos: a character offset within @str - * @end_pos: another character offset within @str - * - * Copies a substring out of a UTF-8 encoded string. - * The substring will contain @end_pos - @start_pos characters. - * - * Returns: (transfer full): a newly allocated copy of the requested - * substring. Free with g_free() when no longer needed. - * Since: 2.30 - */ - - -/** - * g_utf8_to_ucs4: - * @str: a UTF-8 encoded string - * @len: the maximum length of @str to use, in bytes. If @len < 0, - * then the string is nul-terminated. - * @items_read: (out) (optional): location to store number of - * bytes read, or %NULL. - * If %NULL, then %G_CONVERT_ERROR_PARTIAL_INPUT will be - * returned in case @str contains a trailing partial - * character. If an error occurs then the index of the - * invalid input is stored here. - * @items_written: (out) (optional): location to store number - * of characters written or %NULL. The value here stored does not include - * the trailing 0 character. - * @error: location to store the error occurring, or %NULL to ignore - * errors. Any of the errors in #GConvertError other than - * %G_CONVERT_ERROR_NO_CONVERSION may occur. - * - * Convert a string from UTF-8 to a 32-bit fixed width - * representation as UCS-4. A trailing 0 character will be added to the - * string after the converted text. - * - * Returns: (transfer full): a pointer to a newly allocated UCS-4 string. - * This value must be freed with g_free(). If an error occurs, - * %NULL will be returned and @error set. - */ - - -/** - * g_utf8_to_ucs4_fast: - * @str: a UTF-8 encoded string - * @len: the maximum length of @str to use, in bytes. If @len < 0, - * then the string is nul-terminated. - * @items_written: (out) (optional): location to store the - * number of characters in the result, or %NULL. - * - * Convert a string from UTF-8 to a 32-bit fixed width - * representation as UCS-4, assuming valid UTF-8 input. - * This function is roughly twice as fast as g_utf8_to_ucs4() - * but does no error checking on the input. A trailing 0 character - * will be added to the string after the converted text. - * - * Returns: (transfer full): a pointer to a newly allocated UCS-4 string. - * This value must be freed with g_free(). - */ - - -/** - * g_utf8_to_utf16: - * @str: a UTF-8 encoded string - * @len: the maximum length (number of bytes) of @str to use. - * If @len < 0, then the string is nul-terminated. - * @items_read: (out) (optional): location to store number of - * bytes read, or %NULL. If %NULL, then %G_CONVERT_ERROR_PARTIAL_INPUT will - * be returned in case @str contains a trailing partial character. If - * an error occurs then the index of the invalid input is stored here. - * @items_written: (out) (optional): location to store number - * of #gunichar2 written, or %NULL. The value stored here does not include - * the trailing 0. - * @error: location to store the error occurring, or %NULL to ignore - * errors. Any of the errors in #GConvertError other than - * %G_CONVERT_ERROR_NO_CONVERSION may occur. - * - * Convert a string from UTF-8 to UTF-16. A 0 character will be - * added to the result after the converted text. - * - * Returns: (transfer full): a pointer to a newly allocated UTF-16 string. - * This value must be freed with g_free(). If an error occurs, - * %NULL will be returned and @error set. - */ - - -/** - * g_utf8_validate: - * @str: (array length=max_len) (element-type guint8): a pointer to character data - * @max_len: max bytes to validate, or -1 to go until NUL - * @end: (out) (optional) (transfer none): return location for end of valid data - * - * Validates UTF-8 encoded text. @str is the text to validate; - * if @str is nul-terminated, then @max_len can be -1, otherwise - * @max_len should be the number of bytes to validate. - * If @end is non-%NULL, then the end of the valid range - * will be stored there (i.e. the start of the first invalid - * character if some bytes were invalid, or the end of the text - * being validated otherwise). - * - * Note that g_utf8_validate() returns %FALSE if @max_len is - * positive and any of the @max_len bytes are nul. - * - * Returns %TRUE if all of @str was valid. Many GLib and GTK+ - * routines require valid UTF-8 as input; so data read from a file - * or the network should be checked with g_utf8_validate() before - * doing anything else with it. - * - * Returns: %TRUE if the text was valid UTF-8 - */ - - -/** - * g_utf8_validate_len: - * @str: (array length=max_len) (element-type guint8): a pointer to character data - * @max_len: max bytes to validate - * @end: (out) (optional) (transfer none): return location for end of valid data - * - * Validates UTF-8 encoded text. - * - * As with g_utf8_validate(), but @max_len must be set, and hence this function - * will always return %FALSE if any of the bytes of @str are nul. - * - * Returns: %TRUE if the text was valid UTF-8 - * Since: 2.60 - */ - - -/** - * g_utime: - * @filename: (type filename): a pathname in the GLib file name encoding - * (UTF-8 on Windows) - * @utb: a pointer to a struct utimbuf. - * - * A wrapper for the POSIX utime() function. The utime() function - * sets the access and modification timestamps of a file. - * - * See your C library manual for more details about how utime() works - * on your system. - * - * Returns: 0 if the operation was successful, -1 if an error occurred - * Since: 2.18 - */ - - -/** - * g_uuid_string_is_valid: - * @str: a string representing a UUID - * - * Parses the string @str and verify if it is a UUID. - * - * The function accepts the following syntax: - * - * - simple forms (e.g. `f81d4fae-7dec-11d0-a765-00a0c91e6bf6`) - * - * Note that hyphens are required within the UUID string itself, - * as per the aforementioned RFC. - * - * Returns: %TRUE if @str is a valid UUID, %FALSE otherwise. - * Since: 2.52 - */ - - -/** - * g_uuid_string_random: - * - * Generates a random UUID (RFC 4122 version 4) as a string. It has the same - * randomness guarantees as #GRand, so must not be used for cryptographic - * purposes such as key generation, nonces, salts or one-time pads. - * - * Returns: (transfer full): A string that should be freed with g_free(). - * Since: 2.52 - */ - - -/** - * g_variant_builder_add: (skip) - * @builder: a #GVariantBuilder - * @format_string: a #GVariant varargs format string - * @...: arguments, as per @format_string - * - * Adds to a #GVariantBuilder. - * - * This call is a convenience wrapper that is exactly equivalent to - * calling g_variant_new() followed by g_variant_builder_add_value(). - * - * Note that the arguments must be of the correct width for their types - * specified in @format_string. This can be achieved by casting them. See - * the [GVariant varargs documentation][gvariant-varargs]. - * - * This function might be used as follows: - * - * |[<!-- language="C" --> - * GVariant * - * make_pointless_dictionary (void) - * { - * GVariantBuilder builder; - * int i; - * - * g_variant_builder_init (&builder, G_VARIANT_TYPE_ARRAY); - * for (i = 0; i < 16; i++) - * { - * gchar buf[3]; - * - * sprintf (buf, "%d", i); - * g_variant_builder_add (&builder, "{is}", i, buf); - * } - * - * return g_variant_builder_end (&builder); - * } - * ]| - * - * Since: 2.24 - */ - - -/** - * g_variant_builder_add_parsed: - * @builder: a #GVariantBuilder - * @format: a text format #GVariant - * @...: arguments as per @format - * - * Adds to a #GVariantBuilder. - * - * This call is a convenience wrapper that is exactly equivalent to - * calling g_variant_new_parsed() followed by - * g_variant_builder_add_value(). - * - * Note that the arguments must be of the correct width for their types - * specified in @format_string. This can be achieved by casting them. See - * the [GVariant varargs documentation][gvariant-varargs]. - * - * This function might be used as follows: - * - * |[<!-- language="C" --> - * GVariant * - * make_pointless_dictionary (void) - * { - * GVariantBuilder builder; - * int i; - * - * g_variant_builder_init (&builder, G_VARIANT_TYPE_ARRAY); - * g_variant_builder_add_parsed (&builder, "{'width', <%i>}", 600); - * g_variant_builder_add_parsed (&builder, "{'title', <%s>}", "foo"); - * g_variant_builder_add_parsed (&builder, "{'transparency', <0.5>}"); - * return g_variant_builder_end (&builder); - * } - * ]| - * - * Since: 2.26 - */ - - -/** - * g_variant_builder_add_value: - * @builder: a #GVariantBuilder - * @value: a #GVariant - * - * Adds @value to @builder. - * - * It is an error to call this function in any way that would create an - * inconsistent value to be constructed. Some examples of this are - * putting different types of items into an array, putting the wrong - * types or number of items in a tuple, putting more than one value into - * a variant, etc. - * - * If @value is a floating reference (see g_variant_ref_sink()), - * the @builder instance takes ownership of @value. - * - * Since: 2.24 - */ - - -/** - * g_variant_builder_clear: (skip) - * @builder: a #GVariantBuilder - * - * Releases all memory associated with a #GVariantBuilder without - * freeing the #GVariantBuilder structure itself. - * - * It typically only makes sense to do this on a stack-allocated - * #GVariantBuilder if you want to abort building the value part-way - * through. This function need not be called if you call - * g_variant_builder_end() and it also doesn't need to be called on - * builders allocated with g_variant_builder_new() (see - * g_variant_builder_unref() for that). - * - * This function leaves the #GVariantBuilder structure set to all-zeros. - * It is valid to call this function on either an initialised - * #GVariantBuilder or one that is set to all-zeros but it is not valid - * to call this function on uninitialised memory. - * - * Since: 2.24 - */ - - -/** - * g_variant_builder_close: - * @builder: a #GVariantBuilder - * - * Closes the subcontainer inside the given @builder that was opened by - * the most recent call to g_variant_builder_open(). - * - * It is an error to call this function in any way that would create an - * inconsistent value to be constructed (ie: too few values added to the - * subcontainer). - * - * Since: 2.24 - */ - - -/** - * g_variant_builder_end: - * @builder: a #GVariantBuilder - * - * Ends the builder process and returns the constructed value. - * - * It is not permissible to use @builder in any way after this call - * except for reference counting operations (in the case of a - * heap-allocated #GVariantBuilder) or by reinitialising it with - * g_variant_builder_init() (in the case of stack-allocated). This - * means that for the stack-allocated builders there is no need to - * call g_variant_builder_clear() after the call to - * g_variant_builder_end(). - * - * It is an error to call this function in any way that would create an - * inconsistent value to be constructed (ie: insufficient number of - * items added to a container with a specific number of children - * required). It is also an error to call this function if the builder - * was created with an indefinite array or maybe type and no children - * have been added; in this case it is impossible to infer the type of - * the empty array. - * - * Returns: (transfer none): a new, floating, #GVariant - * Since: 2.24 - */ - - -/** - * g_variant_builder_init: (skip) - * @builder: a #GVariantBuilder - * @type: a container type - * - * Initialises a #GVariantBuilder structure. - * - * @type must be non-%NULL. It specifies the type of container to - * construct. It can be an indefinite type such as - * %G_VARIANT_TYPE_ARRAY or a definite type such as "as" or "(ii)". - * Maybe, array, tuple, dictionary entry and variant-typed values may be - * constructed. - * - * After the builder is initialised, values are added using - * g_variant_builder_add_value() or g_variant_builder_add(). - * - * After all the child values are added, g_variant_builder_end() frees - * the memory associated with the builder and returns the #GVariant that - * was created. - * - * This function completely ignores the previous contents of @builder. - * On one hand this means that it is valid to pass in completely - * uninitialised memory. On the other hand, this means that if you are - * initialising over top of an existing #GVariantBuilder you need to - * first call g_variant_builder_clear() in order to avoid leaking - * memory. - * - * You must not call g_variant_builder_ref() or - * g_variant_builder_unref() on a #GVariantBuilder that was initialised - * with this function. If you ever pass a reference to a - * #GVariantBuilder outside of the control of your own code then you - * should assume that the person receiving that reference may try to use - * reference counting; you should use g_variant_builder_new() instead of - * this function. - * - * Since: 2.24 - */ - - -/** - * g_variant_builder_new: - * @type: a container type - * - * Allocates and initialises a new #GVariantBuilder. - * - * You should call g_variant_builder_unref() on the return value when it - * is no longer needed. The memory will not be automatically freed by - * any other call. - * - * In most cases it is easier to place a #GVariantBuilder directly on - * the stack of the calling function and initialise it with - * g_variant_builder_init(). - * - * Returns: (transfer full): a #GVariantBuilder - * Since: 2.24 - */ - - -/** - * g_variant_builder_open: - * @builder: a #GVariantBuilder - * @type: the #GVariantType of the container - * - * Opens a subcontainer inside the given @builder. When done adding - * items to the subcontainer, g_variant_builder_close() must be called. @type - * is the type of the container: so to build a tuple of several values, @type - * must include the tuple itself. - * - * It is an error to call this function in any way that would cause an - * inconsistent value to be constructed (ie: adding too many values or - * a value of an incorrect type). - * - * Example of building a nested variant: - * |[<!-- language="C" --> - * GVariantBuilder builder; - * guint32 some_number = get_number (); - * g_autoptr (GHashTable) some_dict = get_dict (); - * GHashTableIter iter; - * const gchar *key; - * const GVariant *value; - * g_autoptr (GVariant) output = NULL; - * - * g_variant_builder_init (&builder, G_VARIANT_TYPE ("(ua{sv})")); - * g_variant_builder_add (&builder, "u", some_number); - * g_variant_builder_open (&builder, G_VARIANT_TYPE ("a{sv}")); - * - * g_hash_table_iter_init (&iter, some_dict); - * while (g_hash_table_iter_next (&iter, (gpointer *) &key, (gpointer *) &value)) - * { - * g_variant_builder_open (&builder, G_VARIANT_TYPE ("{sv}")); - * g_variant_builder_add (&builder, "s", key); - * g_variant_builder_add (&builder, "v", value); - * g_variant_builder_close (&builder); - * } - * - * g_variant_builder_close (&builder); - * - * output = g_variant_builder_end (&builder); - * ]| - * - * Since: 2.24 - */ - - -/** - * g_variant_builder_ref: - * @builder: a #GVariantBuilder allocated by g_variant_builder_new() - * - * Increases the reference count on @builder. - * - * Don't call this on stack-allocated #GVariantBuilder instances or bad - * things will happen. - * - * Returns: (transfer full): a new reference to @builder - * Since: 2.24 - */ - - -/** - * g_variant_builder_unref: - * @builder: (transfer full): a #GVariantBuilder allocated by g_variant_builder_new() - * - * Decreases the reference count on @builder. - * - * In the event that there are no more references, releases all memory - * associated with the #GVariantBuilder. - * - * Don't call this on stack-allocated #GVariantBuilder instances or bad - * things will happen. - * - * Since: 2.24 - */ - - -/** - * g_variant_byteswap: - * @value: a #GVariant - * - * Performs a byteswapping operation on the contents of @value. The - * result is that all multi-byte numeric data contained in @value is - * byteswapped. That includes 16, 32, and 64bit signed and unsigned - * integers as well as file handles and double precision floating point - * values. - * - * This function is an identity mapping on any value that does not - * contain multi-byte numeric data. That include strings, booleans, - * bytes and containers containing only these things (recursively). - * - * The returned value is always in normal form and is marked as trusted. - * - * Returns: (transfer full): the byteswapped form of @value - * Since: 2.24 - */ - - -/** - * g_variant_check_format_string: - * @value: a #GVariant - * @format_string: a valid #GVariant format string - * @copy_only: %TRUE to ensure the format string makes deep copies - * - * Checks if calling g_variant_get() with @format_string on @value would - * be valid from a type-compatibility standpoint. @format_string is - * assumed to be a valid format string (from a syntactic standpoint). - * - * If @copy_only is %TRUE then this function additionally checks that it - * would be safe to call g_variant_unref() on @value immediately after - * the call to g_variant_get() without invalidating the result. This is - * only possible if deep copies are made (ie: there are no pointers to - * the data inside of the soon-to-be-freed #GVariant instance). If this - * check fails then a g_critical() is printed and %FALSE is returned. - * - * This function is meant to be used by functions that wish to provide - * varargs accessors to #GVariant values of uncertain values (eg: - * g_variant_lookup() or g_menu_model_get_item_attribute()). - * - * Returns: %TRUE if @format_string is safe to use - * Since: 2.34 - */ - - -/** - * g_variant_classify: - * @value: a #GVariant - * - * Classifies @value according to its top-level type. - * - * Returns: the #GVariantClass of @value - * Since: 2.24 - */ - - -/** - * g_variant_compare: - * @one: (type GVariant): a basic-typed #GVariant instance - * @two: (type GVariant): a #GVariant instance of the same type - * - * Compares @one and @two. - * - * The types of @one and @two are #gconstpointer only to allow use of - * this function with #GTree, #GPtrArray, etc. They must each be a - * #GVariant. - * - * Comparison is only defined for basic types (ie: booleans, numbers, - * strings). For booleans, %FALSE is less than %TRUE. Numbers are - * ordered in the usual way. Strings are in ASCII lexographical order. - * - * It is a programmer error to attempt to compare container values or - * two values that have types that are not exactly equal. For example, - * you cannot compare a 32-bit signed integer with a 32-bit unsigned - * integer. Also note that this function is not particularly - * well-behaved when it comes to comparison of doubles; in particular, - * the handling of incomparable values (ie: NaN) is undefined. - * - * If you only require an equality comparison, g_variant_equal() is more - * general. - * - * Returns: negative value if a < b; - * zero if a = b; - * positive value if a > b. - * Since: 2.26 - */ - - -/** - * g_variant_dict_clear: - * @dict: a #GVariantDict - * - * Releases all memory associated with a #GVariantDict without freeing - * the #GVariantDict structure itself. - * - * It typically only makes sense to do this on a stack-allocated - * #GVariantDict if you want to abort building the value part-way - * through. This function need not be called if you call - * g_variant_dict_end() and it also doesn't need to be called on dicts - * allocated with g_variant_dict_new (see g_variant_dict_unref() for - * that). - * - * It is valid to call this function on either an initialised - * #GVariantDict or one that was previously cleared by an earlier call - * to g_variant_dict_clear() but it is not valid to call this function - * on uninitialised memory. - * - * Since: 2.40 - */ - - -/** - * g_variant_dict_contains: - * @dict: a #GVariantDict - * @key: the key to look up in the dictionary - * - * Checks if @key exists in @dict. - * - * Returns: %TRUE if @key is in @dict - * Since: 2.40 - */ - - -/** - * g_variant_dict_end: - * @dict: a #GVariantDict - * - * Returns the current value of @dict as a #GVariant of type - * %G_VARIANT_TYPE_VARDICT, clearing it in the process. - * - * It is not permissible to use @dict in any way after this call except - * for reference counting operations (in the case of a heap-allocated - * #GVariantDict) or by reinitialising it with g_variant_dict_init() (in - * the case of stack-allocated). - * - * Returns: (transfer none): a new, floating, #GVariant - * Since: 2.40 - */ - - -/** - * g_variant_dict_init: (skip) - * @dict: a #GVariantDict - * @from_asv: (nullable): the initial value for @dict - * - * Initialises a #GVariantDict structure. - * - * If @from_asv is given, it is used to initialise the dictionary. - * - * This function completely ignores the previous contents of @dict. On - * one hand this means that it is valid to pass in completely - * uninitialised memory. On the other hand, this means that if you are - * initialising over top of an existing #GVariantDict you need to first - * call g_variant_dict_clear() in order to avoid leaking memory. - * - * You must not call g_variant_dict_ref() or g_variant_dict_unref() on a - * #GVariantDict that was initialised with this function. If you ever - * pass a reference to a #GVariantDict outside of the control of your - * own code then you should assume that the person receiving that - * reference may try to use reference counting; you should use - * g_variant_dict_new() instead of this function. - * - * Since: 2.40 - */ - - -/** - * g_variant_dict_insert: - * @dict: a #GVariantDict - * @key: the key to insert a value for - * @format_string: a #GVariant varargs format string - * @...: arguments, as per @format_string - * - * Inserts a value into a #GVariantDict. - * - * This call is a convenience wrapper that is exactly equivalent to - * calling g_variant_new() followed by g_variant_dict_insert_value(). - * - * Since: 2.40 - */ - - -/** - * g_variant_dict_insert_value: - * @dict: a #GVariantDict - * @key: the key to insert a value for - * @value: the value to insert - * - * Inserts (or replaces) a key in a #GVariantDict. - * - * @value is consumed if it is floating. - * - * Since: 2.40 - */ - - -/** - * g_variant_dict_lookup: - * @dict: a #GVariantDict - * @key: the key to look up in the dictionary - * @format_string: a GVariant format string - * @...: the arguments to unpack the value into - * - * Looks up a value in a #GVariantDict. - * - * This function is a wrapper around g_variant_dict_lookup_value() and - * g_variant_get(). In the case that %NULL would have been returned, - * this function returns %FALSE. Otherwise, it unpacks the returned - * value and returns %TRUE. - * - * @format_string determines the C types that are used for unpacking the - * values and also determines if the values are copied or borrowed, see the - * section on [GVariant format strings][gvariant-format-strings-pointers]. - * - * Returns: %TRUE if a value was unpacked - * Since: 2.40 - */ - - -/** - * g_variant_dict_lookup_value: - * @dict: a #GVariantDict - * @key: the key to look up in the dictionary - * @expected_type: (nullable): a #GVariantType, or %NULL - * - * Looks up a value in a #GVariantDict. - * - * If @key is not found in @dictionary, %NULL is returned. - * - * The @expected_type string specifies what type of value is expected. - * If the value associated with @key has a different type then %NULL is - * returned. - * - * If the key is found and the value has the correct type, it is - * returned. If @expected_type was specified then any non-%NULL return - * value will have this type. - * - * Returns: (transfer full): the value of the dictionary key, or %NULL - * Since: 2.40 - */ - - -/** - * g_variant_dict_new: - * @from_asv: (nullable): the #GVariant with which to initialise the - * dictionary - * - * Allocates and initialises a new #GVariantDict. - * - * You should call g_variant_dict_unref() on the return value when it - * is no longer needed. The memory will not be automatically freed by - * any other call. - * - * In some cases it may be easier to place a #GVariantDict directly on - * the stack of the calling function and initialise it with - * g_variant_dict_init(). This is particularly useful when you are - * using #GVariantDict to construct a #GVariant. - * - * Returns: (transfer full): a #GVariantDict - * Since: 2.40 - */ - - -/** - * g_variant_dict_ref: - * @dict: a heap-allocated #GVariantDict - * - * Increases the reference count on @dict. - * - * Don't call this on stack-allocated #GVariantDict instances or bad - * things will happen. - * - * Returns: (transfer full): a new reference to @dict - * Since: 2.40 - */ - - -/** - * g_variant_dict_remove: - * @dict: a #GVariantDict - * @key: the key to remove - * - * Removes a key and its associated value from a #GVariantDict. - * - * Returns: %TRUE if the key was found and removed - * Since: 2.40 - */ - - -/** - * g_variant_dict_unref: - * @dict: (transfer full): a heap-allocated #GVariantDict - * - * Decreases the reference count on @dict. - * - * In the event that there are no more references, releases all memory - * associated with the #GVariantDict. - * - * Don't call this on stack-allocated #GVariantDict instances or bad - * things will happen. - * - * Since: 2.40 - */ - - -/** - * g_variant_dup_bytestring: - * @value: an array-of-bytes #GVariant instance - * @length: (out) (optional) (default NULL): a pointer to a #gsize, to store - * the length (not including the nul terminator) - * - * Similar to g_variant_get_bytestring() except that instead of - * returning a constant string, the string is duplicated. - * - * The return value must be freed using g_free(). - * - * Returns: (transfer full) (array zero-terminated=1 length=length) (element-type guint8): - * a newly allocated string - * Since: 2.26 - */ - - -/** - * g_variant_dup_bytestring_array: - * @value: an array of array of bytes #GVariant ('aay') - * @length: (out) (optional): the length of the result, or %NULL - * - * Gets the contents of an array of array of bytes #GVariant. This call - * makes a deep copy; the return result should be released with - * g_strfreev(). - * - * If @length is non-%NULL then the number of elements in the result is - * stored there. In any case, the resulting array will be - * %NULL-terminated. - * - * For an empty array, @length will be set to 0 and a pointer to a - * %NULL pointer will be returned. - * - * Returns: (array length=length) (transfer full): an array of strings - * Since: 2.26 - */ - - -/** - * g_variant_dup_objv: - * @value: an array of object paths #GVariant - * @length: (out) (optional): the length of the result, or %NULL - * - * Gets the contents of an array of object paths #GVariant. This call - * makes a deep copy; the return result should be released with - * g_strfreev(). - * - * If @length is non-%NULL then the number of elements in the result - * is stored there. In any case, the resulting array will be - * %NULL-terminated. - * - * For an empty array, @length will be set to 0 and a pointer to a - * %NULL pointer will be returned. - * - * Returns: (array length=length zero-terminated=1) (transfer full): an array of strings - * Since: 2.30 - */ - - -/** - * g_variant_dup_string: - * @value: a string #GVariant instance - * @length: (out): a pointer to a #gsize, to store the length - * - * Similar to g_variant_get_string() except that instead of returning - * a constant string, the string is duplicated. - * - * The string will always be UTF-8 encoded. - * - * The return value must be freed using g_free(). - * - * Returns: (transfer full): a newly allocated string, UTF-8 encoded - * Since: 2.24 - */ - - -/** - * g_variant_dup_strv: - * @value: an array of strings #GVariant - * @length: (out) (optional): the length of the result, or %NULL - * - * Gets the contents of an array of strings #GVariant. This call - * makes a deep copy; the return result should be released with - * g_strfreev(). - * - * If @length is non-%NULL then the number of elements in the result - * is stored there. In any case, the resulting array will be - * %NULL-terminated. - * - * For an empty array, @length will be set to 0 and a pointer to a - * %NULL pointer will be returned. - * - * Returns: (array length=length zero-terminated=1) (transfer full): an array of strings - * Since: 2.24 - */ - - -/** - * g_variant_equal: - * @one: (type GVariant): a #GVariant instance - * @two: (type GVariant): a #GVariant instance - * - * Checks if @one and @two have the same type and value. - * - * The types of @one and @two are #gconstpointer only to allow use of - * this function with #GHashTable. They must each be a #GVariant. - * - * Returns: %TRUE if @one and @two are equal - * Since: 2.24 - */ - - -/** - * g_variant_get: (skip) - * @value: a #GVariant instance - * @format_string: a #GVariant format string - * @...: arguments, as per @format_string - * - * Deconstructs a #GVariant instance. - * - * Think of this function as an analogue to scanf(). - * - * The arguments that are expected by this function are entirely - * determined by @format_string. @format_string also restricts the - * permissible types of @value. It is an error to give a value with - * an incompatible type. See the section on - * [GVariant format strings][gvariant-format-strings]. - * Please note that the syntax of the format string is very likely to be - * extended in the future. - * - * @format_string determines the C types that are used for unpacking - * the values and also determines if the values are copied or borrowed, - * see the section on - * [GVariant format strings][gvariant-format-strings-pointers]. - * - * Since: 2.24 - */ - - -/** - * g_variant_get_boolean: - * @value: a boolean #GVariant instance - * - * Returns the boolean value of @value. - * - * It is an error to call this function with a @value of any type - * other than %G_VARIANT_TYPE_BOOLEAN. - * - * Returns: %TRUE or %FALSE - * Since: 2.24 - */ - - -/** - * g_variant_get_byte: - * @value: a byte #GVariant instance - * - * Returns the byte value of @value. - * - * It is an error to call this function with a @value of any type - * other than %G_VARIANT_TYPE_BYTE. - * - * Returns: a #guint8 - * Since: 2.24 - */ - - -/** - * g_variant_get_bytestring: - * @value: an array-of-bytes #GVariant instance - * - * Returns the string value of a #GVariant instance with an - * array-of-bytes type. The string has no particular encoding. - * - * If the array does not end with a nul terminator character, the empty - * string is returned. For this reason, you can always trust that a - * non-%NULL nul-terminated string will be returned by this function. - * - * If the array contains a nul terminator character somewhere other than - * the last byte then the returned string is the string, up to the first - * such nul character. - * - * g_variant_get_fixed_array() should be used instead if the array contains - * arbitrary data that could not be nul-terminated or could contain nul bytes. - * - * It is an error to call this function with a @value that is not an - * array of bytes. - * - * The return value remains valid as long as @value exists. - * - * Returns: (transfer none) (array zero-terminated=1) (element-type guint8): - * the constant string - * Since: 2.26 - */ - - -/** - * g_variant_get_bytestring_array: - * @value: an array of array of bytes #GVariant ('aay') - * @length: (out) (optional): the length of the result, or %NULL - * - * Gets the contents of an array of array of bytes #GVariant. This call - * makes a shallow copy; the return result should be released with - * g_free(), but the individual strings must not be modified. - * - * If @length is non-%NULL then the number of elements in the result is - * stored there. In any case, the resulting array will be - * %NULL-terminated. - * - * For an empty array, @length will be set to 0 and a pointer to a - * %NULL pointer will be returned. - * - * Returns: (array length=length) (transfer container): an array of constant strings - * Since: 2.26 - */ - - -/** - * g_variant_get_child: (skip) - * @value: a container #GVariant - * @index_: the index of the child to deconstruct - * @format_string: a #GVariant format string - * @...: arguments, as per @format_string - * - * Reads a child item out of a container #GVariant instance and - * deconstructs it according to @format_string. This call is - * essentially a combination of g_variant_get_child_value() and - * g_variant_get(). - * - * @format_string determines the C types that are used for unpacking - * the values and also determines if the values are copied or borrowed, - * see the section on - * [GVariant format strings][gvariant-format-strings-pointers]. - * - * Since: 2.24 - */ - - -/** - * g_variant_get_child_value: - * @value: a container #GVariant - * @index_: the index of the child to fetch - * - * Reads a child item out of a container #GVariant instance. This - * includes variants, maybes, arrays, tuples and dictionary - * entries. It is an error to call this function on any other type of - * #GVariant. - * - * It is an error if @index_ is greater than the number of child items - * in the container. See g_variant_n_children(). - * - * The returned value is never floating. You should free it with - * g_variant_unref() when you're done with it. - * - * Note that values borrowed from the returned child are not guaranteed to - * still be valid after the child is freed even if you still hold a reference - * to @value, if @value has not been serialized at the time this function is - * called. To avoid this, you can serialize @value by calling - * g_variant_get_data() and optionally ignoring the return value. - * - * There may be implementation specific restrictions on deeply nested values, - * which would result in the unit tuple being returned as the child value, - * instead of further nested children. #GVariant is guaranteed to handle - * nesting up to at least 64 levels. - * - * This function is O(1). - * - * Returns: (transfer full): the child at the specified index - * Since: 2.24 - */ - - -/** - * g_variant_get_data: - * @value: a #GVariant instance - * - * Returns a pointer to the serialized form of a #GVariant instance. - * The returned data may not be in fully-normalised form if read from an - * untrusted source. The returned data must not be freed; it remains - * valid for as long as @value exists. - * - * If @value is a fixed-sized value that was deserialized from a - * corrupted serialized container then %NULL may be returned. In this - * case, the proper thing to do is typically to use the appropriate - * number of nul bytes in place of @value. If @value is not fixed-sized - * then %NULL is never returned. - * - * In the case that @value is already in serialized form, this function - * is O(1). If the value is not already in serialized form, - * serialization occurs implicitly and is approximately O(n) in the size - * of the result. - * - * To deserialize the data returned by this function, in addition to the - * serialized data, you must know the type of the #GVariant, and (if the - * machine might be different) the endianness of the machine that stored - * it. As a result, file formats or network messages that incorporate - * serialized #GVariants must include this information either - * implicitly (for instance "the file always contains a - * %G_VARIANT_TYPE_VARIANT and it is always in little-endian order") or - * explicitly (by storing the type and/or endianness in addition to the - * serialized data). - * - * Returns: (transfer none): the serialized form of @value, or %NULL - * Since: 2.24 - */ - - -/** - * g_variant_get_data_as_bytes: - * @value: a #GVariant - * - * Returns a pointer to the serialized form of a #GVariant instance. - * The semantics of this function are exactly the same as - * g_variant_get_data(), except that the returned #GBytes holds - * a reference to the variant data. - * - * Returns: (transfer full): A new #GBytes representing the variant data - * Since: 2.36 - */ - - -/** - * g_variant_get_double: - * @value: a double #GVariant instance - * - * Returns the double precision floating point value of @value. - * - * It is an error to call this function with a @value of any type - * other than %G_VARIANT_TYPE_DOUBLE. - * - * Returns: a #gdouble - * Since: 2.24 - */ - - -/** - * g_variant_get_fixed_array: - * @value: a #GVariant array with fixed-sized elements - * @n_elements: (out): a pointer to the location to store the number of items - * @element_size: the size of each element - * - * Provides access to the serialized data for an array of fixed-sized - * items. - * - * @value must be an array with fixed-sized elements. Numeric types are - * fixed-size, as are tuples containing only other fixed-sized types. - * - * @element_size must be the size of a single element in the array, - * as given by the section on - * [serialized data memory][gvariant-serialized-data-memory]. - * - * In particular, arrays of these fixed-sized types can be interpreted - * as an array of the given C type, with @element_size set to the size - * the appropriate type: - * - %G_VARIANT_TYPE_INT16 (etc.): #gint16 (etc.) - * - %G_VARIANT_TYPE_BOOLEAN: #guchar (not #gboolean!) - * - %G_VARIANT_TYPE_BYTE: #guint8 - * - %G_VARIANT_TYPE_HANDLE: #guint32 - * - %G_VARIANT_TYPE_DOUBLE: #gdouble - * - * For example, if calling this function for an array of 32-bit integers, - * you might say `sizeof(gint32)`. This value isn't used except for the purpose - * of a double-check that the form of the serialized data matches the caller's - * expectation. - * - * @n_elements, which must be non-%NULL, is set equal to the number of - * items in the array. - * - * Returns: (array length=n_elements) (transfer none): a pointer to - * the fixed array - * Since: 2.24 - */ - - -/** - * g_variant_get_handle: - * @value: a handle #GVariant instance - * - * Returns the 32-bit signed integer value of @value. - * - * It is an error to call this function with a @value of any type other - * than %G_VARIANT_TYPE_HANDLE. - * - * By convention, handles are indexes into an array of file descriptors - * that are sent alongside a D-Bus message. If you're not interacting - * with D-Bus, you probably don't need them. - * - * Returns: a #gint32 - * Since: 2.24 - */ - - -/** - * g_variant_get_int16: - * @value: an int16 #GVariant instance - * - * Returns the 16-bit signed integer value of @value. - * - * It is an error to call this function with a @value of any type - * other than %G_VARIANT_TYPE_INT16. - * - * Returns: a #gint16 - * Since: 2.24 - */ - - -/** - * g_variant_get_int32: - * @value: an int32 #GVariant instance - * - * Returns the 32-bit signed integer value of @value. - * - * It is an error to call this function with a @value of any type - * other than %G_VARIANT_TYPE_INT32. - * - * Returns: a #gint32 - * Since: 2.24 - */ - - -/** - * g_variant_get_int64: - * @value: an int64 #GVariant instance - * - * Returns the 64-bit signed integer value of @value. - * - * It is an error to call this function with a @value of any type - * other than %G_VARIANT_TYPE_INT64. - * - * Returns: a #gint64 - * Since: 2.24 - */ - - -/** - * g_variant_get_maybe: - * @value: a maybe-typed value - * - * Given a maybe-typed #GVariant instance, extract its value. If the - * value is Nothing, then this function returns %NULL. - * - * Returns: (nullable) (transfer full): the contents of @value, or %NULL - * Since: 2.24 - */ - - -/** - * g_variant_get_normal_form: - * @value: a #GVariant - * - * Gets a #GVariant instance that has the same value as @value and is - * trusted to be in normal form. - * - * If @value is already trusted to be in normal form then a new - * reference to @value is returned. - * - * If @value is not already trusted, then it is scanned to check if it - * is in normal form. If it is found to be in normal form then it is - * marked as trusted and a new reference to it is returned. - * - * If @value is found not to be in normal form then a new trusted - * #GVariant is created with the same value as @value. - * - * It makes sense to call this function if you've received #GVariant - * data from untrusted sources and you want to ensure your serialized - * output is definitely in normal form. - * - * If @value is already in normal form, a new reference will be returned - * (which will be floating if @value is floating). If it is not in normal form, - * the newly created #GVariant will be returned with a single non-floating - * reference. Typically, g_variant_take_ref() should be called on the return - * value from this function to guarantee ownership of a single non-floating - * reference to it. - * - * Returns: (transfer full): a trusted #GVariant - * Since: 2.24 - */ - - -/** - * g_variant_get_objv: - * @value: an array of object paths #GVariant - * @length: (out) (optional): the length of the result, or %NULL - * - * Gets the contents of an array of object paths #GVariant. This call - * makes a shallow copy; the return result should be released with - * g_free(), but the individual strings must not be modified. - * - * If @length is non-%NULL then the number of elements in the result - * is stored there. In any case, the resulting array will be - * %NULL-terminated. - * - * For an empty array, @length will be set to 0 and a pointer to a - * %NULL pointer will be returned. - * - * Returns: (array length=length zero-terminated=1) (transfer container): an array of constant strings - * Since: 2.30 - */ - - -/** - * g_variant_get_size: - * @value: a #GVariant instance - * - * Determines the number of bytes that would be required to store @value - * with g_variant_store(). - * - * If @value has a fixed-sized type then this function always returned - * that fixed size. - * - * In the case that @value is already in serialized form or the size has - * already been calculated (ie: this function has been called before) - * then this function is O(1). Otherwise, the size is calculated, an - * operation which is approximately O(n) in the number of values - * involved. - * - * Returns: the serialized size of @value - * Since: 2.24 - */ - - -/** - * g_variant_get_string: - * @value: a string #GVariant instance - * @length: (optional) (default 0) (out): a pointer to a #gsize, - * to store the length - * - * Returns the string value of a #GVariant instance with a string - * type. This includes the types %G_VARIANT_TYPE_STRING, - * %G_VARIANT_TYPE_OBJECT_PATH and %G_VARIANT_TYPE_SIGNATURE. - * - * The string will always be UTF-8 encoded, will never be %NULL, and will never - * contain nul bytes. - * - * If @length is non-%NULL then the length of the string (in bytes) is - * returned there. For trusted values, this information is already - * known. Untrusted values will be validated and, if valid, a strlen() will be - * performed. If invalid, a default value will be returned — for - * %G_VARIANT_TYPE_OBJECT_PATH, this is `"/"`, and for other types it is the - * empty string. - * - * It is an error to call this function with a @value of any type - * other than those three. - * - * The return value remains valid as long as @value exists. - * - * Returns: (transfer none): the constant string, UTF-8 encoded - * Since: 2.24 - */ - - -/** - * g_variant_get_strv: - * @value: an array of strings #GVariant - * @length: (out) (optional): the length of the result, or %NULL - * - * Gets the contents of an array of strings #GVariant. This call - * makes a shallow copy; the return result should be released with - * g_free(), but the individual strings must not be modified. - * - * If @length is non-%NULL then the number of elements in the result - * is stored there. In any case, the resulting array will be - * %NULL-terminated. - * - * For an empty array, @length will be set to 0 and a pointer to a - * %NULL pointer will be returned. - * - * Returns: (array length=length zero-terminated=1) (transfer container): an array of constant strings - * Since: 2.24 - */ - - -/** - * g_variant_get_type: - * @value: a #GVariant - * - * Determines the type of @value. - * - * The return value is valid for the lifetime of @value and must not - * be freed. - * - * Returns: a #GVariantType - * Since: 2.24 - */ - - -/** - * g_variant_get_type_string: - * @value: a #GVariant - * - * Returns the type string of @value. Unlike the result of calling - * g_variant_type_peek_string(), this string is nul-terminated. This - * string belongs to #GVariant and must not be freed. - * - * Returns: the type string for the type of @value - * Since: 2.24 - */ - - -/** - * g_variant_get_uint16: - * @value: a uint16 #GVariant instance - * - * Returns the 16-bit unsigned integer value of @value. - * - * It is an error to call this function with a @value of any type - * other than %G_VARIANT_TYPE_UINT16. - * - * Returns: a #guint16 - * Since: 2.24 - */ - - -/** - * g_variant_get_uint32: - * @value: a uint32 #GVariant instance - * - * Returns the 32-bit unsigned integer value of @value. - * - * It is an error to call this function with a @value of any type - * other than %G_VARIANT_TYPE_UINT32. - * - * Returns: a #guint32 - * Since: 2.24 - */ - - -/** - * g_variant_get_uint64: - * @value: a uint64 #GVariant instance - * - * Returns the 64-bit unsigned integer value of @value. - * - * It is an error to call this function with a @value of any type - * other than %G_VARIANT_TYPE_UINT64. - * - * Returns: a #guint64 - * Since: 2.24 - */ - - -/** - * g_variant_get_va: (skip) - * @value: a #GVariant - * @format_string: a string that is prefixed with a format string - * @endptr: (nullable) (default NULL): location to store the end pointer, - * or %NULL - * @app: a pointer to a #va_list - * - * This function is intended to be used by libraries based on #GVariant - * that want to provide g_variant_get()-like functionality to their - * users. - * - * The API is more general than g_variant_get() to allow a wider range - * of possible uses. - * - * @format_string must still point to a valid format string, but it only - * need to be nul-terminated if @endptr is %NULL. If @endptr is - * non-%NULL then it is updated to point to the first character past the - * end of the format string. - * - * @app is a pointer to a #va_list. The arguments, according to - * @format_string, are collected from this #va_list and the list is left - * pointing to the argument following the last. - * - * These two generalisations allow mixing of multiple calls to - * g_variant_new_va() and g_variant_get_va() within a single actual - * varargs call by the user. - * - * @format_string determines the C types that are used for unpacking - * the values and also determines if the values are copied or borrowed, - * see the section on - * [GVariant format strings][gvariant-format-strings-pointers]. - * - * Since: 2.24 - */ - - -/** - * g_variant_get_variant: - * @value: a variant #GVariant instance - * - * Unboxes @value. The result is the #GVariant instance that was - * contained in @value. - * - * Returns: (transfer full): the item contained in the variant - * Since: 2.24 - */ - - -/** - * g_variant_hash: - * @value: (type GVariant): a basic #GVariant value as a #gconstpointer - * - * Generates a hash value for a #GVariant instance. - * - * The output of this function is guaranteed to be the same for a given - * value only per-process. It may change between different processor - * architectures or even different versions of GLib. Do not use this - * function as a basis for building protocols or file formats. - * - * The type of @value is #gconstpointer only to allow use of this - * function with #GHashTable. @value must be a #GVariant. - * - * Returns: a hash value corresponding to @value - * Since: 2.24 - */ - - -/** - * g_variant_is_container: - * @value: a #GVariant instance - * - * Checks if @value is a container. - * - * Returns: %TRUE if @value is a container - * Since: 2.24 - */ - - -/** - * g_variant_is_floating: - * @value: a #GVariant - * - * Checks whether @value has a floating reference count. - * - * This function should only ever be used to assert that a given variant - * is or is not floating, or for debug purposes. To acquire a reference - * to a variant that might be floating, always use g_variant_ref_sink() - * or g_variant_take_ref(). - * - * See g_variant_ref_sink() for more information about floating reference - * counts. - * - * Returns: whether @value is floating - * Since: 2.26 - */ - - -/** - * g_variant_is_normal_form: - * @value: a #GVariant instance - * - * Checks if @value is in normal form. - * - * The main reason to do this is to detect if a given chunk of - * serialized data is in normal form: load the data into a #GVariant - * using g_variant_new_from_data() and then use this function to - * check. - * - * If @value is found to be in normal form then it will be marked as - * being trusted. If the value was already marked as being trusted then - * this function will immediately return %TRUE. - * - * There may be implementation specific restrictions on deeply nested values. - * GVariant is guaranteed to handle nesting up to at least 64 levels. - * - * Returns: %TRUE if @value is in normal form - * Since: 2.24 - */ - - -/** - * g_variant_is_object_path: - * @string: a normal C nul-terminated string - * - * Determines if a given string is a valid D-Bus object path. You - * should ensure that a string is a valid D-Bus object path before - * passing it to g_variant_new_object_path(). - * - * A valid object path starts with `/` followed by zero or more - * sequences of characters separated by `/` characters. Each sequence - * must contain only the characters `[A-Z][a-z][0-9]_`. No sequence - * (including the one following the final `/` character) may be empty. - * - * Returns: %TRUE if @string is a D-Bus object path - * Since: 2.24 - */ - - -/** - * g_variant_is_of_type: - * @value: a #GVariant instance - * @type: a #GVariantType - * - * Checks if a value has a type matching the provided type. - * - * Returns: %TRUE if the type of @value matches @type - * Since: 2.24 - */ - - -/** - * g_variant_is_signature: - * @string: a normal C nul-terminated string - * - * Determines if a given string is a valid D-Bus type signature. You - * should ensure that a string is a valid D-Bus type signature before - * passing it to g_variant_new_signature(). - * - * D-Bus type signatures consist of zero or more definite #GVariantType - * strings in sequence. - * - * Returns: %TRUE if @string is a D-Bus type signature - * Since: 2.24 - */ - - -/** - * g_variant_iter_copy: - * @iter: a #GVariantIter - * - * Creates a new heap-allocated #GVariantIter to iterate over the - * container that was being iterated over by @iter. Iteration begins on - * the new iterator from the current position of the old iterator but - * the two copies are independent past that point. - * - * Use g_variant_iter_free() to free the return value when you no longer - * need it. - * - * A reference is taken to the container that @iter is iterating over - * and will be related only when g_variant_iter_free() is called. - * - * Returns: (transfer full): a new heap-allocated #GVariantIter - * Since: 2.24 - */ - - -/** - * g_variant_iter_free: - * @iter: (transfer full): a heap-allocated #GVariantIter - * - * Frees a heap-allocated #GVariantIter. Only call this function on - * iterators that were returned by g_variant_iter_new() or - * g_variant_iter_copy(). - * - * Since: 2.24 - */ - - -/** - * g_variant_iter_init: (skip) - * @iter: a pointer to a #GVariantIter - * @value: a container #GVariant - * - * Initialises (without allocating) a #GVariantIter. @iter may be - * completely uninitialised prior to this call; its old value is - * ignored. - * - * The iterator remains valid for as long as @value exists, and need not - * be freed in any way. - * - * Returns: the number of items in @value - * Since: 2.24 - */ - - -/** - * g_variant_iter_loop: (skip) - * @iter: a #GVariantIter - * @format_string: a GVariant format string - * @...: the arguments to unpack the value into - * - * Gets the next item in the container and unpacks it into the variable - * argument list according to @format_string, returning %TRUE. - * - * If no more items remain then %FALSE is returned. - * - * On the first call to this function, the pointers appearing on the - * variable argument list are assumed to point at uninitialised memory. - * On the second and later calls, it is assumed that the same pointers - * will be given and that they will point to the memory as set by the - * previous call to this function. This allows the previous values to - * be freed, as appropriate. - * - * This function is intended to be used with a while loop as - * demonstrated in the following example. This function can only be - * used when iterating over an array. It is only valid to call this - * function with a string constant for the format string and the same - * string constant must be used each time. Mixing calls to this - * function and g_variant_iter_next() or g_variant_iter_next_value() on - * the same iterator causes undefined behavior. - * - * If you break out of a such a while loop using g_variant_iter_loop() then - * you must free or unreference all the unpacked values as you would with - * g_variant_get(). Failure to do so will cause a memory leak. - * - * Here is an example for memory management with g_variant_iter_loop(): - * |[<!-- language="C" --> - * // Iterates a dictionary of type 'a{sv}' - * void - * iterate_dictionary (GVariant *dictionary) - * { - * GVariantIter iter; - * GVariant *value; - * gchar *key; - * - * g_variant_iter_init (&iter, dictionary); - * while (g_variant_iter_loop (&iter, "{sv}", &key, &value)) - * { - * g_print ("Item '%s' has type '%s'\n", key, - * g_variant_get_type_string (value)); - * - * // no need to free 'key' and 'value' here - * // unless breaking out of this loop - * } - * } - * ]| - * - * For most cases you should use g_variant_iter_next(). - * - * This function is really only useful when unpacking into #GVariant or - * #GVariantIter in order to allow you to skip the call to - * g_variant_unref() or g_variant_iter_free(). - * - * For example, if you are only looping over simple integer and string - * types, g_variant_iter_next() is definitely preferred. For string - * types, use the '&' prefix to avoid allocating any memory at all (and - * thereby avoiding the need to free anything as well). - * - * @format_string determines the C types that are used for unpacking - * the values and also determines if the values are copied or borrowed. - * - * See the section on - * [GVariant format strings][gvariant-format-strings-pointers]. - * - * Returns: %TRUE if a value was unpacked, or %FALSE if there was no - * value - * Since: 2.24 - */ - - -/** - * g_variant_iter_n_children: - * @iter: a #GVariantIter - * - * Queries the number of child items in the container that we are - * iterating over. This is the total number of items -- not the number - * of items remaining. - * - * This function might be useful for preallocation of arrays. - * - * Returns: the number of children in the container - * Since: 2.24 - */ - - -/** - * g_variant_iter_new: - * @value: a container #GVariant - * - * Creates a heap-allocated #GVariantIter for iterating over the items - * in @value. - * - * Use g_variant_iter_free() to free the return value when you no longer - * need it. - * - * A reference is taken to @value and will be released only when - * g_variant_iter_free() is called. - * - * Returns: (transfer full): a new heap-allocated #GVariantIter - * Since: 2.24 - */ - - -/** - * g_variant_iter_next: (skip) - * @iter: a #GVariantIter - * @format_string: a GVariant format string - * @...: the arguments to unpack the value into - * - * Gets the next item in the container and unpacks it into the variable - * argument list according to @format_string, returning %TRUE. - * - * If no more items remain then %FALSE is returned. - * - * All of the pointers given on the variable arguments list of this - * function are assumed to point at uninitialised memory. It is the - * responsibility of the caller to free all of the values returned by - * the unpacking process. - * - * Here is an example for memory management with g_variant_iter_next(): - * |[<!-- language="C" --> - * // Iterates a dictionary of type 'a{sv}' - * void - * iterate_dictionary (GVariant *dictionary) - * { - * GVariantIter iter; - * GVariant *value; - * gchar *key; - * - * g_variant_iter_init (&iter, dictionary); - * while (g_variant_iter_next (&iter, "{sv}", &key, &value)) - * { - * g_print ("Item '%s' has type '%s'\n", key, - * g_variant_get_type_string (value)); - * - * // must free data for ourselves - * g_variant_unref (value); - * g_free (key); - * } - * } - * ]| - * - * For a solution that is likely to be more convenient to C programmers - * when dealing with loops, see g_variant_iter_loop(). - * - * @format_string determines the C types that are used for unpacking - * the values and also determines if the values are copied or borrowed. - * - * See the section on - * [GVariant format strings][gvariant-format-strings-pointers]. - * - * Returns: %TRUE if a value was unpacked, or %FALSE if there as no value - * Since: 2.24 - */ - - -/** - * g_variant_iter_next_value: - * @iter: a #GVariantIter - * - * Gets the next item in the container. If no more items remain then - * %NULL is returned. - * - * Use g_variant_unref() to drop your reference on the return value when - * you no longer need it. - * - * Here is an example for iterating with g_variant_iter_next_value(): - * |[<!-- language="C" --> - * // recursively iterate a container - * void - * iterate_container_recursive (GVariant *container) - * { - * GVariantIter iter; - * GVariant *child; - * - * g_variant_iter_init (&iter, container); - * while ((child = g_variant_iter_next_value (&iter))) - * { - * g_print ("type '%s'\n", g_variant_get_type_string (child)); - * - * if (g_variant_is_container (child)) - * iterate_container_recursive (child); - * - * g_variant_unref (child); - * } - * } - * ]| - * - * Returns: (nullable) (transfer full): a #GVariant, or %NULL - * Since: 2.24 - */ - - -/** - * g_variant_lookup: (skip) - * @dictionary: a dictionary #GVariant - * @key: the key to look up in the dictionary - * @format_string: a GVariant format string - * @...: the arguments to unpack the value into - * - * Looks up a value in a dictionary #GVariant. - * - * This function is a wrapper around g_variant_lookup_value() and - * g_variant_get(). In the case that %NULL would have been returned, - * this function returns %FALSE. Otherwise, it unpacks the returned - * value and returns %TRUE. - * - * @format_string determines the C types that are used for unpacking - * the values and also determines if the values are copied or borrowed, - * see the section on - * [GVariant format strings][gvariant-format-strings-pointers]. - * - * This function is currently implemented with a linear scan. If you - * plan to do many lookups then #GVariantDict may be more efficient. - * - * Returns: %TRUE if a value was unpacked - * Since: 2.28 - */ - - -/** - * g_variant_lookup_value: - * @dictionary: a dictionary #GVariant - * @key: the key to look up in the dictionary - * @expected_type: (nullable): a #GVariantType, or %NULL - * - * Looks up a value in a dictionary #GVariant. - * - * This function works with dictionaries of the type a{s*} (and equally - * well with type a{o*}, but we only further discuss the string case - * for sake of clarity). - * - * In the event that @dictionary has the type a{sv}, the @expected_type - * string specifies what type of value is expected to be inside of the - * variant. If the value inside the variant has a different type then - * %NULL is returned. In the event that @dictionary has a value type other - * than v then @expected_type must directly match the value type and it is - * used to unpack the value directly or an error occurs. - * - * In either case, if @key is not found in @dictionary, %NULL is returned. - * - * If the key is found and the value has the correct type, it is - * returned. If @expected_type was specified then any non-%NULL return - * value will have this type. - * - * This function is currently implemented with a linear scan. If you - * plan to do many lookups then #GVariantDict may be more efficient. - * - * Returns: (transfer full): the value of the dictionary key, or %NULL - * Since: 2.28 - */ - - -/** - * g_variant_n_children: - * @value: a container #GVariant - * - * Determines the number of children in a container #GVariant instance. - * This includes variants, maybes, arrays, tuples and dictionary - * entries. It is an error to call this function on any other type of - * #GVariant. - * - * For variants, the return value is always 1. For values with maybe - * types, it is always zero or one. For arrays, it is the length of the - * array. For tuples it is the number of tuple items (which depends - * only on the type). For dictionary entries, it is always 2 - * - * This function is O(1). - * - * Returns: the number of children in the container - * Since: 2.24 - */ - - -/** - * g_variant_new: (skip) - * @format_string: a #GVariant format string - * @...: arguments, as per @format_string - * - * Creates a new #GVariant instance. - * - * Think of this function as an analogue to g_strdup_printf(). - * - * The type of the created instance and the arguments that are expected - * by this function are determined by @format_string. See the section on - * [GVariant format strings][gvariant-format-strings]. Please note that - * the syntax of the format string is very likely to be extended in the - * future. - * - * The first character of the format string must not be '*' '?' '@' or - * 'r'; in essence, a new #GVariant must always be constructed by this - * function (and not merely passed through it unmodified). - * - * Note that the arguments must be of the correct width for their types - * specified in @format_string. This can be achieved by casting them. See - * the [GVariant varargs documentation][gvariant-varargs]. - * - * |[<!-- language="C" --> - * MyFlags some_flags = FLAG_ONE | FLAG_TWO; - * const gchar *some_strings[] = { "a", "b", "c", NULL }; - * GVariant *new_variant; - * - * new_variant = g_variant_new ("(t^as)", - * // This cast is required. - * (guint64) some_flags, - * some_strings); - * ]| - * - * Returns: a new floating #GVariant instance - * Since: 2.24 - */ - - -/** - * g_variant_new_array: - * @child_type: (nullable): the element type of the new array - * @children: (nullable) (array length=n_children): an array of - * #GVariant pointers, the children - * @n_children: the length of @children - * - * Creates a new #GVariant array from @children. - * - * @child_type must be non-%NULL if @n_children is zero. Otherwise, the - * child type is determined by inspecting the first element of the - * @children array. If @child_type is non-%NULL then it must be a - * definite type. - * - * The items of the array are taken from the @children array. No entry - * in the @children array may be %NULL. - * - * All items in the array must have the same type, which must be the - * same as @child_type, if given. - * - * If the @children are floating references (see g_variant_ref_sink()), the - * new instance takes ownership of them as if via g_variant_ref_sink(). - * - * Returns: (transfer none): a floating reference to a new #GVariant array - * Since: 2.24 - */ - - -/** - * g_variant_new_boolean: - * @value: a #gboolean value - * - * Creates a new boolean #GVariant instance -- either %TRUE or %FALSE. - * - * Returns: (transfer none): a floating reference to a new boolean #GVariant instance - * Since: 2.24 - */ - - -/** - * g_variant_new_byte: - * @value: a #guint8 value - * - * Creates a new byte #GVariant instance. - * - * Returns: (transfer none): a floating reference to a new byte #GVariant instance - * Since: 2.24 - */ - - -/** - * g_variant_new_bytestring: - * @string: (array zero-terminated=1) (element-type guint8): a normal - * nul-terminated string in no particular encoding - * - * Creates an array-of-bytes #GVariant with the contents of @string. - * This function is just like g_variant_new_string() except that the - * string need not be valid UTF-8. - * - * The nul terminator character at the end of the string is stored in - * the array. - * - * Returns: (transfer none): a floating reference to a new bytestring #GVariant instance - * Since: 2.26 - */ - - -/** - * g_variant_new_bytestring_array: - * @strv: (array length=length): an array of strings - * @length: the length of @strv, or -1 - * - * Constructs an array of bytestring #GVariant from the given array of - * strings. - * - * If @length is -1 then @strv is %NULL-terminated. - * - * Returns: (transfer none): a new floating #GVariant instance - * Since: 2.26 - */ - - -/** - * g_variant_new_dict_entry: (constructor) - * @key: a basic #GVariant, the key - * @value: a #GVariant, the value - * - * Creates a new dictionary entry #GVariant. @key and @value must be - * non-%NULL. @key must be a value of a basic type (ie: not a container). - * - * If the @key or @value are floating references (see g_variant_ref_sink()), - * the new instance takes ownership of them as if via g_variant_ref_sink(). - * - * Returns: (transfer none): a floating reference to a new dictionary entry #GVariant - * Since: 2.24 - */ - - -/** - * g_variant_new_double: - * @value: a #gdouble floating point value - * - * Creates a new double #GVariant instance. - * - * Returns: (transfer none): a floating reference to a new double #GVariant instance - * Since: 2.24 - */ - - -/** - * g_variant_new_fixed_array: - * @element_type: the #GVariantType of each element - * @elements: a pointer to the fixed array of contiguous elements - * @n_elements: the number of elements - * @element_size: the size of each element - * - * Constructs a new array #GVariant instance, where the elements are - * of @element_type type. - * - * @elements must be an array with fixed-sized elements. Numeric types are - * fixed-size as are tuples containing only other fixed-sized types. - * - * @element_size must be the size of a single element in the array. - * For example, if calling this function for an array of 32-bit integers, - * you might say sizeof(gint32). This value isn't used except for the purpose - * of a double-check that the form of the serialized data matches the caller's - * expectation. - * - * @n_elements must be the length of the @elements array. - * - * Returns: (transfer none): a floating reference to a new array #GVariant instance - * Since: 2.32 - */ - - -/** - * g_variant_new_from_bytes: - * @type: a #GVariantType - * @bytes: a #GBytes - * @trusted: if the contents of @bytes are trusted - * - * Constructs a new serialized-mode #GVariant instance. This is the - * inner interface for creation of new serialized values that gets - * called from various functions in gvariant.c. - * - * A reference is taken on @bytes. - * - * The data in @bytes must be aligned appropriately for the @type being loaded. - * Otherwise this function will internally create a copy of the memory (since - * GLib 2.60) or (in older versions) fail and exit the process. - * - * Returns: (transfer none): a new #GVariant with a floating reference - * Since: 2.36 - */ - - -/** - * g_variant_new_from_data: - * @type: a definite #GVariantType - * @data: (array length=size) (element-type guint8): the serialized data - * @size: the size of @data - * @trusted: %TRUE if @data is definitely in normal form - * @notify: (scope async): function to call when @data is no longer needed - * @user_data: data for @notify - * - * Creates a new #GVariant instance from serialized data. - * - * @type is the type of #GVariant instance that will be constructed. - * The interpretation of @data depends on knowing the type. - * - * @data is not modified by this function and must remain valid with an - * unchanging value until such a time as @notify is called with - * @user_data. If the contents of @data change before that time then - * the result is undefined. - * - * If @data is trusted to be serialized data in normal form then - * @trusted should be %TRUE. This applies to serialized data created - * within this process or read from a trusted location on the disk (such - * as a file installed in /usr/lib alongside your application). You - * should set trusted to %FALSE if @data is read from the network, a - * file in the user's home directory, etc. - * - * If @data was not stored in this machine's native endianness, any multi-byte - * numeric values in the returned variant will also be in non-native - * endianness. g_variant_byteswap() can be used to recover the original values. - * - * @notify will be called with @user_data when @data is no longer - * needed. The exact time of this call is unspecified and might even be - * before this function returns. - * - * Note: @data must be backed by memory that is aligned appropriately for the - * @type being loaded. Otherwise this function will internally create a copy of - * the memory (since GLib 2.60) or (in older versions) fail and exit the - * process. - * - * Returns: (transfer none): a new floating #GVariant of type @type - * Since: 2.24 - */ - - -/** - * g_variant_new_handle: - * @value: a #gint32 value - * - * Creates a new handle #GVariant instance. - * - * By convention, handles are indexes into an array of file descriptors - * that are sent alongside a D-Bus message. If you're not interacting - * with D-Bus, you probably don't need them. - * - * Returns: (transfer none): a floating reference to a new handle #GVariant instance - * Since: 2.24 - */ - - -/** - * g_variant_new_int16: - * @value: a #gint16 value - * - * Creates a new int16 #GVariant instance. - * - * Returns: (transfer none): a floating reference to a new int16 #GVariant instance - * Since: 2.24 - */ - - -/** - * g_variant_new_int32: - * @value: a #gint32 value - * - * Creates a new int32 #GVariant instance. - * - * Returns: (transfer none): a floating reference to a new int32 #GVariant instance - * Since: 2.24 - */ - - -/** - * g_variant_new_int64: - * @value: a #gint64 value - * - * Creates a new int64 #GVariant instance. - * - * Returns: (transfer none): a floating reference to a new int64 #GVariant instance - * Since: 2.24 - */ - - -/** - * g_variant_new_maybe: - * @child_type: (nullable): the #GVariantType of the child, or %NULL - * @child: (nullable): the child value, or %NULL - * - * Depending on if @child is %NULL, either wraps @child inside of a - * maybe container or creates a Nothing instance for the given @type. - * - * At least one of @child_type and @child must be non-%NULL. - * If @child_type is non-%NULL then it must be a definite type. - * If they are both non-%NULL then @child_type must be the type - * of @child. - * - * If @child is a floating reference (see g_variant_ref_sink()), the new - * instance takes ownership of @child. - * - * Returns: (transfer none): a floating reference to a new #GVariant maybe instance - * Since: 2.24 - */ - - -/** - * g_variant_new_object_path: - * @object_path: a normal C nul-terminated string - * - * Creates a D-Bus object path #GVariant with the contents of @string. - * @string must be a valid D-Bus object path. Use - * g_variant_is_object_path() if you're not sure. - * - * Returns: (transfer none): a floating reference to a new object path #GVariant instance - * Since: 2.24 - */ - - -/** - * g_variant_new_objv: - * @strv: (array length=length) (element-type utf8): an array of strings - * @length: the length of @strv, or -1 - * - * Constructs an array of object paths #GVariant from the given array of - * strings. - * - * Each string must be a valid #GVariant object path; see - * g_variant_is_object_path(). - * - * If @length is -1 then @strv is %NULL-terminated. - * - * Returns: (transfer none): a new floating #GVariant instance - * Since: 2.30 - */ - - -/** - * g_variant_new_parsed: - * @format: a text format #GVariant - * @...: arguments as per @format - * - * Parses @format and returns the result. - * - * @format must be a text format #GVariant with one extension: at any - * point that a value may appear in the text, a '%' character followed - * by a GVariant format string (as per g_variant_new()) may appear. In - * that case, the same arguments are collected from the argument list as - * g_variant_new() would have collected. - * - * Note that the arguments must be of the correct width for their types - * specified in @format. This can be achieved by casting them. See - * the [GVariant varargs documentation][gvariant-varargs]. - * - * Consider this simple example: - * |[<!-- language="C" --> - * g_variant_new_parsed ("[('one', 1), ('two', %i), (%s, 3)]", 2, "three"); - * ]| - * - * In the example, the variable argument parameters are collected and - * filled in as if they were part of the original string to produce the - * result of - * |[<!-- language="C" --> - * [('one', 1), ('two', 2), ('three', 3)] - * ]| - * - * This function is intended only to be used with @format as a string - * literal. Any parse error is fatal to the calling process. If you - * want to parse data from untrusted sources, use g_variant_parse(). - * - * You may not use this function to return, unmodified, a single - * #GVariant pointer from the argument list. ie: @format may not solely - * be anything along the lines of "%*", "%?", "\%r", or anything starting - * with "%@". - * - * Returns: a new floating #GVariant instance - */ - - -/** - * g_variant_new_parsed_va: - * @format: a text format #GVariant - * @app: a pointer to a #va_list - * - * Parses @format and returns the result. - * - * This is the version of g_variant_new_parsed() intended to be used - * from libraries. - * - * The return value will be floating if it was a newly created GVariant - * instance. In the case that @format simply specified the collection - * of a #GVariant pointer (eg: @format was "%*") then the collected - * #GVariant pointer will be returned unmodified, without adding any - * additional references. - * - * Note that the arguments in @app must be of the correct width for their types - * specified in @format when collected into the #va_list. See - * the [GVariant varargs documentation][gvariant-varargs]. - * - * In order to behave correctly in all cases it is necessary for the - * calling function to g_variant_ref_sink() the return result before - * returning control to the user that originally provided the pointer. - * At this point, the caller will have their own full reference to the - * result. This can also be done by adding the result to a container, - * or by passing it to another g_variant_new() call. - * - * Returns: a new, usually floating, #GVariant - */ - - -/** - * g_variant_new_printf: (skip) - * @format_string: a printf-style format string - * @...: arguments for @format_string - * - * Creates a string-type GVariant using printf formatting. - * - * This is similar to calling g_strdup_printf() and then - * g_variant_new_string() but it saves a temporary variable and an - * unnecessary copy. - * - * Returns: (transfer none): a floating reference to a new string - * #GVariant instance - * Since: 2.38 - */ - - -/** - * g_variant_new_signature: - * @signature: a normal C nul-terminated string - * - * Creates a D-Bus type signature #GVariant with the contents of - * @string. @string must be a valid D-Bus type signature. Use - * g_variant_is_signature() if you're not sure. - * - * Returns: (transfer none): a floating reference to a new signature #GVariant instance - * Since: 2.24 - */ - - -/** - * g_variant_new_string: - * @string: a normal UTF-8 nul-terminated string - * - * Creates a string #GVariant with the contents of @string. - * - * @string must be valid UTF-8, and must not be %NULL. To encode - * potentially-%NULL strings, use g_variant_new() with `ms` as the - * [format string][gvariant-format-strings-maybe-types]. - * - * Returns: (transfer none): a floating reference to a new string #GVariant instance - * Since: 2.24 - */ - - -/** - * g_variant_new_strv: - * @strv: (array length=length) (element-type utf8): an array of strings - * @length: the length of @strv, or -1 - * - * Constructs an array of strings #GVariant from the given array of - * strings. - * - * If @length is -1 then @strv is %NULL-terminated. - * - * Returns: (transfer none): a new floating #GVariant instance - * Since: 2.24 - */ - - -/** - * g_variant_new_take_string: (skip) - * @string: a normal UTF-8 nul-terminated string - * - * Creates a string #GVariant with the contents of @string. - * - * @string must be valid UTF-8, and must not be %NULL. To encode - * potentially-%NULL strings, use this with g_variant_new_maybe(). - * - * This function consumes @string. g_free() will be called on @string - * when it is no longer required. - * - * You must not modify or access @string in any other way after passing - * it to this function. It is even possible that @string is immediately - * freed. - * - * Returns: (transfer none): a floating reference to a new string - * #GVariant instance - * Since: 2.38 - */ - - -/** - * g_variant_new_tuple: - * @children: (array length=n_children): the items to make the tuple out of - * @n_children: the length of @children - * - * Creates a new tuple #GVariant out of the items in @children. The - * type is determined from the types of @children. No entry in the - * @children array may be %NULL. - * - * If @n_children is 0 then the unit tuple is constructed. - * - * If the @children are floating references (see g_variant_ref_sink()), the - * new instance takes ownership of them as if via g_variant_ref_sink(). - * - * Returns: (transfer none): a floating reference to a new #GVariant tuple - * Since: 2.24 - */ - - -/** - * g_variant_new_uint16: - * @value: a #guint16 value - * - * Creates a new uint16 #GVariant instance. - * - * Returns: (transfer none): a floating reference to a new uint16 #GVariant instance - * Since: 2.24 - */ - - -/** - * g_variant_new_uint32: - * @value: a #guint32 value - * - * Creates a new uint32 #GVariant instance. - * - * Returns: (transfer none): a floating reference to a new uint32 #GVariant instance - * Since: 2.24 - */ - - -/** - * g_variant_new_uint64: - * @value: a #guint64 value - * - * Creates a new uint64 #GVariant instance. - * - * Returns: (transfer none): a floating reference to a new uint64 #GVariant instance - * Since: 2.24 - */ - - -/** - * g_variant_new_va: (skip) - * @format_string: a string that is prefixed with a format string - * @endptr: (nullable) (default NULL): location to store the end pointer, - * or %NULL - * @app: a pointer to a #va_list - * - * This function is intended to be used by libraries based on - * #GVariant that want to provide g_variant_new()-like functionality - * to their users. - * - * The API is more general than g_variant_new() to allow a wider range - * of possible uses. - * - * @format_string must still point to a valid format string, but it only - * needs to be nul-terminated if @endptr is %NULL. If @endptr is - * non-%NULL then it is updated to point to the first character past the - * end of the format string. - * - * @app is a pointer to a #va_list. The arguments, according to - * @format_string, are collected from this #va_list and the list is left - * pointing to the argument following the last. - * - * Note that the arguments in @app must be of the correct width for their - * types specified in @format_string when collected into the #va_list. - * See the [GVariant varargs documentation][gvariant-varargs]. - * - * These two generalisations allow mixing of multiple calls to - * g_variant_new_va() and g_variant_get_va() within a single actual - * varargs call by the user. - * - * The return value will be floating if it was a newly created GVariant - * instance (for example, if the format string was "(ii)"). In the case - * that the format_string was '*', '?', 'r', or a format starting with - * '@' then the collected #GVariant pointer will be returned unmodified, - * without adding any additional references. - * - * In order to behave correctly in all cases it is necessary for the - * calling function to g_variant_ref_sink() the return result before - * returning control to the user that originally provided the pointer. - * At this point, the caller will have their own full reference to the - * result. This can also be done by adding the result to a container, - * or by passing it to another g_variant_new() call. - * - * Returns: a new, usually floating, #GVariant - * Since: 2.24 - */ - - -/** - * g_variant_new_variant: (constructor) - * @value: a #GVariant instance - * - * Boxes @value. The result is a #GVariant instance representing a - * variant containing the original value. - * - * If @child is a floating reference (see g_variant_ref_sink()), the new - * instance takes ownership of @child. - * - * Returns: (transfer none): a floating reference to a new variant #GVariant instance - * Since: 2.24 - */ - - -/** - * g_variant_parse: - * @type: (nullable): a #GVariantType, or %NULL - * @text: a string containing a GVariant in text form - * @limit: (nullable): a pointer to the end of @text, or %NULL - * @endptr: (nullable): a location to store the end pointer, or %NULL - * @error: (nullable): a pointer to a %NULL #GError pointer, or %NULL - * - * Parses a #GVariant from a text representation. - * - * A single #GVariant is parsed from the content of @text. - * - * The format is described [here][gvariant-text]. - * - * The memory at @limit will never be accessed and the parser behaves as - * if the character at @limit is the nul terminator. This has the - * effect of bounding @text. - * - * If @endptr is non-%NULL then @text is permitted to contain data - * following the value that this function parses and @endptr will be - * updated to point to the first character past the end of the text - * parsed by this function. If @endptr is %NULL and there is extra data - * then an error is returned. - * - * If @type is non-%NULL then the value will be parsed to have that - * type. This may result in additional parse errors (in the case that - * the parsed value doesn't fit the type) but may also result in fewer - * errors (in the case that the type would have been ambiguous, such as - * with empty arrays). - * - * In the event that the parsing is successful, the resulting #GVariant - * is returned. It is never floating, and must be freed with - * g_variant_unref(). - * - * In case of any error, %NULL will be returned. If @error is non-%NULL - * then it will be set to reflect the error that occurred. - * - * Officially, the language understood by the parser is "any string - * produced by g_variant_print()". - * - * There may be implementation specific restrictions on deeply nested values, - * which would result in a %G_VARIANT_PARSE_ERROR_RECURSION error. #GVariant is - * guaranteed to handle nesting up to at least 64 levels. - * - * Returns: a non-floating reference to a #GVariant, or %NULL - */ - - -/** - * g_variant_parse_error_print_context: - * @error: a #GError from the #GVariantParseError domain - * @source_str: the string that was given to the parser - * - * Pretty-prints a message showing the context of a #GVariant parse - * error within the string for which parsing was attempted. - * - * The resulting string is suitable for output to the console or other - * monospace media where newlines are treated in the usual way. - * - * The message will typically look something like one of the following: - * - * |[ - * unterminated string constant: - * (1, 2, 3, 'abc - * ^^^^ - * ]| - * - * or - * - * |[ - * unable to find a common type: - * [1, 2, 3, 'str'] - * ^ ^^^^^ - * ]| - * - * The format of the message may change in a future version. - * - * @error must have come from a failed attempt to g_variant_parse() and - * @source_str must be exactly the same string that caused the error. - * If @source_str was not nul-terminated when you passed it to - * g_variant_parse() then you must add nul termination before using this - * function. - * - * Returns: (transfer full): the printed message - * Since: 2.40 - */ - - -/** - * g_variant_parser_get_error_quark: - * - * Same as g_variant_error_quark(). - * - * Deprecated: Use g_variant_parse_error_quark() instead. - */ - - -/** - * g_variant_print: - * @value: a #GVariant - * @type_annotate: %TRUE if type information should be included in - * the output - * - * Pretty-prints @value in the format understood by g_variant_parse(). - * - * The format is described [here][gvariant-text]. - * - * If @type_annotate is %TRUE, then type information is included in - * the output. - * - * Returns: (transfer full): a newly-allocated string holding the result. - * Since: 2.24 - */ - - -/** - * g_variant_print_string: (skip) - * @value: a #GVariant - * @string: (nullable) (default NULL): a #GString, or %NULL - * @type_annotate: %TRUE if type information should be included in - * the output - * - * Behaves as g_variant_print(), but operates on a #GString. - * - * If @string is non-%NULL then it is appended to and returned. Else, - * a new empty #GString is allocated and it is returned. - * - * Returns: a #GString containing the string - * Since: 2.24 - */ - - -/** - * g_variant_ref: - * @value: a #GVariant - * - * Increases the reference count of @value. - * - * Returns: the same @value - * Since: 2.24 - */ - - -/** - * g_variant_ref_sink: - * @value: a #GVariant - * - * #GVariant uses a floating reference count system. All functions with - * names starting with `g_variant_new_` return floating - * references. - * - * Calling g_variant_ref_sink() on a #GVariant with a floating reference - * will convert the floating reference into a full reference. Calling - * g_variant_ref_sink() on a non-floating #GVariant results in an - * additional normal reference being added. - * - * In other words, if the @value is floating, then this call "assumes - * ownership" of the floating reference, converting it to a normal - * reference. If the @value is not floating, then this call adds a - * new normal reference increasing the reference count by one. - * - * All calls that result in a #GVariant instance being inserted into a - * container will call g_variant_ref_sink() on the instance. This means - * that if the value was just created (and has only its floating - * reference) then the container will assume sole ownership of the value - * at that point and the caller will not need to unreference it. This - * makes certain common styles of programming much easier while still - * maintaining normal refcounting semantics in situations where values - * are not floating. - * - * Returns: the same @value - * Since: 2.24 - */ - - -/** - * g_variant_store: - * @value: the #GVariant to store - * @data: (not nullable): the location to store the serialized data at - * - * Stores the serialized form of @value at @data. @data should be - * large enough. See g_variant_get_size(). - * - * The stored data is in machine native byte order but may not be in - * fully-normalised form if read from an untrusted source. See - * g_variant_get_normal_form() for a solution. - * - * As with g_variant_get_data(), to be able to deserialize the - * serialized variant successfully, its type and (if the destination - * machine might be different) its endianness must also be available. - * - * This function is approximately O(n) in the size of @data. - * - * Since: 2.24 - */ - - -/** - * g_variant_take_ref: - * @value: a #GVariant - * - * If @value is floating, sink it. Otherwise, do nothing. - * - * Typically you want to use g_variant_ref_sink() in order to - * automatically do the correct thing with respect to floating or - * non-floating references, but there is one specific scenario where - * this function is helpful. - * - * The situation where this function is helpful is when creating an API - * that allows the user to provide a callback function that returns a - * #GVariant. We certainly want to allow the user the flexibility to - * return a non-floating reference from this callback (for the case - * where the value that is being returned already exists). - * - * At the same time, the style of the #GVariant API makes it likely that - * for newly-created #GVariant instances, the user can be saved some - * typing if they are allowed to return a #GVariant with a floating - * reference. - * - * Using this function on the return value of the user's callback allows - * the user to do whichever is more convenient for them. The caller - * will always receives exactly one full reference to the value: either - * the one that was returned in the first place, or a floating reference - * that has been converted to a full reference. - * - * This function has an odd interaction when combined with - * g_variant_ref_sink() running at the same time in another thread on - * the same #GVariant instance. If g_variant_ref_sink() runs first then - * the result will be that the floating reference is converted to a hard - * reference. If g_variant_take_ref() runs first then the result will - * be that the floating reference is converted to a hard reference and - * an additional reference on top of that one is added. It is best to - * avoid this situation. - * - * Returns: the same @value - */ - - -/** - * g_variant_type_copy: - * @type: a #GVariantType - * - * Makes a copy of a #GVariantType. It is appropriate to call - * g_variant_type_free() on the return value. @type may not be %NULL. - * - * Returns: (transfer full): a new #GVariantType - * - * Since 2.24 - */ - - -/** - * g_variant_type_dup_string: - * @type: a #GVariantType - * - * Returns a newly-allocated copy of the type string corresponding to - * @type. The returned string is nul-terminated. It is appropriate to - * call g_free() on the return value. - * - * Returns: (transfer full): the corresponding type string - * - * Since 2.24 - */ - - -/** - * g_variant_type_element: - * @type: an array or maybe #GVariantType - * - * Determines the element type of an array or maybe type. - * - * This function may only be used with array or maybe types. - * - * Returns: (transfer none): the element type of @type - * - * Since 2.24 - */ - - -/** - * g_variant_type_equal: - * @type1: (type GVariantType): a #GVariantType - * @type2: (type GVariantType): a #GVariantType - * - * Compares @type1 and @type2 for equality. - * - * Only returns %TRUE if the types are exactly equal. Even if one type - * is an indefinite type and the other is a subtype of it, %FALSE will - * be returned if they are not exactly equal. If you want to check for - * subtypes, use g_variant_type_is_subtype_of(). - * - * The argument types of @type1 and @type2 are only #gconstpointer to - * allow use with #GHashTable without function pointer casting. For - * both arguments, a valid #GVariantType must be provided. - * - * Returns: %TRUE if @type1 and @type2 are exactly equal - * - * Since 2.24 - */ - - -/** - * g_variant_type_first: - * @type: a tuple or dictionary entry #GVariantType - * - * Determines the first item type of a tuple or dictionary entry - * type. - * - * This function may only be used with tuple or dictionary entry types, - * but must not be used with the generic tuple type - * %G_VARIANT_TYPE_TUPLE. - * - * In the case of a dictionary entry type, this returns the type of - * the key. - * - * %NULL is returned in case of @type being %G_VARIANT_TYPE_UNIT. - * - * This call, together with g_variant_type_next() provides an iterator - * interface over tuple and dictionary entry types. - * - * Returns: (transfer none): the first item type of @type, or %NULL - * - * Since 2.24 - */ - - -/** - * g_variant_type_free: - * @type: (nullable): a #GVariantType, or %NULL - * - * Frees a #GVariantType that was allocated with - * g_variant_type_copy(), g_variant_type_new() or one of the container - * type constructor functions. - * - * In the case that @type is %NULL, this function does nothing. - * - * Since 2.24 - */ - - -/** - * g_variant_type_get_string_length: - * @type: a #GVariantType - * - * Returns the length of the type string corresponding to the given - * @type. This function must be used to determine the valid extent of - * the memory region returned by g_variant_type_peek_string(). - * - * Returns: the length of the corresponding type string - * - * Since 2.24 - */ - - -/** - * g_variant_type_hash: - * @type: (type GVariantType): a #GVariantType - * - * Hashes @type. - * - * The argument type of @type is only #gconstpointer to allow use with - * #GHashTable without function pointer casting. A valid - * #GVariantType must be provided. - * - * Returns: the hash value - * - * Since 2.24 - */ - - -/** - * g_variant_type_is_array: - * @type: a #GVariantType - * - * Determines if the given @type is an array type. This is true if the - * type string for @type starts with an 'a'. - * - * This function returns %TRUE for any indefinite type for which every - * definite subtype is an array type -- %G_VARIANT_TYPE_ARRAY, for - * example. - * - * Returns: %TRUE if @type is an array type - * - * Since 2.24 - */ - - -/** - * g_variant_type_is_basic: - * @type: a #GVariantType - * - * Determines if the given @type is a basic type. - * - * Basic types are booleans, bytes, integers, doubles, strings, object - * paths and signatures. - * - * Only a basic type may be used as the key of a dictionary entry. - * - * This function returns %FALSE for all indefinite types except - * %G_VARIANT_TYPE_BASIC. - * - * Returns: %TRUE if @type is a basic type - * - * Since 2.24 - */ - - -/** - * g_variant_type_is_container: - * @type: a #GVariantType - * - * Determines if the given @type is a container type. - * - * Container types are any array, maybe, tuple, or dictionary - * entry types plus the variant type. - * - * This function returns %TRUE for any indefinite type for which every - * definite subtype is a container -- %G_VARIANT_TYPE_ARRAY, for - * example. - * - * Returns: %TRUE if @type is a container type - * - * Since 2.24 - */ - - -/** - * g_variant_type_is_definite: - * @type: a #GVariantType - * - * Determines if the given @type is definite (ie: not indefinite). - * - * A type is definite if its type string does not contain any indefinite - * type characters ('*', '?', or 'r'). - * - * A #GVariant instance may not have an indefinite type, so calling - * this function on the result of g_variant_get_type() will always - * result in %TRUE being returned. Calling this function on an - * indefinite type like %G_VARIANT_TYPE_ARRAY, however, will result in - * %FALSE being returned. - * - * Returns: %TRUE if @type is definite - * - * Since 2.24 - */ - - -/** - * g_variant_type_is_dict_entry: - * @type: a #GVariantType - * - * Determines if the given @type is a dictionary entry type. This is - * true if the type string for @type starts with a '{'. - * - * This function returns %TRUE for any indefinite type for which every - * definite subtype is a dictionary entry type -- - * %G_VARIANT_TYPE_DICT_ENTRY, for example. - * - * Returns: %TRUE if @type is a dictionary entry type - * - * Since 2.24 - */ - - -/** - * g_variant_type_is_maybe: - * @type: a #GVariantType - * - * Determines if the given @type is a maybe type. This is true if the - * type string for @type starts with an 'm'. - * - * This function returns %TRUE for any indefinite type for which every - * definite subtype is a maybe type -- %G_VARIANT_TYPE_MAYBE, for - * example. - * - * Returns: %TRUE if @type is a maybe type - * - * Since 2.24 - */ - - -/** - * g_variant_type_is_subtype_of: - * @type: a #GVariantType - * @supertype: a #GVariantType - * - * Checks if @type is a subtype of @supertype. - * - * This function returns %TRUE if @type is a subtype of @supertype. All - * types are considered to be subtypes of themselves. Aside from that, - * only indefinite types can have subtypes. - * - * Returns: %TRUE if @type is a subtype of @supertype - * - * Since 2.24 - */ - - -/** - * g_variant_type_is_tuple: - * @type: a #GVariantType - * - * Determines if the given @type is a tuple type. This is true if the - * type string for @type starts with a '(' or if @type is - * %G_VARIANT_TYPE_TUPLE. - * - * This function returns %TRUE for any indefinite type for which every - * definite subtype is a tuple type -- %G_VARIANT_TYPE_TUPLE, for - * example. - * - * Returns: %TRUE if @type is a tuple type - * - * Since 2.24 - */ - - -/** - * g_variant_type_is_variant: - * @type: a #GVariantType - * - * Determines if the given @type is the variant type. - * - * Returns: %TRUE if @type is the variant type - * - * Since 2.24 - */ - - -/** - * g_variant_type_key: - * @type: a dictionary entry #GVariantType - * - * Determines the key type of a dictionary entry type. - * - * This function may only be used with a dictionary entry type. Other - * than the additional restriction, this call is equivalent to - * g_variant_type_first(). - * - * Returns: (transfer none): the key type of the dictionary entry - * - * Since 2.24 - */ - - -/** - * g_variant_type_n_items: - * @type: a tuple or dictionary entry #GVariantType - * - * Determines the number of items contained in a tuple or - * dictionary entry type. - * - * This function may only be used with tuple or dictionary entry types, - * but must not be used with the generic tuple type - * %G_VARIANT_TYPE_TUPLE. - * - * In the case of a dictionary entry type, this function will always - * return 2. - * - * Returns: the number of items in @type - * - * Since 2.24 - */ - - -/** - * g_variant_type_new: - * @type_string: a valid GVariant type string - * - * Creates a new #GVariantType corresponding to the type string given - * by @type_string. It is appropriate to call g_variant_type_free() on - * the return value. - * - * It is a programmer error to call this function with an invalid type - * string. Use g_variant_type_string_is_valid() if you are unsure. - * - * Returns: (transfer full): a new #GVariantType - * Since: 2.24 - */ - - -/** - * g_variant_type_new_array: (constructor) - * @element: a #GVariantType - * - * Constructs the type corresponding to an array of elements of the - * type @type. - * - * It is appropriate to call g_variant_type_free() on the return value. - * - * Returns: (transfer full): a new array #GVariantType - * - * Since 2.24 - */ - - -/** - * g_variant_type_new_dict_entry: (constructor) - * @key: a basic #GVariantType - * @value: a #GVariantType - * - * Constructs the type corresponding to a dictionary entry with a key - * of type @key and a value of type @value. - * - * It is appropriate to call g_variant_type_free() on the return value. - * - * Returns: (transfer full): a new dictionary entry #GVariantType - * - * Since 2.24 - */ - - -/** - * g_variant_type_new_maybe: (constructor) - * @element: a #GVariantType - * - * Constructs the type corresponding to a maybe instance containing - * type @type or Nothing. - * - * It is appropriate to call g_variant_type_free() on the return value. - * - * Returns: (transfer full): a new maybe #GVariantType - * - * Since 2.24 - */ - - -/** - * g_variant_type_new_tuple: - * @items: (array length=length): an array of #GVariantTypes, one for each item - * @length: the length of @items, or -1 - * - * Constructs a new tuple type, from @items. - * - * @length is the number of items in @items, or -1 to indicate that - * @items is %NULL-terminated. - * - * It is appropriate to call g_variant_type_free() on the return value. - * - * Returns: (transfer full): a new tuple #GVariantType - * - * Since 2.24 - */ - - -/** - * g_variant_type_next: - * @type: a #GVariantType from a previous call - * - * Determines the next item type of a tuple or dictionary entry - * type. - * - * @type must be the result of a previous call to - * g_variant_type_first() or g_variant_type_next(). - * - * If called on the key type of a dictionary entry then this call - * returns the value type. If called on the value type of a dictionary - * entry then this call returns %NULL. - * - * For tuples, %NULL is returned when @type is the last item in a tuple. - * - * Returns: (transfer none): the next #GVariantType after @type, or %NULL - * - * Since 2.24 - */ - - -/** - * g_variant_type_peek_string: (skip) - * @type: a #GVariantType - * - * Returns the type string corresponding to the given @type. The - * result is not nul-terminated; in order to determine its length you - * must call g_variant_type_get_string_length(). - * - * To get a nul-terminated string, see g_variant_type_dup_string(). - * - * Returns: the corresponding type string (not nul-terminated) - * - * Since 2.24 - */ - - -/** - * g_variant_type_string_is_valid: - * @type_string: a pointer to any string - * - * Checks if @type_string is a valid GVariant type string. This call is - * equivalent to calling g_variant_type_string_scan() and confirming - * that the following character is a nul terminator. - * - * Returns: %TRUE if @type_string is exactly one valid type string - * - * Since 2.24 - */ - - -/** - * g_variant_type_string_scan: - * @string: a pointer to any string - * @limit: (nullable): the end of @string, or %NULL - * @endptr: (out) (optional): location to store the end pointer, or %NULL - * - * Scan for a single complete and valid GVariant type string in @string. - * The memory pointed to by @limit (or bytes beyond it) is never - * accessed. - * - * If a valid type string is found, @endptr is updated to point to the - * first character past the end of the string that was found and %TRUE - * is returned. - * - * If there is no valid type string starting at @string, or if the type - * string does not end before @limit then %FALSE is returned. - * - * For the simple case of checking if a string is a valid type string, - * see g_variant_type_string_is_valid(). - * - * Returns: %TRUE if a valid type string was found - * Since: 2.24 - */ - - -/** - * g_variant_type_value: - * @type: a dictionary entry #GVariantType - * - * Determines the value type of a dictionary entry type. - * - * This function may only be used with a dictionary entry type. - * - * Returns: (transfer none): the value type of the dictionary entry - * - * Since 2.24 - */ - - -/** - * g_variant_unref: - * @value: a #GVariant - * - * Decreases the reference count of @value. When its reference count - * drops to 0, the memory used by the variant is freed. - * - * Since: 2.24 - */ - - -/** - * g_vasprintf: - * @string: (not optional) (nullable): the return location for the newly-allocated string. - * @format: (not nullable): a standard printf() format string, but notice - * [string precision pitfalls][string-precision] - * @args: the list of arguments to insert in the output. - * - * An implementation of the GNU vasprintf() function which supports - * positional parameters, as specified in the Single Unix Specification. - * This function is similar to g_vsprintf(), except that it allocates a - * string to hold the output, instead of putting the output in a buffer - * you allocate in advance. - * - * The returned value in @string is guaranteed to be non-NULL, unless - * @format contains `%lc` or `%ls` conversions, which can fail if no - * multibyte representation is available for the given character. - * - * `glib/gprintf.h` must be explicitly included in order to use this function. - * - * Returns: the number of bytes printed. - * Since: 2.4 - */ - - -/** - * g_vfprintf: - * @file: (not nullable): the stream to write to. - * @format: a standard printf() format string, but notice - * [string precision pitfalls][string-precision] - * @args: the list of arguments to insert in the output. - * - * An implementation of the standard fprintf() function which supports - * positional parameters, as specified in the Single Unix Specification. - * - * `glib/gprintf.h` must be explicitly included in order to use this function. - * - * Returns: the number of bytes printed. - * Since: 2.2 - */ - - -/** - * g_vprintf: - * @format: a standard printf() format string, but notice - * [string precision pitfalls][string-precision] - * @args: the list of arguments to insert in the output. - * - * An implementation of the standard vprintf() function which supports - * positional parameters, as specified in the Single Unix Specification. - * - * `glib/gprintf.h` must be explicitly included in order to use this function. - * - * Returns: the number of bytes printed. - * Since: 2.2 - */ - - -/** - * g_vsnprintf: - * @string: the buffer to hold the output. - * @n: the maximum number of bytes to produce (including the - * terminating nul character). - * @format: a standard printf() format string, but notice - * [string precision pitfalls][string-precision] - * @args: the list of arguments to insert in the output. - * - * A safer form of the standard vsprintf() function. The output is guaranteed - * to not exceed @n characters (including the terminating nul character), so - * it is easy to ensure that a buffer overflow cannot occur. - * - * See also g_strdup_vprintf(). - * - * In versions of GLib prior to 1.2.3, this function may return -1 if the - * output was truncated, and the truncated string may not be nul-terminated. - * In versions prior to 1.3.12, this function returns the length of the output - * string. - * - * The return value of g_vsnprintf() conforms to the vsnprintf() function - * as standardized in ISO C99. Note that this is different from traditional - * vsnprintf(), which returns the length of the output string. - * - * The format string may contain positional parameters, as specified in - * the Single Unix Specification. - * - * Returns: the number of bytes which would be produced if the buffer - * was large enough. - */ - - -/** - * g_vsprintf: - * @string: the buffer to hold the output. - * @format: a standard printf() format string, but notice - * [string precision pitfalls][string-precision] - * @args: the list of arguments to insert in the output. - * - * An implementation of the standard vsprintf() function which supports - * positional parameters, as specified in the Single Unix Specification. - * - * `glib/gprintf.h` must be explicitly included in order to use this function. - * - * Returns: the number of bytes printed. - * Since: 2.2 - */ - - -/** - * g_wakeup_acknowledge: - * @wakeup: a #GWakeup - * - * Acknowledges receipt of a wakeup signal on @wakeup. - * - * You must call this after @wakeup polls as ready. If not, it will - * continue to poll as ready until you do so. - * - * If you call this function and @wakeup is not signaled, nothing - * happens. - * - * Since: 2.30 - */ - - -/** - * g_wakeup_free: - * @wakeup: a #GWakeup - * - * Frees @wakeup. - * - * You must not currently be polling on the #GPollFD returned by - * g_wakeup_get_pollfd(), or the result is undefined. - */ - - -/** - * g_wakeup_get_pollfd: - * @wakeup: a #GWakeup - * @poll_fd: a #GPollFD - * - * Prepares a @poll_fd such that polling on it will succeed when - * g_wakeup_signal() has been called on @wakeup. - * - * @poll_fd is valid until @wakeup is freed. - * - * Since: 2.30 - */ - - -/** - * g_wakeup_new: - * - * Creates a new #GWakeup. - * - * You should use g_wakeup_free() to free it when you are done. - * - * Returns: a new #GWakeup - * Since: 2.30 - */ - - -/** - * g_wakeup_signal: - * @wakeup: a #GWakeup - * - * Signals @wakeup. - * - * Any future (or present) polling on the #GPollFD returned by - * g_wakeup_get_pollfd() will immediately succeed until such a time as - * g_wakeup_acknowledge() is called. - * - * This function is safe to call from a UNIX signal handler. - * - * Since: 2.30 - */ - - -/** - * g_warn_message: (skip) - * @domain: (nullable): log domain - * @file: file containing the warning - * @line: line number of the warning - * @func: function containing the warning - * @warnexpr: (nullable): expression which failed - * - * Internal function used to print messages from the public g_warn_if_reached() - * and g_warn_if_fail() macros. - */ - - -/** - * g_warning: - * @...: format string, followed by parameters to insert - * into the format string (as with printf()) - * - * A convenience function/macro to log a warning message. The message should - * typically *not* be translated to the user's language. - * - * This is not intended for end user error reporting. Use of #GError is - * preferred for that instead, as it allows calling functions to perform actions - * conditional on the type of error. - * - * Warning messages are intended to be used in the event of unexpected - * external conditions (system misconfiguration, missing files, - * other trusted programs violating protocol, invalid contents in - * trusted files, etc.) - * - * If attempting to deal with programmer errors (for example, incorrect function - * parameters) then you should use %G_LOG_LEVEL_CRITICAL instead. - * - * g_warn_if_reached() and g_warn_if_fail() log at %G_LOG_LEVEL_WARNING. - * - * You can make warnings fatal at runtime by setting the `G_DEBUG` - * environment variable (see - * [Running GLib Applications](glib-running.html)): - * - * |[ - * G_DEBUG=fatal-warnings gdb ./my-program - * ]| - * - * Any unrelated failures can be skipped over in - * [gdb](https://www.gnu.org/software/gdb/) using the `continue` command. - * - * If g_log_default_handler() is used as the log handler function, - * a newline character will automatically be appended to @..., and - * need not be entered manually. - * - * If structured logging is enabled, this will use g_log_structured(); - * otherwise it will use g_log(). See - * [Using Structured Logging][using-structured-logging]. - */ - - -/** - * g_win32_check_windows_version: - * @major: major version of Windows - * @minor: minor version of Windows - * @spver: Windows Service Pack Level, 0 if none - * @os_type: Type of Windows OS - * - * Returns whether the version of the Windows operating system the - * code is running on is at least the specified major, minor and - * service pack versions. See MSDN documentation for the Operating - * System Version. Software that needs even more detailed version and - * feature information should use the Win32 API VerifyVersionInfo() - * directly. - * - * Successive calls of this function can be used for enabling or - * disabling features at run-time for a range of Windows versions, - * as per the VerifyVersionInfo() API documentation. - * - * Returns: %TRUE if the Windows Version is the same or greater than - * the specified major, minor and service pack versions, and - * whether the running Windows is a workstation or server edition - * of Windows, if specifically specified. - * Since: 2.44 - */ - - -/** - * g_win32_error_message: - * @error: error code. - * - * Translate a Win32 error code (as returned by GetLastError() or - * WSAGetLastError()) into the corresponding message. The message is - * either language neutral, or in the thread's language, or the user's - * language, the system's language, or US English (see docs for - * FormatMessage()). The returned string is in UTF-8. It should be - * deallocated with g_free(). - * - * Returns: newly-allocated error message - */ - - -/** - * g_win32_get_command_line: - * - * Gets the command line arguments, on Windows, in the GLib filename - * encoding (ie: UTF-8). - * - * Normally, on Windows, the command line arguments are passed to main() - * in the system codepage encoding. This prevents passing filenames as - * arguments if the filenames contain characters that fall outside of - * this codepage. If such filenames are passed, then substitutions - * will occur (such as replacing some characters with '?'). - * - * GLib's policy of using UTF-8 as a filename encoding on Windows was - * designed to localise the pain of dealing with filenames outside of - * the system codepage to one area: dealing with commandline arguments - * in main(). - * - * As such, most GLib programs should ignore the value of argv passed to - * their main() function and call g_win32_get_command_line() instead. - * This will get the "full Unicode" commandline arguments using - * GetCommandLineW() and convert it to the GLib filename encoding (which - * is UTF-8 on Windows). - * - * The strings returned by this function are suitable for use with - * functions such as g_open() and g_file_new_for_commandline_arg() but - * are not suitable for use with g_option_context_parse(), which assumes - * that its input will be in the system codepage. The return value is - * suitable for use with g_option_context_parse_strv(), however, which - * is a better match anyway because it won't leak memory. - * - * Unlike argv, the returned value is a normal strv and can (and should) - * be freed with g_strfreev() when no longer needed. - * - * Returns: (transfer full): the commandline arguments in the GLib - * filename encoding (ie: UTF-8) - * Since: 2.40 - */ - - -/** - * g_win32_get_package_installation_directory: - * @package: (nullable): You should pass %NULL for this. - * @dll_name: (nullable): The name of a DLL that a package provides in UTF-8, or %NULL. - * - * Try to determine the installation directory for a software package. - * - * This function is deprecated. Use - * g_win32_get_package_installation_directory_of_module() instead. - * - * The use of @package is deprecated. You should always pass %NULL. A - * warning is printed if non-NULL is passed as @package. - * - * The original intended use of @package was for a short identifier of - * the package, typically the same identifier as used for - * `GETTEXT_PACKAGE` in software configured using GNU - * autotools. The function first looks in the Windows Registry for the - * value `#InstallationDirectory` in the key - * `#HKLM\Software\@package`, and if that value - * exists and is a string, returns that. - * - * It is strongly recommended that packagers of GLib-using libraries - * for Windows do not store installation paths in the Registry to be - * used by this function as that interfers with having several - * parallel installations of the library. Enabling multiple - * installations of different versions of some GLib-using library, or - * GLib itself, is desirable for various reasons. - * - * For this reason it is recommended to always pass %NULL as - * @package to this function, to avoid the temptation to use the - * Registry. In version 2.20 of GLib the @package parameter - * will be ignored and this function won't look in the Registry at all. - * - * If @package is %NULL, or the above value isn't found in the - * Registry, but @dll_name is non-%NULL, it should name a DLL loaded - * into the current process. Typically that would be the name of the - * DLL calling this function, looking for its installation - * directory. The function then asks Windows what directory that DLL - * was loaded from. If that directory's last component is "bin" or - * "lib", the parent directory is returned, otherwise the directory - * itself. If that DLL isn't loaded, the function proceeds as if - * @dll_name was %NULL. - * - * If both @package and @dll_name are %NULL, the directory from where - * the main executable of the process was loaded is used instead in - * the same way as above. - * - * Returns: a string containing the installation directory for - * @package. The string is in the GLib file name encoding, - * i.e. UTF-8. The return value should be freed with g_free() when not - * needed any longer. If the function fails %NULL is returned. - * Deprecated: 2.18: Pass the HMODULE of a DLL or EXE to - * g_win32_get_package_installation_directory_of_module() instead. - */ - - -/** - * g_win32_get_package_installation_directory_of_module: - * @hmodule: (nullable): The Win32 handle for a DLL loaded into the current process, or %NULL - * - * This function tries to determine the installation directory of a - * software package based on the location of a DLL of the software - * package. - * - * @hmodule should be the handle of a loaded DLL or %NULL. The - * function looks up the directory that DLL was loaded from. If - * @hmodule is NULL, the directory the main executable of the current - * process is looked up. If that directory's last component is "bin" - * or "lib", its parent directory is returned, otherwise the directory - * itself. - * - * It thus makes sense to pass only the handle to a "public" DLL of a - * software package to this function, as such DLLs typically are known - * to be installed in a "bin" or occasionally "lib" subfolder of the - * installation folder. DLLs that are of the dynamically loaded module - * or plugin variety are often located in more private locations - * deeper down in the tree, from which it is impossible for GLib to - * deduce the root of the package installation. - * - * The typical use case for this function is to have a DllMain() that - * saves the handle for the DLL. Then when code in the DLL needs to - * construct names of files in the installation tree it calls this - * function passing the DLL handle. - * - * Returns: a string containing the guessed installation directory for - * the software package @hmodule is from. The string is in the GLib - * file name encoding, i.e. UTF-8. The return value should be freed - * with g_free() when not needed any longer. If the function fails - * %NULL is returned. - * Since: 2.16 - */ - - -/** - * g_win32_get_package_installation_subdirectory: - * @package: (nullable): You should pass %NULL for this. - * @dll_name: (nullable): The name of a DLL that a package provides, in UTF-8, or %NULL. - * @subdir: A subdirectory of the package installation directory, also in UTF-8 - * - * This function is deprecated. Use - * g_win32_get_package_installation_directory_of_module() and - * g_build_filename() instead. - * - * Returns a newly-allocated string containing the path of the - * subdirectory @subdir in the return value from calling - * g_win32_get_package_installation_directory() with the @package and - * @dll_name parameters. See the documentation for - * g_win32_get_package_installation_directory() for more details. In - * particular, note that it is deprecated to pass anything except NULL - * as @package. - * - * Returns: a string containing the complete path to @subdir inside - * the installation directory of @package. The returned string is in - * the GLib file name encoding, i.e. UTF-8. The return value should be - * freed with g_free() when no longer needed. If something goes wrong, - * %NULL is returned. - * Deprecated: 2.18: Pass the HMODULE of a DLL or EXE to - * g_win32_get_package_installation_directory_of_module() instead, and - * then construct a subdirectory pathname with g_build_filename(). - */ - - -/** - * g_win32_get_windows_version: - * - * This function is deprecated. Use - * g_win32_check_windows_version() instead. - * - * Returns version information for the Windows operating system the - * code is running on. See MSDN documentation for the GetVersion() - * function. To summarize, the most significant bit is one on Win9x, - * and zero on NT-based systems. Since version 2.14, GLib works only - * on NT-based systems, so checking whether your are running on Win9x - * in your own software is moot. The least significant byte is 4 on - * Windows NT 4, and 5 on Windows XP. Software that needs really - * detailed version and feature information should use Win32 API like - * GetVersionEx() and VerifyVersionInfo(). - * - * Returns: The version information. - * Deprecated: 2.44: Be aware that for Windows 8.1 and Windows Server - * 2012 R2 and later, this will return 62 unless the application is - * manifested for Windows 8.1/Windows Server 2012 R2, for example. - * MSDN stated that GetVersion(), which is used here, is subject to - * further change or removal after Windows 8.1. - */ - - -/** - * g_win32_getlocale: - * - * The setlocale() function in the Microsoft C library uses locale - * names of the form "English_United States.1252" etc. We want the - * UNIXish standard form "en_US", "zh_TW" etc. This function gets the - * current thread locale from Windows - without any encoding info - - * and returns it as a string of the above form for use in forming - * file names etc. The returned string should be deallocated with - * g_free(). - * - * Returns: newly-allocated locale name. - */ - - -/** - * g_win32_locale_filename_from_utf8: - * @utf8filename: a UTF-8 encoded filename. - * - * Converts a filename from UTF-8 to the system codepage. - * - * On NT-based Windows, on NTFS file systems, file names are in - * Unicode. It is quite possible that Unicode file names contain - * characters not representable in the system codepage. (For instance, - * Greek or Cyrillic characters on Western European or US Windows - * installations, or various less common CJK characters on CJK Windows - * installations.) - * - * In such a case, and if the filename refers to an existing file, and - * the file system stores alternate short (8.3) names for directory - * entries, the short form of the filename is returned. Note that the - * "short" name might in fact be longer than the Unicode name if the - * Unicode name has very short pathname components containing - * non-ASCII characters. If no system codepage name for the file is - * possible, %NULL is returned. - * - * The return value is dynamically allocated and should be freed with - * g_free() when no longer needed. - * - * Returns: The converted filename, or %NULL on conversion - * failure and lack of short names. - * Since: 2.8 - */ - - -/** - * g_win32_readlink_utf8: - * @filename: (type filename): a pathname in UTF-8 - * @buf: (array length=buf_size): a buffer to receive the reparse point - * target path. Mutually-exclusive - * with @alloc_buf. - * @buf_size: size of the @buf, in bytes - * @alloc_buf: points to a location where internally-allocated buffer - * pointer will be written. That buffer receives the - * link data. Mutually-exclusive with @buf. - * @terminate: ensures that the buffer is NUL-terminated if - * it isn't already. If %FALSE, the returned string - * might not be NUL-terminated (depends entirely on - * what the contents of the filesystem are). - * - * Tries to read the reparse point indicated by @filename, filling - * @buf or @alloc_buf with the path that the reparse point redirects to. - * The path will be UTF-8-encoded, and an extended path prefix - * or a NT object manager prefix will be removed from it, if - * possible, but otherwise the path is returned as-is. Specifically, - * it could be a "\\\\Volume{GUID}\\" path. It also might use - * backslashes as path separators. - * - * Returns: -1 on error (sets errno), 0 if there's no (recognizable) - * path in the reparse point (@alloc_buf will not be allocated in that case, - * and @buf will be left unmodified), - * or the number of bytes placed into @buf otherwise, - * including NUL-terminator (if present or if @terminate is TRUE). - * The buffer returned via @alloc_buf should be freed with g_free(). - * Since: 2.60 - */ - - -/** - * gatomicrefcount: - * - * A type for implementing atomic reference count semantics. - * - * Use g_atomic_ref_count_init() to initialize it; g_atomic_ref_count_inc() - * to increase the counter, and g_atomic_ref_count_dec() to decrease it. - * - * It is safe to use #gatomicrefcount if you're expecting to operate on the - * reference counter from multiple threads. - * - * See also: #grefcount - * - * Since: 2.58 - */ - - -/** - * gboolean: - * - * A standard boolean type. - * Variables of this type should only contain the value - * %TRUE or %FALSE. - * - * Never directly compare the contents of a #gboolean variable with the values - * %TRUE or %FALSE. Use `if (condition)` to check a #gboolean is "true", instead - * of `if (condition == TRUE)`. Likewise use `if (!condition)` to check a - * #gboolean is "false". - * - * There is no validation when assigning to a #gboolean variable and so it could - * contain any value represented by a #gint. This is why the use of `if - * (condition)` is recommended. All non-zero values in C evaluate to "true". - */ - - -/** - * gchar: - * - * Corresponds to the standard C char type. - */ - - -/** - * gconstpointer: - * - * An untyped pointer to constant data. - * The data pointed to should not be changed. - * - * This is typically used in function prototypes to indicate - * that the data pointed to will not be altered by the function. - */ - - -/** - * gdouble: - * - * Corresponds to the standard C double type. - * Values of this type can range from -#G_MAXDOUBLE to #G_MAXDOUBLE. - */ - - -/** - * gfloat: - * - * Corresponds to the standard C float type. - * Values of this type can range from -#G_MAXFLOAT to #G_MAXFLOAT. - */ - - -/** - * gint: - * - * Corresponds to the standard C int type. - * Values of this type can range from #G_MININT to #G_MAXINT. - */ - - -/** - * gint16: - * - * A signed integer guaranteed to be 16 bits on all platforms. - * Values of this type can range from #G_MININT16 (= -32,768) to - * #G_MAXINT16 (= 32,767). - * - * To print or scan values of this type, use - * %G_GINT16_MODIFIER and/or %G_GINT16_FORMAT. - */ - - -/** - * gint32: - * - * A signed integer guaranteed to be 32 bits on all platforms. - * Values of this type can range from #G_MININT32 (= -2,147,483,648) - * to #G_MAXINT32 (= 2,147,483,647). - * - * To print or scan values of this type, use - * %G_GINT32_MODIFIER and/or %G_GINT32_FORMAT. - */ - - -/** - * gint64: - * - * A signed integer guaranteed to be 64 bits on all platforms. - * Values of this type can range from #G_MININT64 - * (= -9,223,372,036,854,775,808) to #G_MAXINT64 - * (= 9,223,372,036,854,775,807). - * - * To print or scan values of this type, use - * %G_GINT64_MODIFIER and/or %G_GINT64_FORMAT. - */ - - -/** - * gint8: - * - * A signed integer guaranteed to be 8 bits on all platforms. - * Values of this type can range from #G_MININT8 (= -128) to - * #G_MAXINT8 (= 127). - */ - - -/** - * gintptr: - * - * Corresponds to the C99 type intptr_t, - * a signed integer type that can hold any pointer. - * - * To print or scan values of this type, use - * %G_GINTPTR_MODIFIER and/or %G_GINTPTR_FORMAT. - * - * Since: 2.18 - */ - - -/** - * glib__private__: - * @arg: Do not use this argument - * - * Do not call this function; it is used to share private - * API between glib, gobject, and gio. - */ - - -/** - * glib_binary_age: - * - * The binary age of the GLib library. - * Defines how far back backwards compatibility reaches. - * - * An integer variable exported from the library linked - * against at application run time. - */ - - -/** - * glib_check_version: - * @required_major: the required major version - * @required_minor: the required minor version - * @required_micro: the required micro version - * - * Checks that the GLib library in use is compatible with the - * given version. - * - * Generally you would pass in the constants %GLIB_MAJOR_VERSION, - * %GLIB_MINOR_VERSION, %GLIB_MICRO_VERSION as the three arguments - * to this function; that produces a check that the library in use - * is compatible with the version of GLib the application or module - * was compiled against. - * - * Compatibility is defined by two things: first the version - * of the running library is newer than the version - * `@required_major.required_minor.@required_micro`. Second - * the running library must be binary compatible with the - * version `@required_major.@required_minor.@required_micro` - * (same major version.) - * - * Returns: (transfer none) (nullable): %NULL if the GLib library is - * compatible with the given version, or a string describing the - * version mismatch. The returned string is owned by GLib and must - * not be modified or freed. - * Since: 2.6 - */ - - -/** - * glib_gettext: - * @str: The string to be translated - * - * Returns the translated string from the glib translations. - * This is an internal function and should only be used by - * the internals of glib (such as libgio). - * - * Returns: the translation of @str to the current locale - */ - - -/** - * glib_interface_age: - * - * The interface age of the GLib library. - * Defines how far back the API has last been extended. - * - * An integer variable exported from the library linked - * against at application run time. - */ - - -/** - * glib_major_version: - * - * The major version of the GLib library. - * - * An integer variable exported from the library linked - * against at application run time. - */ - - -/** - * glib_mem_profiler_table: - * - * Used to be a #GMemVTable containing profiling variants of the memory - * allocation functions, but this variable shouldn't be modified anymore. - * - * Deprecated: 2.46: Use other memory profiling tools instead - */ - - -/** - * glib_micro_version: - * - * The micro version number of the GLib library. - * - * An integer variable exported from the library linked - * against at application run time. - */ - - -/** - * glib_minor_version: - * - * The minor version number of the GLib library. - * - * An integer variable exported from the library linked - * against at application run time. - */ - - -/** - * glib_pgettext: - * @msgctxtid: a combined message context and message id, separated - * by a \004 character - * @msgidoffset: the offset of the message id in @msgctxid - * - * This function is a variant of glib_gettext() which supports - * a disambiguating message context. See g_dpgettext() for full - * details. - * - * This is an internal function and should only be used by - * the internals of glib (such as libgio). - * - * Returns: the translation of @str to the current locale - */ - - -/** - * glong: - * - * Corresponds to the standard C long type. - * Values of this type can range from #G_MINLONG to #G_MAXLONG. - */ - - -/** - * goffset: - * - * A signed integer type that is used for file offsets, - * corresponding to the POSIX type `off_t` as if compiling with - * `_FILE_OFFSET_BITS` set to 64. #goffset is always 64 bits wide, even on - * 32-bit architectures. - * Values of this type can range from #G_MINOFFSET to - * #G_MAXOFFSET. - * - * To print or scan values of this type, use - * %G_GOFFSET_MODIFIER and/or %G_GOFFSET_FORMAT. - * - * Since: 2.14 - */ - - -/** - * gpointer: - * - * An untyped pointer. - * #gpointer looks better and is easier to use than void*. - */ - - -/** - * grefcount: - * - * A type for implementing non-atomic reference count semantics. - * - * Use g_ref_count_init() to initialize it; g_ref_count_inc() to - * increase the counter, and g_ref_count_dec() to decrease it. - * - * It is safe to use #grefcount only if you're expecting to operate - * on the reference counter from a single thread. It is entirely up - * to you to ensure that all reference count changes happen in the - * same thread. - * - * See also: #gatomicrefcount - * - * Since: 2.58 - */ - - -/** - * gshort: - * - * Corresponds to the standard C short type. - * Values of this type can range from #G_MINSHORT to #G_MAXSHORT. - */ - - -/** - * gsize: - * - * An unsigned integer type of the result of the sizeof operator, - * corresponding to the size_t type defined in C99. - * This type is wide enough to hold the numeric value of a pointer, - * so it is usually 32 bit wide on a 32-bit platform and 64 bit wide - * on a 64-bit platform. Values of this type can range from 0 to - * #G_MAXSIZE. - * - * To print or scan values of this type, use - * %G_GSIZE_MODIFIER and/or %G_GSIZE_FORMAT. - */ - - -/** - * gssize: - * - * A signed variant of #gsize, corresponding to the - * ssize_t defined on most platforms. - * Values of this type can range from #G_MINSSIZE - * to #G_MAXSSIZE. - * - * To print or scan values of this type, use - * %G_GSSIZE_MODIFIER and/or %G_GSSIZE_FORMAT. - */ - - -/** - * guchar: - * - * Corresponds to the standard C unsigned char type. - */ - - -/** - * guint: - * - * Corresponds to the standard C unsigned int type. - * Values of this type can range from 0 to #G_MAXUINT. - */ - - -/** - * guint16: - * - * An unsigned integer guaranteed to be 16 bits on all platforms. - * Values of this type can range from 0 to #G_MAXUINT16 (= 65,535). - * - * To print or scan values of this type, use - * %G_GINT16_MODIFIER and/or %G_GUINT16_FORMAT. - */ - - -/** - * guint32: - * - * An unsigned integer guaranteed to be 32 bits on all platforms. - * Values of this type can range from 0 to #G_MAXUINT32 (= 4,294,967,295). - * - * To print or scan values of this type, use - * %G_GINT32_MODIFIER and/or %G_GUINT32_FORMAT. - */ - - -/** - * guint64: - * - * An unsigned integer guaranteed to be 64-bits on all platforms. - * Values of this type can range from 0 to #G_MAXUINT64 - * (= 18,446,744,073,709,551,615). - * - * To print or scan values of this type, use - * %G_GINT64_MODIFIER and/or %G_GUINT64_FORMAT. - */ - - -/** - * guint8: - * - * An unsigned integer guaranteed to be 8 bits on all platforms. - * Values of this type can range from 0 to #G_MAXUINT8 (= 255). - */ - - -/** - * guintptr: - * - * Corresponds to the C99 type uintptr_t, - * an unsigned integer type that can hold any pointer. - * - * To print or scan values of this type, use - * %G_GINTPTR_MODIFIER and/or %G_GUINTPTR_FORMAT. - * - * Since: 2.18 - */ - - -/** - * gulong: - * - * Corresponds to the standard C unsigned long type. - * Values of this type can range from 0 to #G_MAXULONG. - */ - - -/** - * gushort: - * - * Corresponds to the standard C unsigned short type. - * Values of this type can range from 0 to #G_MAXUSHORT. - */ - - - -/************************************************************/ -/* THIS FILE IS GENERATED DO NOT EDIT */ -/************************************************************/ |