Add additional Fl_Browser_ fixes for STR #834.
git-svn-id: file:///fltk/svn/fltk/branches/branch-1.1@4484 ea41ed52-d2ee-0310-a9c1-e6b18d33e121
This commit is contained in:
parent
a78af9b2b8
commit
4264573f18
@ -599,6 +599,23 @@ int Fl_Browser_::handle(int event) {
|
|||||||
if (Fl_Group::handle(event)) return 1;
|
if (Fl_Group::handle(event)) return 1;
|
||||||
int X, Y, W, H; bbox(X, Y, W, H);
|
int X, Y, W, H; bbox(X, Y, W, H);
|
||||||
int my;
|
int my;
|
||||||
|
// NOTE:
|
||||||
|
// instead of:
|
||||||
|
// change = select_only(find_item(my), when() & FL_WHEN_CHANGED)
|
||||||
|
// we use the construct:
|
||||||
|
// change = select_only(find_item(my), 0);
|
||||||
|
// if (change && (when() & FL_WHEN_CHANGED)) {
|
||||||
|
// set_changed();
|
||||||
|
// do_callback();
|
||||||
|
// }
|
||||||
|
// See str #834
|
||||||
|
// The first form calls the callback *before* setting change.
|
||||||
|
// The callback may execute an Fl::wait(), resulting in another
|
||||||
|
// call of Fl_Browser_::handle() for the same widget. The sequence
|
||||||
|
// of events can be an FL_PUSH followed by an FL_RELEASE.
|
||||||
|
// This second call of Fl_Browser_::handle() may result in a -
|
||||||
|
// somewhat unexpected - second concurrent invocation of the callback.
|
||||||
|
|
||||||
static char change;
|
static char change;
|
||||||
static char whichway;
|
static char whichway;
|
||||||
static int py;
|
static int py;
|
||||||
@ -626,7 +643,11 @@ int Fl_Browser_::handle(int event) {
|
|||||||
TOGGLE:
|
TOGGLE:
|
||||||
if (l) {
|
if (l) {
|
||||||
whichway = !item_selected(l);
|
whichway = !item_selected(l);
|
||||||
change = select(l, whichway, when() & FL_WHEN_CHANGED);
|
change = select(l, whichway, 0);
|
||||||
|
if (change && (when() & FL_WHEN_CHANGED)) {
|
||||||
|
set_changed();
|
||||||
|
do_callback();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
} else if (Fl::event_state(FL_SHIFT)) { // extend selection:
|
} else if (Fl::event_state(FL_SHIFT)) { // extend selection:
|
||||||
if (l == selection_) goto TOGGLE;
|
if (l == selection_) goto TOGGLE;
|
||||||
@ -651,10 +672,14 @@ int Fl_Browser_::handle(int event) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
// do the clicked item last so the select box is around it:
|
// do the clicked item last so the select box is around it:
|
||||||
if (l) select(l, whichway, when() & FL_WHEN_CHANGED);
|
|
||||||
change = 1;
|
change = 1;
|
||||||
|
if (l) select(l, whichway, when() & FL_WHEN_CHANGED);
|
||||||
} else { // select only this item
|
} else { // select only this item
|
||||||
change = select_only(l, when() & FL_WHEN_CHANGED);
|
change = select_only(l, 0);
|
||||||
|
if (change && (when() & FL_WHEN_CHANGED)) {
|
||||||
|
set_changed();
|
||||||
|
do_callback();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return 1;
|
return 1;
|
||||||
@ -683,16 +708,23 @@ int Fl_Browser_::handle(int event) {
|
|||||||
t = l;
|
t = l;
|
||||||
b = selection_;
|
b = selection_;
|
||||||
}
|
}
|
||||||
for (; t && t != b; t = item_next(t))
|
for (; t && t != b; t = item_next(t)) {
|
||||||
change |= select(t, whichway, when() & FL_WHEN_CHANGED);
|
char change_t;
|
||||||
|
change_t = select(t, whichway, 0);
|
||||||
|
change |= change_t;
|
||||||
|
if (change_t && (when() & FL_WHEN_CHANGED)) {
|
||||||
|
set_changed();
|
||||||
|
do_callback();
|
||||||
|
}
|
||||||
|
}
|
||||||
if (l) selection_ = l;
|
if (l) selection_ = l;
|
||||||
} else {
|
} else {
|
||||||
void* l1 = selection_;
|
void* l1 = selection_;
|
||||||
void* l =
|
void* l =
|
||||||
(Fl::event_x()<x() || Fl::event_x()>x()+w()) ? selection_ :
|
(Fl::event_x()<x() || Fl::event_x()>x()+w()) ? selection_ :
|
||||||
find_item(my);
|
find_item(my);
|
||||||
select_only(l, when() & FL_WHEN_CHANGED);
|
|
||||||
change = (l != l1);
|
change = (l != l1);
|
||||||
|
select_only(l, when() & FL_WHEN_CHANGED);
|
||||||
}
|
}
|
||||||
py = my;
|
py = my;
|
||||||
return 1;
|
return 1;
|
||||||
|
Loading…
Reference in New Issue
Block a user