]> Pileus Git - ~andy/gtk/blobdiff - examples/calendar/calendar.c
Use gtk_separator_new() instead gtk_[v|h]separator_new()
[~andy/gtk] / examples / calendar / calendar.c
index b608a5647721f51cfba5941a71c1db2327a73f52..06312063c53948c2880340263ff0280f3a0b66f7 100644 (file)
@@ -1,5 +1,5 @@
 /*
- * Copyright (C) 1998 Cesar Miquel, Shawn T. Amundson, Mattias Grönlund
+ * Copyright (C) 1998 Cesar Miquel, Shawn T. Amundson, Mattias Grönlund
  * Copyright (C) 2000 Tony Gale
  *
  * This program is free software; you can redistribute it and/or modify
  * 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;
@@ -42,7 +40,7 @@ typedef struct _CalendarData {
 enum {
   calendar_show_header,
   calendar_show_days,
-  calendar_month_change, 
+  calendar_month_change,
   calendar_show_week,
   calendar_monday_first
 };
@@ -51,23 +49,22 @@ enum {
  * GtkCalendar
  */
 
-void calendar_date_to_string( CalendarData *data,
-                             char         *buffer,
-                             gint          buff_len )
+static void calendar_date_to_string( CalendarData *data,
+                                     char         *buffer,
+                                     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);
+  g_date_set_dmy (&date, day, month + 1, year);
+  g_date_strftime (buffer, buff_len - 1, "%x", &date);
+
 }
 
-void calendar_set_signal_strings( char         *sig_str,
-                                 CalendarData *data)
+static void calendar_set_signal_strings( char         *sig_str,
+                                         CalendarData *data )
 {
   const gchar *prev_sig;
 
@@ -79,100 +76,95 @@ void calendar_set_signal_strings( char         *sig_str,
   gtk_label_set_text (GTK_LABEL (data->last_sig), sig_str);
 }
 
-void calendar_month_changed( GtkWidget    *widget,
-                             CalendarData *data )
+static 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_selected( GtkWidget    *widget,
-                            CalendarData *data )
+static 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_click( GtkWidget    *widget,
-                                         CalendarData *data )
+static 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_month( GtkWidget    *widget,
-                            CalendarData *data )
+static 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_month( GtkWidget    *widget,
-                            CalendarData *data )
+static 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_year( GtkWidget    *widget,
-                            CalendarData *data )
+static 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_year( GtkWidget    *widget,
-                            CalendarData *data )
+static 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 )
+static 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);
+    gtk_calendar_set_display_options (GTK_CALENDAR (calendar->window), options);
 }
 
-void calendar_toggle_flag( GtkWidget    *toggle,
-                           CalendarData *calendar )
+static void calendar_toggle_flag( GtkWidget    *toggle,
+                                  CalendarData *calendar)
 {
   gint i;
   gint j;
@@ -183,31 +175,33 @@ void calendar_toggle_flag( GtkWidget    *toggle,
 
   calendar->settings[j] = !calendar->settings[j];
   calendar_set_flags (calendar);
-  
+
 }
 
-void calendar_font_selection_ok( GtkWidget    *button,
-                                 CalendarData *calendar )
+static 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_font( GtkWidget    *button,
-                           CalendarData *calendar )
+static void calendar_select_font( GtkWidget    *button,
+                                  CalendarData *calendar )
 {
   GtkWidget *window;
 
@@ -215,30 +209,29 @@ void calendar_select_font( GtkWidget    *button,
     window = gtk_font_selection_dialog_new ("Font Selection Dialog");
     g_return_if_fail (GTK_IS_FONT_SELECTION_DIALOG (window));
     calendar->font_dialog = window;
-    
+
     gtk_window_set_position (GTK_WINDOW (window), GTK_WIN_POS_MOUSE);
-    
-    g_signal_connect (G_OBJECT (window), "destroy",
-                     G_CALLBACK (gtk_widget_destroyed),
+
+    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),
                      calendar);
-    g_signal_connect_swapped (G_OBJECT (GTK_FONT_SELECTION_DIALOG (window)->cancel_button),
-                             "clicked",
-                             G_CALLBACK (gtk_widget_destroy), 
-                             calendar->font_dialog);
+    g_signal_connect_swapped (GTK_FONT_SELECTION_DIALOG (window)->cancel_button,
+                            "clicked", G_CALLBACK (gtk_widget_destroy),
+                            calendar->font_dialog);
   }
-  window=calendar->font_dialog;
-  if (!GTK_WIDGET_VISIBLE (window))
+  window = calendar->font_dialog;
+  if (!gtk_widget_get_visible (window))
     gtk_widget_show (window);
   else
     gtk_widget_destroy (window);
 
 }
 
-void create_calendar()
+static void create_calendar( void )
 {
   GtkWidget *window;
   GtkWidget *vbox, *vbox2, *vbox3;
@@ -253,7 +246,7 @@ void create_calendar()
   GtkWidget *bbox;
   static CalendarData calendar_data;
   gint i;
-  
+
   struct {
     char *label;
   } flags[] =
@@ -265,9 +258,8 @@ void create_calendar()
       { "Week Start Monday" }
     };
 
