aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--widgets/e-table/ChangeLog5
-rw-r--r--widgets/e-table/e-table-selection-model.c9
-rw-r--r--widgets/table/e-table-selection-model.c9
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,5 +1,10 @@
2000-07-25 Christopher James Lahey <clahey@helixcode.com>
+ * e-table-selection-model.c: Made foreach call the callback in top
+ to bottom order.
+
+2000-07-25 Christopher James Lahey <clahey@helixcode.com>
+
* e-table-selection-model.c, e-table-selection-model.h: Replaced
get_selection_list with foreach.
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;
}
}
}