[gtk+] Fixed GtkCellArea to never activate/start editing insensitive cells.



commit 34a7dbae3b5092215afd217b66b9b038240196ab
Author: Tristan Van Berkom <tristan van berkom gmail com>
Date:   Mon Jan 10 17:56:51 2011 +0900

    Fixed GtkCellArea to never activate/start editing insensitive cells.
    
    Included extension to tests/testtreeedit to show this is working properly.

 gtk/gtkcellarea.c    |    3 ++
 tests/testtreeedit.c |   64 +++++++++++++++++++++++++++++++++++++++++--------
 2 files changed, 56 insertions(+), 11 deletions(-)
---
diff --git a/gtk/gtkcellarea.c b/gtk/gtkcellarea.c
index e859c8d..0a94ca5 100644
--- a/gtk/gtkcellarea.c
+++ b/gtk/gtkcellarea.c
@@ -3395,6 +3395,9 @@ gtk_cell_area_activate_cell (GtkCellArea          *area,
 
   priv = area->priv;
 
+  if (!gtk_cell_renderer_get_sensitive (renderer))
+    return FALSE;
+
   g_object_get (renderer, "mode", &mode, NULL);
 
   if (mode == GTK_CELL_RENDERER_MODE_ACTIVATABLE)
diff --git a/tests/testtreeedit.c b/tests/testtreeedit.c
index 712dad4..8e0cc32 100644
--- a/tests/testtreeedit.c
+++ b/tests/testtreeedit.c
@@ -24,12 +24,14 @@
 typedef struct {
   const gchar *string;
   gboolean is_editable;
+  gboolean is_sensitive;
   gint progress;
 } ListEntry;
 
 enum {
   STRING_COLUMN,
   IS_EDITABLE_COLUMN,
+  IS_SENSITIVE_COLUMN,
   PIXBUF_COLUMN,
   LAST_PIXBUF_COLUMN,
   PROGRESS_COLUMN,
@@ -38,11 +40,11 @@ enum {
 
 static ListEntry model_strings[] =
 {
-  {"A simple string", TRUE, 0 },
-  {"Another string!", TRUE, 10 },
-  {"Guess what, a third string. This one can't be edited", FALSE, 47 },
-  {"And then a fourth string. Neither can this", FALSE, 48 },
-  {"Multiline\nFun!", TRUE, 75 },
+  {"A simple string", TRUE, TRUE, 0 },
+  {"Another string!", TRUE, TRUE, 10 },
+  {"Guess what, a third string. This one can't be edited", FALSE, TRUE, 47 },
+  {"And then a fourth string. Neither can this", FALSE, TRUE, 48 },
+  {"Multiline\nFun!", TRUE, FALSE, 75 },
   { NULL }
 };
 
@@ -63,6 +65,7 @@ create_model (void)
   model = gtk_tree_store_new (NUM_COLUMNS,
 			      G_TYPE_STRING,
 			      G_TYPE_BOOLEAN,
+			      G_TYPE_BOOLEAN,
 			      GDK_TYPE_PIXBUF,
 			      GDK_TYPE_PIXBUF,
 			      G_TYPE_INT);
@@ -74,6 +77,7 @@ create_model (void)
       gtk_tree_store_set (model, &iter,
 			  STRING_COLUMN, model_strings[i].string,
 			  IS_EDITABLE_COLUMN, model_strings[i].is_editable,
+			  IS_SENSITIVE_COLUMN, model_strings[i].is_sensitive,
 			  PIXBUF_COLUMN, foo,
 			  LAST_PIXBUF_COLUMN, bar,
 			  PROGRESS_COLUMN, model_strings[i].progress,
@@ -84,9 +88,9 @@ create_model (void)
 }
 
 static void
-toggled (GtkCellRendererToggle *cell,
-	 gchar                 *path_string,
-	 gpointer               data)
+editable_toggled (GtkCellRendererToggle *cell,
+		  gchar                 *path_string,
+		  gpointer               data)
 {
   GtkTreeModel *model = GTK_TREE_MODEL (data);
   GtkTreeIter iter;
@@ -103,6 +107,25 @@ toggled (GtkCellRendererToggle *cell,
 }
 
 static void
+sensitive_toggled (GtkCellRendererToggle *cell,
+		   gchar                 *path_string,
+		   gpointer               data)
+{
+  GtkTreeModel *model = GTK_TREE_MODEL (data);
+  GtkTreeIter iter;
+  GtkTreePath *path = gtk_tree_path_new_from_string (path_string);
+  gboolean value;
+
+  gtk_tree_model_get_iter (model, &iter, path);
+  gtk_tree_model_get (model, &iter, IS_SENSITIVE_COLUMN, &value, -1);
+
+  value = !value;
+  gtk_tree_store_set (GTK_TREE_STORE (model), &iter, IS_SENSITIVE_COLUMN, value, -1);
+
+  gtk_tree_path_free (path);
+}
+
+static void
 edited (GtkCellRendererText *cell,
 	gchar               *path_string,
 	gchar               *new_text,
@@ -247,7 +270,9 @@ main (gint argc, gchar **argv)
   renderer = gtk_cell_renderer_pixbuf_new ();
   gtk_tree_view_column_pack_start (column, renderer, FALSE);
   gtk_tree_view_column_set_attributes (column, renderer,
-				       "pixbuf", PIXBUF_COLUMN, NULL);
+				       "pixbuf", PIXBUF_COLUMN, 
+				       "sensitive", IS_SENSITIVE_COLUMN,
+				       NULL);
   callback[0].area = area;
   callback[0].renderer = renderer;
 
@@ -256,6 +281,7 @@ main (gint argc, gchar **argv)
   gtk_tree_view_column_set_attributes (column, renderer,
 				       "text", STRING_COLUMN,
 				       "editable", IS_EDITABLE_COLUMN,
+				       "sensitive", IS_SENSITIVE_COLUMN,
 				       NULL);
   callback[1].area = area;
   callback[1].renderer = renderer;
@@ -267,6 +293,7 @@ main (gint argc, gchar **argv)
   gtk_tree_view_column_set_attributes (column, renderer,
 		  		       "text", STRING_COLUMN,
 				       "editable", IS_EDITABLE_COLUMN,
+				       "sensitive", IS_SENSITIVE_COLUMN,
 				       NULL);
   callback[2].area = area;
   callback[2].renderer = renderer;
@@ -279,7 +306,9 @@ main (gint argc, gchar **argv)
 		NULL);
   gtk_tree_view_column_pack_start (column, renderer, FALSE);
   gtk_tree_view_column_set_attributes (column, renderer,
-				       "pixbuf", LAST_PIXBUF_COLUMN, NULL);
+				       "pixbuf", LAST_PIXBUF_COLUMN, 
+				       "sensitive", IS_SENSITIVE_COLUMN,
+				       NULL);
   callback[3].area = area;
   callback[3].renderer = renderer;
 
@@ -287,7 +316,7 @@ main (gint argc, gchar **argv)
 
   renderer = gtk_cell_renderer_toggle_new ();
   g_signal_connect (renderer, "toggled",
-		    G_CALLBACK (toggled), tree_model);
+		    G_CALLBACK (editable_toggled), tree_model);
   
   g_object_set (renderer,
 		"xalign", 0.0,
@@ -298,6 +327,19 @@ main (gint argc, gchar **argv)
 					       "active", IS_EDITABLE_COLUMN,
 					       NULL);
 
+  renderer = gtk_cell_renderer_toggle_new ();
+  g_signal_connect (renderer, "toggled",
+		    G_CALLBACK (sensitive_toggled), tree_model);
+  
+  g_object_set (renderer,
+		"xalign", 0.0,
+		NULL);
+  gtk_tree_view_insert_column_with_attributes (GTK_TREE_VIEW (tree_view),
+					       -1, "Sensitive",
+					       renderer,
+					       "active", IS_SENSITIVE_COLUMN,
+					       NULL);
+
   renderer = gtk_cell_renderer_progress_new ();
   gtk_tree_view_insert_column_with_attributes (GTK_TREE_VIEW (tree_view),
 					       -1, "Progress",



[Date Prev][Date Next]   [Thread Prev][Thread Next]   [Thread Index] [Date Index] [Author Index]