summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorEmmanuele Bassi <ebassi@gnome.org>2013-11-18 11:04:37 +0000
committerMatthias Clasen <mclasen@redhat.com>2013-11-22 22:19:58 -0500
commite2aabc016a818de99fae3661c65ebd224c5cce11 (patch)
tree264c04e3693f1ebb8997f51ea173113ec04c5c4f
parentc988a258cc73d225ccd98a478da99963ec604cfa (diff)
downloadgtk+-e2aabc016a818de99fae3661c65ebd224c5cce11.tar.gz
pixbuf-engine: Improve ThemePixbuf clean up functions
Make theme_pixbuf_destroy() NULL-safe like g_free(), and add a clear function in the spirit of the g_clear_* family of functions. https://bugzilla.gnome.org/show_bug.cgi?id=712536
-rw-r--r--modules/engines/pixbuf/pixbuf-render.c21
-rw-r--r--modules/engines/pixbuf/pixbuf.h1
2 files changed, 20 insertions, 2 deletions
diff --git a/modules/engines/pixbuf/pixbuf-render.c b/modules/engines/pixbuf/pixbuf-render.c
index c05832da34..a272ff4a5e 100644
--- a/modules/engines/pixbuf/pixbuf-render.c
+++ b/modules/engines/pixbuf/pixbuf-render.c
@@ -524,8 +524,25 @@ theme_pixbuf_new (void)
void
theme_pixbuf_destroy (ThemePixbuf *theme_pb)
{
- theme_pixbuf_set_filename (theme_pb, NULL);
- g_free (theme_pb);
+ if (G_LIKELY (theme_pb))
+ {
+ theme_pixbuf_set_filename (theme_pb, NULL);
+ g_free (theme_pb);
+ }
+}
+
+void
+theme_clear_pixbuf (ThemePixbuf **theme_pb)
+{
+#if GLIB_CHECK_VERSION (2, 34, 0)
+ g_clear_pointer (theme_pb, theme_pixbuf_destroy);
+#else
+ if (*theme_pb)
+ {
+ theme_pixbuf_destroy (*theme_pb);
+ *theme_pb = NULL;
+ }
+#endif
}
void
diff --git a/modules/engines/pixbuf/pixbuf.h b/modules/engines/pixbuf/pixbuf.h
index d0c74e9159..c656c6fd81 100644
--- a/modules/engines/pixbuf/pixbuf.h
+++ b/modules/engines/pixbuf/pixbuf.h
@@ -195,6 +195,7 @@ struct _ThemeImage
G_GNUC_INTERNAL ThemePixbuf *theme_pixbuf_new (void);
G_GNUC_INTERNAL void theme_pixbuf_destroy (ThemePixbuf *theme_pb);
+G_GNUC_INTERNAL void theme_clear_pixbuf (ThemePixbuf **theme_pb);
G_GNUC_INTERNAL void theme_pixbuf_set_filename (ThemePixbuf *theme_pb,
const char *filename);
G_GNUC_INTERNAL GdkPixbuf * theme_pixbuf_get_pixbuf (ThemePixbuf *theme_pb);