[Android] Implement 3-way sensor fallback for Device Orientation.
[chromium-blink-merge.git] / ppapi / host / dispatch_host_message.h
blob5d05019cd0e3e277b12de9a51274ea3735c3e628
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
5 // This file provides infrastructure for dispatching host resource call
6 // messages. Normal IPC message handlers can't take extra parameters or
7 // return values. We want to take a HostMessageContext as a parameter and
8 // also return the int32_t return value to the caller.
10 #ifndef PPAPI_HOST_DISPATCH_HOST_MESSAGE_H_
11 #define PPAPI_HOST_DISPATCH_HOST_MESSAGE_H_
13 #include "base/profiler/scoped_profile.h"
14 #include "ipc/ipc_message_macros.h"
15 #include "ppapi/c/pp_errors.h"
17 namespace ppapi {
18 namespace host {
20 struct HostMessageContext;
22 template <class ObjT, class Method>
23 inline int32_t DispatchResourceCall(ObjT* obj, Method method,
24 HostMessageContext* context,
25 base::Tuple<>& arg) {
26 return (obj->*method)(context);
29 template <class ObjT, class Method, class A>
30 inline int32_t DispatchResourceCall(ObjT* obj, Method method,
31 HostMessageContext* context,
32 base::Tuple<A>& arg) {
33 return (obj->*method)(context, base::get<0>(arg));
36 template<class ObjT, class Method, class A, class B>
37 inline int32_t DispatchResourceCall(ObjT* obj, Method method,
38 HostMessageContext* context,
39 base::Tuple<A, B>& arg) {
40 return (obj->*method)(context, base::get<0>(arg), base::get<1>(arg));
43 template<class ObjT, class Method, class A, class B, class C>
44 inline int32_t DispatchResourceCall(ObjT* obj, Method method,
45 HostMessageContext* context,
46 base::Tuple<A, B, C>& arg) {
47 return (obj->*method)(context, base::get<0>(arg), base::get<1>(arg),
48 base::get<2>(arg));
51 template<class ObjT, class Method, class A, class B, class C, class D>
52 inline int32_t DispatchResourceCall(ObjT* obj, Method method,
53 HostMessageContext* context,
54 base::Tuple<A, B, C, D>& arg) {
55 return (obj->*method)(context, base::get<0>(arg), base::get<1>(arg),
56 base::get<2>(arg), base::get<3>(arg));
59 template<class ObjT, class Method, class A, class B, class C, class D, class E>
60 inline int32_t DispatchResourceCall(ObjT* obj, Method method,
61 HostMessageContext* context,
62 base::Tuple<A, B, C, D, E>& arg) {
63 return (obj->*method)(context, base::get<0>(arg), base::get<1>(arg),
64 base::get<2>(arg), base::get<3>(arg),
65 base::get<4>(arg));
68 // Note that this only works for message with 1 or more parameters. For
69 // 0-parameter messages you need to use the _0 version below (since there are
70 // no params in the message).
71 #define PPAPI_DISPATCH_HOST_RESOURCE_CALL(msg_class, member_func) \
72 case msg_class::ID: { \
73 TRACK_RUN_IN_THIS_SCOPED_REGION(member_func); \
74 msg_class::Schema::Param p; \
75 if (msg_class::Read(&ipc_message__, &p)) { \
76 return ppapi::host::DispatchResourceCall( \
77 this, \
78 &_IpcMessageHandlerClass::member_func, \
79 context, p); \
80 } \
81 return PP_ERROR_FAILED; \
84 #define PPAPI_DISPATCH_HOST_RESOURCE_CALL_0(msg_class, member_func) \
85 case msg_class::ID: { \
86 TRACK_RUN_IN_THIS_SCOPED_REGION(member_func); \
87 return member_func(context); \
90 } // namespace host
91 } // namespace ppapi
93 #endif // PPAPI_HOST_DISPATCH_HOST_MESSAGE_H_