[bijiben] notebook: port to G_DECLARE_FINAL_TYPE
- From: Mohammed Sadiq <pksadiq src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [bijiben] notebook: port to G_DECLARE_FINAL_TYPE
- Date: Wed, 8 Nov 2017 04:14:36 +0000 (UTC)
commit cd4e887c064aecba3e73dcd5cdbe3ec2a557f79e
Author: Mohammed Sadiq <sadiq sadiqpk org>
Date: Tue Nov 7 12:55:37 2017 +0530
notebook: port to G_DECLARE_FINAL_TYPE
* Use G_DECLARE_FINAL_TYPE to avoid boilerplate code
* Don't use private members.
This class isn't derivable. So there isn't any difference.
* Don't intialize members explicitly with NULL/0.
Because all members are initialized with NULL/0 by default.
* Adapt main-view and controller accordingly
This is a part of effort to clean up codebase and make the code more
maintainable.
https://bugzilla.gnome.org/show_bug.cgi?id=789696
src/bjb-controller.c | 4 +-
src/bjb-main-view.c | 4 +-
src/libbiji/biji-notebook.c | 90 ++++++++++++++++++------------------------
src/libbiji/biji-notebook.h | 27 +------------
4 files changed, 45 insertions(+), 80 deletions(-)
---
diff --git a/src/bjb-controller.c b/src/bjb-controller.c
index 0f80526..938381c 100644
--- a/src/bjb-controller.c
+++ b/src/bjb-controller.c
@@ -345,13 +345,13 @@ most_recent_item_first (gconstpointer a, gconstpointer b)
glong result = 0;
/* Always sort notebooks before notes */
- if (BIJI_IS_NOTEBOOK (a))
+ if (BIJI_IS_NOTEBOOK ((gpointer) a))
{
if (BIJI_IS_NOTE_OBJ (b))
result = -1;
}
- else if (BIJI_IS_NOTEBOOK (b))
+ else if (BIJI_IS_NOTEBOOK ((gpointer) b))
{
result = 1;
}
diff --git a/src/bjb-main-view.c b/src/bjb-main-view.c
index 22c1e59..aa07c6f 100644
--- a/src/bjb-main-view.c
+++ b/src/bjb-main-view.c
@@ -493,10 +493,10 @@ render_type (GtkTreeViewColumn *tree_column,
if (item != NULL)
{
- if BIJI_IS_NOTEBOOK (item)
+ if (BIJI_IS_NOTEBOOK (item))
str= _("Notebook");
- else if BIJI_IS_NOTE_OBJ (item)
+ else if (BIJI_IS_NOTE_OBJ (item))
str = _("Note");
}
diff --git a/src/libbiji/biji-notebook.c b/src/libbiji/biji-notebook.c
index f426180..789d6fe 100644
--- a/src/libbiji/biji-notebook.c
+++ b/src/libbiji/biji-notebook.c
@@ -39,8 +39,9 @@
static void biji_notebook_update_collected (GList *result, gpointer user_data);
-struct BijiNotebookPrivate_
+struct _BijiNotebook
{
+ BijiItem parent_instance;
gchar *urn;
gchar *name;
@@ -80,24 +81,24 @@ static guint biji_notebooks_signals [BIJI_NOTEBOOKS_SIGNALS] = { 0 };
static const gchar *
biji_notebook_get_title (BijiItem *coll)
{
- BijiNotebook *notebook;
+ BijiNotebook *self;
g_return_val_if_fail (BIJI_IS_NOTEBOOK (coll), NULL);
- notebook = BIJI_NOTEBOOK (coll);
+ self = BIJI_NOTEBOOK (coll);
- return notebook->priv->name;
+ return self->name;
}
static const gchar *
biji_notebook_get_uuid (BijiItem *coll)
{
- BijiNotebook *notebook;
+ BijiNotebook *self;
g_return_val_if_fail (BIJI_IS_NOTEBOOK (coll), NULL);
- notebook = BIJI_NOTEBOOK (coll);
+ self = BIJI_NOTEBOOK (coll);
- return notebook->priv->urn;
+ return self->urn;
}
@@ -195,7 +196,7 @@ get_collected_pix (BijiNotebook *self,
{
GList *result = NULL, *l;
- for (l = self->priv->collected_items ; l != NULL; l = l->next)
+ for (l = self->collected_items ; l != NULL; l = l->next)
{
if (BIJI_IS_ITEM (l->data))
result = g_list_prepend (
@@ -213,14 +214,14 @@ biji_notebook_get_icon (BijiItem *coll,
BijiNotebook *self = BIJI_NOTEBOOK (coll);
GList *pix;
- if (!self->priv->icon)
+ if (!self->icon)
{
pix = get_collected_pix (self, scale);
- self->priv->icon = biji_create_notebook_icon (BIJI_ICON_WIDTH, scale, pix);
+ self->icon = biji_create_notebook_icon (BIJI_ICON_WIDTH, scale, pix);
g_list_free (pix);
}
- return self->priv->icon;
+ return self->icon;
}
@@ -231,14 +232,14 @@ biji_notebook_get_emblem (BijiItem *coll,
BijiNotebook *self = BIJI_NOTEBOOK (coll);
GList *pix;
- if (!self->priv->emblem)
+ if (!self->emblem)
{
pix = get_collected_pix (self, scale);
- self->priv->emblem = biji_create_notebook_icon (BIJI_EMBLEM_WIDTH, scale, pix);
+ self->emblem = biji_create_notebook_icon (BIJI_EMBLEM_WIDTH, scale, pix);
g_list_free (pix);
}
- return self->priv->emblem;
+ return self->emblem;
}
@@ -251,7 +252,7 @@ biji_notebook_get_mtime (BijiItem *coll)
g_return_val_if_fail (BIJI_IS_NOTEBOOK (coll), 0);
self = BIJI_NOTEBOOK (coll);
- return self->priv->mtime;
+ return self->mtime;
}
@@ -272,7 +273,7 @@ biji_notebook_trash (BijiItem *item)
g_return_val_if_fail (BIJI_IS_NOTEBOOK (item), FALSE);
self = BIJI_NOTEBOOK (item);
- biji_remove_notebook_from_tracker (biji_item_get_manager (item), self->priv->urn);
+ biji_remove_notebook_from_tracker (biji_item_get_manager (item), self->urn);
return TRUE;
}
@@ -331,13 +332,13 @@ biji_notebook_set_property (GObject *object,
switch (property_id)
{
case PROP_URN:
- self->priv->urn = g_strdup (g_value_get_string (value));
+ self->urn = g_strdup (g_value_get_string (value));
break;
case PROP_NAME:
- self->priv->name = g_strdup (g_value_get_string (value));
+ self->name = g_strdup (g_value_get_string (value));
break;
case PROP_MTIME:
- self->priv->mtime = g_value_get_int64 (value);
+ self->mtime = g_value_get_int64 (value);
break;
default:
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, property_id, pspec);
@@ -357,13 +358,13 @@ biji_notebook_get_property (GObject *object,
switch (property_id)
{
case PROP_URN:
- g_value_set_string (value, self->priv->urn);
+ g_value_set_string (value, self->urn);
break;
case PROP_NAME:
- g_value_set_string (value, self->priv->name);
+ g_value_set_string (value, self->name);
break;
case PROP_MTIME:
- g_value_set_int64 (value, self->priv->mtime);
+ g_value_set_int64 (value, self->mtime);
break;
default:
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, property_id, pspec);
@@ -375,23 +376,22 @@ biji_notebook_get_property (GObject *object,
static void
on_collected_item_change (BijiNotebook *self)
{
- BijiNotebookPrivate *priv = self->priv;
BijiManager *manager;
GList *l;
manager = biji_item_get_manager (BIJI_ITEM (self));
/* Diconnected any handler */
- for (l= priv->collected_items; l!= NULL; l=l->next)
+ for (l = self->collected_items; l != NULL; l = l->next)
{
g_signal_handlers_disconnect_by_func (l->data, on_collected_item_change, self);
}
/* Then re-process the whole stuff */
biji_get_items_with_notebook_async (manager,
- self->priv->name,
- biji_notebook_update_collected,
- self);
+ self->name,
+ biji_notebook_update_collected,
+ self);
}
/* For convenience, items are retrieved async.
@@ -401,17 +401,16 @@ biji_notebook_update_collected (GList *result,
gpointer user_data)
{
BijiNotebook *self = user_data;
- BijiNotebookPrivate *priv = self->priv;
GList *l;
- g_clear_pointer (&priv->collected_items, g_list_free);
- g_clear_pointer (&priv->icon, cairo_surface_destroy);
- g_clear_pointer (&priv->emblem, cairo_surface_destroy);
+ g_clear_pointer (&self->collected_items, g_list_free);
+ g_clear_pointer (&self->icon, cairo_surface_destroy);
+ g_clear_pointer (&self->emblem, cairo_surface_destroy);
- priv->collected_items = result;
+ self->collected_items = result;
/* Connect */
- for (l = priv->collected_items; l!= NULL; l=l->next)
+ for (l = self->collected_items; l != NULL; l = l->next)
{
g_signal_connect_swapped (l->data, "color-changed",
G_CALLBACK (on_collected_item_change), self);
@@ -424,9 +423,9 @@ biji_notebook_update_collected (GList *result,
}
void
-biji_notebook_refresh (BijiNotebook *notebook)
+biji_notebook_refresh (BijiNotebook *self)
{
- on_collected_item_change (notebook);
+ on_collected_item_change (self);
}
static void
@@ -439,9 +438,9 @@ biji_notebook_constructed (GObject *obj)
manager = biji_item_get_manager (BIJI_ITEM (obj));
biji_get_items_with_notebook_async (manager,
- self->priv->name,
- biji_notebook_update_collected,
- self);
+ self->name,
+ biji_notebook_update_collected,
+ self);
}
static gboolean
@@ -465,9 +464,6 @@ biji_notebook_class_init (BijiNotebookClass *klass)
g_object_class->set_property = biji_notebook_set_property;
g_object_class->get_property = biji_notebook_get_property;
- g_type_class_add_private ((gpointer)klass, sizeof (BijiNotebookPrivate));
-
-
properties[PROP_URN] =
g_param_spec_string ("urn",
"Collection URN",
@@ -528,8 +524,8 @@ biji_notebook_finalize (GObject *object)
g_return_if_fail (BIJI_IS_NOTEBOOK (object));
self = BIJI_NOTEBOOK (object);
- g_free (self->priv->name);
- g_free (self->priv->urn);
+ g_free (self->name);
+ g_free (self->urn);
G_OBJECT_CLASS (biji_notebook_parent_class)->finalize (object);
}
@@ -538,14 +534,6 @@ biji_notebook_finalize (GObject *object)
static void
biji_notebook_init (BijiNotebook *self)
{
- self->priv = G_TYPE_INSTANCE_GET_PRIVATE (self, BIJI_TYPE_NOTEBOOK, BijiNotebookPrivate);
-
- self->priv->mtime = 0;
-
- self->priv->icon = NULL;
- self->priv->emblem = NULL;
-
- self->priv->collected_items = NULL;
}
diff --git a/src/libbiji/biji-notebook.h b/src/libbiji/biji-notebook.h
index 613b0a6..567f502 100644
--- a/src/libbiji/biji-notebook.h
+++ b/src/libbiji/biji-notebook.h
@@ -25,32 +25,9 @@
G_BEGIN_DECLS
+#define BIJI_TYPE_NOTEBOOK (biji_notebook_get_type ())
-#define BIJI_TYPE_NOTEBOOK (biji_notebook_get_type ())
-#define BIJI_NOTEBOOK(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), BIJI_TYPE_NOTEBOOK, BijiNotebook))
-#define BIJI_NOTEBOOK_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), BIJI_TYPE_NOTEBOOK,
BijiNotebookClass))
-#define BIJI_IS_NOTEBOOK(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), BIJI_TYPE_NOTEBOOK))
-#define BIJI_IS_NOTEBOOK_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), BIJI_TYPE_NOTEBOOK))
-#define BIJI_NOTEBOOK_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), BIJI_TYPE_NOTEBOOK,
BijiNotebookClass))
-
-typedef struct BijiNotebook_ BijiNotebook;
-typedef struct BijiNotebookClass_ BijiNotebookClass;
-typedef struct BijiNotebookPrivate_ BijiNotebookPrivate;
-
-struct BijiNotebook_
-{
- BijiItem parent;
-
- BijiNotebookPrivate *priv;
-};
-
-struct BijiNotebookClass_
-{
- BijiItemClass parent_class;
-};
-
-
-GType biji_notebook_get_type (void);
+G_DECLARE_FINAL_TYPE (BijiNotebook, biji_notebook, BIJI, NOTEBOOK, BijiItem)
/* Exiting coll in tracker : provide urn & iso8601 date
* To create a brand new notebook in tracker rather gobjectize existing one,
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]