[gnome-calendar/wip/gbsneto/final-classes: 2/9] date-selector: turn into a final class
- From: Georges Basile Stavracas Neto <gbsneto src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gnome-calendar/wip/gbsneto/final-classes: 2/9] date-selector: turn into a final class
- Date: Tue, 19 Jan 2016 23:13:13 +0000 (UTC)
commit 5fe6578b1632ae46c5228558d9766c15d7cf92d3
Author: Georges Basile Stavracas Neto <georges stavracas gmail com>
Date: Tue Jan 19 18:54:29 2016 -0200
date-selector: turn into a final class
There is no subclass of GcalDateSelector, and
actually it isn't needed. So, turn the class
into a final class and get rid of the needless
private field.
src/gcal-date-selector.c | 135 +++++++++++++++++++++-------------------------
src/gcal-date-selector.h | 26 +---------
2 files changed, 63 insertions(+), 98 deletions(-)
---
diff --git a/src/gcal-date-selector.c b/src/gcal-date-selector.c
index a2a66bf..3b39616 100644
--- a/src/gcal-date-selector.c
+++ b/src/gcal-date-selector.c
@@ -32,8 +32,10 @@ enum
NUM_ENTRIES
};
-struct _GcalDateSelectorPrivate
+struct _GcalDateSelector
{
+ GtkMenuButton parent;
+
/* widgets */
GtkWidget *date_label;
GtkWidget *calendar;
@@ -64,7 +66,7 @@ enum
static guint signals[NUM_SIGNALS] = { 0, };
static void calendar_day_selected (GtkCalendar *calendar,
- gpointer user_data);
+ GcalDateSelector *selector);
static gboolean date_entry_focus_out (GtkWidget *widget,
GdkEvent *event,
@@ -83,27 +85,25 @@ static void text_inserted (GtkEditable
static void gcal_date_selector_constructed (GObject *object);
-G_DEFINE_TYPE_WITH_PRIVATE (GcalDateSelector, gcal_date_selector, GTK_TYPE_MENU_BUTTON);
+G_DEFINE_TYPE (GcalDateSelector, gcal_date_selector, GTK_TYPE_MENU_BUTTON);
static void
-calendar_day_selected (GtkCalendar *calendar,
- gpointer user_data)
+calendar_day_selected (GtkCalendar *calendar,
+ GcalDateSelector *selector)
{
- GcalDateSelectorPrivate *priv;
guint day, month, year;
- priv = gcal_date_selector_get_instance_private (GCAL_DATE_SELECTOR (user_data));
gtk_calendar_get_date (calendar, &year, &month, &day);
/**
* Block signal handler to avoid an infinite
* recursion, exploding the proccess stack.
*/
- g_signal_handlers_block_by_func (priv->calendar, calendar_day_selected, user_data);
+ g_signal_handlers_block_by_func (selector->calendar, calendar_day_selected, selector);
- gcal_date_selector_set_date (GCAL_DATE_SELECTOR (user_data), day, month + 1, year);
+ gcal_date_selector_set_date (selector, day, month + 1, year);
- g_signal_handlers_unblock_by_func (priv->calendar, calendar_day_selected, user_data);
+ g_signal_handlers_unblock_by_func (selector->calendar, calendar_day_selected, selector);
}
static gboolean
@@ -125,21 +125,18 @@ entry_activated (GtkEntry *entry,
static void
parse_entries (GcalDateSelector *selector)
{
- GcalDateSelectorPrivate *priv;
gint day, month, year;
- priv = gcal_date_selector_get_instance_private (selector);
-
- day = atoi (gtk_entry_get_text (GTK_ENTRY (priv->entries[DAY])));
- month = atoi (gtk_entry_get_text (GTK_ENTRY (priv->entries[MONTH])));
- year = atoi (gtk_entry_get_text (GTK_ENTRY (priv->entries[YEAR])));
+ day = atoi (gtk_entry_get_text (GTK_ENTRY (selector->entries[DAY])));
+ month = atoi (gtk_entry_get_text (GTK_ENTRY (selector->entries[MONTH])));
+ year = atoi (gtk_entry_get_text (GTK_ENTRY (selector->entries[YEAR])));
/* select the date */
- g_signal_handlers_block_by_func (priv->calendar, calendar_day_selected, selector);
+ g_signal_handlers_block_by_func (selector->calendar, calendar_day_selected, selector);
gcal_date_selector_set_date (selector, day, month, year);
- g_signal_handlers_unblock_by_func (priv->calendar, calendar_day_selected, selector);
+ g_signal_handlers_unblock_by_func (selector->calendar, calendar_day_selected, selector);
}
static void
@@ -201,15 +198,15 @@ gcal_date_selector_class_init (GcalDateSelectorClass *klass)
signals[MODIFIED] = g_signal_new ("modified",
GCAL_TYPE_DATE_SELECTOR,
G_SIGNAL_RUN_LAST,
- G_STRUCT_OFFSET (GcalDateSelectorClass, modified),
+ 0,
NULL, NULL, NULL,
G_TYPE_NONE, 0);
gtk_widget_class_set_template_from_resource (GTK_WIDGET_CLASS (klass),
"/org/gnome/calendar/date-selector.ui");
- gtk_widget_class_bind_template_child_private (GTK_WIDGET_CLASS (klass), GcalDateSelector, date_label);
- gtk_widget_class_bind_template_child_private (GTK_WIDGET_CLASS (klass), GcalDateSelector, calendar);
- gtk_widget_class_bind_template_child_private (GTK_WIDGET_CLASS (klass), GcalDateSelector, grid);
+ gtk_widget_class_bind_template_child (GTK_WIDGET_CLASS (klass), GcalDateSelector, date_label);
+ gtk_widget_class_bind_template_child (GTK_WIDGET_CLASS (klass), GcalDateSelector, calendar);
+ gtk_widget_class_bind_template_child (GTK_WIDGET_CLASS (klass), GcalDateSelector, grid);
gtk_widget_class_bind_template_callback (GTK_WIDGET_CLASS (klass), text_inserted);
gtk_widget_class_bind_template_callback (GTK_WIDGET_CLASS (klass), date_entry_focus_out);
@@ -220,36 +217,33 @@ gcal_date_selector_class_init (GcalDateSelectorClass *klass)
static void
gcal_date_selector_init (GcalDateSelector *self)
{
- GcalDateSelectorPrivate *priv;
gint i, d_index, max;
gtk_widget_set_has_window (GTK_WIDGET (self), FALSE);
- priv = gcal_date_selector_get_instance_private (GCAL_DATE_SELECTOR (self));;
-
gtk_widget_init_template (GTK_WIDGET (self));
- priv->day = 1;
- priv->month = 1;
- priv->year = 1970;
+ self->day = 1;
+ self->month = 1;
+ self->year = 1970;
/* This string represents day/month/year order for each of the different
* languages. It could possibly be default value, %m/%d/%y placing the month
* before, or any ordering according to the translator's environment. */
- priv->mask = g_dpgettext2 ("glib20", "GDateTime", "%m/%d/%y");
+ self->mask = g_dpgettext2 ("glib20", "GDateTime", "%m/%d/%y");
/**
* Translators: Select the day, month and year indexes. This will
* be used later on to map the date entries to the
* corresponding indexes. I should have added more validations here.
*/
- max = strlen (priv->mask);
+ max = strlen (self->mask);
if (max != 8)
{
/* I'll assume an error and bail out with the default values */
- priv->day_pos = 0;
- priv->month_pos = 1;
- priv->year_pos = 2;
+ self->day_pos = 0;
+ self->month_pos = 1;
+ self->year_pos = 2;
return;
}
@@ -259,7 +253,7 @@ gcal_date_selector_init (GcalDateSelector *self)
{
gchar c;
- c = *(priv->mask + i);
+ c = *(self->mask + i);
/* No need to check these common separators */
if (c == '%' || c == '-' || c == '/' || c == '.')
@@ -275,23 +269,23 @@ gcal_date_selector_init (GcalDateSelector *self)
case 'j':
case 'u':
case 'w':
- priv->day_pos = d_index++;
+ self->day_pos = d_index++;
break;
/* month */
case 'b':
case 'B':
case 'm':
- priv->month_pos = d_index++;
+ self->month_pos = d_index++;
break;
/* year */
case 'y':
- priv->year_pos = d_index++;
+ self->year_pos = d_index++;
break;
case 'Y':
- priv->year_pos = d_index++;
+ self->year_pos = d_index++;
break;
}
}
@@ -300,45 +294,45 @@ gcal_date_selector_init (GcalDateSelector *self)
static void
gcal_date_selector_constructed (GObject *object)
{
- GcalDateSelectorPrivate *priv;
+ GcalDateSelector *self;
GtkWidget *label, *box;
GList *l, *aux;
- priv = gcal_date_selector_get_instance_private (GCAL_DATE_SELECTOR (object));
+ self = GCAL_DATE_SELECTOR (object);
/* chaining up */
G_OBJECT_CLASS (gcal_date_selector_parent_class)->constructed (object);
/* set labels, on the first row */
- label = gtk_grid_get_child_at (GTK_GRID (priv->grid), priv->day_pos, 0);
+ label = gtk_grid_get_child_at (GTK_GRID (self->grid), self->day_pos, 0);
gtk_label_set_text (GTK_LABEL (label), _("Day"));
- label = gtk_grid_get_child_at (GTK_GRID (priv->grid), priv->month_pos, 0);
+ label = gtk_grid_get_child_at (GTK_GRID (self->grid), self->month_pos, 0);
gtk_label_set_text (GTK_LABEL (label), _("Month"));
- label = gtk_grid_get_child_at (GTK_GRID (priv->grid), priv->year_pos, 0);
+ label = gtk_grid_get_child_at (GTK_GRID (self->grid), self->year_pos, 0);
gtk_label_set_text (GTK_LABEL (label), _("Year"));
/* retrieve components from UI definition: entries */
- box = gtk_grid_get_child_at (GTK_GRID (priv->grid), 0, 1);
+ box = gtk_grid_get_child_at (GTK_GRID (self->grid), 0, 1);
aux = gtk_container_get_children (GTK_CONTAINER (box));
for (l = aux; l != NULL; l = g_list_next (l))
{
gint position;
gtk_container_child_get (GTK_CONTAINER (box), l->data, "position", &position, NULL);
- if (position == priv->day_pos)
- priv->entries[DAY] = l->data;
- if (position == priv->month_pos)
- priv->entries[MONTH] = l->data;
- if (position == priv->year_pos)
- priv->entries[YEAR] = l->data;
-
- if (position == priv->day_pos || position == priv->month_pos)
+ if (position == self->day_pos)
+ self->entries[DAY] = l->data;
+ if (position == self->month_pos)
+ self->entries[MONTH] = l->data;
+ if (position == self->year_pos)
+ self->entries[YEAR] = l->data;
+
+ if (position == self->day_pos || position == self->month_pos)
gtk_entry_set_max_length (GTK_ENTRY (l->data), 2);
}
g_list_free (aux);
gtk_widget_set_direction (box, GTK_TEXT_DIR_LTR);
- gtk_widget_set_direction (priv->grid, GTK_TEXT_DIR_LTR);
+ gtk_widget_set_direction (self->grid, GTK_TEXT_DIR_LTR);
}
/* Public API */
@@ -363,12 +357,10 @@ gcal_date_selector_set_date (GcalDateSelector *selector,
gint month,
gint year)
{
- GcalDateSelectorPrivate *priv;
GDateTime *dt;
gchar *label;
g_return_if_fail (GCAL_IS_DATE_SELECTOR (selector));
- priv = gcal_date_selector_get_instance_private (selector);
day = CLAMP (day, 1, 31);
month = CLAMP (month, 1, 12);
/* since we're dealing only with the date, the tz shouldn't be a problem */
@@ -382,40 +374,40 @@ gcal_date_selector_set_date (GcalDateSelector *selector,
if (dt == NULL)
return;
- priv->day = day;
- priv->month = month;
- priv->year = year;
+ selector->day = day;
+ selector->month = month;
+ selector->year = year;
month = CLAMP (month - 1, 0, 11);
/* set calendar's date */
- g_signal_handlers_block_by_func (priv->calendar, calendar_day_selected, selector);
- g_object_set (priv->calendar, "day", day, "month", month, "year", year, NULL);
- g_signal_handlers_unblock_by_func (priv->calendar, calendar_day_selected, selector);
+ g_signal_handlers_block_by_func (selector->calendar, calendar_day_selected, selector);
+ g_object_set (selector->calendar, "day", day, "month", month, "year", year, NULL);
+ g_signal_handlers_unblock_by_func (selector->calendar, calendar_day_selected, selector);
/* rebuild the date label */
- label = g_date_time_format (dt, priv->mask);
+ label = g_date_time_format (dt, selector->mask);
- gtk_label_set_label (GTK_LABEL (priv->date_label), label);
+ gtk_label_set_label (GTK_LABEL (selector->date_label), label);
g_free (label);
/* set date entries' text */
/* day entry */
label = g_strdup_printf ("%.2d", day);
- gtk_entry_set_text (GTK_ENTRY (priv->entries[DAY]), label);
+ gtk_entry_set_text (GTK_ENTRY (selector->entries[DAY]), label);
g_free (label);
/* month entry */
- label = g_strdup_printf ("%.2d", priv->month);
+ label = g_strdup_printf ("%.2d", selector->month);
- gtk_entry_set_text (GTK_ENTRY (priv->entries[MONTH]), label);
+ gtk_entry_set_text (GTK_ENTRY (selector->entries[MONTH]), label);
g_free (label);
/* year entry */
label = g_strdup_printf ("%.4d", year);
- gtk_entry_set_text (GTK_ENTRY (priv->entries[YEAR]), label);
+ gtk_entry_set_text (GTK_ENTRY (selector->entries[YEAR]), label);
/* emit the MODIFIED signal */
g_signal_emit (selector, signals[MODIFIED], 0);
@@ -439,15 +431,12 @@ gcal_date_selector_get_date (GcalDateSelector *selector,
gint *month,
gint *year)
{
- GcalDateSelectorPrivate *priv;
-
g_return_if_fail (GCAL_IS_DATE_SELECTOR (selector));
- priv = gcal_date_selector_get_instance_private (selector);
if (day != NULL)
- *day = priv->day;
+ *day = selector->day;
if (month != NULL)
- *month = priv->month;
+ *month = selector->month;
if (year != NULL)
- *year = priv->year;
+ *year = selector->year;
}
diff --git a/src/gcal-date-selector.h b/src/gcal-date-selector.h
index dde2fc1..ccfb1bb 100644
--- a/src/gcal-date-selector.h
+++ b/src/gcal-date-selector.h
@@ -25,32 +25,8 @@
G_BEGIN_DECLS
#define GCAL_TYPE_DATE_SELECTOR (gcal_date_selector_get_type ())
-#define GCAL_DATE_SELECTOR(obj) (G_TYPE_CHECK_INSTANCE_CAST((obj), GCAL_TYPE_DATE_SELECTOR,
GcalDateSelector))
-#define GCAL_DATE_SELECTOR_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST((klass), GCAL_TYPE_DATE_SELECTOR,
GcalDateSelectorClass))
-#define GCAL_IS_DATE_SELECTOR(obj) (G_TYPE_CHECK_INSTANCE_TYPE((obj), GCAL_TYPE_DATE_SELECTOR))
-#define GCAL_IS_DATE_SELECTOR_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE((klass), GCAL_TYPE_DATE_SELECTOR))
-#define GCAL_DATE_SELECTOR_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS((obj), GCAL_TYPE_DATE_SELECTOR,
GcalDateSelectorClass))
-typedef struct _GcalTime GcalTime;
-
-typedef struct _GcalDateSelector GcalDateSelector;
-typedef struct _GcalDateSelectorClass GcalDateSelectorClass;
-typedef struct _GcalDateSelectorPrivate GcalDateSelectorPrivate;
-
-struct _GcalDateSelector
-{
- GtkMenuButton parent;
-};
-
-struct _GcalDateSelectorClass
-{
- GtkMenuButtonClass parent_class;
-
- /* signals */
- void (*modified) (GcalDateSelector *selector);
-};
-
-GType gcal_date_selector_get_type (void);
+G_DECLARE_FINAL_TYPE (GcalDateSelector, gcal_date_selector, GCAL, DATE_SELECTOR, GtkMenuButton)
GtkWidget* gcal_date_selector_new (void);
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]