aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--widgets/table/e-table-item.c36
1 files changed, 8 insertions, 28 deletions
diff --git a/widgets/table/e-table-item.c b/widgets/table/e-table-item.c
index 828aaf357a..f3f776c2d6 100644
--- a/widgets/table/e-table-item.c
+++ b/widgets/table/e-table-item.c
@@ -666,7 +666,7 @@ eti_request_region_redraw (ETableItem *eti,
static void
eti_request_region_show (ETableItem *eti,
int start_col, int start_row,
- int end_col, int end_row)
+ int end_col, int end_row, int delay)
{
int x1, y1, x2, y2;
@@ -675,7 +675,10 @@ eti_request_region_show (ETableItem *eti,
x2 = x1 + e_table_header_col_diff (eti->header, start_col, end_col + 1);
y2 = y1 + eti_row_diff (eti, start_row, end_row + 1);
- e_canvas_item_show_area(GNOME_CANVAS_ITEM(eti), x1, y1, x2, y2);
+ if (delay)
+ e_canvas_item_show_area_delayed(GNOME_CANVAS_ITEM(eti), x1, y1, x2, y2, delay);
+ else
+ e_canvas_item_show_area(GNOME_CANVAS_ITEM(eti), x1, y1, x2, y2);
}
static void
@@ -927,7 +930,7 @@ eti_destroy (GtkObject *object)
if (eti->height_cache_idle_id)
g_source_remove(eti->height_cache_idle_id);
- g_free (eti->height_cache);
+ free_height_cache(eti);
if (eti->tooltip->window)
gtk_widget_destroy (eti->tooltip->window);
@@ -2203,29 +2206,11 @@ e_table_item_get_focused_column (ETableItem *eti)
return cursor_col;
}
-typedef struct {
- gint view_row;
- gint view_col;
- ETableItem *eti;
-} IntsAndEti;
-
-static gboolean
-region_timeout (gpointer data)
-{
- IntsAndEti *iae = data;
-
- eti_request_region_show (iae->eti, iae->view_col, iae->view_row, iae->view_col, iae->view_row);
- gtk_object_unref(GTK_OBJECT(iae->eti));
- g_free(iae);
- return FALSE;
-}
-
static void
eti_cursor_change (ETableSelectionModel *selection, int row, int col, ETableItem *eti)
{
int view_row = model_to_view_row(eti, row);
int view_col = model_to_view_col(eti, col);
- IntsAndEti *iae;
if (view_row == -1 || view_col == -1) {
e_table_item_leave_edit (eti);
@@ -2233,14 +2218,9 @@ eti_cursor_change (ETableSelectionModel *selection, int row, int col, ETableItem
}
if (!eti->in_key_press) {
- iae = g_new(IntsAndEti, 1);
- iae->view_row = view_row;
- iae->view_col = view_col;
- iae->eti = eti;
- gtk_object_ref(GTK_OBJECT(eti));
- g_timeout_add(DOUBLE_CLICK_TIME + 10, region_timeout, iae);
+ eti_request_region_show (eti, view_col, view_row, view_col, view_row, DOUBLE_CLICK_TIME + 10);
} else {
- eti_request_region_show (eti, view_col, view_row, view_col, view_row);
+ eti_request_region_show (eti, view_col, view_row, view_col, view_row, 0);
}
e_canvas_item_grab_focus(GNOME_CANVAS_ITEM(eti));