1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
|
/*
* %CopyrightBegin%
*
* Copyright Ericsson AB 2008-2013. All Rights Reserved.
*
* The contents of this file are subject to the Erlang Public License,
* Version 1.1, (the "License"); you may not use this file except in
* compliance with the License. You should have received a copy of the
* Erlang Public License along with this software. If not, it can be
* retrieved online at http://www.erlang.org/.
*
* Software distributed under the License is distributed on an "AS IS"
* basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. See
* the License for the specific language governing rights and limitations
* under the License.
*
* %CopyrightEnd%
*/
#ifndef __WXE_EVENT_H__
#define __WXE_EVENT_H__
#include "wxe_driver.h"
class wxeEtype
{
public:
wxeEtype (const char *, int);
const char *eName;
int cID;
};
/* One EvtListener per listening erlang process */
/* If callbacks are used the receiver is wxe_master process */
/* and a wxeEvtListener pre callback is registered */
class wxeEvtListener : public wxEvtHandler
{
public:
wxeEvtListener(ErlDrvTermData Thisport) : port(Thisport)
{}
// {fprintf(stderr, "Creating %x\r\n", (unsigned int) this); fflush(stderr);}
~wxeEvtListener() {}
void forward(wxEvent& event);
ErlDrvTermData port;
};
void initEventTable();
int wxeEventTypeFromAtom(char *etype_atom);
/* Fun Callback id */
class wxeCallbackData : public wxObject
{
public:
wxeCallbackData(ErlDrvTermData caller, int req, char *req_type,
int funcb, int skip_ev, wxeErlTerm * userData,
wxeEvtListener *handler_cb);
~wxeCallbackData();
wxeEvtListener * handler;
ErlDrvTermData listener;
int fun_id;
int obj;
char class_name[40];
int skip;
wxeErlTerm * user_data;
};
#endif
|