-  
+
   calendar_data.window = NULL;
-  calendar_data.font = NULL;
   calendar_data.font_dialog = NULL;
 
   for (i = 0; i < 5; i++) {
@@ -277,13 +269,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);
@@ -295,49 +286,49 @@ void create_calendar()
 
   hbox = gtk_hbox_new (FALSE, DEF_PAD);
   gtk_box_pack_start (GTK_BOX (vbox), hbox, TRUE, TRUE, DEF_PAD);
-  hbbox = gtk_hbutton_box_new ();
+  hbbox = gtk_button_box_new (GTK_ORIENTATION_HORIZONTAL);
   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_add( GTK_CONTAINER (frame), calendar);
-  g_signal_connect (G_OBJECT (calendar), "month_changed", 
-                    G_CALLBACK (calendar_month_changed),
+  gtk_calendar_mark_day (GTK_CALENDAR (calendar), 19);
+  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 (G_OBJECT (calendar), "day_selected", 
-                    G_CALLBACK (calendar_day_selected),
+  g_signal_connect (calendar, "day-selected-double-click",
+                   G_CALLBACK (calendar_day_selected_double_click),
                    &calendar_data);
-  g_signal_connect (G_OBJECT (calendar), "day_selected_double_click", 
-                    G_CALLBACK (calendar_day_selected_double_click),
-                   &calendar_data);
-  g_signal_connect (G_OBJECT (calendar), "prev_month", 
-                    G_CALLBACK (calendar_prev_month),
+  g_signal_connect (calendar, "prev-month",
+                   G_CALLBACK (calendar_prev_month),
                    &calendar_data);
-  g_signal_connect (G_OBJECT (calendar), "next_month", 
-                    G_CALLBACK (calendar_next_month),
+  g_signal_connect (calendar, "next-month",
+                   G_CALLBACK (calendar_next_month),
                    &calendar_data);
-  g_signal_connect (G_OBJECT (calendar), "prev_year", 
-                    G_CALLBACK (calendar_prev_year),
+  g_signal_connect (calendar, "prev-year",
+                   G_CALLBACK (calendar_prev_year),
                    &calendar_data);
-  g_signal_connect (G_OBJECT (calendar), "next_year", 
-                    G_CALLBACK (calendar_next_year),
+  g_signal_connect (calendar, "next-year",
+                   G_CALLBACK (calendar_next_year),
                    &calendar_data);
 
 
-  separator = gtk_vseparator_new ();
+  separator = gtk_separator_new (GTK_ORIENTATION_VERTICAL);
   gtk_box_pack_start (GTK_BOX (hbox), separator, FALSE, TRUE, 0);
 
   vbox2 = gtk_vbox_new (FALSE, DEF_PAD);
   gtk_box_pack_start (GTK_BOX (hbox), vbox2, FALSE, FALSE, DEF_PAD);
-  
-  /* Build the Right frame with the flags in */ 
+
+  /* Build the Right frame with the flags in */
 
   frame = gtk_frame_new ("Flags");
   gtk_box_pack_start (GTK_BOX (vbox2), frame, TRUE, TRUE, DEF_PAD);
@@ -347,16 +338,16 @@ 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),
                        &calendar_data);
       gtk_box_pack_start (GTK_BOX (vbox3), toggle, TRUE, TRUE, 0);
       calendar_data.flag_checkboxes[i] = toggle;
     }
-  /* Build the right font-button */ 
+  /* 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),
                    &calendar_data);
@@ -371,7 +362,7 @@ void create_calendar()
 
   vbox2 = gtk_vbox_new (TRUE, DEF_PAD_SMALL);
   gtk_container_add (GTK_CONTAINER (frame), vbox2);
-  
+
   hbox = gtk_hbox_new (FALSE, 3);
   gtk_box_pack_start (GTK_BOX (vbox2), hbox, FALSE, TRUE, 0);
   label = gtk_label_new ("Signal:");
@@ -393,24 +384,24 @@ void create_calendar()
   calendar_data.prev2_sig = gtk_label_new ("");
   gtk_box_pack_start (GTK_BOX (hbox), calendar_data.prev2_sig, FALSE, TRUE, 0);
 
-  bbox = gtk_hbutton_box_new ();
+  bbox = gtk_button_box_new (GTK_ORIENTATION_HORIZONTAL);
   gtk_box_pack_start (GTK_BOX (vbox), bbox, FALSE, FALSE, 0);
   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_CALLBACK (gtk_main_quit), 
+  g_signal_connect (button, "clicked",
+                   G_CALLBACK (gtk_main_quit),
                    NULL);
   gtk_container_add (GTK_CONTAINER (bbox), button);
-  GTK_WIDGET_SET_FLAGS (button, GTK_CAN_DEFAULT);
+  gtk_widget_set_can_default (button, TRUE);
   gtk_widget_grab_default (button);
 
   gtk_widget_show_all (window);
 }
 
 
-int main(int   argc,
-         char *argv[] )
+int main (int   argc,
+          char *argv[])
 {
   gtk_init (&argc, &argv);