]> Pileus Git - ~andy/gtk/commitdiff
Numerous fixes to the calendar example. (#97956, Owen Taylor)
authorMatthias Clasen <matthiasc@src.gnome.org>
Thu, 21 Nov 2002 19:56:52 +0000 (19:56 +0000)
committerMatthias Clasen <matthiasc@src.gnome.org>
Thu, 21 Nov 2002 19:56:52 +0000 (19:56 +0000)
* docs/tutorial/gtk-tut.sgml:
* examples/calendar/calendar.c: Numerous fixes to the calendar
example.  (#97956, Owen Taylor)

ChangeLog
ChangeLog.pre-2-10
ChangeLog.pre-2-2
ChangeLog.pre-2-4
ChangeLog.pre-2-6
ChangeLog.pre-2-8
docs/tutorial/gtk-tut.sgml
examples/calendar/calendar.c

index a54ad30a5b06766cee3b2175736027f2b3a43456..72016362193c984be8fd99e832c0879b0d0c06da 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,5 +1,9 @@
 2002-11-21  Matthias Clasen  <maclas@gmx.de>
 
+       * docs/tutorial/gtk-tut.sgml: 
+       * examples/calendar/calendar.c: Numerous fixes to the calendar 
+       example.  (#97956, Owen Taylor)
+
        * gtk/gtktreeview.c (gtk_tree_view_set_cursor): Fix doc 
        comment typos.  (#97432, Vitaly Tishkov)
 
index a54ad30a5b06766cee3b2175736027f2b3a43456..72016362193c984be8fd99e832c0879b0d0c06da 100644 (file)
@@ -1,5 +1,9 @@
 2002-11-21  Matthias Clasen  <maclas@gmx.de>
 
+       * docs/tutorial/gtk-tut.sgml: 
+       * examples/calendar/calendar.c: Numerous fixes to the calendar 
+       example.  (#97956, Owen Taylor)
+
        * gtk/gtktreeview.c (gtk_tree_view_set_cursor): Fix doc 
        comment typos.  (#97432, Vitaly Tishkov)
 
index a54ad30a5b06766cee3b2175736027f2b3a43456..72016362193c984be8fd99e832c0879b0d0c06da 100644 (file)
@@ -1,5 +1,9 @@
 2002-11-21  Matthias Clasen  <maclas@gmx.de>
 
+       * docs/tutorial/gtk-tut.sgml: 
+       * examples/calendar/calendar.c: Numerous fixes to the calendar 
+       example.  (#97956, Owen Taylor)
+
        * gtk/gtktreeview.c (gtk_tree_view_set_cursor): Fix doc 
        comment typos.  (#97432, Vitaly Tishkov)
 
index a54ad30a5b06766cee3b2175736027f2b3a43456..72016362193c984be8fd99e832c0879b0d0c06da 100644 (file)
@@ -1,5 +1,9 @@
 2002-11-21  Matthias Clasen  <maclas@gmx.de>
 
+       * docs/tutorial/gtk-tut.sgml: 
+       * examples/calendar/calendar.c: Numerous fixes to the calendar 
+       example.  (#97956, Owen Taylor)
+
        * gtk/gtktreeview.c (gtk_tree_view_set_cursor): Fix doc 
        comment typos.  (#97432, Vitaly Tishkov)
 
index a54ad30a5b06766cee3b2175736027f2b3a43456..72016362193c984be8fd99e832c0879b0d0c06da 100644 (file)
@@ -1,5 +1,9 @@
 2002-11-21  Matthias Clasen  <maclas@gmx.de>
 
+       * docs/tutorial/gtk-tut.sgml: 
+       * examples/calendar/calendar.c: Numerous fixes to the calendar 
+       example.  (#97956, Owen Taylor)
+
        * gtk/gtktreeview.c (gtk_tree_view_set_cursor): Fix doc 
        comment typos.  (#97432, Vitaly Tishkov)
 
index a54ad30a5b06766cee3b2175736027f2b3a43456..72016362193c984be8fd99e832c0879b0d0c06da 100644 (file)
@@ -1,5 +1,9 @@
 2002-11-21  Matthias Clasen  <maclas@gmx.de>
 
+       * docs/tutorial/gtk-tut.sgml: 
+       * examples/calendar/calendar.c: Numerous fixes to the calendar 
+       example.  (#97956, Owen Taylor)
+
        * gtk/gtktreeview.c (gtk_tree_view_set_cursor): Fix doc 
        comment typos.  (#97432, Vitaly Tishkov)
 
index 6002da3ee229d4ff26424763299f7ad0cb7197c9..d5beba5ec1d278b2f9cb40d0ea512371e8a96a3b 100755 (executable)
@@ -5560,10 +5560,9 @@ example code.</para>
  * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
  */
 
-#include &lt;gtk/gtk.h&gt;
 #include &lt;stdio.h&gt;
 #include &lt;string.h&gt;
-#include &lt;time.h&gt;
+#include &lt;gtk/gtk.h&gt;
 
 #define DEF_PAD 10
 #define DEF_PAD_SMALL 5
@@ -5573,7 +5572,6 @@ example code.</para>
 typedef struct _CalendarData {
   GtkWidget *flag_checkboxes[5];
   gboolean  settings[5];
-  gchar     *font;
   GtkWidget *font_dialog;
   GtkWidget *window;
   GtkWidget *prev2_sig;
@@ -5594,22 +5592,22 @@ enum {
  * GtkCalendar
  */
 
-void calendar_date_to_stringCalendarData *data,
+void calendar_date_to_string (CalendarData *data,
                              char         *buffer,
-                             gint          buff_len )
+                             gint          buff_len)
 {
-  struct tm tm;
-  time_t time;
+  GDate *date;
+  guint year, month, day;
 
-  memset (&amp;tm, 0, sizeof (tm));
   gtk_calendar_get_date (GTK_CALENDAR (data-&gt;window),
-                        &amp;tm.tm_year, &amp;tm.tm_mon, &amp;tm.tm_mday);
-  tm.tm_year -= TM_YEAR_BASE;
-  time = mktime (&amp;tm);
-  strftime (buffer, buff_len-1, "%x", gmtime (&amp;time));
+                        &amp;year, &amp;month, &amp;day);
+  date = g_date_new_dmy (day, month + 1, year);
+  g_date_strftime (buffer, buff_len - 1, "%x", date);
+
+  g_date_free (date);
 }
 
-void calendar_set_signal_stringschar         *sig_str,
+void calendar_set_signal_strings (char         *sig_str,
                                  CalendarData *data)
 {
   const gchar *prev_sig;
@@ -5622,100 +5620,95 @@ void calendar_set_signal_strings( char         *sig_str,
   gtk_label_set_text (GTK_LABEL (data-&gt;last_sig), sig_str);
 }
 
-void calendar_month_changedGtkWidget    *widget,
-                             CalendarData *data )
+void calendar_month_changed (GtkWidget    *widget,
+                             CalendarData *data)
 {
   char buffer[256] = "month_changed: ";
 
-  calendar_date_to_string (data, buffer+15, 256-15);
+  calendar_date_to_string (data, buffer + 15, 256 - 15);
   calendar_set_signal_strings (buffer, data);
 }
 
-void calendar_day_selectedGtkWidget    *widget,
-                            CalendarData *data )
+void calendar_day_selected (GtkWidget    *widget,
+                            CalendarData *data)
 {
   char buffer[256] = "day_selected: ";
 
-  calendar_date_to_string (data, buffer+14, 256-14);
+  calendar_date_to_string (data, buffer + 14, 256 - 14);
   calendar_set_signal_strings (buffer, data);
 }
 
-void calendar_day_selected_double_clickGtkWidget    *widget,
-                                         CalendarData *data )
+void calendar_day_selected_double_click (GtkWidget    *widget,
+                                         CalendarData *data)
 {
-  struct tm tm;
   char buffer[256] = "day_selected_double_click: ";
+  guint day;
 
-  calendar_date_to_string (data, buffer+27, 256-27);
+  calendar_date_to_string (data, buffer + 27, 256 - 27);
   calendar_set_signal_strings (buffer, data);
 
-  memset (&amp;tm, 0, sizeof (tm));
   gtk_calendar_get_date (GTK_CALENDAR (data-&gt;window),
-                        &amp;tm.tm_year, &amp;tm.tm_mon, &amp;tm.tm_mday);
-  tm.tm_year -= TM_YEAR_BASE;
+                        NULL, NULL, &amp;day);
 
-  if (GTK_CALENDAR (data-&gt;window)-&gt;marked_date[tm.tm_mday-1] == 0) 
-    {
-      gtk_calendar_mark_day (GTK_CALENDAR (data-&gt;window), tm.tm_mday);
-    } 
-  else 
-    { 
-      gtk_calendar_unmark_day (GTK_CALENDAR (data-&gt;window), tm.tm_mday);
-    }
+  if (GTK_CALENDAR (data-&gt;window)-&gt;marked_date[day-1] == 0) {
+    gtk_calendar_mark_day (GTK_CALENDAR (data-&gt;window), day);
+  } else { 
+    gtk_calendar_unmark_day (GTK_CALENDAR (data-&gt;window), day);
+  }
 }
 
-void calendar_prev_monthGtkWidget    *widget,
-                            CalendarData *data )
+void calendar_prev_month (GtkWidget    *widget,
+                          CalendarData *data)
 {
   char buffer[256] = "prev_month: ";
 
-  calendar_date_to_string (data, buffer+12, 256-12);
+  calendar_date_to_string (data, buffer + 12, 256 - 12);
   calendar_set_signal_strings (buffer, data);
 }
 
-void calendar_next_monthGtkWidget    *widget,
-                            CalendarData *data )
+void calendar_next_month (GtkWidget    *widget,
+                          CalendarData *data)
 {
   char buffer[256] = "next_month: ";
 
-  calendar_date_to_string (data, buffer+12, 256-12);
+  calendar_date_to_string (data, buffer + 12, 256 - 12);
   calendar_set_signal_strings (buffer, data);
 }
 
-void calendar_prev_yearGtkWidget    *widget,
-                            CalendarData *data )
+void calendar_prev_year (GtkWidget    *widget,
+                         CalendarData *data)
 {
   char buffer[256] = "prev_year: ";
 
-  calendar_date_to_string (data, buffer+11, 256-11);
+  calendar_date_to_string (data, buffer + 11, 256 - 11);
   calendar_set_signal_strings (buffer, data);
 }
 
-void calendar_next_yearGtkWidget    *widget,
-                            CalendarData *data )
+void calendar_next_year (GtkWidget    *widget,
+                         CalendarData *data)
 {
   char buffer[256] = "next_year: ";
 
-  calendar_date_to_string (data, buffer+11, 256-11);
+  calendar_date_to_string (data, buffer + 11, 256 - 11);
   calendar_set_signal_strings (buffer, data);
 }
 
 
-void calendar_set_flags( CalendarData *calendar )
+void calendar_set_flags (CalendarData *calendar)
 {
   gint i;
   gint options = 0;
-  for (i = 0; i &lt; 5; i++) 
+  for (i = 0;i &lt; 5; i++) 
     if (calendar-&gt;settings[i])
       {
-       options=options + (1&lt;&lt;i);
+       options = options + (1 &lt;&lt; i);
       }
   if (calendar-&gt;window)
     gtk_calendar_display_options (GTK_CALENDAR (calendar-&gt;window), options);
 }
 
-void calendar_toggle_flagGtkWidget    *toggle,
-                           CalendarData *calendar )
+void calendar_toggle_flag (GtkWidget    *toggle,
+                           CalendarData *calendar)
 {
   gint i;
   gint j;
@@ -5729,28 +5722,30 @@ void calendar_toggle_flag( GtkWidget    *toggle,
   
 }
 
-void calendar_font_selection_okGtkWidget    *button,
-                                 CalendarData *calendar )
+void calendar_font_selection_ok (GtkWidget    *button,
+                                 CalendarData *calendar)
 {
-  GtkStyle *style;
-  PangoFontDescription *font_desc;
+  GtkRcStyle *style;
+  char *font_name;
 
-  calendar-&gt;font = gtk_font_selection_dialog_get_font_name (
-                       GTK_FONT_SELECTION_DIALOG (calendar-&gt;font_dialog));
   if (calendar-&gt;window)
     {
-      font_desc = pango_font_description_from_string (calendar-&gt;font);
-      if (font_desc
+      font_name = gtk_font_selection_dialog_get_font_name (GTK_FONT_SELECTION_DIALOG (calendar-&gt;font_dialog));
+      if (font_name
        {
-         style = gtk_style_copy (gtk_widget_get_style (calendar-&gt;window));
-         style-&gt;font_desc = font_desc;
-         gtk_widget_set_style (calendar-&gt;window, style);
+         style = gtk_rc_style_new ();
+         pango_font_description_free (style-&gt;font_desc);
+         style-&gt;font_desc = pango_font_description_from_string (font_name);
+         gtk_widget_modify_style (calendar-&gt;window, style);
+         g_free (font_name);
        }
     }
+
+  gtk_widget_destroy (calendar-&gt;font_dialog);
 }
 
-void calendar_select_fontGtkWidget    *button,
-                           CalendarData *calendar )
+void calendar_select_font (GtkWidget    *button,
+                           CalendarData *calendar)
 {
   GtkWidget *window;
 
@@ -5761,19 +5756,18 @@ void calendar_select_font( GtkWidget    *button,
     
     gtk_window_set_position (GTK_WINDOW (window), GTK_WIN_POS_MOUSE);
     
-    g_signal_connect (G_OBJECT (window), "destroy",
-                     G_CALLBACK (gtk_widget_destroyed),
-                     (gpointer) &amp;calendar-&gt;font_dialog);
+    g_signal_connect (window, "destroy",
+                     G_CALLBACK (gtk_widget_destroyed),
+                     &amp;calendar-&gt;font_dialog);
     
-    g_signal_connect (G_OBJECT (GTK_FONT_SELECTION_DIALOG (window)-&gt;ok_button),
+    g_signal_connect (GTK_FONT_SELECTION_DIALOG (window)-&gt;ok_button,
                      "clicked", G_CALLBACK (calendar_font_selection_ok),
-                     (gpointer) calendar);
-    g_signal_connect_swapped (G_OBJECT (GTK_FONT_SELECTION_DIALOG (window)-&gt;cancel_button),
-                             "clicked",
-                             G_CALLBACK (gtk_widget_destroy), 
-                             G_OBJECT (calendar-&gt;font_dialog));
+                     calendar);
+    g_signal_connect_swapped (GTK_FONT_SELECTION_DIALOG (window)-&gt;cancel_button,
+                            "clicked", G_CALLBACK (gtk_widget_destroy), 
+                            calendar-&gt;font_dialog);
   }
-  window=calendar-&gt;font_dialog;
+  window = calendar-&gt;font_dialog;
   if (!GTK_WIDGET_VISIBLE (window))
     gtk_widget_show (window);
   else
@@ -5781,7 +5775,7 @@ void calendar_select_font( GtkWidget    *button,
 
 }
 
-void create_calendar()
+void create_calendar ()
 {
   GtkWidget *window;
   GtkWidget *vbox, *vbox2, *vbox3;
@@ -5810,7 +5804,6 @@ void create_calendar()
 
   
   calendar_data.window = NULL;
-  calendar_data.font = NULL;
   calendar_data.font_dialog = NULL;
 
   for (i = 0; i &lt; 5; i++) {
@@ -5820,13 +5813,12 @@ void create_calendar()
   window = gtk_window_new (GTK_WINDOW_TOPLEVEL);
   gtk_window_set_title (GTK_WINDOW (window), "GtkCalendar Example");
   gtk_container_set_border_width (GTK_CONTAINER (window), 5);
-  g_signal_connect (G_OBJECT (window), "destroy",
+  g_signal_connect (window, "destroy",
                    G_CALLBACK (gtk_main_quit),
                    NULL);
-  g_signal_connect (G_OBJECT (window), "delete-event",
+  g_signal_connect (window, "delete-event",
                    G_CALLBACK (gtk_false),
                    NULL);
-
   gtk_window_set_resizable (GTK_WINDOW (window), FALSE);
 
   vbox = gtk_vbox_new (FALSE, DEF_PAD);
@@ -5840,38 +5832,38 @@ void create_calendar()
   gtk_box_pack_start (GTK_BOX (vbox), hbox, TRUE, TRUE, DEF_PAD);
   hbbox = gtk_hbutton_box_new ();
   gtk_box_pack_start (GTK_BOX (hbox), hbbox, FALSE, FALSE, DEF_PAD);
-  gtk_button_box_set_layout (GTK_BUTTON_BOX(hbbox), GTK_BUTTONBOX_SPREAD);
+  gtk_button_box_set_layout (GTK_BUTTON_BOX (hbbox), GTK_BUTTONBOX_SPREAD);
   gtk_box_set_spacing (GTK_BOX (hbbox), 5);
 
   /* Calendar widget */
   frame = gtk_frame_new ("Calendar");
-  gtk_box_pack_start (GTK_BOX (hbbox), frame, FALSE, TRUE, DEF_PAD);
+  gtk_box_pack_start(GTK_BOX (hbbox), frame, FALSE, TRUE, DEF_PAD);
   calendar=gtk_calendar_new ();
   calendar_data.window = calendar;
   calendar_set_flags (&amp;calendar_data);
   gtk_calendar_mark_day (GTK_CALENDAR (calendar), 19); 
-  gtk_container_addGTK_CONTAINER (frame), calendar);
-  g_signal_connect (G_OBJECT (calendar), "month_changed", 
-                    G_CALLBACK (calendar_month_changed),
-                   (gpointer) &amp;calendar_data);
-  g_signal_connect (G_OBJECT (calendar), "day_selected", 
-                    G_CALLBACK (calendar_day_selected),
-                   (gpointer) &amp;calendar_data);
-  g_signal_connect (G_OBJECT (calendar), "day_selected_double_click", 
-                    G_CALLBACK (calendar_day_selected_double_click),
-                   (gpointer) &amp;calendar_data);
-  g_signal_connect (G_OBJECT (calendar), "prev_month", 
-                    G_CALLBACK (calendar_prev_month),
-                   (gpointer) &amp;calendar_data);
-  g_signal_connect (G_OBJECT (calendar), "next_month", 
-                    G_CALLBACK (calendar_next_month),
-                   (gpointer) &amp;calendar_data);
-  g_signal_connect (G_OBJECT (calendar), "prev_year", 
-                    G_CALLBACK (calendar_prev_year),
-                   (gpointer) &amp;calendar_data);
-  g_signal_connect (G_OBJECT (calendar), "next_year", 
-                    G_CALLBACK (calendar_next_year),
-                   (gpointer) &amp;calendar_data);
+  gtk_container_add (GTK_CONTAINER (frame), calendar);
+  g_signal_connect (calendar, "month_changed", 
+                   G_CALLBACK (calendar_month_changed),
+                   &amp;calendar_data);
+  g_signal_connect (calendar, "day_selected", 
+                   G_CALLBACK (calendar_day_selected),
+                   &amp;calendar_data);
+  g_signal_connect (calendar, "day_selected_double_click", 
+                   G_CALLBACK (calendar_day_selected_double_click),
+                   &amp;calendar_data);
+  g_signal_connect (calendar, "prev_month", 
+                   G_CALLBACK (calendar_prev_month),
+                   &amp;calendar_data);
+  g_signal_connect (calendar, "next_month", 
+                   G_CALLBACK (calendar_next_month),
+                   &amp;calendar_data);
+  g_signal_connect (calendar, "prev_year", 
+                   G_CALLBACK (calendar_prev_year),
+                   &amp;calendar_data);
+  g_signal_connect (calendar, "next_year", 
+                   G_CALLBACK (calendar_next_year),
+                   &amp;calendar_data);
 
 
   separator = gtk_vseparator_new ();
@@ -5890,19 +5882,19 @@ void create_calendar()
   for (i = 0; i &lt; 5; i++)
     {
       toggle = gtk_check_button_new_with_label (flags[i].label);
-      g_signal_connect (G_OBJECT (toggle),
+      g_signal_connect (toggle,
                        "toggled",
                        G_CALLBACK (calendar_toggle_flag),
-                       (gpointer) &amp;calendar_data);
+                       &amp;calendar_data);
       gtk_box_pack_start (GTK_BOX (vbox3), toggle, TRUE, TRUE, 0);
       calendar_data.flag_checkboxes[i] = toggle;
     }
   /* Build the right font-button */ 
   button = gtk_button_new_with_label ("Font...");
-  g_signal_connect (G_OBJECT (button),
+  g_signal_connect (button,
                    "clicked",
                    G_CALLBACK (calendar_select_font),
-                   (gpointer) &amp;calendar_data);
+                   &amp;calendar_data);
   gtk_box_pack_start (GTK_BOX (vbox2), button, FALSE, FALSE, 0);
 
   /*
@@ -5941,7 +5933,7 @@ void create_calendar()
   gtk_button_box_set_layout (GTK_BUTTON_BOX (bbox), GTK_BUTTONBOX_END);
 
   button = gtk_button_new_with_label ("Close");
-  g_signal_connect (G_OBJECT (button), "clicked", 
+  g_signal_connect (button, "clicked", 
                    G_CALLBACK (gtk_main_quit), 
                    NULL);
   gtk_container_add (GTK_CONTAINER (bbox), button);
@@ -5952,8 +5944,8 @@ void create_calendar()
 }
 
 
-int main(int   argc,
-         char *argv[] )
+int main (int   argc,
+          char *argv[])
 {
   gtk_init (&amp;argc, &amp;argv);
 
index 96eb8731bd0e0f3332274388638f04021b0a5d6e..87100e509ee0fb6669ec76f7027922827a019a42 100644 (file)
  * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
  */
 
-#include <gtk/gtk.h>
 #include <stdio.h>
 #include <string.h>
-#include <time.h>
+#include <gtk/gtk.h>
 
 #define DEF_PAD 10
 #define DEF_PAD_SMALL 5
@@ -30,7 +29,6 @@
 typedef struct _CalendarData {
   GtkWidget *flag_checkboxes[5];
   gboolean  settings[5];
-  gchar     *font;
   GtkWidget *font_dialog;
   GtkWidget *window;
   GtkWidget *prev2_sig;
@@ -51,22 +49,22 @@ enum {
  * GtkCalendar
  */
 
-void calendar_date_to_stringCalendarData *data,
+void calendar_date_to_string (CalendarData *data,
                              char         *buffer,
-                             gint          buff_len )
+                             gint          buff_len)
 {
-  struct tm tm;
-  time_t time;
+  GDate *date;
+  guint year, month, day;
 
-  memset (&tm, 0, sizeof (tm));
   gtk_calendar_get_date (GTK_CALENDAR (data->window),
-                        &tm.tm_year, &tm.tm_mon, &tm.tm_mday);
-  tm.tm_year -= TM_YEAR_BASE;
-  time = mktime (&tm);
-  strftime (buffer, buff_len-1, "%x", gmtime (&time));
+                        &year, &month, &day);
+  date = g_date_new_dmy (day, month + 1, year);
+  g_date_strftime (buffer, buff_len - 1, "%x", date);
+
+  g_date_free (date);
 }
 
-void calendar_set_signal_stringschar         *sig_str,
+void calendar_set_signal_strings (char         *sig_str,
                                  CalendarData *data)
 {
   const gchar *prev_sig;
@@ -79,100 +77,95 @@ void calendar_set_signal_strings( char         *sig_str,
   gtk_label_set_text (GTK_LABEL (data->last_sig), sig_str);
 }
 
-void calendar_month_changedGtkWidget    *widget,
-                             CalendarData *data )
+void calendar_month_changed (GtkWidget    *widget,
+                             CalendarData *data)
 {
   char buffer[256] = "month_changed: ";
 
-  calendar_date_to_string (data, buffer+15, 256-15);
+  calendar_date_to_string (data, buffer + 15, 256 - 15);
   calendar_set_signal_strings (buffer, data);
 }
 
-void calendar_day_selectedGtkWidget    *widget,
-                            CalendarData *data )
+void calendar_day_selected (GtkWidget    *widget,
+                            CalendarData *data)
 {
   char buffer[256] = "day_selected: ";
 
-  calendar_date_to_string (data, buffer+14, 256-14);
+  calendar_date_to_string (data, buffer + 14, 256 - 14);
   calendar_set_signal_strings (buffer, data);
 }
 
-void calendar_day_selected_double_clickGtkWidget    *widget,
-                                         CalendarData *data )
+void calendar_day_selected_double_click (GtkWidget    *widget,
+                                         CalendarData *data)
 {
-  struct tm tm;
   char buffer[256] = "day_selected_double_click: ";
+  guint day;
 
-  calendar_date_to_string (data, buffer+27, 256-27);
+  calendar_date_to_string (data, buffer + 27, 256 - 27);
   calendar_set_signal_strings (buffer, data);
 
-  memset (&tm, 0, sizeof (tm));
   gtk_calendar_get_date (GTK_CALENDAR (data->window),
-                        &tm.tm_year, &tm.tm_mon, &tm.tm_mday);
-  tm.tm_year -= TM_YEAR_BASE;
+                        NULL, NULL, &day);
 
-  if (GTK_CALENDAR (data->window)->marked_date[tm.tm_mday-1] == 0) 
-    {
-      gtk_calendar_mark_day (GTK_CALENDAR (data->window), tm.tm_mday);
-    } 
-  else 
-    { 
-      gtk_calendar_unmark_day (GTK_CALENDAR (data->window), tm.tm_mday);
-    }
+  if (GTK_CALENDAR (data->window)->marked_date[day-1] == 0) {
+    gtk_calendar_mark_day (GTK_CALENDAR (data->window), day);
+  } else { 
+    gtk_calendar_unmark_day (GTK_CALENDAR (data->window), day);
+  }
 }
 
-void calendar_prev_monthGtkWidget    *widget,
-                            CalendarData *data )
+void calendar_prev_month (GtkWidget    *widget,
+                          CalendarData *data)
 {
   char buffer[256] = "prev_month: ";
 
-  calendar_date_to_string (data, buffer+12, 256-12);
+  calendar_date_to_string (data, buffer + 12, 256 - 12);
   calendar_set_signal_strings (buffer, data);
 }
 
-void calendar_next_monthGtkWidget    *widget,
-                            CalendarData *data )
+void calendar_next_month (GtkWidget    *widget,
+                          CalendarData *data)
 {
   char buffer[256] = "next_month: ";
 
-  calendar_date_to_string (data, buffer+12, 256-12);
+  calendar_date_to_string (data, buffer + 12, 256 - 12);
   calendar_set_signal_strings (buffer, data);
 }
 
-void calendar_prev_yearGtkWidget    *widget,
-                            CalendarData *data )
+void calendar_prev_year (GtkWidget    *widget,
+                         CalendarData *data)
 {
   char buffer[256] = "prev_year: ";
 
-  calendar_date_to_string (data, buffer+11, 256-11);
+  calendar_date_to_string (data, buffer + 11, 256 - 11);
   calendar_set_signal_strings (buffer, data);
 }
 
-void calendar_next_yearGtkWidget    *widget,
-                            CalendarData *data )
+void calendar_next_year (GtkWidget    *widget,
+                         CalendarData *data)
 {
   char buffer[256] = "next_year: ";
 
-  calendar_date_to_string (data, buffer+11, 256-11);
+  calendar_date_to_string (data, buffer + 11, 256 - 11);
   calendar_set_signal_strings (buffer, data);
 }
 
 
-void calendar_set_flags( CalendarData *calendar )
+void calendar_set_flags (CalendarData *calendar)
 {
   gint i;
   gint options = 0;
-  for (i = 0; i < 5; i++) 
+  for (i = 0;i < 5; i++) 
     if (calendar->settings[i])
       {
-       options=options + (1<<i);
+       options = options + (1 << i);
       }
   if (calendar->window)
     gtk_calendar_display_options (GTK_CALENDAR (calendar->window), options);
 }
 
-void calendar_toggle_flagGtkWidget    *toggle,
-                           CalendarData *calendar )
+void calendar_toggle_flag (GtkWidget    *toggle,
+                           CalendarData *calendar)
 {
   gint i;
   gint j;
@@ -186,28 +179,30 @@ void calendar_toggle_flag( GtkWidget    *toggle,
   
 }
 
-void calendar_font_selection_okGtkWidget    *button,
-                                 CalendarData *calendar )
+void calendar_font_selection_ok (GtkWidget    *button,
+                                 CalendarData *calendar)
 {
-  GtkStyle *style;
-  PangoFontDescription *font_desc;
+  GtkRcStyle *style;
+  char *font_name;
 
-  calendar->font = gtk_font_selection_dialog_get_font_name (
-                       GTK_FONT_SELECTION_DIALOG (calendar->font_dialog));
   if (calendar->window)
     {
-      font_desc = pango_font_description_from_string (calendar->font);
-      if (font_desc
+      font_name = gtk_font_selection_dialog_get_font_name (GTK_FONT_SELECTION_DIALOG (calendar->font_dialog));
+      if (font_name
        {
-         style = gtk_style_copy (gtk_widget_get_style (calendar->window));
-         style->font_desc = font_desc;
-         gtk_widget_set_style (calendar->window, style);
+         style = gtk_rc_style_new ();
+         pango_font_description_free (style->font_desc);
+         style->font_desc = pango_font_description_from_string (font_name);
+         gtk_widget_modify_style (calendar->window, style);
+         g_free (font_name);
        }
     }
+
+  gtk_widget_destroy (calendar->font_dialog);
 }
 
-void calendar_select_fontGtkWidget    *button,
-                           CalendarData *calendar )
+void calendar_select_font (GtkWidget    *button,
+                           CalendarData *calendar)
 {
   GtkWidget *window;
 
@@ -218,19 +213,18 @@ void calendar_select_font( GtkWidget    *button,
     
     gtk_window_set_position (GTK_WINDOW (window), GTK_WIN_POS_MOUSE);
     
-    g_signal_connect (G_OBJECT (window), "destroy",
-                     G_CALLBACK (gtk_widget_destroyed),
-                     (gpointer) &calendar->font_dialog);
+    g_signal_connect (window, "destroy",
+                     G_CALLBACK (gtk_widget_destroyed),
+                     &calendar->font_dialog);
     
-    g_signal_connect (G_OBJECT (GTK_FONT_SELECTION_DIALOG (window)->ok_button),
+    g_signal_connect (GTK_FONT_SELECTION_DIALOG (window)->ok_button,
                      "clicked", G_CALLBACK (calendar_font_selection_ok),
-                     (gpointer) calendar);
-    g_signal_connect_swapped (G_OBJECT (GTK_FONT_SELECTION_DIALOG (window)->cancel_button),
-                             "clicked",
-                             G_CALLBACK (gtk_widget_destroy), 
-                             G_OBJECT (calendar->font_dialog));
+                     calendar);
+    g_signal_connect_swapped (GTK_FONT_SELECTION_DIALOG (window)->cancel_button,
+                            "clicked", G_CALLBACK (gtk_widget_destroy), 
+                            calendar->font_dialog);
   }
-  window=calendar->font_dialog;
+  window = calendar->font_dialog;
   if (!GTK_WIDGET_VISIBLE (window))
     gtk_widget_show (window);
   else
@@ -238,7 +232,7 @@ void calendar_select_font( GtkWidget    *button,
 
 }
 
-void create_calendar()
+void create_calendar ()
 {
   GtkWidget *window;
   GtkWidget *vbox, *vbox2, *vbox3;
@@ -267,7 +261,6 @@ void create_calendar()
 
   
   calendar_data.window = NULL;
-  calendar_data.font = NULL;
   calendar_data.font_dialog = NULL;
 
   for (i = 0; i < 5; i++) {
@@ -277,13 +270,12 @@ void create_calendar()
   window = gtk_window_new (GTK_WINDOW_TOPLEVEL);
   gtk_window_set_title (GTK_WINDOW (window), "GtkCalendar Example");
   gtk_container_set_border_width (GTK_CONTAINER (window), 5);
-  g_signal_connect (G_OBJECT (window), "destroy",
+  g_signal_connect (window, "destroy",
                    G_CALLBACK (gtk_main_quit),
                    NULL);
-  g_signal_connect (G_OBJECT (window), "delete-event",
+  g_signal_connect (window, "delete-event",
                    G_CALLBACK (gtk_false),
                    NULL);
-
   gtk_window_set_resizable (GTK_WINDOW (window), FALSE);
 
   vbox = gtk_vbox_new (FALSE, DEF_PAD);
@@ -297,38 +289,38 @@ void create_calendar()
   gtk_box_pack_start (GTK_BOX (vbox), hbox, TRUE, TRUE, DEF_PAD);
   hbbox = gtk_hbutton_box_new ();
   gtk_box_pack_start (GTK_BOX (hbox), hbbox, FALSE, FALSE, DEF_PAD);
-  gtk_button_box_set_layout (GTK_BUTTON_BOX(hbbox), GTK_BUTTONBOX_SPREAD);
+  gtk_button_box_set_layout (GTK_BUTTON_BOX (hbbox), GTK_BUTTONBOX_SPREAD);
   gtk_box_set_spacing (GTK_BOX (hbbox), 5);
 
   /* Calendar widget */
   frame = gtk_frame_new ("Calendar");
-  gtk_box_pack_start (GTK_BOX (hbbox), frame, FALSE, TRUE, DEF_PAD);
+  gtk_box_pack_start(GTK_BOX (hbbox), frame, FALSE, TRUE, DEF_PAD);
   calendar=gtk_calendar_new ();
   calendar_data.window = calendar;
   calendar_set_flags (&calendar_data);
   gtk_calendar_mark_day (GTK_CALENDAR (calendar), 19); 
-  gtk_container_addGTK_CONTAINER (frame), calendar);
-  g_signal_connect (G_OBJECT (calendar), "month_changed", 
-                    G_CALLBACK (calendar_month_changed),
-                   (gpointer) &calendar_data);
-  g_signal_connect (G_OBJECT (calendar), "day_selected", 
-                    G_CALLBACK (calendar_day_selected),
-                   (gpointer) &calendar_data);
-  g_signal_connect (G_OBJECT (calendar), "day_selected_double_click", 
-                    G_CALLBACK (calendar_day_selected_double_click),
-                   (gpointer) &calendar_data);
-  g_signal_connect (G_OBJECT (calendar), "prev_month", 
-                    G_CALLBACK (calendar_prev_month),
-                   (gpointer) &calendar_data);
-  g_signal_connect (G_OBJECT (calendar), "next_month", 
-                    G_CALLBACK (calendar_next_month),
-                   (gpointer) &calendar_data);
-  g_signal_connect (G_OBJECT (calendar), "prev_year", 
-                    G_CALLBACK (calendar_prev_year),
-                   (gpointer) &calendar_data);
-  g_signal_connect (G_OBJECT (calendar), "next_year", 
-                    G_CALLBACK (calendar_next_year),
-                   (gpointer) &calendar_data);
+  gtk_container_add (GTK_CONTAINER (frame), calendar);
+  g_signal_connect (calendar, "month_changed", 
+                   G_CALLBACK (calendar_month_changed),
+                   &calendar_data);
+  g_signal_connect (calendar, "day_selected", 
+                   G_CALLBACK (calendar_day_selected),
+                   &calendar_data);
+  g_signal_connect (calendar, "day_selected_double_click", 
+                   G_CALLBACK (calendar_day_selected_double_click),
+                   &calendar_data);
+  g_signal_connect (calendar, "prev_month", 
+                   G_CALLBACK (calendar_prev_month),
+                   &calendar_data);
+  g_signal_connect (calendar, "next_month", 
+                   G_CALLBACK (calendar_next_month),
+                   &calendar_data);
+  g_signal_connect (calendar, "prev_year", 
+                   G_CALLBACK (calendar_prev_year),
+                   &calendar_data);
+  g_signal_connect (calendar, "next_year", 
+                   G_CALLBACK (calendar_next_year),
+                   &calendar_data);
 
 
   separator = gtk_vseparator_new ();
@@ -347,19 +339,19 @@ void create_calendar()
   for (i = 0; i < 5; i++)
     {
       toggle = gtk_check_button_new_with_label (flags[i].label);
-      g_signal_connect (G_OBJECT (toggle),
+      g_signal_connect (toggle,
                        "toggled",
                        G_CALLBACK (calendar_toggle_flag),
-                       (gpointer) &calendar_data);
+                       &calendar_data);
       gtk_box_pack_start (GTK_BOX (vbox3), toggle, TRUE, TRUE, 0);
       calendar_data.flag_checkboxes[i] = toggle;
     }
   /* Build the right font-button */ 
   button = gtk_button_new_with_label ("Font...");
-  g_signal_connect (G_OBJECT (button),
+  g_signal_connect (button,
                    "clicked",
                    G_CALLBACK (calendar_select_font),
-                   (gpointer) &calendar_data);
+                   &calendar_data);
   gtk_box_pack_start (GTK_BOX (vbox2), button, FALSE, FALSE, 0);
 
   /*
@@ -398,7 +390,7 @@ void create_calendar()
   gtk_button_box_set_layout (GTK_BUTTON_BOX (bbox), GTK_BUTTONBOX_END);
 
   button = gtk_button_new_with_label ("Close");
-  g_signal_connect (G_OBJECT (button), "clicked", 
+  g_signal_connect (button, "clicked", 
                    G_CALLBACK (gtk_main_quit), 
                    NULL);
   gtk_container_add (GTK_CONTAINER (bbox), button);
@@ -409,8 +401,8 @@ void create_calendar()
 }
 
 
-int main(int   argc,
-         char *argv[] )
+int main (int   argc,
+          char *argv[])
 {
   gtk_init (&argc, &argv);