// Copyright (c) 2012 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include "ppapi/proxy/ppp_mouse_lock_proxy.h"
#include "ppapi/c/ppp_mouse_lock.h"
#include "ppapi/proxy/host_dispatcher.h"
#include "ppapi/proxy/ppapi_messages.h"
#include "ppapi/shared_impl/proxy_lock.h"
namespace ppapi {
namespace proxy {
namespace {
#if !defined(OS_NACL)
void MouseLockLost(PP_Instance instance) {
HostDispatcher* dispatcher = HostDispatcher::GetForInstance(instance);
if (!dispatcher) {
// The dispatcher should always be valid.
NOTREACHED();
return;
}
dispatcher->Send(new PpapiMsg_PPPMouseLock_MouseLockLost(
API_ID_PPP_MOUSE_LOCK, instance));
}
static const PPP_MouseLock mouse_lock_interface = {
&MouseLockLost
};
#else
// The NaCl plugin doesn't need the host side interface - stub it out.
static const PPP_MouseLock mouse_lock_interface = {};
#endif // !defined(OS_NACL)
} // namespace
PPP_MouseLock_Proxy::PPP_MouseLock_Proxy(Dispatcher* dispatcher)
: InterfaceProxy(dispatcher),
ppp_mouse_lock_impl_(NULL) {
if (dispatcher->IsPlugin()) {
ppp_mouse_lock_impl_ = static_cast<const PPP_MouseLock*>(
dispatcher->local_get_interface()(PPP_MOUSELOCK_INTERFACE));
}
}
PPP_MouseLock_Proxy::~PPP_MouseLock_Proxy() {
}
// static
const PPP_MouseLock* PPP_MouseLock_Proxy::GetProxyInterface() {
return &mouse_lock_interface;
}
bool PPP_MouseLock_Proxy::OnMessageReceived(const IPC::Message& msg) {
if (!dispatcher()->IsPlugin())
return false;
bool handled = true;
IPC_BEGIN_MESSAGE_MAP(PPP_MouseLock_Proxy, msg)
IPC_MESSAGE_HANDLER(PpapiMsg_PPPMouseLock_MouseLockLost,
OnMsgMouseLockLost)
IPC_MESSAGE_UNHANDLED(handled = false)
IPC_END_MESSAGE_MAP()
return handled;
}
void PPP_MouseLock_Proxy::OnMsgMouseLockLost(PP_Instance instance) {
if (ppp_mouse_lock_impl_)
CallWhileUnlocked(ppp_mouse_lock_impl_->MouseLockLost, instance);
}
} // namespace proxy
} // namespace ppapi