Blame SOURCES/kasumi-1928410-gtk3.patch

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