From: Carlos Garcia Campos Date: Sat, 24 Jan 2009 18:10:21 +0000 (+0000) Subject: Add EV_DEFINE_BOXED_TYPE macro to define boxed types. See bug #568228. X-Git-Tag: EVINCE_2_25_90~29 X-Git-Url: https://www.fi.muni.cz/~kas/git//home/kas/public_html/git/?a=commitdiff_plain;h=95395e6b0e5e174a43931605043dba668232d331;p=evince.git Add EV_DEFINE_BOXED_TYPE macro to define boxed types. See bug #568228. 2009-01-24 Carlos Garcia Campos * libdocument/ev-document.[ch]: Add EV_DEFINE_BOXED_TYPE macro to define boxed types. See bug #568228. svn path=/trunk/; revision=3378 --- diff --git a/ChangeLog b/ChangeLog index 3de2a6a4..6ea1dadc 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,10 @@ +2009-01-24 Carlos Garcia Campos + + * libdocument/ev-document.[ch]: + + Add EV_DEFINE_BOXED_TYPE macro to define boxed types. See bug + #568228. + 2009-01-24 Nickolay V. Shmyrev * cut-n-paste/toolbar-editor/egg-editable-toolbar.c @@ -19,7 +26,7 @@ respecting umask and any setgid bit on the directory. Uses the new G_FILE_COPY_TARGET_DEFAULT_PERMS flag in glib 2.19.0, if available. Bug #568593. - + 2009-01-21 Christian Persch * configure.ac: diff --git a/libdocument/ev-document.c b/libdocument/ev-document.c index 1ca362e0..163f2e26 100644 --- a/libdocument/ev-document.c +++ b/libdocument/ev-document.c @@ -244,16 +244,7 @@ ev_document_render (EvDocument *document, } /* EvDocumentInfo */ -GType -ev_document_info_get_type (void) -{ - static GType type = 0; - if (type == 0) - type = g_boxed_type_register_static ("EvDocumentInfo", - (GBoxedCopyFunc)ev_document_info_copy, - (GBoxedFreeFunc)ev_document_info_free); - return type; -} +EV_DEFINE_BOXED_TYPE (EvDocumentInfo, ev_document_info, ev_document_info_copy, ev_document_info_free) EvDocumentInfo * ev_document_info_copy (EvDocumentInfo *info) diff --git a/libdocument/ev-document.h b/libdocument/ev-document.h index 367d6e6a..e07e3a22 100644 --- a/libdocument/ev-document.h +++ b/libdocument/ev-document.h @@ -216,6 +216,26 @@ register_evince_backend (GTypeModule *module) \ #define EV_BACKEND_REGISTER(BackendName, backend_name) \ EV_BACKEND_REGISTER_WITH_CODE(BackendName, backend_name, ;) +/* + * A convenience macro for boxed type implementations, which defines a + * type_name_get_type() function registering the boxed type. + */ +#define EV_DEFINE_BOXED_TYPE(TypeName, type_name, copy_func, free_func) \ +GType \ +type_name##_get_type (void) \ +{ \ + static volatile gsize g_define_type_id__volatile = 0; \ + if (g_once_init_enter (&g_define_type_id__volatile)) { \ + GType g_define_type_id = \ + g_boxed_type_register_static (g_intern_static_string (#TypeName), \ + (GBoxedCopyFunc) copy_func, \ + (GBoxedFreeFunc) free_func); \ + g_once_init_leave (&g_define_type_id__volatile, g_define_type_id); \ + } \ + return g_define_type_id__volatile; \ +} + + G_END_DECLS #endif /* EV_DOCUMENT_H */