Blame SOURCES/kasumi-1928410-gtk3.patch

472413
From 9de5eb6d221bf3438c75a756c9acffa01e2c51fb Mon Sep 17 00:00:00 2001
472413
From: fujiwarat <takao.fujiwara1@gmail.com>
472413
Date: Tue, 16 Feb 2021 07:45:51 +0900
472413
Subject: [PATCH] Migrate kasumi GUI to GTK3
472413
472413
---
472413
 KasumiAddWindow.cxx  | 41 ++++++++++------------
472413
 KasumiAddWindow.hxx  |  1 -
472413
 KasumiMainWindow.cxx | 82 ++++++++++++++++++++++----------------------
472413
 cellrendererspin.c   | 16 +++++----
472413
 cellrendererspin.h   |  2 +-
472413
 main.cxx             | 15 ++++----
472413
 6 files changed, 79 insertions(+), 78 deletions(-)
472413
472413
diff --git a/KasumiAddWindow.cxx b/KasumiAddWindow.cxx
472413
index 9b42c12..49c6a05 100644
472413
--- a/KasumiAddWindow.cxx
472413
+++ b/KasumiAddWindow.cxx
472413
@@ -59,9 +59,6 @@ KasumiAddWindow::KasumiAddWindow(KasumiDic *aDictionary,
472413
     g_signal_connect(G_OBJECT(window), "delete_event",
472413
 		     G_CALLBACK(_call_back_add_window_delete_event), this);
472413
 
472413
-    // tooltips for every widget
472413
-    Tooltips = gtk_tooltips_new();
472413
-
472413
     // creating vbox for text entries, spin button and so on.
472413
     GtkWidget *vbox = gtk_vbox_new(FALSE,0);
472413
     gtk_container_set_border_width(GTK_CONTAINER(vbox), 6);
472413
@@ -111,12 +108,12 @@ KasumiAddWindow::KasumiAddWindow(KasumiDic *aDictionary,
472413
     const int FREQ_DEFAULT = conf->getPropertyValueByInt("DefaultFrequency");
472413
     const int FREQ_LBOUND = conf->getPropertyValueByInt("MinFrequency");  
472413
     const int FREQ_UBOUND = conf->getPropertyValueByInt("MaxFrequency");
472413
-    GtkObject *adjustment = gtk_adjustment_new(FREQ_DEFAULT,
472413
-					       FREQ_LBOUND,
472413
-					       FREQ_UBOUND,
472413
-					       1,
472413
-					       FREQ_UBOUND / 100
472413
-					       ,0);
472413
+    GtkAdjustment *adjustment = GTK_ADJUSTMENT (gtk_adjustment_new(FREQ_DEFAULT,
472413
+						FREQ_LBOUND,
472413
+						FREQ_UBOUND,
472413
+						1,
472413
+						FREQ_UBOUND / 100
472413
+						,0));
472413
     FrequencySpin = gtk_spin_button_new(GTK_ADJUSTMENT(adjustment),1.0,0);
472413
     alignment = gtk_alignment_new(0, 0.5, 1.0, 1.0);
472413
     gtk_alignment_set_padding(GTK_ALIGNMENT(alignment), 0, 6, 6, 6);
472413
@@ -205,16 +202,14 @@ KasumiAddWindow::KasumiAddWindow(KasumiDic *aDictionary,
472413
 	gtk_box_pack_start(GTK_BOX(hbutton_box),GTK_WIDGET(button),TRUE,TRUE,0);
472413
 	g_signal_connect(G_OBJECT(button),"clicked",
472413
 			 G_CALLBACK(_call_back_add_window_add),this);
472413
-	gtk_tooltips_set_tip(Tooltips, button,
472413
-			     _("Add entered word and quit registration."),
472413
+	gtk_widget_set_tooltip_text(button,
472413
 			     _("If all the necessary items are filled in, add entered word and quit registration."));
472413
 
472413
 	button = gtk_button_new_from_stock(GTK_STOCK_CLOSE);
472413
 	gtk_box_pack_start(GTK_BOX(hbutton_box),GTK_WIDGET(button),TRUE,TRUE,0);
472413
 	g_signal_connect(G_OBJECT(button),"clicked",
472413
 			 G_CALLBACK(_call_back_add_window_quit),this);
472413
-	gtk_tooltips_set_tip(Tooltips, button,
472413
-			     _("Cancel registration and quit."),
472413
+	gtk_widget_set_tooltip_text(button,
472413
 			     _("Cancel registration and quit."));
472413
 
472413
 	gtk_window_set_keep_above(GTK_WINDOW(window), TRUE);
472413
@@ -227,24 +222,21 @@ KasumiAddWindow::KasumiAddWindow(KasumiDic *aDictionary,
472413
 	gtk_box_pack_start(GTK_BOX(hbutton_box),GTK_WIDGET(button),TRUE,TRUE,0);
472413
 	g_signal_connect(G_OBJECT(button),"clicked",
472413
 			 G_CALLBACK(_call_back_add_window_add),this);
472413
-	gtk_tooltips_set_tip(Tooltips, button,
472413
-			     _("Add entered word"),
472413
+	gtk_widget_set_tooltip_text(button,
472413
 			     _("If all the necessary items are filled in, add entered word."));
472413
 
472413
 	button = gtk_button_new_from_stock(GTK_STOCK_EDIT);
472413
 	gtk_box_pack_start(GTK_BOX(hbutton_box),GTK_WIDGET(button),TRUE,TRUE,0);
472413
 	g_signal_connect(G_OBJECT(button),"clicked",
472413
 			 G_CALLBACK(_call_back_manage_mode),this);
472413
-	gtk_tooltips_set_tip(Tooltips, button,
472413
-			     _("Manage mode"),
472413
+	gtk_widget_set_tooltip_text(button,
472413
 			     _("Make the shift to manage mode to modify and remove registered words."));
472413
 
472413
 	button = gtk_button_new_from_stock(GTK_STOCK_CLOSE);
472413
 	gtk_box_pack_start(GTK_BOX(hbutton_box),GTK_WIDGET(button),TRUE,TRUE,0);
472413
 	g_signal_connect(G_OBJECT(button),"clicked",
472413
 			 G_CALLBACK(_call_back_add_window_quit),this);
472413
-	gtk_tooltips_set_tip(Tooltips, button,
472413
-			     _("Quit this application"),
472413
+	gtk_widget_set_tooltip_text(button,
472413
 			     _("Save dictionary and quit this application."));
472413
 
472413
 	// get selection at the time of launching
472413
@@ -443,16 +435,19 @@ void _call_back_manage_mode(GtkWidget *widget,
472413
 void _call_back_selection_data_received(GtkWidget *widget,
472413
                                         GtkSelectionData *selection_data,
472413
                                         gpointer data){
472413
-    if(selection_data->length < 0){
472413
+    int emit_length = gtk_selection_data_get_length(selection_data);
472413
+    GdkAtom emit_type = gtk_selection_data_get_data_type(selection_data);
472413
+    const guchar *emit_data = gtk_selection_data_get_data(selection_data);
472413
+    if(emit_length < 0){
472413
 	// failed retrieving selection
472413
 	// do nothing
472413
 	return;
472413
     }
472413
 
472413
-    string atom_name = string(gdk_atom_name(selection_data->type));
472413
+    string atom_name = string(gdk_atom_name(emit_type));
472413
 
472413
-    gchar *str;
472413
-    str = reinterpret_cast<gchar*>(selection_data->data);
472413
+    const gchar *str;
472413
+    str = reinterpret_cast<const gchar*>(emit_data);
472413
 
472413
     if(atom_name == "UTF8_STRING"){
472413
 	gtk_entry_set_text(GTK_ENTRY(widget), str);
472413
diff --git a/KasumiAddWindow.hxx b/KasumiAddWindow.hxx
472413
index 5101314..352326a 100644
472413
--- a/KasumiAddWindow.hxx
472413
+++ b/KasumiAddWindow.hxx
472413
@@ -77,7 +77,6 @@ private:
472413
     GtkWidget *FrequencySpin;
472413
     GtkWidget *WordTypeCategoryCombo;
472413
     GtkWidget *WordTypeCombo;
472413
-    GtkTooltips *Tooltips;
472413
 
472413
     GtkTreeIter defaultWordTypeCategoryIter;
472413
   
472413
diff --git a/KasumiMainWindow.cxx b/KasumiMainWindow.cxx
472413
index 4e86c7a..e8a8d56 100644
472413
--- a/KasumiMainWindow.cxx
472413
+++ b/KasumiMainWindow.cxx
472413
@@ -150,22 +150,22 @@ void KasumiMainWindow::createWindow()
472413
   mSaveButton = gtk_button_new_from_stock ("gtk-save");
472413
   gtk_widget_show (mSaveButton);
472413
   gtk_box_pack_start (GTK_BOX (hbuttonbox1), mSaveButton, FALSE, TRUE, 0);
472413
-  GTK_WIDGET_SET_FLAGS (mSaveButton, GTK_CAN_DEFAULT);
472413
+  gtk_widget_set_can_default (mSaveButton, TRUE);
472413
 
472413
   mAddButton = gtk_button_new_from_stock ("gtk-add");
472413
   gtk_widget_show (mAddButton);
472413
   gtk_box_pack_start (GTK_BOX (hbuttonbox1), mAddButton, FALSE, TRUE, 0);
472413
-  GTK_WIDGET_SET_FLAGS (mAddButton, GTK_CAN_DEFAULT);
472413
+  gtk_widget_set_can_default (mAddButton, TRUE);
472413
 
472413
   mRemoveButton = gtk_button_new_from_stock ("gtk-delete");
472413
   gtk_widget_show (mRemoveButton);
472413
   gtk_box_pack_start (GTK_BOX (hbuttonbox1), mRemoveButton, FALSE, TRUE, 0);
472413
-  GTK_WIDGET_SET_FLAGS (mRemoveButton, GTK_CAN_DEFAULT);
472413
+  gtk_widget_set_can_default (mRemoveButton, TRUE);
472413
 
472413
   mQuitButton = gtk_button_new_from_stock ("gtk-close");
472413
   gtk_widget_show (mQuitButton);
472413
   gtk_box_pack_end (GTK_BOX (hbuttonbox1), mQuitButton, FALSE, TRUE, 0);
472413
-  GTK_WIDGET_SET_FLAGS (mQuitButton, GTK_CAN_DEFAULT);
472413
+  gtk_widget_set_can_default (mQuitButton, TRUE);
472413
 }
472413
 
472413
 void KasumiMainWindow::createWordList()
472413
@@ -474,7 +474,7 @@ void KasumiMainWindow::editedTextColumn(GtkCellRendererText *renderer,
472413
 
472413
 	// set cursor right or left
472413
 	GtkTreeViewColumn *postCol = NULL;
472413
-	if(lastKeyVal == GDK_Tab)
472413
+	if(lastKeyVal == GDK_KEY_Tab)
472413
 	{
472413
 	    if(lastKeyState & GDK_CONTROL_MASK)
472413
 	    { // set cursor left
472413
@@ -887,42 +887,42 @@ guint getAccelKey(const string &key){
472413
 
472413
   string shortkey = key.substr(i+1);
472413
 
472413
-  if(shortkey == "A") return GDK_A;
472413
-  else if(shortkey == "B") return GDK_B;
472413
-  else if(shortkey == "C") return GDK_C;
472413
-  else if(shortkey == "D") return GDK_D;
472413
-  else if(shortkey == "E") return GDK_E;
472413
-  else if(shortkey == "F") return GDK_F;
472413
-  else if(shortkey == "G") return GDK_G;
472413
-  else if(shortkey == "H") return GDK_H;
472413
-  else if(shortkey == "I") return GDK_I;
472413
-  else if(shortkey == "J") return GDK_J;
472413
-  else if(shortkey == "K") return GDK_K;
472413
-  else if(shortkey == "L") return GDK_L;
472413
-  else if(shortkey == "M") return GDK_M;
472413
-  else if(shortkey == "N") return GDK_N;
472413
-  else if(shortkey == "O") return GDK_O;
472413
-  else if(shortkey == "P") return GDK_P;
472413
-  else if(shortkey == "Q") return GDK_Q;
472413
-  else if(shortkey == "R") return GDK_R;
472413
-  else if(shortkey == "S") return GDK_S;
472413
-  else if(shortkey == "T") return GDK_T;
472413
-  else if(shortkey == "U") return GDK_U;
472413
-  else if(shortkey == "V") return GDK_V;
472413
-  else if(shortkey == "W") return GDK_W;
472413
-  else if(shortkey == "X") return GDK_X;
472413
-  else if(shortkey == "Y") return GDK_Y;
472413
-  else if(shortkey == "Z") return GDK_Z;
472413
-  else if(shortkey == "0") return GDK_0;
472413
-  else if(shortkey == "1") return GDK_1;
472413
-  else if(shortkey == "2") return GDK_2;
472413
-  else if(shortkey == "3") return GDK_3;
472413
-  else if(shortkey == "4") return GDK_4;
472413
-  else if(shortkey == "5") return GDK_5;
472413
-  else if(shortkey == "6") return GDK_5;
472413
-  else if(shortkey == "7") return GDK_7;
472413
-  else if(shortkey == "8") return GDK_8;
472413
-  else if(shortkey == "9") return GDK_9;
472413
+  if(shortkey == "A") return GDK_KEY_A;
472413
+  else if(shortkey == "B") return GDK_KEY_B;
472413
+  else if(shortkey == "C") return GDK_KEY_C;
472413
+  else if(shortkey == "D") return GDK_KEY_D;
472413
+  else if(shortkey == "E") return GDK_KEY_E;
472413
+  else if(shortkey == "F") return GDK_KEY_F;
472413
+  else if(shortkey == "G") return GDK_KEY_G;
472413
+  else if(shortkey == "H") return GDK_KEY_H;
472413
+  else if(shortkey == "I") return GDK_KEY_I;
472413
+  else if(shortkey == "J") return GDK_KEY_J;
472413
+  else if(shortkey == "K") return GDK_KEY_K;
472413
+  else if(shortkey == "L") return GDK_KEY_L;
472413
+  else if(shortkey == "M") return GDK_KEY_M;
472413
+  else if(shortkey == "N") return GDK_KEY_N;
472413
+  else if(shortkey == "O") return GDK_KEY_O;
472413
+  else if(shortkey == "P") return GDK_KEY_P;
472413
+  else if(shortkey == "Q") return GDK_KEY_Q;
472413
+  else if(shortkey == "R") return GDK_KEY_R;
472413
+  else if(shortkey == "S") return GDK_KEY_S;
472413
+  else if(shortkey == "T") return GDK_KEY_T;
472413
+  else if(shortkey == "U") return GDK_KEY_U;
472413
+  else if(shortkey == "V") return GDK_KEY_V;
472413
+  else if(shortkey == "W") return GDK_KEY_W;
472413
+  else if(shortkey == "X") return GDK_KEY_X;
472413
+  else if(shortkey == "Y") return GDK_KEY_Y;
472413
+  else if(shortkey == "Z") return GDK_KEY_Z;
472413
+  else if(shortkey == "0") return GDK_KEY_0;
472413
+  else if(shortkey == "1") return GDK_KEY_1;
472413
+  else if(shortkey == "2") return GDK_KEY_2;
472413
+  else if(shortkey == "3") return GDK_KEY_3;
472413
+  else if(shortkey == "4") return GDK_KEY_4;
472413
+  else if(shortkey == "5") return GDK_KEY_5;
472413
+  else if(shortkey == "6") return GDK_KEY_5;
472413
+  else if(shortkey == "7") return GDK_KEY_7;
472413
+  else if(shortkey == "8") return GDK_KEY_8;
472413
+  else if(shortkey == "9") return GDK_KEY_9;
472413
   
472413
   cerr << "Invalid shortcut key option: " << key << endl;
472413
   exit(1);
472413
diff --git a/cellrendererspin.c b/cellrendererspin.c
472413
index 885d462..85d3bda 100644
472413
--- a/cellrendererspin.c
472413
+++ b/cellrendererspin.c
472413
@@ -52,8 +52,6 @@
472413
  */
472413
 
472413
 #include "cellrendererspin.h"
472413
-#include <gtk/gtkadjustment.h>
472413
-#include <gtk/gtkspinbutton.h>
472413
 #include <stdlib.h>
472413
 
472413
 #define GUI_CELL_RENDERER_SPIN_PATH     "gui-cell-renderer-spin-path"
472413
@@ -239,6 +237,7 @@ gui_cell_renderer_spin_editing_done (GtkCellEditable *spinbutton,
472413
   const gchar         *path;
472413
   const gchar         *new_text;
472413
   GCRSpinInfo         *info;
472413
+  gboolean canceled = FALSE;
472413
 
472413
   info = g_object_get_data (G_OBJECT (data), GUI_CELL_RENDERER_SPIN_INFO);
472413
 
472413
@@ -248,7 +247,8 @@ gui_cell_renderer_spin_editing_done (GtkCellEditable *spinbutton,
472413
                 info->focus_out_id = 0;
472413
         }
472413
 
472413
-  if (GTK_ENTRY(spinbutton)->editing_canceled)
472413
+  g_object_get (spinbutton, "editing-canceled", &canceled, NULL);
472413
+  if (canceled)
472413
     return;
472413
 
472413
   path = g_object_get_data (G_OBJECT (spinbutton), GUI_CELL_RENDERER_SPIN_PATH);
472413
@@ -317,19 +317,23 @@ gui_cell_renderer_spin_start_editing (GtkCellRenderer      *cell,
472413
   GtkWidget           *spinbutton;
472413
         GCRSpinInfo         *info;
472413
         gdouble              curval = 0.0;
472413
+  gboolean editable = FALSE;
472413
+  gchar* str = NULL;
472413
 
472413
   celltext = GTK_CELL_RENDERER_TEXT(cell);
472413
         spincell = GUI_CELL_RENDERER_SPIN(cell);
472413
 
472413
   /* If the cell isn't editable we return NULL. */
472413
-  if (celltext->editable == FALSE)
472413
+  editable = GPOINTER_TO_INT(g_object_get_data (G_OBJECT (celltext), "editable"));
472413
+  if (editable == FALSE)
472413
     return NULL;
472413
 
472413
   spinbutton = g_object_new (GTK_TYPE_SPIN_BUTTON, "has_frame", FALSE, "numeric", TRUE, NULL);
472413
 
472413
         /* dirty */
472413
-  if (celltext->text)
472413
-                curval = atof(celltext->text);
472413
+  str = (gchar *)g_object_get_data (G_OBJECT (celltext), "text");
472413
+  if (str)
472413
+                curval = atof(str);
472413
 
472413
         adj = GTK_ADJUSTMENT(gtk_adjustment_new(curval,
472413
                                                 spincell->lower,
472413
diff --git a/cellrendererspin.h b/cellrendererspin.h
472413
index c6b33d2..36a2740 100644
472413
--- a/cellrendererspin.h
472413
+++ b/cellrendererspin.h
472413
@@ -27,7 +27,7 @@
472413
 #ifndef _cellrendererspin_h_included_
472413
 #define _cellrendererspin_h_included_
472413
 
472413
-#include <gtk/gtkcellrenderertext.h>
472413
+#include <gtk/gtk.h>
472413
 
472413
 G_BEGIN_DECLS
472413
 
472413
diff --git a/main.cxx b/main.cxx
472413
index c5c459e..8ed5edf 100644
472413
--- a/main.cxx
472413
+++ b/main.cxx
472413
@@ -101,14 +101,15 @@ static void cb_selection_get(GtkWidget *widget,
472413
 {
472413
   gchar *text = NULL;
472413
   gint length = 0;
472413
+  GdkAtom emit_selection = gtk_selection_data_get_selection(data);
472413
 
472413
-  if (data->selection == atom0) {
472413
+  if (emit_selection == atom0) {
472413
     text = "Kasumi Selection";
472413
     length = strlen(text);
472413
     gtk_selection_convert(window, atom1,
472413
 			  GDK_SELECTION_TYPE_STRING,
472413
 			  GDK_CURRENT_TIME);
472413
-  } else if (data->selection == atom1 && arg_text != NULL) {
472413
+  } else if (emit_selection == atom1 && arg_text != NULL) {
472413
     text = arg_text;
472413
     arg_text = NULL;
472413
     length = strlen(text);
472413
@@ -116,7 +117,7 @@ static void cb_selection_get(GtkWidget *widget,
472413
 
472413
   if (text != NULL) {
472413
     gtk_selection_data_set_text(data, text, length);
472413
-    if (data->selection == atom1)
472413
+    if (emit_selection == atom1)
472413
       g_free(text);
472413
   }
472413
 }
472413
@@ -126,9 +127,11 @@ static void cb_selection_received(GtkWidget *widget,
472413
 				  guint time,
472413
 				  gpointer user_data)
472413
 {
472413
-  if (data->selection == atom0) {
472413
-    instance = MAX(data->length, 0);
472413
-  } else if (data->selection == atom1 && data->length > 0) {
472413
+  GdkAtom emit_selection = gtk_selection_data_get_selection(data);
472413
+  int emit_length = gtk_selection_data_get_length(data);
472413
+  if (emit_selection == atom0) {
472413
+    instance = MAX(emit_length, 0);
472413
+  } else if (emit_selection == atom1 && emit_length > 0) {
472413
   }
472413
 }
472413
 
472413
-- 
472413
2.28.0
472413