[devhelp/wip/tintou/language-gobject] Transform DhLanguage into a GObject



commit 40551913c95697d00a001e2c4d81f73682a5ea75
Author: Corentin Noël <corentin elementary io>
Date:   Tue Nov 22 10:21:21 2016 +0100

    Transform DhLanguage into a GObject
    
    https://bugzilla.gnome.org/show_bug.cgi?id=775261

 src/dh-book-manager.c |    4 +-
 src/dh-language.c     |   75 +++++++++++++++++++++++++++++++++++++-----------
 src/dh-language.h     |   29 ++++++++++++++++--
 3 files changed, 85 insertions(+), 23 deletions(-)
---
diff --git a/src/dh-book-manager.c b/src/dh-book-manager.c
index b10cc6b..796574d 100644
--- a/src/dh-book-manager.c
+++ b/src/dh-book-manager.c
@@ -118,7 +118,7 @@ dh_book_manager_finalize (GObject *object)
 
         priv = dh_book_manager_get_instance_private (DH_BOOK_MANAGER (object));
 
-        g_list_free_full (priv->languages, (GDestroyNotify)dh_language_free);
+        g_list_free_full (priv->languages, g_object_unref);
 
         g_slist_free_full (priv->books_disabled, g_free);
 
@@ -876,7 +876,7 @@ book_manager_dec_language (DhBookManager *book_manager,
 
         /* If language count reaches zero, remove from list */
         if (dh_language_dec_n_books_enabled (li->data)) {
-                dh_language_free (li->data);
+                g_object_unref (li->data);
                 priv->languages = g_list_delete_link (priv->languages, li);
 
                 /* Emit signal to notify others */
diff --git a/src/dh-language.c b/src/dh-language.c
index b2e0f8d..841098f 100644
--- a/src/dh-language.c
+++ b/src/dh-language.c
@@ -20,24 +20,51 @@
 #include "dh-language.h"
 #include <string.h>
 
-struct _DhLanguage {
+typedef struct {
         /* Name of the language */
         gchar *name;
+
         /* Number of books enabled in the language */
-        gint   n_books_enabled;
-};
+        gint   n_books_enabled : 0;
+} DhLanguagePrivate;
+
+G_DEFINE_TYPE_WITH_PRIVATE (DhLanguage, dh_language, G_TYPE_OBJECT)
 
 /**
  * dh_language_free:
  * @language: a #DhLanguage object
  *
  * Free memory associated with the language.
+ *
+ * Deprecated: 3.24: Use g_object_unref() instead.
  */
 void
 dh_language_free (DhLanguage *language)
 {
-        g_free (language->name);
-        g_slice_free (DhLanguage, language);
+        g_object_unref (language);
+}
+
+static void
+dh_language_finalize (GObject *gobject)
+{
+        DhLanguagePrivate *priv = dh_language_get_instance_private (DH_LANGUAGE(gobject));
+        g_free (priv->name);
+        G_OBJECT_CLASS (dh_language_parent_class)->finalize (gobject);
+}
+
+static void
+dh_language_class_init (DhLanguageClass *klass)
+{
+        GObjectClass *object_class = G_OBJECT_CLASS (klass);
+        g_type_class_add_private (object_class, sizeof (DhLanguagePrivate));
+        object_class->finalize = dh_language_finalize;
+}
+
+static void
+dh_language_init (DhLanguage *self)
+{
+        DhLanguagePrivate *priv = dh_language_get_instance_private (book_manager);
+        priv->name = NULL;
 }
 
 /**
@@ -52,11 +79,13 @@ DhLanguage *
 dh_language_new (const gchar *name)
 {
         DhLanguage *language;
+        DhLanguagePrivate *priv;
 
         g_return_val_if_fail (name != NULL, NULL);
 
-        language = g_slice_new0 (DhLanguage);
-        language->name = g_strdup (name);
+        language = g_object_new (DH_TYPE_LANGUAGE, NULL);
+        priv = dh_language_get_instance_private (language);
+        priv->name = g_strdup (name);
 
         return language;
 }
@@ -72,13 +101,13 @@ dh_language_new (const gchar *name)
  * of @language_a is <, == or > than the name of @language_b
  */
 gint
-dh_language_compare (const DhLanguage *language_a,
-                     const DhLanguage *language_b)
+dh_language_compare (DhLanguage *language_a,
+                     DhLanguage *language_b)
 {
         g_return_val_if_fail (language_a != NULL, -1);
         g_return_val_if_fail (language_b != NULL, -1);
 
-        return strcmp (language_a->name, language_b->name);
+        return strcmp (dh_language_get_name (language_a), dh_language_get_name (language_b));
 }
 
 /**
@@ -92,13 +121,13 @@ dh_language_compare (const DhLanguage *language_a,
  * of @language_a is <, == or > than @language_name_b
  */
 gint
-dh_language_compare_by_name (const DhLanguage *language_a,
+dh_language_compare_by_name (DhLanguage *language_a,
                              const gchar      *language_name_b)
 {
         g_return_val_if_fail (language_a != NULL, -1);
         g_return_val_if_fail (language_name_b != NULL, -1);
 
-        return strcmp (language_a->name, language_name_b);
+        return strcmp (dh_language_get_name (language_a), language_name_b);
 }
 
 /**
@@ -112,9 +141,12 @@ dh_language_compare_by_name (const DhLanguage *language_a,
 const gchar *
 dh_language_get_name (DhLanguage *language)
 {
+        DhLanguagePrivate *priv;
+
         g_return_val_if_fail (language != NULL, NULL);
 
-        return language->name;
+        priv = dh_language_get_instance_private (language);
+        return priv->name;
 }
 
 /**
@@ -128,9 +160,12 @@ dh_language_get_name (DhLanguage *language)
 gint
 dh_language_get_n_books_enabled (DhLanguage *language)
 {
+        DhLanguagePrivate *priv;
+
         g_return_val_if_fail (language != NULL, -1);
 
-        return language->n_books_enabled;
+        priv = dh_language_get_instance_private (language);
+        return priv->n_books_enabled;
 }
 
 /**
@@ -142,9 +177,12 @@ dh_language_get_n_books_enabled (DhLanguage *language)
 void
 dh_language_inc_n_books_enabled (DhLanguage *language)
 {
+        DhLanguagePrivate *priv;
+
         g_return_if_fail (language != NULL);
 
-        language->n_books_enabled++;
+        priv = dh_language_get_instance_private (language);
+        priv->n_books_enabled++;
 }
 
 /**
@@ -158,8 +196,11 @@ dh_language_inc_n_books_enabled (DhLanguage *language)
 gboolean
 dh_language_dec_n_books_enabled (DhLanguage *language)
 {
+        DhLanguagePrivate *priv;
+
         g_return_val_if_fail (language != NULL, FALSE);
 
-        language->n_books_enabled--;
-        return (language->n_books_enabled <= 0) ? TRUE : FALSE;
+        priv = dh_language_get_instance_private (language);
+        priv->n_books_enabled--;
+        return (priv->n_books_enabled <= 0) ? TRUE : FALSE;
 }
diff --git a/src/dh-language.h b/src/dh-language.h
index 2c65400..dcb8b72 100644
--- a/src/dh-language.h
+++ b/src/dh-language.h
@@ -21,17 +21,38 @@
 
 #include <glib-object.h>
 
+G_BEGIN_DECLS
+
+#define DH_TYPE_LANGUAGE                (dh_language_get_type ())
+#define DH_LANGUAGE(obj)                (G_TYPE_CHECK_INSTANCE_CAST ((obj), DH_TYPE_LANGUAGE, DhLanguage))
+#define DH_LANGUAGE_CLASS(klass)        (G_TYPE_CHECK_CLASS_CAST ((klass), DH_TYPE_LANGUAGE, 
DhLanguageClass))
+#define DH_IS_LANGUAGE(obj)             (G_TYPE_CHECK_INSTANCE_TYPE ((obj), DH_TYPE_LANGUAGE))
+#define DH_IS_LANGUAGE_CLASS(klass)     (G_TYPE_CHECK_CLASS_TYPE ((klass), DH_TYPE_LANGUAGE))
+#define DH_LANGUAGE_GET_CLASS(obj)      (G_TYPE_INSTANCE_GET_CLASS ((obj), DH_TYPE_LANGUAGE, 
DhLanguageClass))
+
 typedef struct _DhLanguage DhLanguage;
+typedef struct _DhLanguageClass DhLanguageClass;
+
+struct _DhLanguage {
+        GObject parent_instance;
+};
 
+struct _DhLanguageClass {
+        GObjectClass parent_class;
+};
+
+GType        dh_language_get_type            (void) G_GNUC_CONST;
 DhLanguage  *dh_language_new                 (const gchar      *name);
 void         dh_language_free                (DhLanguage       *language);
-const gchar *dh_language_get_name            (DhLanguage       *language);
-gint         dh_language_compare             (const DhLanguage *language_a,
-                                              const DhLanguage *language_b);
-gint         dh_language_compare_by_name     (const DhLanguage *language_a,
+const gchar *dh_language_get_name            (DhLanguage *language);
+gint         dh_language_compare             (DhLanguage *language_a,
+                                              DhLanguage *language_b);
+gint         dh_language_compare_by_name     (DhLanguage *language_a,
                                               const gchar      *language_name_b);
 gint         dh_language_get_n_books_enabled (DhLanguage       *language);
 void         dh_language_inc_n_books_enabled (DhLanguage       *language);
 gboolean     dh_language_dec_n_books_enabled (DhLanguage       *language);
 
+G_END_DECLS
+
 #endif /* __DH_LANGUAGE_H__ */


[Date Prev][Date Next]   [Thread Prev][Thread Next]   [Thread Index] [Date Index] [Author Index]