2009-09-19 05:19:11 +04:00
|
|
|
/* -*- Mode: C++; c-basic-offset: 4; indent-tabs-mode: nil; tab-width: 8 -*- */
|
|
|
|
/* vim: set sw=4 ts=8 et tw=80 ft=cpp : */
|
2012-05-21 15:12:37 +04:00
|
|
|
/* This Source Code Form is subject to the terms of the Mozilla Public
|
|
|
|
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
|
|
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
|
2009-09-19 05:19:11 +04:00
|
|
|
|
|
|
|
#ifndef mozilla_dom_plugins_NPEventWindows_h
|
|
|
|
#define mozilla_dom_plugins_NPEventWindows_h 1
|
|
|
|
|
|
|
|
|
|
|
|
#include "npapi.h"
|
2009-10-27 22:58:33 +03:00
|
|
|
namespace mozilla {
|
2009-09-19 05:19:11 +04:00
|
|
|
|
2009-10-27 22:58:33 +03:00
|
|
|
namespace plugins {
|
|
|
|
|
|
|
|
// We use an NPRemoteEvent struct so that we can store the extra data on
|
|
|
|
// the stack so that we don't need to worry about managing the memory.
|
|
|
|
struct NPRemoteEvent
|
|
|
|
{
|
|
|
|
NPEvent event;
|
|
|
|
union {
|
2009-12-15 03:27:25 +03:00
|
|
|
RECT rect;
|
2009-10-27 22:58:33 +03:00
|
|
|
WINDOWPOS windowpos;
|
|
|
|
} lParamData;
|
|
|
|
};
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
2009-09-19 23:24:24 +04:00
|
|
|
|
|
|
|
namespace IPC {
|
2009-09-19 05:19:11 +04:00
|
|
|
|
|
|
|
template <>
|
2009-10-27 22:58:33 +03:00
|
|
|
struct ParamTraits<mozilla::plugins::NPRemoteEvent>
|
2009-09-19 05:19:11 +04:00
|
|
|
{
|
2009-10-27 22:58:33 +03:00
|
|
|
typedef mozilla::plugins::NPRemoteEvent paramType;
|
2009-09-19 05:19:11 +04:00
|
|
|
|
|
|
|
static void Write(Message* aMsg, const paramType& aParam)
|
|
|
|
{
|
2009-10-27 22:58:33 +03:00
|
|
|
// Make a non-const copy of aParam so that we can muck with
|
|
|
|
// its insides for tranport
|
|
|
|
paramType paramCopy;
|
|
|
|
|
|
|
|
paramCopy.event = aParam.event;
|
|
|
|
|
|
|
|
// We can't blindly ipc events because they may sometimes contain
|
|
|
|
// pointers to memory in the sending process. For example, the
|
|
|
|
// WM_IME_CONTROL with the IMC_GETCOMPOSITIONFONT message has lParam
|
|
|
|
// set to a pointer to a LOGFONT structure.
|
|
|
|
switch (paramCopy.event.event) {
|
|
|
|
case WM_WINDOWPOSCHANGED:
|
2010-07-07 17:33:52 +04:00
|
|
|
// The lParam parameter of WM_WINDOWPOSCHANGED holds a pointer to
|
2009-10-27 22:58:33 +03:00
|
|
|
// a WINDOWPOS structure that contains information about the
|
|
|
|
// window's new size and position
|
|
|
|
paramCopy.lParamData.windowpos = *(reinterpret_cast<WINDOWPOS*>(paramCopy.event.lParam));
|
|
|
|
break;
|
|
|
|
case WM_PAINT:
|
2010-07-07 17:33:52 +04:00
|
|
|
// The lParam parameter of WM_PAINT holds a pointer to an RECT
|
2009-10-27 22:58:33 +03:00
|
|
|
// structure specifying the bounding box of the update area.
|
2009-12-15 03:27:25 +03:00
|
|
|
paramCopy.lParamData.rect = *(reinterpret_cast<RECT*>(paramCopy.event.lParam));
|
2009-10-27 22:58:33 +03:00
|
|
|
break;
|
|
|
|
|
|
|
|
// the white list of events that we will ipc to the client
|
|
|
|
case WM_CHAR:
|
|
|
|
case WM_SYSCHAR:
|
|
|
|
|
|
|
|
case WM_KEYUP:
|
|
|
|
case WM_SYSKEYUP:
|
|
|
|
|
|
|
|
case WM_KEYDOWN:
|
|
|
|
case WM_SYSKEYDOWN:
|
|
|
|
|
|
|
|
case WM_DEADCHAR:
|
|
|
|
case WM_SYSDEADCHAR:
|
|
|
|
case WM_CONTEXTMENU:
|
|
|
|
|
|
|
|
case WM_CUT:
|
|
|
|
case WM_COPY:
|
|
|
|
case WM_PASTE:
|
|
|
|
case WM_CLEAR:
|
|
|
|
case WM_UNDO:
|
|
|
|
|
2010-01-14 04:46:44 +03:00
|
|
|
case WM_MOUSELEAVE:
|
2009-10-27 22:58:33 +03:00
|
|
|
case WM_MOUSEMOVE:
|
|
|
|
case WM_LBUTTONDOWN:
|
|
|
|
case WM_MBUTTONDOWN:
|
|
|
|
case WM_RBUTTONDOWN:
|
|
|
|
case WM_LBUTTONUP:
|
|
|
|
case WM_MBUTTONUP:
|
|
|
|
case WM_RBUTTONUP:
|
|
|
|
case WM_LBUTTONDBLCLK:
|
|
|
|
case WM_MBUTTONDBLCLK:
|
|
|
|
case WM_RBUTTONDBLCLK:
|
|
|
|
|
|
|
|
case WM_SETFOCUS:
|
|
|
|
case WM_KILLFOCUS:
|
|
|
|
break;
|
|
|
|
|
|
|
|
default:
|
2009-12-15 03:27:25 +03:00
|
|
|
// RegisterWindowMessage events should be passed.
|
2012-10-04 12:31:37 +04:00
|
|
|
if (paramCopy.event.event >= 0xC000)
|
2009-12-15 03:27:25 +03:00
|
|
|
break;
|
|
|
|
|
2010-05-26 04:41:02 +04:00
|
|
|
// FIXME/bug 567465: temporarily work around unhandled
|
|
|
|
// events by forwarding a "dummy event". The eventual
|
|
|
|
// fix will be to stop trying to send these events
|
|
|
|
// entirely.
|
|
|
|
paramCopy.event.event = WM_NULL;
|
|
|
|
break;
|
2009-10-27 22:58:33 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
aMsg->WriteBytes(¶mCopy, sizeof(paramType));
|
2009-09-19 05:19:11 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
static bool Read(const Message* aMsg, void** aIter, paramType* aResult)
|
|
|
|
{
|
2009-10-27 22:58:33 +03:00
|
|
|
const char* bytes = 0;
|
|
|
|
|
|
|
|
if (!aMsg->ReadBytes(aIter, &bytes, sizeof(paramType))) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
memcpy(aResult, bytes, sizeof(paramType));
|
|
|
|
|
|
|
|
if (aResult->event.event == WM_PAINT) {
|
2009-12-15 03:27:25 +03:00
|
|
|
// restore the lParam to point at the RECT
|
2009-10-27 22:58:33 +03:00
|
|
|
aResult->event.lParam = reinterpret_cast<LPARAM>(&aResult->lParamData.rect);
|
|
|
|
} else if (aResult->event.event == WM_WINDOWPOSCHANGED) {
|
|
|
|
// restore the lParam to point at the WINDOWPOS
|
|
|
|
aResult->event.lParam = reinterpret_cast<LPARAM>(&aResult->lParamData.windowpos);
|
|
|
|
}
|
|
|
|
|
2009-09-19 05:19:11 +04:00
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
static void Log(const paramType& aParam, std::wstring* aLog)
|
|
|
|
{
|
2009-10-27 22:58:33 +03:00
|
|
|
aLog->append(L"(WINEvent)");
|
2009-09-19 05:19:11 +04:00
|
|
|
}
|
2009-10-27 22:58:33 +03:00
|
|
|
|
2009-09-19 05:19:11 +04:00
|
|
|
};
|
|
|
|
|
2009-09-19 23:24:24 +04:00
|
|
|
} // namespace IPC
|
2009-09-19 05:19:11 +04:00
|
|
|
|
|
|
|
#endif // ifndef mozilla_dom_plugins_NPEventWindows_h
|