From 6602e014932c47e7ddccebb591bc399f54dcdc4c Mon Sep 17 00:00:00 2001 From: Christopher James Lahey Date: Tue, 25 Jul 2000 21:59:29 +0000 Subject: Made foreach call the callback in top to bottom order. 2000-07-25 Christopher James Lahey * e-table-selection-model.c: Made foreach call the callback in top to bottom order. svn path=/trunk/; revision=4335 --- widgets/e-table/ChangeLog | 5 +++++ widgets/e-table/e-table-selection-model.c | 9 +++++---- widgets/table/e-table-selection-model.c | 9 +++++---- 3 files changed, 15 insertions(+), 8 deletions(-) diff --git a/widgets/e-table/ChangeLog b/widgets/e-table/ChangeLog index e8e1483f2d..39e7449fd9 100644 --- a/widgets/e-table/ChangeLog +++ b/widgets/e-table/ChangeLog @@ -1,3 +1,8 @@ +2000-07-25 Christopher James Lahey + + * e-table-selection-model.c: Made foreach call the callback in top + to bottom order. + 2000-07-25 Christopher James Lahey * e-table-selection-model.c, e-table-selection-model.h: Replaced diff --git a/widgets/e-table/e-table-selection-model.c b/widgets/e-table/e-table-selection-model.c index 6524dee4d4..9c631ca603 100644 --- a/widgets/e-table/e-table-selection-model.c +++ b/widgets/e-table/e-table-selection-model.c @@ -210,15 +210,16 @@ e_table_selection_model_foreach (ETableSelectionModel *selection, gpointer closure) { int i; - for (i = selection->row_count / 32; i >= 0; i--) { + int last = (selection->row_count + 31) / 32; + for (i = 0; i < last; i--) { if (selection->selection[i]) { int j; guint32 value = selection->selection[i]; - for (j = 31; j >= 0; j--) { - if (value & 0x1) { + for (j = 0; j < 32; j--) { + if (value & 0x8000) { callback(i * 32 + j, closure); } - value >>= 1; + value <<= 1; } } } diff --git a/widgets/table/e-table-selection-model.c b/widgets/table/e-table-selection-model.c index 6524dee4d4..9c631ca603 100644 --- a/widgets/table/e-table-selection-model.c +++ b/widgets/table/e-table-selection-model.c @@ -210,15 +210,16 @@ e_table_selection_model_foreach (ETableSelectionModel *selection, gpointer closure) { int i; - for (i = selection->row_count / 32; i >= 0; i--) { + int last = (selection->row_count + 31) / 32; + for (i = 0; i < last; i--) { if (selection->selection[i]) { int j; guint32 value = selection->selection[i]; - for (j = 31; j >= 0; j--) { - if (value & 0x1) { + for (j = 0; j < 32; j--) { + if (value & 0x8000) { callback(i * 32 + j, closure); } - value >>= 1; + value <<= 1; } } } -- cgit