Corrected BView::GetMouse(), untested though:
- it returned on _UPDATE_ messages without a mouse position - it no longer calls DispatchMessage() for everything anymore, however, it will still call BWindow::DispatchMessage() directly for _UPDATE_ messages - it didn't care for B_MOUSE_DOWN messages - it didn't unlock the queue in case it found a message. (this message actually reflects the differences to r12683 of this file, but the newer one r12705 was even more broken, but in other ways) git-svn-id: file:///srv/svn/repos/haiku/haiku/trunk@12714 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
parent
c1fc0493cb
commit
c66f958bb6
@ -1172,16 +1172,12 @@ BView::GetMouse(BPoint *location, uint32 *buttons, bool checkMessageQueue)
|
|||||||
{
|
{
|
||||||
do_owner_check();
|
do_owner_check();
|
||||||
|
|
||||||
// TODO: This doesn't look correct, and it's probably the
|
// ToDo: We should check if we are calling this from the BWindow's thread or not.
|
||||||
// reason for synchronous controls not working well.
|
// But why exactly do we have to do this? If the looper is locked, it
|
||||||
// 1. We shouldn't return in case we find an _UPDATE_
|
// shouldn't do too much harm, besides, who would do this, anyway :) -- axeld.
|
||||||
// message in the queue, as this leaves us without a mouse position.
|
|
||||||
// 2. we should check if we are calling this from the BWindow's thread or not.
|
|
||||||
// 3. We should maybe take care of more things as the window's loop is blocked.
|
|
||||||
|
|
||||||
if (checkMessageQueue) {
|
if (checkMessageQueue) {
|
||||||
BWindow *window = Window();
|
BMessageQueue *queue = Window()->MessageQueue();
|
||||||
BMessageQueue *queue = window->MessageQueue();
|
|
||||||
BMessage *msg;
|
BMessage *msg;
|
||||||
int32 i = 0;
|
int32 i = 0;
|
||||||
|
|
||||||
@ -1189,22 +1185,36 @@ BView::GetMouse(BPoint *location, uint32 *buttons, bool checkMessageQueue)
|
|||||||
|
|
||||||
while ((msg = queue->FindMessage(i++)) != NULL) {
|
while ((msg = queue->FindMessage(i++)) != NULL) {
|
||||||
switch (msg->what) {
|
switch (msg->what) {
|
||||||
case _UPDATE_:
|
|
||||||
// TODO: This is probably not correct:
|
|
||||||
// we should not dispatch the message but instead
|
|
||||||
// call the right function to update the views directly ?
|
|
||||||
window->DispatchMessage(msg, window);
|
|
||||||
|
|
||||||
// Fall through
|
|
||||||
case B_MOUSE_UP:
|
case B_MOUSE_UP:
|
||||||
|
case B_MOUSE_DOWN:
|
||||||
case B_MOUSE_MOVED:
|
case B_MOUSE_MOVED:
|
||||||
// We need to eat up all these messages
|
{
|
||||||
|
msg->FindPoint("where", location);
|
||||||
|
msg->FindInt32("buttons", (int32 *)buttons);
|
||||||
|
|
||||||
|
// ToDo: if we're intercepting a mouse message for another
|
||||||
|
// view, the coordinates must be updated to fit
|
||||||
|
|
||||||
queue->RemoveMessage(msg);
|
queue->RemoveMessage(msg);
|
||||||
delete msg;
|
delete msg;
|
||||||
break;
|
|
||||||
|
|
||||||
default:
|
queue->Unlock();
|
||||||
break;
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
case _UPDATE_:
|
||||||
|
{
|
||||||
|
// ToDo: We should even eat *all* _UPDATE_ messages
|
||||||
|
// in the queue, not only the ones before the current
|
||||||
|
// mouse message...
|
||||||
|
Window()->BWindow::DispatchMessage(msg, Window());
|
||||||
|
// we need to make sure that no overridden method is called
|
||||||
|
// here; for BWindow::DispatchMessage() we now exactly what
|
||||||
|
// will happen
|
||||||
|
queue->RemoveMessage(msg);
|
||||||
|
delete msg;
|
||||||
|
i--;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
queue->Unlock();
|
queue->Unlock();
|
||||||
|
Loading…
Reference in New Issue
Block a user