… | |
… | |
5 | #ifndef RXVTPERL_H_ |
5 | #ifndef RXVTPERL_H_ |
6 | #define RXVTPERL_H_ |
6 | #define RXVTPERL_H_ |
7 | |
7 | |
8 | #if ENABLE_PERL |
8 | #if ENABLE_PERL |
9 | |
9 | |
10 | #include "rxvt.h" |
10 | #define SHOULD_INVOKE(htype) \ |
11 | |
11 | ( (htype) == HOOK_INIT \ |
|
|
12 | || (htype) == HOOK_DESTROY \ |
|
|
13 | || (htype) == HOOK_REFRESH_BEGIN \ |
|
|
14 | || (htype) == HOOK_REFRESH_END \ |
|
|
15 | || perl.should_invoke [htype]) |
12 | #define PERL_INVOKE(args) rxvt_perl.invoke args |
16 | #define HOOK_INVOKE(args) rxvt_perl.invoke args |
13 | |
17 | |
14 | enum data_type { |
18 | enum data_type { |
15 | DT_END, |
19 | DT_END, // no further arguments |
16 | DT_INT, |
20 | DT_INT, |
17 | DT_LONG, |
21 | DT_LONG, |
18 | DT_STRING, |
22 | DT_STR, // 0-terminated string |
|
|
23 | DT_STR_LEN, // string + length |
|
|
24 | DT_WCS_LEN, // wchar_t* + length |
|
|
25 | DT_LCS_LEN, // long* + length |
19 | DT_XEVENT, |
26 | DT_XEVENT, |
20 | }; |
27 | }; |
21 | |
28 | |
22 | enum hook_type { |
29 | enum hook_type { |
23 | HOOK_INIT = 0, // special, hardcoded |
30 | # define def(sym) HOOK_ ## sym, |
24 | HOOK_DESTROY = 1, // values in urxvt.pm |
31 | # include "hookinc.h" |
25 | HOOK_RESET, |
32 | # undef def |
26 | HOOK_START, |
33 | HOOK_NUM, |
|
|
34 | }; |
27 | |
35 | |
28 | HOOK_SEL_BEGIN, |
36 | struct rxvt_perl_term |
29 | HOOK_SEL_EXTEND, |
37 | { |
30 | HOOK_SEL_MAKE, |
38 | void *self; |
31 | HOOK_SEL_GRAB, |
39 | unsigned long grabtime; |
|
|
40 | uint8_t should_invoke[HOOK_NUM]; |
32 | |
41 | |
33 | HOOK_SEL_CLICK, |
42 | // this object must be zero-initialised |
34 | |
43 | rxvt_perl_term () |
35 | HOOK_FOCUS_IN, |
44 | { |
36 | HOOK_FOCUS_OUT, |
45 | should_invoke [HOOK_INIT] = |
37 | |
46 | should_invoke [HOOK_DESTROY] = 1; |
38 | HOOK_VIEW_CHANGE, |
47 | } |
39 | HOOK_SCROLL_BACK, |
|
|
40 | HOOK_TTY_ACTIVITY, |
|
|
41 | |
|
|
42 | HOOK_REFRESH_BEGIN, |
|
|
43 | HOOK_REFRESH_END, |
|
|
44 | |
|
|
45 | HOOK_KEYBOARD_COMMAND, |
|
|
46 | |
|
|
47 | HOOK_MOUSE_CLICK, |
|
|
48 | HOOK_MOUSE_MOVE, |
|
|
49 | |
|
|
50 | HOOK_NUM, |
|
|
51 | }; |
48 | }; |
52 | |
49 | |
53 | struct rxvt_perl_interp |
50 | struct rxvt_perl_interp |
54 | { |
51 | { |
55 | rxvt_perl_interp (); |
52 | char **perl_environ; |
|
|
53 | |
|
|
54 | #if 0 // see rxvtperl.xs |
56 | ~rxvt_perl_interp (); |
55 | ~rxvt_perl_interp (); |
57 | |
56 | #endif |
58 | bool should_invoke[HOOK_NUM]; |
|
|
59 | |
57 | |
60 | void init (); |
58 | void init (); |
|
|
59 | void init (rxvt_term *term); |
|
|
60 | void eval (const char *str); |
61 | bool invoke (rxvt_term *term, hook_type htype, ...); |
61 | bool invoke (rxvt_term *term, hook_type htype, ...); |
|
|
62 | void line_update (rxvt_term *term); |
|
|
63 | void selection_finish (rxvt_selection *sel, char *data, unsigned int len); |
|
|
64 | void usage (rxvt_term *term, int type); |
|
|
65 | |
|
|
66 | enum |
|
|
67 | { |
|
|
68 | RESOURCE_AVAILABLE = 1, // whether the option is valid |
|
|
69 | RESOURCE_ARG = 2 // whether the option eats the next arg |
|
|
70 | }; |
|
|
71 | uint8_t parse_resource (rxvt_term *term, const char *name, bool arg, bool longopt, bool flag, const char *value); |
62 | }; |
72 | }; |
63 | |
73 | |
64 | extern struct rxvt_perl_interp rxvt_perl; |
74 | extern struct rxvt_perl_interp rxvt_perl; |
65 | |
75 | |
66 | #else |
76 | #else |
|
|
77 | |
|
|
78 | #define SHOULD_INVOKE(htype) false |
67 | # define PERL_INVOKE(args) false |
79 | #define HOOK_INVOKE(args) false |
|
|
80 | |
68 | #endif |
81 | #endif |
69 | |
82 | |
70 | #endif |
83 | #endif |
71 | |
84 | |