summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorNeil Roberts <neil@linux.intel.com>2012-11-22 17:07:15 +0000
committerNeil Roberts <neil@linux.intel.com>2012-11-27 12:05:21 +0000
commit91266162bef9f89fb42c01be0f929d5079758096 (patch)
treedf0fac285739585abcaa8ba98ad24cb7ba1af176
parent5fb4a6178c3e64371c01510690d9de1e8a740bde (diff)
downloadcogl-91266162bef9f89fb42c01be0f929d5079758096.tar.gz
error: Don't allocate a new CoglError when propagating
The _cogl_propagate_error() function takes ownership of the incoming error pointer so there's no need to allocate a new error when passing it on. The errors can potentially be passed up from a number of layers so it seems worthwhile to avoid the allocation. The _cogl_propagate_gerror() function was previously using _cogl_propagate_error(). Presumably this would not have worked because that function would try to free the error from glib using cogl_error_free but that would use the wrong free function and thus the wrong slice allocator. The GError propagating function is only used when gdk-pixbuf is enabled which now requires glib support anyway so we can just avoid defining the function when compiling without glib. Reviewed-by: Robert Bragg <robert@linux.intel.com>
-rw-r--r--cogl/cogl-error-private.h2
-rw-r--r--cogl/cogl-error.c17
2 files changed, 16 insertions, 3 deletions
diff --git a/cogl/cogl-error-private.h b/cogl/cogl-error-private.h
index 31b2eabd..a886084d 100644
--- a/cogl/cogl-error-private.h
+++ b/cogl/cogl-error-private.h
@@ -43,9 +43,11 @@ void
_cogl_propagate_error (CoglError **dest,
CoglError *src);
+#ifdef COGL_HAS_GLIB_SUPPORT
void
_cogl_propagate_gerror (CoglError **dest,
GError *src);
+#endif /* COGL_HAS_GLIB_SUPPORT */
#define _cogl_clear_error(X) g_clear_error ((GError **)X)
diff --git a/cogl/cogl-error.c b/cogl/cogl-error.c
index 4ef36816..753e4c82 100644
--- a/cogl/cogl-error.c
+++ b/cogl/cogl-error.c
@@ -104,13 +104,24 @@ _cogl_propagate_error (CoglError **dest,
{
_COGL_RETURN_IF_FAIL (src != NULL);
- _cogl_set_error_literal (dest, src->domain, src->code, src->message);
- cogl_error_free (src);
+ if (dest == NULL)
+ cogl_error_free (src);
+ else if (*dest)
+ g_warning (ERROR_OVERWRITTEN_WARNING, src->message);
+ else
+ *dest = src;
}
+/* This function is only used from the gdk-pixbuf image backend so it
+ * should only be called if we are using the system GLib. It would be
+ * difficult to get this to work without the system glib because we
+ * would need to somehow call the same g_error_free function that
+ * gdk-pixbuf is using */
+#ifdef COGL_HAS_GLIB_SUPPORT
void
_cogl_propagate_gerror (CoglError **dest,
GError *src)
{
- _cogl_propagate_error (dest, (CoglError *)src);
+ _cogl_propagate_error (dest, (CoglError *) src);
}
+#endif /* COGL_HAS_GLIB_SUPPORT */