blob: e58ce661473c2058f83fa8e9e0b884cf74b0cdd3 (
plain)
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
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
|
/**
* ExtensionImpl.h
*
* Extension implementation for the Zend engine.
*
* @author Emiel Bruijntjes <emiel.bruijntjes@copernica.com>
* @copyright 2013, 2014 Copernica BV
*/
/**
* Set up namespace
*/
namespace Php {
/**
* Class definition
*/
class ExtensionImpl : public ExtensionBase
{
protected:
/**
* The information that is passed to the Zend engine
*
* Although it would be slightly faster to not make this a pointer, this
* would require that client code also includes the PHP header files, which
* we try to prevent with the PHP-CPP library, so we allocate it dynamically.
*
* @var zend_module_entry
*/
zend_module_entry _entry;
public:
/**
* Constructor
* @param data Extension object created by the extension programmer
* @param name Name of the extension
* @param version Version number
*/
ExtensionImpl(Extension *data, const char *name, const char *version);
/**
* No copy'ing and no moving
*/
ExtensionImpl(const ExtensionImpl &extension) = delete;
ExtensionImpl(ExtensionImpl &&extension) = delete;
/**
* Destructor
*/
virtual ~ExtensionImpl();
/**
* Retrieve the module entry
*
* This is the memory address that should be exported by the get_module()
* function.
*
* @return _zend_module_entry
*/
zend_module_entry *module();
/**
* Cast to a module entry
* @return _zend_module_entry*
*/
operator zend_module_entry * ()
{
return module();
}
private:
/**
* Initialize the namespace after it was registered
* @param tsrm_ls
*/
void initialize(TSRMLS_D);
/**
* Function that is called when the extension initializes
* @param type Module type
* @param number Module number
* @param tsrm_ls
* @return int 0 on success
*/
static int processStartup(int type, int module_number TSRMLS_DC);
/**
* Function that is called when the extension is about to be stopped
* @param type Module type
* @param number Module number
* @param tsrm_ls
* @return int
*/
static int processShutdown(int type, int module_number TSRMLS_DC);
/**
* Function that is called when a request starts
* @param type Module type
* @param number Module number
* @param tsrm_ls
* @return int 0 on success
*/
static int processRequest(int type, int module_number TSRMLS_DC);
/**
* Function that is called when a request is ended
* @param type Module type
* @param number Module number
* @param tsrm_ls
* @return int 0 on success
*/
static int processIdle(int type, int module_number TSRMLS_DC);
};
/**
* End of namespace
*/
}
|