diff options
Diffstat (limited to 'calendar/gui')
-rw-r--r-- | calendar/gui/Makefile.am | 2 | ||||
-rw-r--r-- | calendar/gui/main.c | 164 | ||||
-rw-r--r-- | calendar/gui/test.vcf | 153 |
3 files changed, 196 insertions, 123 deletions
diff --git a/calendar/gui/Makefile.am b/calendar/gui/Makefile.am index c0d18f5b55..43726a6714 100644 --- a/calendar/gui/Makefile.am +++ b/calendar/gui/Makefile.am @@ -1,6 +1,8 @@ SUBDIRS = versit help_base = $(datadir)/gnome/help/cal +CFLAGS += -Wall + INCLUDES = \ -I$(includedir) \ $(GNOME_INCLUDEDIR) \ diff --git a/calendar/gui/main.c b/calendar/gui/main.c index f24371d79a..aab8c9947b 100644 --- a/calendar/gui/main.c +++ b/calendar/gui/main.c @@ -12,6 +12,7 @@ #include <pwd.h> #include <sys/types.h> #include <string.h> +#include <ctype.h> #include "alarm.h" #include "calendar.h" #include "eventedit.h" @@ -19,6 +20,8 @@ #include "main.h" #include "timeutil.h" +#define COOKIE_USER_HOME_DIR ((char *) -1) + /* The username, used to set the `owner' field of the event */ char *user_name; @@ -40,7 +43,7 @@ int active_calendars = 0; /* A list of all of the calendars started */ GList *all_calendars = NULL; -static void new_calendar (char *full_name, char *calendar_file); +static void new_calendar (char *full_name, char *calendar_file, char *geometry); /* For dumping part of a calendar */ static time_t from_t, to_t; @@ -51,9 +54,6 @@ static char *load_file; /* If set, show events for the specified date and quit */ static int show_events; -/* Session management */ -static GnomeClient *sm_client; - static void init_username (void) { @@ -210,14 +210,14 @@ today_clicked (GtkWidget *widget, GnomeCalendar *gcal) static void new_calendar_cmd (GtkWidget *widget, void *data) { - new_calendar (full_name, NULL); + new_calendar (full_name, NULL, NULL); } static void open_ok (GtkWidget *widget, GtkFileSelection *fs) { /* FIXME: find out who owns this calendar and use that name */ - new_calendar ("Somebody", gtk_file_selection_get_filename (fs)); + new_calendar ("Somebody", gtk_file_selection_get_filename (fs), NULL); gtk_widget_destroy (GTK_WIDGET (fs)); } @@ -376,14 +376,21 @@ calendar_close_event (GtkWidget *widget, GdkEvent *event, GnomeCalendar *gcal) } static void -new_calendar (char *full_name, char *calendar_file) +new_calendar (char *full_name, char *calendar_file, char *geometry) { GtkWidget *toplevel; char *title; - + int xpos, ypos, width, height; + title = g_copy_strings (full_name, "'s calendar", NULL); toplevel = gnome_calendar_new (title); + if (gnome_parse_geometry (geometry, &xpos, &ypos, &width, &height)){ + if (xpos != -1) + gtk_widget_set_uposition (toplevel, xpos, ypos); + if (width != -1) + gtk_widget_set_usize (toplevel, width, height); + } g_free (title); setup_menu (toplevel); @@ -410,14 +417,24 @@ process_dates (void) to_t = time_add_day (from_t, 1); } +enum { + GEOMETRY_KEY = -1, + USERFILE_KEY = -2 +}; + static struct argp_option argp_options [] = { - { "events", 'e', NULL, 0, N_("Show events and quit"), 0 }, - { "from", 'f', N_("DATE"), 0, N_("Specifies start date [for --events]"), 1 }, - { "file", 'F', N_("FILE"), 0, N_("File to load calendar from"), 1 }, - { "to", 't', N_("DATE"), 0, N_("Specifies ending date [for --events]"), 1 }, + { "events", 'e', NULL, 0, N_("Show events and quit"), 0 }, + { "from", 'f', N_("DATE"), 0, N_("Specifies start date [for --events]"), 1 }, + { "file", 'F', N_("FILE"), 0, N_("File to load calendar from"), 1 }, + { "userfile", USERFILE_KEY, NULL, 0, N_("Load the user calendar"), 1 }, + { "geometry", GEOMETRY_KEY, N_("GEOMETRY"), 0, N_("Geometry for starting up"), 1 }, + { "to", 't', N_("DATE"), 0, N_("Specifies ending date [for --events]"), 1 }, { NULL, 0, NULL, 0, NULL, 0 }, }; +static GList *start_calendars; +static GList *start_geometries; + static int same_day (struct tm *a, struct tm *b) { @@ -486,8 +503,21 @@ parse_an_arg (int key, char *arg, struct argp_state *state) to_t = get_date (arg, NULL); break; + case GEOMETRY_KEY: + start_geometries = g_list_append (start_geometries, arg); + break; + + case USERFILE_KEY: + /* This is a special key that tells the program to load + * the user's calendar file. This allows session management + * to work even if the User's home directory changes location + * (ie, on a networked setup). + */ + arg = COOKIE_USER_HOME_DIR; + /* fall trough */ + case 'F': - load_file = arg; + start_calendars = g_list_append (start_calendars, arg); break; case 'e': @@ -515,53 +545,111 @@ session_die (void) quit_cmd (); } +/* + * Save the session callback + */ static int session_save_state (GnomeClient *client, gint phase, GnomeRestartStyle save_style, gint shutdown, GnomeInteractStyle interact_style, gint fast, gpointer client_data) { - printf ("Got a message to save the state\n"); -} - -/* Setup the Session Manager shutdown routine */ -static GnomeClient * -new_client (void) -{ - GnomeClient *client; - char buf [4096]; - - client = gnome_client_new_default (); - if (client) - return NULL; + char *sess_id; + char **argv = (char **) g_malloc ((active_calendars * 4) + 2); + GList *l, *free_list = 0; + int i; + + sess_id = gnome_client_get_id (client); - getcwd ((void *)&buf, sizeof (buf)); + argv [0] = client_data; + for (i = 1, l = all_calendars; l; l = l->next){ + GnomeCalendar *gcal = GNOME_CALENDAR (l->data); + int x, y, w, h; + char *buffer = g_malloc (32); + + gdk_window_get_origin (GTK_WIDGET (gcal)->window, &x, &y); + gdk_window_get_size (GTK_WIDGET (gcal)->window, &w, &h); + printf ("X, Y = %d, %d\n", x, y); + printf ("w, h = %d, %d\n", w, h); + sprintf (buffer, "%dx%d+%d+%d", w, h, x, y); + + if (strcmp (gcal->cal->filename, user_calendar_file) == 0) + argv [i++] = "--userfile"; + else { + argv [i++] = "--file"; + argv [i++] = gcal->cal->filename; + } + argv [i++] = "--geometry"; + argv [i++] = buffer; + free_list = g_list_append (free_list, buffer); + calendar_save (gcal->cal, gcal->cal->filename); + } + argv [i] = NULL; + gnome_client_set_clone_command (client, i, argv); + gnome_client_set_restart_command (client, i, argv); + + for (l = free_list; l; l = l->next) + g_free (l->data); + g_list_free (free_list); - gtk_object_ref(GTK_OBJECT(client)); - gtk_object_sink(GTK_OBJECT(client)); - - gtk_signal_connect (GTK_OBJECT (client), "save_yourself", - GTK_SIGNAL_FUNC (session_save_state), NULL); - gtk_signal_connect (GTK_OBJECT (client), "die", - GTK_SIGNAL_FUNC (session_die), NULL); - return client; + return 1; } int main(int argc, char *argv[]) { + GnomeClient *client; + argp_program_version = VERSION; bindtextdomain(PACKAGE, GNOMELOCALEDIR); textdomain(PACKAGE); + client = gnome_client_new_default (); + if (client){ + gtk_signal_connect (GTK_OBJECT (client), "save_yourself", + GTK_SIGNAL_FUNC (session_save_state), argv [0]); + gtk_signal_connect (GTK_OBJECT (client), "die", + GTK_SIGNAL_FUNC (session_die), NULL); + } gnome_init ("calendar", &parser, argc, argv, 0, NULL); - sm_client = new_client (); - process_dates (); alarm_init (); init_calendar (); - new_calendar (full_name, load_file ? load_file : user_calendar_file); + /* + * Load all of the calendars specifies in the command line with + * the geometry specificied -if any- + */ + if (start_calendars){ + GList *p, *g; + char *title; + + p = start_calendars; + g = start_geometries; + while (p){ + char *file = p->data; + char *geometry = g ? g->data : NULL; + + if (file == COOKIE_USER_HOME_DIR) + file = user_calendar_file; + + if (strcmp (file, user_calendar_file) == 0) + title = full_name; + else + title = file; + new_calendar (title, file, geometry); + + p = p->next; + if (g) + g = g->next; + } + g_list_free (p); + } else { + char *geometry = start_geometries ? start_geometries->data : NULL; + + new_calendar (full_name, user_calendar_file, geometry); + } gtk_main (); return 0; } + diff --git a/calendar/gui/test.vcf b/calendar/gui/test.vcf index 4010e70457..bfe93b3c14 100644 --- a/calendar/gui/test.vcf +++ b/calendar/gui/test.vcf @@ -1,150 +1,133 @@ BEGIN:VCALENDAR - -PRODID:-//K Desktop Environment//NONSGML KOrganizer//EN -TZ:-05 -VERSION:1.0 -BEGIN:VTODO -DCREATED:19980402T023552 -UID:KOrganizer - 1804289383 +PRODID:-//GNOME//NONSGML GnomeCalendar//EN +TZ:MST +VERSION:0.13 +BEGIN:VEVENT +UID:KOrganizer - 846930886 SEQUENCE:1 -LAST-MODIFIED:19980330T225948 -DTSTART:19980415T003000 -DTEND:19980415T010000 -SUMMARY: Semana: Mi, Ju, Vi, Dom (10 veces) +DTSTART:19980601T150000 +DTEND:19980601T150000 +DCREATED:19980402T023558 +LAST-MODIFIED:19980402T023558 +SUMMARY:Cada dos dias de 06/01 al 07/01 STATUS:NEEDS ACTION CLASS:PUBLIC PRIORITY:0 TRANSP:0 -RRULE:W1 WE TH FR SU #10 RELATED-TO:0 -X-PILOTID:0 -X-PILOTSTAT:0 -END:VTODO +RRULE:D2 19980701T140000 +END:VEVENT BEGIN:VEVENT -DCREATED:19980402T023552 -UID:KOrganizer - 1804289383 +UID:KOrganizer - 846930886 SEQUENCE:1 -LAST-MODIFIED:19980330T225948 -DTSTART:19980415T006000 -DTEND:19980415T009000 -SUMMARY:Diario durante 5 dias +DTSTART:19980501T140000 +DTEND:19980501T140000 +DCREATED:19980402T023558 +LAST-MODIFIED:19980402T023558 +SUMMARY:5 dias. STATUS:NEEDS ACTION CLASS:PUBLIC PRIORITY:0 TRANSP:0 -RRULE:D1 #5 RELATED-TO:0 -X-PILOTID:0 -X-PILOTSTAT:0 +RRULE:D1 #5 END:VEVENT -BEGIN:VTODO -DCREATED:19980402T023552 -UID:KOrganizer - 1804289383 +BEGIN:VEVENT +UID:KOrganizer - 846930886 SEQUENCE:1 -LAST-MODIFIED:19980330T225948 -DTSTART:19980415T116000 -DTEND:19980415T119000 -SUMMARY:Semanal -- 4 semanas +DTSTART:19980501T140000 +DTEND:19980501T150000 +DCREATED:19980402T023558 +LAST-MODIFIED:19980429T004635 +SUMMARY:Diariamente de 05/01 al 06/01 STATUS:NEEDS ACTION -CLASS:PUBLIC +CLASS:PRIVATE PRIORITY:0 TRANSP:0 -RRULE:W1 #4 RELATED-TO:0 -X-PILOTID:0 -X-PILOTSTAT:0 -END:VTODO +RRULE:D1 19980601T000000 +END:VEVENT BEGIN:VEVENT -DCREATED:19980402T023552 UID:KOrganizer - 1804289383 SEQUENCE:1 -LAST-MODIFIED:19980330T225948 -DTSTART:19980415T006000 -DTEND:19980415T009000 +DTSTART:19980415T010000 +DTEND:19980415T013000 +DCREATED:19980402T023552 +LAST-MODIFIED:19980330T225948 SUMMARY:Diario durante 5 dias STATUS:NEEDS ACTION CLASS:PUBLIC PRIORITY:0 TRANSP:0 -RRULE:D1 #5 RELATED-TO:0 -X-PILOTID:0 -X-PILOTSTAT:0 +RRULE:D1 #5 END:VEVENT -BEGIN:VTODO -DCREATED:19980402T023558 -UID:KOrganizer - 846930886 +BEGIN:VEVENT +UID:KOrganizer - 1804289383 SEQUENCE:1 -LAST-MODIFIED:19980402T023558 -DTSTART:19980415T140000 -DTEND:19980415T160000 -SUMMARY:Normal +DTSTART:19980415T010000 +DTEND:19980415T013000 +DCREATED:19980402T023552 +LAST-MODIFIED:19980330T225948 +SUMMARY:Diario durante 5 dias STATUS:NEEDS ACTION CLASS:PUBLIC PRIORITY:0 TRANSP:0 RELATED-TO:0 -X-PILOTID:0 -X-PILOTSTAT:0 -END:VTODO +RRULE:D1 #5 +END:VEVENT -BEGIN:VEVENT -DCREATED:19980402T023558 +BEGIN:VTODO UID:KOrganizer - 846930886 SEQUENCE:1 -LAST-MODIFIED:19980402T023558 -DTSTART:19980501T140000 -DTEND:19980501T140000 -RRULE:D1 19980601T140000 -SUMMARY:Diariamente de 05/01 al 06/01 +DTSTART:19980415T140000 +DUE:19691231T180000 +DCREATED:19980402T023558 +LAST-MODIFIED:19980402T023558 +SUMMARY:Normal STATUS:NEEDS ACTION CLASS:PUBLIC PRIORITY:0 TRANSP:0 RELATED-TO:0 -X-PILOTID:0 -X-PILOTSTAT:0 -END:VEVENT +END:VTODO -BEGIN:VEVENT -DCREATED:19980402T023558 -UID:KOrganizer - 846930886 +BEGIN:VTODO +UID:KOrganizer - 1804289383 SEQUENCE:1 -LAST-MODIFIED:19980402T023558 -DTSTART:19980501T140000 -DTEND:19980501T140000 -RRULE:D1 #5 -SUMMARY:5 dias. +DTSTART:19980415T120000 +DUE:19691231T180000 +DCREATED:19980402T023552 +LAST-MODIFIED:19980330T225948 +SUMMARY:Semanal -- 4 semanas STATUS:NEEDS ACTION CLASS:PUBLIC PRIORITY:0 TRANSP:0 RELATED-TO:0 -X-PILOTID:0 -X-PILOTSTAT:0 -END:VEVENT +RRULE:W1 WE #4 +END:VTODO -BEGIN:VEVENT -DCREATED:19980402T023558 -UID:KOrganizer - 846930886 +BEGIN:VTODO +UID:KOrganizer - 1804289383 SEQUENCE:1 -LAST-MODIFIED:19980402T023558 -DTSTART:19980601T150000 -DTEND:19980601T150000 -RRULE:D2 19980701T140000 -SUMMARY:Cada dos dias de 06/01 al 07/01 +DTSTART:19980415T003000 +DUE:19691231T180000 +DCREATED:19980402T023552 +LAST-MODIFIED:19980330T225948 +SUMMARY:Semana: Mi, Ju, Vi, Dom (10 veces) STATUS:NEEDS ACTION CLASS:PUBLIC PRIORITY:0 TRANSP:0 RELATED-TO:0 -X-PILOTID:0 -X-PILOTSTAT:0 -END:VEVENT +RRULE:W1 SU WE TH FR #10 +END:VTODO END:VCALENDAR |