1998-06-10 23:21:14 +00:00
|
|
|
|
/* GLIB - Library of useful routines for C programming
|
|
|
|
|
* Copyright (C) 1995-1997 Peter Mattis, Spencer Kimball and Josh MacDonald
|
|
|
|
|
*
|
2022-05-18 09:15:38 +01:00
|
|
|
|
* SPDX-License-Identifier: LGPL-2.1-or-later
|
|
|
|
|
*
|
1998-06-10 23:21:14 +00:00
|
|
|
|
* This library is free software; you can redistribute it and/or
|
2000-07-26 11:02:02 +00:00
|
|
|
|
* modify it under the terms of the GNU Lesser General Public
|
1998-06-10 23:21:14 +00:00
|
|
|
|
* License as published by the Free Software Foundation; either
|
2017-01-05 12:47:07 +01:00
|
|
|
|
* version 2.1 of the License, or (at your option) any later version.
|
1998-06-10 23:21:14 +00:00
|
|
|
|
*
|
|
|
|
|
* This library is distributed in the hope that it will be useful,
|
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
2000-07-26 11:02:02 +00:00
|
|
|
|
* Lesser General Public License for more details.
|
1998-06-10 23:21:14 +00:00
|
|
|
|
*
|
2000-07-26 11:02:02 +00:00
|
|
|
|
* You should have received a copy of the GNU Lesser General Public
|
2014-01-23 12:58:29 +01:00
|
|
|
|
* License along with this library; if not, see <http://www.gnu.org/licenses/>.
|
1998-06-10 23:21:14 +00:00
|
|
|
|
*/
|
1998-11-01 01:32:59 +00:00
|
|
|
|
|
1999-02-24 06:14:27 +00:00
|
|
|
|
/*
|
2000-07-26 11:02:02 +00:00
|
|
|
|
* Modified by the GLib Team and others 1997-2000. See the AUTHORS
|
1999-02-24 06:14:27 +00:00
|
|
|
|
* file for a list of people on the GLib Team. See the ChangeLog
|
|
|
|
|
* files for a list of changes. These files are distributed with
|
2009-07-05 23:55:00 -04:00
|
|
|
|
* GLib at ftp://ftp.gtk.org/pub/gtk/.
|
1999-02-24 06:14:27 +00:00
|
|
|
|
*/
|
|
|
|
|
|
2002-12-04 01:27:44 +00:00
|
|
|
|
#include "config.h"
|
|
|
|
|
|
2020-12-20 01:09:25 +01:00
|
|
|
|
#include "gvalgrind.h"
|
2019-12-25 13:07:32 +01:00
|
|
|
|
#include <string.h>
|
|
|
|
|
|
2010-09-05 00:23:03 -04:00
|
|
|
|
#include "gerror.h"
|
1998-06-10 23:21:14 +00:00
|
|
|
|
|
2019-12-25 13:07:32 +01:00
|
|
|
|
#include "ghash.h"
|
|
|
|
|
#include "glib-init.h"
|
2011-09-18 18:59:20 -04:00
|
|
|
|
#include "gslice.h"
|
2010-09-05 00:23:03 -04:00
|
|
|
|
#include "gstrfuncs.h"
|
|
|
|
|
#include "gtestutils.h"
|
2019-12-25 13:07:32 +01:00
|
|
|
|
#include "gthread.h"
|
|
|
|
|
|
|
|
|
|
static GRWLock error_domain_global;
|
|
|
|
|
/* error_domain_ht must be accessed with error_domain_global
|
|
|
|
|
* locked.
|
|
|
|
|
*/
|
|
|
|
|
static GHashTable *error_domain_ht = NULL;
|
2002-12-04 01:27:44 +00:00
|
|
|
|
|
2019-12-25 13:07:32 +01:00
|
|
|
|
void
|
|
|
|
|
g_error_init (void)
|
|
|
|
|
{
|
|
|
|
|
error_domain_ht = g_hash_table_new (NULL, NULL);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
typedef struct
|
|
|
|
|
{
|
|
|
|
|
/* private_size is already aligned. */
|
|
|
|
|
gsize private_size;
|
|
|
|
|
GErrorInitFunc init;
|
|
|
|
|
GErrorCopyFunc copy;
|
|
|
|
|
GErrorClearFunc clear;
|
|
|
|
|
} ErrorDomainInfo;
|
|
|
|
|
|
|
|
|
|
/* Must be called with error_domain_global locked.
|
|
|
|
|
*/
|
|
|
|
|
static inline ErrorDomainInfo *
|
|
|
|
|
error_domain_lookup (GQuark domain)
|
|
|
|
|
{
|
|
|
|
|
return g_hash_table_lookup (error_domain_ht,
|
|
|
|
|
GUINT_TO_POINTER (domain));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Copied from gtype.c. */
|
|
|
|
|
#define STRUCT_ALIGNMENT (2 * sizeof (gsize))
|
|
|
|
|
#define ALIGN_STRUCT(offset) \
|
|
|
|
|
((offset + (STRUCT_ALIGNMENT - 1)) & -STRUCT_ALIGNMENT)
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
error_domain_register (GQuark error_quark,
|
|
|
|
|
gsize error_type_private_size,
|
|
|
|
|
GErrorInitFunc error_type_init,
|
|
|
|
|
GErrorCopyFunc error_type_copy,
|
|
|
|
|
GErrorClearFunc error_type_clear)
|
|
|
|
|
{
|
|
|
|
|
g_rw_lock_writer_lock (&error_domain_global);
|
|
|
|
|
if (error_domain_lookup (error_quark) == NULL)
|
|
|
|
|
{
|
|
|
|
|
ErrorDomainInfo *info = g_new (ErrorDomainInfo, 1);
|
|
|
|
|
info->private_size = ALIGN_STRUCT (error_type_private_size);
|
|
|
|
|
info->init = error_type_init;
|
|
|
|
|
info->copy = error_type_copy;
|
|
|
|
|
info->clear = error_type_clear;
|
|
|
|
|
|
|
|
|
|
g_hash_table_insert (error_domain_ht,
|
|
|
|
|
GUINT_TO_POINTER (error_quark),
|
|
|
|
|
info);
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
const char *name = g_quark_to_string (error_quark);
|
|
|
|
|
|
|
|
|
|
g_critical ("Attempted to register an extended error domain for %s more than once", name);
|
|
|
|
|
}
|
|
|
|
|
g_rw_lock_writer_unlock (&error_domain_global);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* 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
|
2023-11-29 12:02:04 +00:00
|
|
|
|
* @error_type_init: (scope forever): function initializing fields of the private error data
|
|
|
|
|
* @error_type_copy: (scope forever): function copying fields of the private error data
|
|
|
|
|
* @error_type_clear: (scope forever): function freeing fields of the private error data
|
2019-12-25 13:07:32 +01:00
|
|
|
|
*
|
|
|
|
|
* 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
|
|
|
|
|
*/
|
|
|
|
|
GQuark
|
|
|
|
|
g_error_domain_register_static (const char *error_type_name,
|
|
|
|
|
gsize error_type_private_size,
|
|
|
|
|
GErrorInitFunc error_type_init,
|
|
|
|
|
GErrorCopyFunc error_type_copy,
|
|
|
|
|
GErrorClearFunc error_type_clear)
|
|
|
|
|
{
|
|
|
|
|
GQuark error_quark;
|
|
|
|
|
|
|
|
|
|
g_return_val_if_fail (error_type_name != NULL, 0);
|
|
|
|
|
g_return_val_if_fail (error_type_private_size > 0, 0);
|
|
|
|
|
g_return_val_if_fail (error_type_init != NULL, 0);
|
|
|
|
|
g_return_val_if_fail (error_type_copy != NULL, 0);
|
|
|
|
|
g_return_val_if_fail (error_type_clear != NULL, 0);
|
|
|
|
|
|
|
|
|
|
error_quark = g_quark_from_static_string (error_type_name);
|
|
|
|
|
error_domain_register (error_quark,
|
|
|
|
|
error_type_private_size,
|
|
|
|
|
error_type_init,
|
|
|
|
|
error_type_copy,
|
|
|
|
|
error_type_clear);
|
|
|
|
|
return error_quark;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* 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
|
2023-11-29 12:02:04 +00:00
|
|
|
|
* @error_type_init: (scope forever): function initializing fields of the private error data
|
|
|
|
|
* @error_type_copy: (scope forever): function copying fields of the private error data
|
|
|
|
|
* @error_type_clear: (scope forever): function freeing fields of the private error data
|
2019-12-25 13:07:32 +01:00
|
|
|
|
*
|
|
|
|
|
* 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
|
|
|
|
|
*/
|
|
|
|
|
GQuark
|
|
|
|
|
g_error_domain_register (const char *error_type_name,
|
|
|
|
|
gsize error_type_private_size,
|
|
|
|
|
GErrorInitFunc error_type_init,
|
|
|
|
|
GErrorCopyFunc error_type_copy,
|
|
|
|
|
GErrorClearFunc error_type_clear)
|
|
|
|
|
{
|
|
|
|
|
GQuark error_quark;
|
|
|
|
|
|
|
|
|
|
g_return_val_if_fail (error_type_name != NULL, 0);
|
|
|
|
|
g_return_val_if_fail (error_type_private_size > 0, 0);
|
|
|
|
|
g_return_val_if_fail (error_type_init != NULL, 0);
|
|
|
|
|
g_return_val_if_fail (error_type_copy != NULL, 0);
|
|
|
|
|
g_return_val_if_fail (error_type_clear != NULL, 0);
|
|
|
|
|
|
|
|
|
|
error_quark = g_quark_from_string (error_type_name);
|
|
|
|
|
error_domain_register (error_quark,
|
|
|
|
|
error_type_private_size,
|
|
|
|
|
error_type_init,
|
|
|
|
|
error_type_copy,
|
|
|
|
|
error_type_clear);
|
|
|
|
|
return error_quark;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static GError *
|
|
|
|
|
g_error_allocate (GQuark domain, ErrorDomainInfo *out_info)
|
|
|
|
|
{
|
|
|
|
|
guint8 *allocated;
|
|
|
|
|
GError *error;
|
|
|
|
|
ErrorDomainInfo *info;
|
|
|
|
|
gsize private_size;
|
|
|
|
|
|
|
|
|
|
g_rw_lock_reader_lock (&error_domain_global);
|
|
|
|
|
info = error_domain_lookup (domain);
|
|
|
|
|
if (info != NULL)
|
|
|
|
|
{
|
|
|
|
|
if (out_info != NULL)
|
|
|
|
|
*out_info = *info;
|
|
|
|
|
private_size = info->private_size;
|
|
|
|
|
g_rw_lock_reader_unlock (&error_domain_global);
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
g_rw_lock_reader_unlock (&error_domain_global);
|
|
|
|
|
if (out_info != NULL)
|
|
|
|
|
memset (out_info, 0, sizeof (*out_info));
|
|
|
|
|
private_size = 0;
|
|
|
|
|
}
|
2020-12-20 01:09:25 +01:00
|
|
|
|
/* See comments in g_type_create_instance in gtype.c to see what
|
|
|
|
|
* this magic is about.
|
|
|
|
|
*/
|
|
|
|
|
#ifdef ENABLE_VALGRIND
|
|
|
|
|
if (private_size > 0 && RUNNING_ON_VALGRIND)
|
|
|
|
|
{
|
|
|
|
|
private_size += ALIGN_STRUCT (1);
|
|
|
|
|
allocated = g_slice_alloc0 (private_size + sizeof (GError) + sizeof (gpointer));
|
|
|
|
|
*(gpointer *) (allocated + private_size + sizeof (GError)) = allocated + ALIGN_STRUCT (1);
|
|
|
|
|
VALGRIND_MALLOCLIKE_BLOCK (allocated + private_size, sizeof (GError) + sizeof (gpointer), 0, TRUE);
|
|
|
|
|
VALGRIND_MALLOCLIKE_BLOCK (allocated + ALIGN_STRUCT (1), private_size - ALIGN_STRUCT (1), 0, TRUE);
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
#endif
|
|
|
|
|
allocated = g_slice_alloc0 (private_size + sizeof (GError));
|
|
|
|
|
|
2019-12-25 13:07:32 +01:00
|
|
|
|
error = (GError *) (allocated + private_size);
|
|
|
|
|
return error;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* This function takes ownership of @message. */
|
2019-12-26 16:23:23 +01:00
|
|
|
|
static GError *
|
2019-12-25 13:07:32 +01:00
|
|
|
|
g_error_new_steal (GQuark domain,
|
|
|
|
|
gint code,
|
|
|
|
|
gchar *message,
|
|
|
|
|
ErrorDomainInfo *out_info)
|
2019-12-26 16:23:23 +01:00
|
|
|
|
{
|
2019-12-25 13:07:32 +01:00
|
|
|
|
ErrorDomainInfo info;
|
|
|
|
|
GError *error = g_error_allocate (domain, &info);
|
2019-12-26 16:23:23 +01:00
|
|
|
|
|
|
|
|
|
error->domain = domain;
|
|
|
|
|
error->code = code;
|
|
|
|
|
error->message = message;
|
|
|
|
|
|
2019-12-25 13:07:32 +01:00
|
|
|
|
if (info.init != NULL)
|
|
|
|
|
info.init (error);
|
|
|
|
|
if (out_info != NULL)
|
|
|
|
|
*out_info = info;
|
|
|
|
|
|
2019-12-26 16:23:23 +01:00
|
|
|
|
return error;
|
|
|
|
|
}
|
2002-12-04 01:27:44 +00:00
|
|
|
|
|
2009-04-20 13:22:17 +02:00
|
|
|
|
/**
|
|
|
|
|
* g_error_new_valist:
|
|
|
|
|
* @domain: error domain
|
|
|
|
|
* @code: error code
|
|
|
|
|
* @format: printf()-style format for error message
|
2009-07-05 23:55:00 -04:00
|
|
|
|
* @args: #va_list of parameters for the message format
|
2009-04-20 13:22:17 +02:00
|
|
|
|
*
|
|
|
|
|
* Creates a new #GError with the given @domain and @code,
|
|
|
|
|
* and a message formatted with @format.
|
|
|
|
|
*
|
|
|
|
|
* Returns: a new #GError
|
|
|
|
|
*
|
|
|
|
|
* Since: 2.22
|
2009-07-05 23:55:00 -04:00
|
|
|
|
*/
|
2009-04-20 13:22:17 +02:00
|
|
|
|
GError*
|
2009-07-05 23:55:00 -04:00
|
|
|
|
g_error_new_valist (GQuark domain,
|
|
|
|
|
gint code,
|
|
|
|
|
const gchar *format,
|
|
|
|
|
va_list args)
|
2000-07-12 21:06:16 +00:00
|
|
|
|
{
|
2023-02-20 16:41:23 +00:00
|
|
|
|
g_return_val_if_fail (format != NULL, NULL);
|
|
|
|
|
|
2011-09-30 14:02:29 +01:00
|
|
|
|
/* Historically, GError allowed this (although it was never meant to work),
|
|
|
|
|
* and it has significant use in the wild, which g_return_val_if_fail
|
|
|
|
|
* would break. It should maybe g_return_val_if_fail in GLib 4.
|
|
|
|
|
* (GNOME#660371, GNOME#560482)
|
|
|
|
|
*/
|
|
|
|
|
g_warn_if_fail (domain != 0);
|
|
|
|
|
|
2019-12-25 13:07:32 +01:00
|
|
|
|
return g_error_new_steal (domain, code, g_strdup_vprintf (format, args), NULL);
|
2000-07-12 21:06:16 +00:00
|
|
|
|
}
|
|
|
|
|
|
2000-09-06 23:30:21 +00:00
|
|
|
|
/**
|
|
|
|
|
* g_error_new:
|
2009-07-05 23:55:00 -04:00
|
|
|
|
* @domain: error domain
|
2000-09-06 23:30:21 +00:00
|
|
|
|
* @code: error code
|
2003-07-25 21:32:47 +00:00
|
|
|
|
* @format: printf()-style format for error message
|
2011-07-22 13:25:32 +02:00
|
|
|
|
* @...: parameters for message format
|
2009-07-05 23:55:00 -04:00
|
|
|
|
*
|
2000-09-06 23:30:21 +00:00
|
|
|
|
* Creates a new #GError with the given @domain and @code,
|
|
|
|
|
* and a message formatted with @format.
|
2009-07-05 23:55:00 -04:00
|
|
|
|
*
|
2014-02-19 19:35:23 -05:00
|
|
|
|
* Returns: a new #GError
|
2009-07-05 23:55:00 -04:00
|
|
|
|
*/
|
2000-07-12 21:06:16 +00:00
|
|
|
|
GError*
|
|
|
|
|
g_error_new (GQuark domain,
|
|
|
|
|
gint code,
|
|
|
|
|
const gchar *format,
|
|
|
|
|
...)
|
|
|
|
|
{
|
|
|
|
|
GError* error;
|
|
|
|
|
va_list args;
|
1998-06-10 23:21:14 +00:00
|
|
|
|
|
2000-07-12 21:06:16 +00:00
|
|
|
|
g_return_val_if_fail (format != NULL, NULL);
|
|
|
|
|
g_return_val_if_fail (domain != 0, NULL);
|
1998-06-10 23:21:14 +00:00
|
|
|
|
|
2000-07-12 21:06:16 +00:00
|
|
|
|
va_start (args, format);
|
|
|
|
|
error = g_error_new_valist (domain, code, format, args);
|
|
|
|
|
va_end (args);
|
1998-06-10 23:21:14 +00:00
|
|
|
|
|
2000-07-12 21:06:16 +00:00
|
|
|
|
return error;
|
|
|
|
|
}
|
1998-06-10 23:21:14 +00:00
|
|
|
|
|
2000-09-06 23:30:21 +00:00
|
|
|
|
/**
|
|
|
|
|
* g_error_new_literal:
|
|
|
|
|
* @domain: error domain
|
|
|
|
|
* @code: error code
|
|
|
|
|
* @message: error message
|
2009-07-05 23:55:00 -04:00
|
|
|
|
*
|
|
|
|
|
* 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,
|
2003-07-25 21:32:47 +00:00
|
|
|
|
* that could include printf() escape sequences.
|
2009-07-05 23:55:00 -04:00
|
|
|
|
*
|
2014-02-19 19:35:23 -05:00
|
|
|
|
* Returns: a new #GError
|
2000-09-06 23:30:21 +00:00
|
|
|
|
**/
|
2000-07-12 21:06:16 +00:00
|
|
|
|
GError*
|
|
|
|
|
g_error_new_literal (GQuark domain,
|
|
|
|
|
gint code,
|
|
|
|
|
const gchar *message)
|
|
|
|
|
{
|
|
|
|
|
g_return_val_if_fail (message != NULL, NULL);
|
|
|
|
|
g_return_val_if_fail (domain != 0, NULL);
|
1998-06-10 23:21:14 +00:00
|
|
|
|
|
2019-12-25 13:07:32 +01:00
|
|
|
|
return g_error_new_steal (domain, code, g_strdup (message), NULL);
|
2000-07-12 21:06:16 +00:00
|
|
|
|
}
|
1998-06-10 23:21:14 +00:00
|
|
|
|
|
2000-09-06 23:30:21 +00:00
|
|
|
|
/**
|
|
|
|
|
* g_error_free:
|
|
|
|
|
* @error: a #GError
|
|
|
|
|
*
|
|
|
|
|
* Frees a #GError and associated resources.
|
2009-07-05 23:55:00 -04:00
|
|
|
|
*/
|
1998-06-10 23:21:14 +00:00
|
|
|
|
void
|
2000-07-12 21:06:16 +00:00
|
|
|
|
g_error_free (GError *error)
|
1998-06-10 23:21:14 +00:00
|
|
|
|
{
|
2019-12-25 13:07:32 +01:00
|
|
|
|
gsize private_size;
|
|
|
|
|
ErrorDomainInfo *info;
|
|
|
|
|
guint8 *allocated;
|
|
|
|
|
|
2009-07-05 23:55:00 -04:00
|
|
|
|
g_return_if_fail (error != NULL);
|
removed this function which was not publically exported in glib.h. to
Mon Aug 24 02:08:56 1998 Tim Janik <timj@gtk.org>
* glib.h:
* gstring.c:
* gstrfuncs.c:
(g_vsprintf): removed this function which was not publically
exported in glib.h. to export it, it should have been named
differently in the first place, since its semantics differ from
vsprintf(). apart from that, it was a possible cause for
problems since it worked on a previously allocated memory area and
was used in a lot places of glib. exporting it would have been a
guararant for problems with threaded programs.
(g_printf_string_upper_bound): exported this function to return
a string size, guarranteed to be big enough to hold the fully
expanded format+args string. added 'q', 'L' and 'll' flag handling.
in fact, the newly allocated area is in most cases much bigger than
required.
(g_strdup_vprintf()): new function returning a newly allocated string
containing the contents of *format and associated args (size is
calculated with g_printf_string_upper_bound()).
(g_strdup_printf): new function which wraps g_strdup_vprintf().
* configure.in: check for va_copy() or __va_copy() alternatively.
check whether va_lists can be copyied by value.
* glib.h: provide a definition for G_VA_COPY.
* glib.h:
* gmessages.c:
(g_logv):
(g_vsnprintf):
pass va_lists by value, not by reference, since this causes problems
on platforms that implement va_list as as arrays. internaly, use
G_VA_COPY (new_arg, org_arg); va_end (new_arg); to produce a second
va_list variable, if multiple passes are required. changed all
callers.
* glib.h:
* gerror.h:
renamed g_debug() to g_on_error_query(), cleaned up a bit.
renamed g_stack_trace() to g_on_error_stack_trace() since both
functions cluttered different namespaces.
there is an appropriate comment in glib.h now that explains the
unix and gdb specific dependencies of both functions.
removed g_attach_process().
g_on_error_stack_trace() should probably be handled with caution,
i've seem several different linux versions (2.0.x) become unstable
after invokation of this function.
1998-08-24 05:26:53 +00:00
|
|
|
|
|
2019-12-25 13:07:32 +01:00
|
|
|
|
g_rw_lock_reader_lock (&error_domain_global);
|
|
|
|
|
info = error_domain_lookup (error->domain);
|
|
|
|
|
if (info != NULL)
|
|
|
|
|
{
|
|
|
|
|
GErrorClearFunc clear = info->clear;
|
|
|
|
|
|
|
|
|
|
private_size = info->private_size;
|
|
|
|
|
g_rw_lock_reader_unlock (&error_domain_global);
|
|
|
|
|
clear (error);
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
g_rw_lock_reader_unlock (&error_domain_global);
|
|
|
|
|
private_size = 0;
|
|
|
|
|
}
|
removed this function which was not publically exported in glib.h. to
Mon Aug 24 02:08:56 1998 Tim Janik <timj@gtk.org>
* glib.h:
* gstring.c:
* gstrfuncs.c:
(g_vsprintf): removed this function which was not publically
exported in glib.h. to export it, it should have been named
differently in the first place, since its semantics differ from
vsprintf(). apart from that, it was a possible cause for
problems since it worked on a previously allocated memory area and
was used in a lot places of glib. exporting it would have been a
guararant for problems with threaded programs.
(g_printf_string_upper_bound): exported this function to return
a string size, guarranteed to be big enough to hold the fully
expanded format+args string. added 'q', 'L' and 'll' flag handling.
in fact, the newly allocated area is in most cases much bigger than
required.
(g_strdup_vprintf()): new function returning a newly allocated string
containing the contents of *format and associated args (size is
calculated with g_printf_string_upper_bound()).
(g_strdup_printf): new function which wraps g_strdup_vprintf().
* configure.in: check for va_copy() or __va_copy() alternatively.
check whether va_lists can be copyied by value.
* glib.h: provide a definition for G_VA_COPY.
* glib.h:
* gmessages.c:
(g_logv):
(g_vsnprintf):
pass va_lists by value, not by reference, since this causes problems
on platforms that implement va_list as as arrays. internaly, use
G_VA_COPY (new_arg, org_arg); va_end (new_arg); to produce a second
va_list variable, if multiple passes are required. changed all
callers.
* glib.h:
* gerror.h:
renamed g_debug() to g_on_error_query(), cleaned up a bit.
renamed g_stack_trace() to g_on_error_stack_trace() since both
functions cluttered different namespaces.
there is an appropriate comment in glib.h now that explains the
unix and gdb specific dependencies of both functions.
removed g_attach_process().
g_on_error_stack_trace() should probably be handled with caution,
i've seem several different linux versions (2.0.x) become unstable
after invokation of this function.
1998-08-24 05:26:53 +00:00
|
|
|
|
|
2019-12-25 13:07:32 +01:00
|
|
|
|
g_free (error->message);
|
|
|
|
|
allocated = ((guint8 *) error) - private_size;
|
2020-12-20 01:09:25 +01:00
|
|
|
|
/* See comments in g_type_free_instance in gtype.c to see what this
|
|
|
|
|
* magic is about.
|
|
|
|
|
*/
|
|
|
|
|
#ifdef ENABLE_VALGRIND
|
|
|
|
|
if (private_size > 0 && RUNNING_ON_VALGRIND)
|
|
|
|
|
{
|
|
|
|
|
private_size += ALIGN_STRUCT (1);
|
|
|
|
|
allocated -= ALIGN_STRUCT (1);
|
|
|
|
|
*(gpointer *) (allocated + private_size + sizeof (GError)) = NULL;
|
|
|
|
|
g_slice_free1 (private_size + sizeof (GError) + sizeof (gpointer), allocated);
|
|
|
|
|
VALGRIND_FREELIKE_BLOCK (allocated + ALIGN_STRUCT (1), 0);
|
|
|
|
|
VALGRIND_FREELIKE_BLOCK (error, 0);
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
#endif
|
2019-12-25 13:07:32 +01:00
|
|
|
|
g_slice_free1 (private_size + sizeof (GError), allocated);
|
1998-06-10 23:21:14 +00:00
|
|
|
|
}
|
|
|
|
|
|
2000-09-06 23:30:21 +00:00
|
|
|
|
/**
|
|
|
|
|
* g_error_copy:
|
|
|
|
|
* @error: a #GError
|
2009-07-05 23:55:00 -04:00
|
|
|
|
*
|
2000-09-06 23:30:21 +00:00
|
|
|
|
* Makes a copy of @error.
|
2009-07-05 23:55:00 -04:00
|
|
|
|
*
|
2014-02-19 19:35:23 -05:00
|
|
|
|
* Returns: a new #GError
|
2009-07-05 23:55:00 -04:00
|
|
|
|
*/
|
2000-07-12 21:06:16 +00:00
|
|
|
|
GError*
|
|
|
|
|
g_error_copy (const GError *error)
|
1998-06-10 23:21:14 +00:00
|
|
|
|
{
|
2000-07-12 21:06:16 +00:00
|
|
|
|
GError *copy;
|
2019-12-25 13:07:32 +01:00
|
|
|
|
ErrorDomainInfo info;
|
|
|
|
|
|
2000-07-12 21:06:16 +00:00
|
|
|
|
g_return_val_if_fail (error != NULL, NULL);
|
2023-02-20 16:41:23 +00:00
|
|
|
|
g_return_val_if_fail (error->message != NULL, NULL);
|
|
|
|
|
|
|
|
|
|
/* See g_error_new_valist for why this doesn’t return */
|
2011-09-30 14:02:29 +01:00
|
|
|
|
g_warn_if_fail (error->domain != 0);
|
removed this function which was not publically exported in glib.h. to
Mon Aug 24 02:08:56 1998 Tim Janik <timj@gtk.org>
* glib.h:
* gstring.c:
* gstrfuncs.c:
(g_vsprintf): removed this function which was not publically
exported in glib.h. to export it, it should have been named
differently in the first place, since its semantics differ from
vsprintf(). apart from that, it was a possible cause for
problems since it worked on a previously allocated memory area and
was used in a lot places of glib. exporting it would have been a
guararant for problems with threaded programs.
(g_printf_string_upper_bound): exported this function to return
a string size, guarranteed to be big enough to hold the fully
expanded format+args string. added 'q', 'L' and 'll' flag handling.
in fact, the newly allocated area is in most cases much bigger than
required.
(g_strdup_vprintf()): new function returning a newly allocated string
containing the contents of *format and associated args (size is
calculated with g_printf_string_upper_bound()).
(g_strdup_printf): new function which wraps g_strdup_vprintf().
* configure.in: check for va_copy() or __va_copy() alternatively.
check whether va_lists can be copyied by value.
* glib.h: provide a definition for G_VA_COPY.
* glib.h:
* gmessages.c:
(g_logv):
(g_vsnprintf):
pass va_lists by value, not by reference, since this causes problems
on platforms that implement va_list as as arrays. internaly, use
G_VA_COPY (new_arg, org_arg); va_end (new_arg); to produce a second
va_list variable, if multiple passes are required. changed all
callers.
* glib.h:
* gerror.h:
renamed g_debug() to g_on_error_query(), cleaned up a bit.
renamed g_stack_trace() to g_on_error_stack_trace() since both
functions cluttered different namespaces.
there is an appropriate comment in glib.h now that explains the
unix and gdb specific dependencies of both functions.
removed g_attach_process().
g_on_error_stack_trace() should probably be handled with caution,
i've seem several different linux versions (2.0.x) become unstable
after invokation of this function.
1998-08-24 05:26:53 +00:00
|
|
|
|
|
2019-12-25 13:07:32 +01:00
|
|
|
|
copy = g_error_new_steal (error->domain,
|
2019-12-26 16:23:23 +01:00
|
|
|
|
error->code,
|
2019-12-25 13:07:32 +01:00
|
|
|
|
g_strdup (error->message),
|
|
|
|
|
&info);
|
|
|
|
|
if (info.copy != NULL)
|
|
|
|
|
info.copy (error, copy);
|
1998-06-10 23:21:14 +00:00
|
|
|
|
|
2000-07-12 21:06:16 +00:00
|
|
|
|
return copy;
|
removed this function which was not publically exported in glib.h. to
Mon Aug 24 02:08:56 1998 Tim Janik <timj@gtk.org>
* glib.h:
* gstring.c:
* gstrfuncs.c:
(g_vsprintf): removed this function which was not publically
exported in glib.h. to export it, it should have been named
differently in the first place, since its semantics differ from
vsprintf(). apart from that, it was a possible cause for
problems since it worked on a previously allocated memory area and
was used in a lot places of glib. exporting it would have been a
guararant for problems with threaded programs.
(g_printf_string_upper_bound): exported this function to return
a string size, guarranteed to be big enough to hold the fully
expanded format+args string. added 'q', 'L' and 'll' flag handling.
in fact, the newly allocated area is in most cases much bigger than
required.
(g_strdup_vprintf()): new function returning a newly allocated string
containing the contents of *format and associated args (size is
calculated with g_printf_string_upper_bound()).
(g_strdup_printf): new function which wraps g_strdup_vprintf().
* configure.in: check for va_copy() or __va_copy() alternatively.
check whether va_lists can be copyied by value.
* glib.h: provide a definition for G_VA_COPY.
* glib.h:
* gmessages.c:
(g_logv):
(g_vsnprintf):
pass va_lists by value, not by reference, since this causes problems
on platforms that implement va_list as as arrays. internaly, use
G_VA_COPY (new_arg, org_arg); va_end (new_arg); to produce a second
va_list variable, if multiple passes are required. changed all
callers.
* glib.h:
* gerror.h:
renamed g_debug() to g_on_error_query(), cleaned up a bit.
renamed g_stack_trace() to g_on_error_stack_trace() since both
functions cluttered different namespaces.
there is an appropriate comment in glib.h now that explains the
unix and gdb specific dependencies of both functions.
removed g_attach_process().
g_on_error_stack_trace() should probably be handled with caution,
i've seem several different linux versions (2.0.x) become unstable
after invokation of this function.
1998-08-24 05:26:53 +00:00
|
|
|
|
}
|
|
|
|
|
|
2000-09-06 23:30:21 +00:00
|
|
|
|
/**
|
|
|
|
|
* g_error_matches:
|
2013-12-06 12:23:09 +00:00
|
|
|
|
* @error: (nullable): a #GError
|
2000-09-06 23:30:21 +00:00
|
|
|
|
* @domain: an error domain
|
|
|
|
|
* @code: an error code
|
2009-07-05 23:55:00 -04:00
|
|
|
|
*
|
2001-12-16 19:31:36 +00:00
|
|
|
|
* Returns %TRUE if @error matches @domain and @code, %FALSE
|
2009-08-06 18:17:32 +02:00
|
|
|
|
* otherwise. In particular, when @error is %NULL, %FALSE will
|
|
|
|
|
* be returned.
|
2009-07-05 23:55:00 -04:00
|
|
|
|
*
|
2014-03-20 09:25:19 -04:00
|
|
|
|
* 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
|
2015-06-05 11:21:57 -04:00
|
|
|
|
* equivalent to the `FAILED` code. This way, if the domain is
|
2014-03-20 09:25:19 -04:00
|
|
|
|
* extended in the future to provide a more specific error code for
|
|
|
|
|
* a certain case, your code will still work.
|
|
|
|
|
*
|
2014-02-19 19:35:23 -05:00
|
|
|
|
* Returns: whether @error has @domain and @code
|
2009-07-05 23:55:00 -04:00
|
|
|
|
*/
|
2000-07-12 21:06:16 +00:00
|
|
|
|
gboolean
|
|
|
|
|
g_error_matches (const GError *error,
|
|
|
|
|
GQuark domain,
|
|
|
|
|
gint code)
|
removed this function which was not publically exported in glib.h. to
Mon Aug 24 02:08:56 1998 Tim Janik <timj@gtk.org>
* glib.h:
* gstring.c:
* gstrfuncs.c:
(g_vsprintf): removed this function which was not publically
exported in glib.h. to export it, it should have been named
differently in the first place, since its semantics differ from
vsprintf(). apart from that, it was a possible cause for
problems since it worked on a previously allocated memory area and
was used in a lot places of glib. exporting it would have been a
guararant for problems with threaded programs.
(g_printf_string_upper_bound): exported this function to return
a string size, guarranteed to be big enough to hold the fully
expanded format+args string. added 'q', 'L' and 'll' flag handling.
in fact, the newly allocated area is in most cases much bigger than
required.
(g_strdup_vprintf()): new function returning a newly allocated string
containing the contents of *format and associated args (size is
calculated with g_printf_string_upper_bound()).
(g_strdup_printf): new function which wraps g_strdup_vprintf().
* configure.in: check for va_copy() or __va_copy() alternatively.
check whether va_lists can be copyied by value.
* glib.h: provide a definition for G_VA_COPY.
* glib.h:
* gmessages.c:
(g_logv):
(g_vsnprintf):
pass va_lists by value, not by reference, since this causes problems
on platforms that implement va_list as as arrays. internaly, use
G_VA_COPY (new_arg, org_arg); va_end (new_arg); to produce a second
va_list variable, if multiple passes are required. changed all
callers.
* glib.h:
* gerror.h:
renamed g_debug() to g_on_error_query(), cleaned up a bit.
renamed g_stack_trace() to g_on_error_stack_trace() since both
functions cluttered different namespaces.
there is an appropriate comment in glib.h now that explains the
unix and gdb specific dependencies of both functions.
removed g_attach_process().
g_on_error_stack_trace() should probably be handled with caution,
i've seem several different linux versions (2.0.x) become unstable
after invokation of this function.
1998-08-24 05:26:53 +00:00
|
|
|
|
{
|
2000-07-12 21:06:16 +00:00
|
|
|
|
return error &&
|
|
|
|
|
error->domain == domain &&
|
|
|
|
|
error->code == code;
|
1998-06-10 23:21:14 +00:00
|
|
|
|
}
|
|
|
|
|
|
2000-09-01 12:47:42 +00:00
|
|
|
|
#define ERROR_OVERWRITTEN_WARNING "GError set over the top of a previous GError or uninitialized memory.\n" \
|
2001-02-13 18:20:13 +00:00
|
|
|
|
"This indicates a bug in someone's code. You must ensure an error is NULL before it's set.\n" \
|
|
|
|
|
"The overwriting error message was: %s"
|
2000-09-01 12:47:42 +00:00
|
|
|
|
|
2000-09-06 23:30:21 +00:00
|
|
|
|
/**
|
|
|
|
|
* g_set_error:
|
2013-12-06 12:23:09 +00:00
|
|
|
|
* @err: (out callee-allocates) (optional): a return location for a #GError
|
2000-09-06 23:30:21 +00:00
|
|
|
|
* @domain: error domain
|
2009-07-05 23:55:00 -04:00
|
|
|
|
* @code: error code
|
2003-07-25 21:32:47 +00:00
|
|
|
|
* @format: printf()-style format
|
2011-07-22 13:25:32 +02:00
|
|
|
|
* @...: args for @format
|
2009-07-05 23:55:00 -04:00
|
|
|
|
*
|
|
|
|
|
* 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.
|
|
|
|
|
*/
|
2000-07-12 21:06:16 +00:00
|
|
|
|
void
|
2000-09-01 12:47:42 +00:00
|
|
|
|
g_set_error (GError **err,
|
|
|
|
|
GQuark domain,
|
|
|
|
|
gint code,
|
|
|
|
|
const gchar *format,
|
2000-07-12 21:06:16 +00:00
|
|
|
|
...)
|
1998-06-10 23:21:14 +00:00
|
|
|
|
{
|
2001-02-13 18:20:13 +00:00
|
|
|
|
GError *new;
|
2009-07-05 23:55:00 -04:00
|
|
|
|
|
2000-07-12 21:06:16 +00:00
|
|
|
|
va_list args;
|
1998-06-10 23:21:14 +00:00
|
|
|
|
|
2000-07-12 21:06:16 +00:00
|
|
|
|
if (err == NULL)
|
|
|
|
|
return;
|
2009-07-05 23:55:00 -04:00
|
|
|
|
|
2000-07-12 21:06:16 +00:00
|
|
|
|
va_start (args, format);
|
2001-02-13 18:20:13 +00:00
|
|
|
|
new = g_error_new_valist (domain, code, format, args);
|
2000-07-12 21:06:16 +00:00
|
|
|
|
va_end (args);
|
2001-02-13 18:20:13 +00:00
|
|
|
|
|
|
|
|
|
if (*err == NULL)
|
|
|
|
|
*err = new;
|
|
|
|
|
else
|
2013-11-07 22:38:52 +01:00
|
|
|
|
{
|
|
|
|
|
g_warning (ERROR_OVERWRITTEN_WARNING, new->message);
|
|
|
|
|
g_error_free (new);
|
|
|
|
|
}
|
2000-07-12 21:06:16 +00:00
|
|
|
|
}
|
1998-06-10 23:21:14 +00:00
|
|
|
|
|
2008-06-16 16:41:01 +00:00
|
|
|
|
/**
|
|
|
|
|
* g_set_error_literal:
|
2013-12-06 12:23:09 +00:00
|
|
|
|
* @err: (out callee-allocates) (optional): a return location for a #GError
|
2008-06-16 16:41:01 +00:00
|
|
|
|
* @domain: error domain
|
2009-07-05 23:55:00 -04:00
|
|
|
|
* @code: error code
|
2008-06-16 16:41:01 +00:00
|
|
|
|
* @message: error message
|
|
|
|
|
*
|
2009-07-05 23:55:00 -04:00
|
|
|
|
* 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.
|
2008-06-16 16:41:01 +00:00
|
|
|
|
* 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.
|
2008-08-01 18:30:37 +00:00
|
|
|
|
*
|
|
|
|
|
* Since: 2.18
|
2009-07-05 23:55:00 -04:00
|
|
|
|
*/
|
2008-06-16 16:41:01 +00:00
|
|
|
|
void
|
|
|
|
|
g_set_error_literal (GError **err,
|
|
|
|
|
GQuark domain,
|
|
|
|
|
gint code,
|
|
|
|
|
const gchar *message)
|
|
|
|
|
{
|
|
|
|
|
if (err == NULL)
|
|
|
|
|
return;
|
|
|
|
|
|
|
|
|
|
if (*err == NULL)
|
2013-10-31 14:39:05 +01:00
|
|
|
|
*err = g_error_new_literal (domain, code, message);
|
2008-06-16 16:41:01 +00:00
|
|
|
|
else
|
2013-10-31 14:39:05 +01:00
|
|
|
|
g_warning (ERROR_OVERWRITTEN_WARNING, message);
|
2008-06-16 16:41:01 +00:00
|
|
|
|
}
|
|
|
|
|
|
2000-09-06 23:30:21 +00:00
|
|
|
|
/**
|
|
|
|
|
* g_propagate_error:
|
2015-10-08 11:16:02 +01:00
|
|
|
|
* @dest: (out callee-allocates) (optional) (nullable): error return location
|
|
|
|
|
* @src: (transfer full): error to move into the return location
|
2007-12-06 09:20:13 +00:00
|
|
|
|
*
|
|
|
|
|
* If @dest is %NULL, free @src; otherwise, moves @src into *@dest.
|
|
|
|
|
* The error variable @dest points to must be %NULL.
|
2014-10-10 14:17:56 -04:00
|
|
|
|
*
|
2015-10-08 11:16:02 +01:00
|
|
|
|
* @src must be non-%NULL.
|
|
|
|
|
*
|
2014-10-10 14:17:56 -04:00
|
|
|
|
* 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.
|
2009-07-05 23:55:00 -04:00
|
|
|
|
*/
|
2007-12-06 09:20:13 +00:00
|
|
|
|
void
|
2009-07-05 23:55:00 -04:00
|
|
|
|
g_propagate_error (GError **dest,
|
|
|
|
|
GError *src)
|
2000-09-01 12:47:42 +00:00
|
|
|
|
{
|
|
|
|
|
g_return_if_fail (src != NULL);
|
2009-07-05 23:55:00 -04:00
|
|
|
|
|
2000-11-05 17:02:37 +00:00
|
|
|
|
if (dest == NULL)
|
|
|
|
|
{
|
2021-01-06 17:23:31 +00:00
|
|
|
|
g_error_free (src);
|
2000-11-05 17:02:37 +00:00
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
if (*dest != NULL)
|
2013-11-07 22:38:52 +01:00
|
|
|
|
{
|
|
|
|
|
g_warning (ERROR_OVERWRITTEN_WARNING, src->message);
|
|
|
|
|
g_error_free (src);
|
|
|
|
|
}
|
2001-02-13 18:20:13 +00:00
|
|
|
|
else
|
|
|
|
|
*dest = src;
|
2000-11-05 17:02:37 +00:00
|
|
|
|
}
|
2000-09-01 12:47:42 +00:00
|
|
|
|
}
|
|
|
|
|
|
2000-09-06 23:30:21 +00:00
|
|
|
|
/**
|
|
|
|
|
* g_clear_error:
|
|
|
|
|
* @err: a #GError return location
|
2009-07-05 23:55:00 -04:00
|
|
|
|
*
|
2015-09-29 17:50:39 +02:00
|
|
|
|
* If @err or *@err is %NULL, does nothing. Otherwise,
|
2001-12-16 19:31:36 +00:00
|
|
|
|
* calls g_error_free() on *@err and sets *@err to %NULL.
|
2009-07-05 23:55:00 -04:00
|
|
|
|
*/
|
2000-07-12 21:06:16 +00:00
|
|
|
|
void
|
|
|
|
|
g_clear_error (GError **err)
|
|
|
|
|
{
|
|
|
|
|
if (err && *err)
|
1998-06-10 23:21:14 +00:00
|
|
|
|
{
|
2000-07-12 21:06:16 +00:00
|
|
|
|
g_error_free (*err);
|
|
|
|
|
*err = NULL;
|
1998-06-10 23:21:14 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
2005-03-14 04:26:57 +00:00
|
|
|
|
|
2013-01-13 14:05:14 -02:00
|
|
|
|
G_GNUC_PRINTF(2, 0)
|
2007-11-16 03:05:45 +00:00
|
|
|
|
static void
|
|
|
|
|
g_error_add_prefix (gchar **string,
|
|
|
|
|
const gchar *format,
|
|
|
|
|
va_list ap)
|
|
|
|
|
{
|
|
|
|
|
gchar *oldstring;
|
|
|
|
|
gchar *prefix;
|
|
|
|
|
|
|
|
|
|
prefix = g_strdup_vprintf (format, ap);
|
|
|
|
|
oldstring = *string;
|
2007-11-20 10:46:15 +00:00
|
|
|
|
*string = g_strconcat (prefix, oldstring, NULL);
|
2007-11-16 03:05:45 +00:00
|
|
|
|
g_free (oldstring);
|
|
|
|
|
g_free (prefix);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* g_prefix_error:
|
2017-04-28 12:29:44 +01:00
|
|
|
|
* @err: (inout) (optional) (nullable): a return location for a #GError
|
2007-11-16 03:05:45 +00:00
|
|
|
|
* @format: printf()-style format string
|
2007-11-29 02:36:12 +00:00
|
|
|
|
* @...: arguments to @format
|
2007-11-16 03:05:45 +00:00
|
|
|
|
*
|
2014-01-31 20:34:33 -05:00
|
|
|
|
* Formats a string according to @format and prefix it to an existing
|
|
|
|
|
* error message. If @err is %NULL (ie: no error variable) then do
|
2007-11-16 03:05:45 +00:00
|
|
|
|
* nothing.
|
|
|
|
|
*
|
2014-01-31 20:34:33 -05:00
|
|
|
|
* If *@err is %NULL (ie: an error variable is present but there is no
|
2018-01-05 19:36:07 +00:00
|
|
|
|
* error condition) then also do nothing.
|
2007-11-29 02:36:12 +00:00
|
|
|
|
*
|
|
|
|
|
* Since: 2.16
|
2009-07-05 23:55:00 -04:00
|
|
|
|
*/
|
2007-11-16 03:05:45 +00:00
|
|
|
|
void
|
|
|
|
|
g_prefix_error (GError **err,
|
|
|
|
|
const gchar *format,
|
|
|
|
|
...)
|
|
|
|
|
{
|
|
|
|
|
if (err && *err)
|
|
|
|
|
{
|
|
|
|
|
va_list ap;
|
|
|
|
|
|
|
|
|
|
va_start (ap, format);
|
|
|
|
|
g_error_add_prefix (&(*err)->message, format, ap);
|
|
|
|
|
va_end (ap);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2021-05-27 13:29:54 +02:00
|
|
|
|
/**
|
|
|
|
|
* g_prefix_error_literal:
|
2023-12-13 13:26:40 +00:00
|
|
|
|
* @err: (inout) (nullable) (optional): a return location for a #GError, or %NULL
|
2021-05-27 13:29:54 +02:00
|
|
|
|
* @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
|
|
|
|
|
*/
|
|
|
|
|
void
|
|
|
|
|
g_prefix_error_literal (GError **err,
|
|
|
|
|
const gchar *prefix)
|
|
|
|
|
{
|
|
|
|
|
if (err && *err)
|
|
|
|
|
{
|
|
|
|
|
gchar *oldstring;
|
|
|
|
|
|
|
|
|
|
oldstring = (*err)->message;
|
|
|
|
|
(*err)->message = g_strconcat (prefix, oldstring, NULL);
|
|
|
|
|
g_free (oldstring);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2007-11-16 03:05:45 +00:00
|
|
|
|
/**
|
|
|
|
|
* g_propagate_prefixed_error:
|
|
|
|
|
* @dest: error return location
|
|
|
|
|
* @src: error to move into the return location
|
|
|
|
|
* @format: printf()-style format string
|
2007-11-29 02:36:12 +00:00
|
|
|
|
* @...: arguments to @format
|
2009-07-05 23:55:00 -04:00
|
|
|
|
*
|
2014-01-31 20:34:33 -05:00
|
|
|
|
* If @dest is %NULL, free @src; otherwise, moves @src into *@dest.
|
|
|
|
|
* *@dest must be %NULL. After the move, add a prefix as with
|
2007-11-16 03:05:45 +00:00
|
|
|
|
* g_prefix_error().
|
2007-11-29 02:36:12 +00:00
|
|
|
|
*
|
|
|
|
|
* Since: 2.16
|
2007-11-16 03:05:45 +00:00
|
|
|
|
**/
|
|
|
|
|
void
|
|
|
|
|
g_propagate_prefixed_error (GError **dest,
|
|
|
|
|
GError *src,
|
|
|
|
|
const gchar *format,
|
|
|
|
|
...)
|
|
|
|
|
{
|
|
|
|
|
g_propagate_error (dest, src);
|
|
|
|
|
|
2021-01-06 17:24:00 +00:00
|
|
|
|
if (dest)
|
2007-11-16 03:05:45 +00:00
|
|
|
|
{
|
|
|
|
|
va_list ap;
|
|
|
|
|
|
2021-01-06 17:24:00 +00:00
|
|
|
|
g_assert (*dest != NULL);
|
2007-11-16 03:05:45 +00:00
|
|
|
|
va_start (ap, format);
|
|
|
|
|
g_error_add_prefix (&(*dest)->message, format, ap);
|
|
|
|
|
va_end (ap);
|
|
|
|
|
}
|
|
|
|
|
}
|