$OpenBSD: patch-wmclockmon-cal_mainwindow_c,v 1.1 2010/03/23 22:12:39 jasper Exp $

Switch to gtk+2:
- Remove call to deprecated function.

--- wmclockmon-cal/mainwindow.c.orig	Mon May 31 10:15:18 2004
+++ wmclockmon-cal/mainwindow.c	Tue Mar 23 23:11:30 2010
@@ -51,7 +51,6 @@ static void show_editor() {
     gtk_widget_hide(calendar);
     gtk_widget_hide(closewindow);
     gtk_widget_grab_default(GTK_WIDGET(cancel));
-    gtk_widget_draw_default(GTK_WIDGET(cancel));
     gtk_widget_grab_focus(GTK_WIDGET(edit));
     gtk_widget_show(text_buttons);
     gtk_widget_show(edit);
@@ -69,7 +68,6 @@ static void hide_editor() {
     gtk_widget_hide(cancel);
     gtk_widget_show(calendar);
     gtk_widget_grab_default(GTK_WIDGET(closewindow));
-    gtk_widget_draw_default(GTK_WIDGET(closewindow));
     gtk_widget_grab_focus(GTK_WIDGET(closewindow));
     gtk_widget_show(closewindow);
 }
@@ -93,13 +91,20 @@ static void load_file(const char *datestr) {
     FILE *file;
     char *filename = get_file(datestr);
 
+    GtkTextIter iter;
+    GtkTextBuffer *buf;
+
+    buf = GTK_TEXT_BUFFER(gtk_text_view_get_buffer(GTK_TEXT_VIEW(edit)));
+    gtk_text_buffer_get_end_iter(GTK_TEXT_BUFFER(gtk_text_view_get_buffer(GTK_TEXT_VIEW(edit))), &iter);
+    gtk_text_buffer_place_cursor(GTK_TEXT_BUFFER(gtk_text_view_get_buffer(GTK_TEXT_VIEW(edit))), &iter);
+
     if ((file = fopen(filename, "r")) != NULL) {
         while (! feof(file)) {
             char line[MAXSTRLEN + 1];
             bzero(line, MAXSTRLEN + 1);
             fgets(line, MAXSTRLEN, file);
             if (line[0] != 0)
-                gtk_text_insert(GTK_TEXT(edit), NULL, NULL, NULL, line, -1);
+	      gtk_text_buffer_insert(buf, &iter, line, -1);
         }
         fclose(file);
     }
@@ -152,23 +157,14 @@ static void set_buttons_text() {
     gtk_label_set_text(GTK_LABEL(label_m), datestr);
 }
 
-
 static void editor_flush() {
-    int cont = TRUE;
-
-    while (cont) {
-       cont = gtk_text_backward_delete(GTK_TEXT(edit), 1);
-    }
-    cont = TRUE;
-    while (cont) {
-       cont = gtk_text_forward_delete(GTK_TEXT(edit), 1);
-    }
+	gtk_text_buffer_set_text(GTK_TEXT_BUFFER(gtk_text_view_get_buffer(GTK_TEXT_VIEW(edit))), "", 0);
 }
 
-
 static void editor_fill(int which) {
     char *filename, *dstr;
-    GtkWidget *label;
+    GtkWidget *label = NULL;
+    GtkTextIter iter;
 
     switch (which) {
         case UNIQUE: label = label_u; break;
@@ -179,11 +175,10 @@ static void editor_fill(int which) {
     gtk_label_get(GTK_LABEL(label), &dstr);
     strcpy(daystr, dstr);
     to_button(which);
-    gtk_text_freeze(GTK_TEXT(edit));
     editor_flush();
     load_file(daystr);
-    gtk_text_set_point(GTK_TEXT(edit), gtk_text_get_length(GTK_TEXT(edit)));
-    gtk_text_thaw(GTK_TEXT(edit));
+    gtk_text_buffer_get_end_iter(GTK_TEXT_BUFFER(gtk_text_view_get_buffer(GTK_TEXT_VIEW(edit))), &iter);
+    gtk_text_buffer_place_cursor(GTK_TEXT_BUFFER(gtk_text_view_get_buffer(GTK_TEXT_VIEW(edit))), &iter);
 }
 
 
@@ -225,8 +220,15 @@ static void save_datas() {
     char *dirname  = xmalloc(len + 2);
     struct stat stat_buf;
 
+    GtkTextIter ts, te;
+    gchar *tbuf;
+    int tlen;
+
+    tlen = gtk_text_buffer_get_char_count(GTK_TEXT_BUFFER(gtk_text_view_get_buffer(GTK_TEXT_VIEW(edit))));
+    gtk_text_buffer_get_bounds(GTK_TEXT_BUFFER(gtk_text_view_get_buffer(GTK_TEXT_VIEW(edit))), &ts, &te);
+
     sprintf(dirname, "%s/%s", robust_home(), DEFAULT_CONFIGDIR);
-    if (gtk_text_get_length(GTK_TEXT(edit)) > 0) {
+    if (tlen > 0) {
         if (! ((stat(dirname, &stat_buf) == 0) && S_ISDIR(stat_buf.st_mode)))
             mkdir(dirname, 0755);
 
@@ -235,13 +237,11 @@ static void save_datas() {
             int   year, month, day;
 
             if (file) {
-                int i;
-                for (i = 0 ; i < gtk_text_get_length(GTK_TEXT(edit)) ; i++) {
-                    char t = GTK_TEXT_INDEX(GTK_TEXT(edit), i);
-                    fprintf(file, "%c", t);
-                }
-                fflush(file);
-                fclose(file);
+	      tbuf = gtk_text_buffer_get_text(GTK_TEXT_BUFFER(gtk_text_view_get_buffer(GTK_TEXT_VIEW(edit))), &ts, &te, TRUE);
+	      fprintf(file, "%s", tbuf);
+	      g_free(tbuf);
+	      fflush(file);
+	      fclose(file);
             }
             gtk_calendar_get_date(GTK_CALENDAR(calendar), &year, &month, &day);
             gtk_calendar_mark_day(GTK_CALENDAR(calendar), day);
@@ -259,9 +259,7 @@ static void delete_file() {
     gtk_calendar_get_date(GTK_CALENDAR(calendar), &year, &month, &day);
     gtk_calendar_unmark_day(GTK_CALENDAR(calendar), day);
     FREE(filename);
-    gtk_text_freeze(GTK_TEXT(edit));
     editor_flush();
-    gtk_text_thaw(GTK_TEXT(edit));
 }
 
 
@@ -357,10 +355,10 @@ void create_mainwindow() {
             GTK_SIGNAL_FUNC(mark_days), NULL);
     gtk_widget_show(calendar);
 
-    edit = gtk_text_new(NULL, NULL);
-    gtk_text_set_editable(GTK_TEXT(edit), TRUE);
-    gtk_text_set_word_wrap(GTK_TEXT(edit), TRUE);
-    gtk_text_set_line_wrap(GTK_TEXT(edit), TRUE);
+    edit = gtk_text_view_new();
+    gtk_text_view_set_editable(GTK_TEXT_VIEW(edit), TRUE);
+    gtk_text_view_set_wrap_mode(GTK_TEXT_VIEW(edit), GTK_WRAP_WORD_CHAR);
+
     gtk_box_pack_start(GTK_BOX(main_vbox), edit, TRUE, TRUE, 1);
 
 
@@ -413,7 +411,6 @@ void create_mainwindow() {
     gtk_box_pack_start(GTK_BOX(buttons_hbox), closewindow, TRUE, TRUE, 0);
     GTK_WIDGET_SET_FLAGS(GTK_WIDGET(closewindow), GTK_CAN_DEFAULT);
     gtk_widget_grab_default(GTK_WIDGET(closewindow));
-    gtk_widget_draw_default(GTK_WIDGET(closewindow));
     gtk_widget_show(closewindow);
 
 
