1 // Copyright (c) 2013 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 #ifndef PPAPI_CPP_EXTENSIONS_EVENT_BASE_H_
6 #define PPAPI_CPP_EXTENSIONS_EVENT_BASE_H_
8 #include "ppapi/c/extensions/dev/ppb_ext_events_dev.h"
9 #include "ppapi/c/pp_macros.h"
10 #include "ppapi/c/pp_stdint.h"
11 #include "ppapi/c/pp_var.h"
12 #include "ppapi/cpp/extensions/from_var_converter.h"
13 #include "ppapi/cpp/instance_handle.h"
14 #include "ppapi/cpp/logging.h"
20 // This file contains base classes for events. Usually you don't need to use
23 // For each event type, there is a corresponding event class derived from
24 // EventBase[0-3]. The event class defines a Listener interface and exposes the
25 // public methods of GenericEventBase.
27 // Take pp::ext::alarms::OnAlarmEvent_Dev as example, your code to listen to the
28 // event would look like this:
30 // class MyListener : public pp::ext::alarms::OnAlarmEvent_Dev {
32 // // The parameter is a non-const reference so you could directly modify it
34 // virtual void OnAlarm(Alarm_Dev& alarm) {
35 // ...handle the event...
39 // MyListener on_alarm_listener;
40 // // The listener is not owned by the event and must outlive it.
41 // pp::ext::alarms::OnAlarmEvent_Dev on_alarm(instance, &on_alarm_listener);
42 // on_alarm.StartListening();
44 // // It is guaranteed that |on_alarm_listener| won't get called after
45 // // |on_alarm| goes away. So this step is optional.
46 // on_alarm.StopListening();
48 class GenericEventBase
{
50 bool StartListening();
53 bool IsListening() const { return listener_id_
!= 0; }
54 uint32_t listener_id() const { return listener_id_
; }
57 GenericEventBase(const InstanceHandle
& instance
,
58 const PP_Ext_EventListener
& pp_listener
);
61 InstanceHandle instance_
;
62 uint32_t listener_id_
;
63 const PP_Ext_EventListener pp_listener_
;
66 // Disallow copying and assignment.
67 GenericEventBase(const GenericEventBase
&);
68 GenericEventBase
& operator=(const GenericEventBase
&);
71 // EventBase[0-3] are event base classes which can be instantiated with a
72 // pointer to a PP_Ext_EventListener creation function and the input parameter
73 // types of the listener callback.
75 // For example, EvenBase1<PP_Ext_Alarms_OnAlarm_Dev, Alarm_Dev> deals with
76 // the event type defined by the PP_Ext_Alarms_OnAlarm_Dev function pointer. And
77 // it defines a pure virtual method as the listener callback:
78 // virtual void Callback(Alarm_Dev&) = 0;
80 typedef PP_Ext_EventListener (*CreatePPEventListener0
)(
81 void (*)(uint32_t, void*), void*);
82 template <const CreatePPEventListener0 kCreatePPEventListener0
>
83 class EventBase0
: public GenericEventBase
{
85 explicit EventBase0(const InstanceHandle
& instance
)
86 : PP_ALLOW_THIS_IN_INITIALIZER_LIST(
87 GenericEventBase(instance
,
88 kCreatePPEventListener0(&CallbackThunk
, this))) {
91 virtual ~EventBase0() {}
94 virtual void Callback() = 0;
96 static void CallbackThunk(uint32_t listener_id
, void* user_data
) {
97 EventBase0
<kCreatePPEventListener0
>* event_base
=
98 static_cast<EventBase0
<kCreatePPEventListener0
>*>(user_data
);
99 PP_DCHECK(listener_id
== event_base
->listener_id_
);
100 // Suppress unused variable warnings.
101 static_cast<void>(listener_id
);
103 event_base
->Callback();
106 // Disallow copying and assignment.
107 EventBase0(const EventBase0
<kCreatePPEventListener0
>&);
108 EventBase0
<kCreatePPEventListener0
>& operator=(
109 const EventBase0
<kCreatePPEventListener0
>&);
112 typedef PP_Ext_EventListener (*CreatePPEventListener1
)(
113 void (*)(uint32_t, void*, PP_Var
), void*);
114 template <const CreatePPEventListener1 kCreatePPEventListener1
, class A
>
115 class EventBase1
: public GenericEventBase
{
117 explicit EventBase1(const InstanceHandle
& instance
)
118 : PP_ALLOW_THIS_IN_INITIALIZER_LIST(
119 GenericEventBase(instance
,
120 kCreatePPEventListener1(&CallbackThunk
, this))) {
123 virtual ~EventBase1() {}
126 virtual void Callback(A
&) = 0;
128 static void CallbackThunk(uint32_t listener_id
,
131 EventBase1
<kCreatePPEventListener1
, A
>* event_base
=
132 static_cast<EventBase1
<kCreatePPEventListener1
, A
>*>(user_data
);
133 PP_DCHECK(listener_id
== event_base
->listener_id_
);
134 // Suppress unused variable warnings.
135 static_cast<void>(listener_id
);
137 FromVarConverter
<A
> a(var_a
);
138 event_base
->Callback(a
.value());
141 // Disallow copying and assignment.
142 EventBase1(const EventBase1
<kCreatePPEventListener1
, A
>&);
143 EventBase1
<kCreatePPEventListener1
, A
>& operator=(
144 const EventBase1
<kCreatePPEventListener1
, A
>&);
147 typedef PP_Ext_EventListener (*CreatePPEventListener2
)(
148 void (*)(uint32_t, void*, PP_Var
, PP_Var
), void*);
149 template <const CreatePPEventListener2 kCreatePPEventListener2
,
152 class EventBase2
: public GenericEventBase
{
154 explicit EventBase2(const InstanceHandle
& instance
)
155 : PP_ALLOW_THIS_IN_INITIALIZER_LIST(
156 GenericEventBase(instance
,
157 kCreatePPEventListener2(&CallbackThunk
, this))) {
160 virtual ~EventBase2() {}
163 virtual void Callback(A
&, B
&) = 0;
165 static void CallbackThunk(uint32_t listener_id
,
169 EventBase2
<kCreatePPEventListener2
, A
, B
>* event_base
=
170 static_cast<EventBase2
<kCreatePPEventListener2
, A
, B
>*>(user_data
);
171 PP_DCHECK(listener_id
== event_base
->listener_id_
);
172 // Suppress unused variable warnings.
173 static_cast<void>(listener_id
);
175 FromVarConverter
<A
> a(var_a
);
176 FromVarConverter
<B
> b(var_b
);
177 event_base
->Callback(a
.value(), b
.value());
180 // Disallow copying and assignment.
181 EventBase2(const EventBase2
<kCreatePPEventListener2
, A
, B
>&);
182 EventBase2
<kCreatePPEventListener2
, A
, B
>& operator=(
183 const EventBase2
<kCreatePPEventListener2
, A
, B
>&);
186 typedef PP_Ext_EventListener (*CreatePPEventListener3
)(
187 void (*)(uint32_t, void*, PP_Var
, PP_Var
, PP_Var
), void*);
188 template <const CreatePPEventListener3 kCreatePPEventListener3
,
192 class EventBase3
: public GenericEventBase
{
194 explicit EventBase3(const InstanceHandle
& instance
)
195 : PP_ALLOW_THIS_IN_INITIALIZER_LIST(
196 GenericEventBase(instance
,
197 kCreatePPEventListener3(&CallbackThunk
, this))) {
200 virtual ~EventBase3() {}
203 virtual void Callback(A
&, B
&, C
&) = 0;
205 static void CallbackThunk(uint32_t listener_id
,
210 EventBase3
<kCreatePPEventListener3
, A
, B
, C
>* event_base
=
211 static_cast<EventBase3
<kCreatePPEventListener3
, A
, B
, C
>*>(user_data
);
212 PP_DCHECK(listener_id
== event_base
->listener_id_
);
213 // Suppress unused variable warnings.
214 static_cast<void>(listener_id
);
216 FromVarConverter
<A
> a(var_a
);
217 FromVarConverter
<B
> b(var_b
);
218 FromVarConverter
<C
> c(var_c
);
219 event_base
->Callback(a
.value(), b
.value(), c
.value());
222 // Disallow copying and assignment.
223 EventBase3(const EventBase3
<kCreatePPEventListener3
, A
, B
, C
>&);
224 EventBase3
<kCreatePPEventListener3
, A
, B
, C
>& operator=(
225 const EventBase3
<kCreatePPEventListener3
, A
, B
, C
>&);
228 } // namespace internal
232 #endif // PPAPI_CPP_EXTENSIONS_EVENT_BASE_H_