* Dropped messages come in a _MESSAGE_DROPPED_ "packet", and were unpacked much too
late, in DispatchMessage(), working around all eventually installed message filters. This fixes the odd "cannot drop files into file panel" bug mentioned in bug #669. * They are now handled in _DetermineTarget() and _SanitizeMessage(). * _SanitizeMessage() is now called earlier, so that no user code can see them before; even though this might give you wrong MouseDown() coordinates in combination with a redirecting message filter, I think that's exactly what would happen in this situation under R5 as well. git-svn-id: file:///srv/svn/repos/haiku/haiku/trunk@17839 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
parent
e39da397f5
commit
7477c792d5
@ -1144,20 +1144,6 @@ FrameMoved(origin);
|
|||||||
msg->SendReply(B_MESSAGE_NOT_UNDERSTOOD);
|
msg->SendReply(B_MESSAGE_NOT_UNDERSTOOD);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case _MESSAGE_DROPPED_:
|
|
||||||
{
|
|
||||||
if (fLastMouseMovedView)
|
|
||||||
target = fLastMouseMovedView;
|
|
||||||
|
|
||||||
uint32 originalWhat;
|
|
||||||
if (msg->FindInt32("_original_what", (int32*)&originalWhat) == B_OK) {
|
|
||||||
msg->what = originalWhat;
|
|
||||||
msg->RemoveName("_original_what");
|
|
||||||
}
|
|
||||||
|
|
||||||
BLooper::DispatchMessage(msg, target);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
default:
|
default:
|
||||||
BLooper::DispatchMessage(msg, target);
|
BLooper::DispatchMessage(msg, target);
|
||||||
@ -2536,6 +2522,9 @@ BWindow::task_looper()
|
|||||||
while (_UnpackMessage(cookie, &fLastMessage, &handler, &usePreferred)) {
|
while (_UnpackMessage(cookie, &fLastMessage, &handler, &usePreferred)) {
|
||||||
// if there is no target handler, the message is dropped
|
// if there is no target handler, the message is dropped
|
||||||
if (handler != NULL) {
|
if (handler != NULL) {
|
||||||
|
if (handler != NULL)
|
||||||
|
_SanitizeMessage(fLastMessage, handler, usePreferred);
|
||||||
|
|
||||||
// Is this a scripting message?
|
// Is this a scripting message?
|
||||||
if (fLastMessage->HasSpecifiers()) {
|
if (fLastMessage->HasSpecifiers()) {
|
||||||
int32 index = 0;
|
int32 index = 0;
|
||||||
@ -2547,11 +2536,9 @@ BWindow::task_looper()
|
|||||||
if (handler != NULL)
|
if (handler != NULL)
|
||||||
handler = _TopLevelFilter(fLastMessage, handler);
|
handler = _TopLevelFilter(fLastMessage, handler);
|
||||||
|
|
||||||
if (handler != NULL) {
|
if (handler != NULL)
|
||||||
_SanitizeMessage(fLastMessage, handler, usePreferred);
|
|
||||||
DispatchMessage(fLastMessage, handler);
|
DispatchMessage(fLastMessage, handler);
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
// Delete the current message
|
// Delete the current message
|
||||||
delete fLastMessage;
|
delete fLastMessage;
|
||||||
@ -2780,6 +2767,11 @@ BWindow::_DetermineTarget(BMessage *message, BHandler *target)
|
|||||||
// TODO: test wether R5 will let BView dispatch these messages
|
// TODO: test wether R5 will let BView dispatch these messages
|
||||||
return this;
|
return this;
|
||||||
|
|
||||||
|
case _MESSAGE_DROPPED_:
|
||||||
|
if (fLastMouseMovedView != NULL)
|
||||||
|
return fLastMouseMovedView;
|
||||||
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -2891,6 +2883,11 @@ BWindow::_UnpackMessage(unpack_cookie& cookie, BMessage** _message, BHandler** _
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/*!
|
||||||
|
Some messages don't get to the window in a shape an application should see.
|
||||||
|
This method is supposed to give a message the last grinding before
|
||||||
|
it's acceptable for the receiving application.
|
||||||
|
*/
|
||||||
void
|
void
|
||||||
BWindow::_SanitizeMessage(BMessage* message, BHandler* target, bool usePreferred)
|
BWindow::_SanitizeMessage(BMessage* message, BHandler* target, bool usePreferred)
|
||||||
{
|
{
|
||||||
@ -2901,6 +2898,7 @@ BWindow::_SanitizeMessage(BMessage* message, BHandler* target, bool usePreferred
|
|||||||
case B_MOUSE_MOVED:
|
case B_MOUSE_MOVED:
|
||||||
case B_MOUSE_UP:
|
case B_MOUSE_UP:
|
||||||
case B_MOUSE_DOWN:
|
case B_MOUSE_DOWN:
|
||||||
|
{
|
||||||
BPoint where;
|
BPoint where;
|
||||||
if (message->FindPoint("screen_where", &where) != B_OK)
|
if (message->FindPoint("screen_where", &where) != B_OK)
|
||||||
break;
|
break;
|
||||||
@ -2944,6 +2942,17 @@ BWindow::_SanitizeMessage(BMessage* message, BHandler* target, bool usePreferred
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
case _MESSAGE_DROPPED_:
|
||||||
|
{
|
||||||
|
uint32 originalWhat;
|
||||||
|
if (message->FindInt32("_original_what", (int32*)&originalWhat) == B_OK) {
|
||||||
|
message->what = originalWhat;
|
||||||
|
message->RemoveName("_original_what");
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user