Commit | Line | Data |
---|---|---|
f2c01b15 FC |
1 | /* -*- buffer-read-only: t -*- |
2 | !!!!!!! DO NOT EDIT THIS FILE !!!!!!! | |
3 | This file is built by regen/feature.pl. | |
4 | Any changes made here will be lost! | |
5 | */ | |
6 | ||
7 | ||
3dd7db29 JK |
8 | #ifndef PERL_FEATURE_H_ |
9 | #define PERL_FEATURE_H_ | |
10 | ||
f2c01b15 FC |
11 | #if defined(PERL_CORE) || defined (PERL_EXT) |
12 | ||
13 | #define HINT_FEATURE_SHIFT 26 | |
14 | ||
0f2beabb TC |
15 | #define FEATURE_BAREWORD_FILEHANDLES_BIT 0x0001 |
16 | #define FEATURE_BITWISE_BIT 0x0002 | |
17 | #define FEATURE___SUB___BIT 0x0004 | |
18 | #define FEATURE_MYREF_BIT 0x0008 | |
19 | #define FEATURE_EVALBYTES_BIT 0x0010 | |
20 | #define FEATURE_FC_BIT 0x0020 | |
21 | #define FEATURE_INDIRECT_BIT 0x0040 | |
22 | #define FEATURE_ISA_BIT 0x0080 | |
23 | #define FEATURE_MULTIDIMENSIONAL_BIT 0x0100 | |
24 | #define FEATURE_POSTDEREF_QQ_BIT 0x0200 | |
25 | #define FEATURE_REFALIASING_BIT 0x0400 | |
26 | #define FEATURE_SAY_BIT 0x0800 | |
27 | #define FEATURE_SIGNATURES_BIT 0x1000 | |
28 | #define FEATURE_STATE_BIT 0x2000 | |
29 | #define FEATURE_SWITCH_BIT 0x4000 | |
a1325b90 PE |
30 | #define FEATURE_TRY_BIT 0x8000 |
31 | #define FEATURE_UNIEVAL_BIT 0x10000 | |
32 | #define FEATURE_UNICODE_BIT 0x20000 | |
9f601cf3 | 33 | |
f2c01b15 FC |
34 | #define FEATURE_BUNDLE_DEFAULT 0 |
35 | #define FEATURE_BUNDLE_510 1 | |
36 | #define FEATURE_BUNDLE_511 2 | |
37 | #define FEATURE_BUNDLE_515 3 | |
2ad792cd | 38 | #define FEATURE_BUNDLE_523 4 |
401d2aaa | 39 | #define FEATURE_BUNDLE_527 5 |
2b9e0ab7 | 40 | #define FEATURE_BUNDLE_CUSTOM (HINT_FEATURE_MASK >> HINT_FEATURE_SHIFT) |
f2c01b15 | 41 | |
d1fd0100 FC |
42 | #define CURRENT_HINTS \ |
43 | (PL_curcop == &PL_compiling ? PL_hints : PL_curcop->cop_hints) | |
035b6821 FC |
44 | #define CURRENT_FEATURE_BUNDLE \ |
45 | ((CURRENT_HINTS & HINT_FEATURE_MASK) >> HINT_FEATURE_SHIFT) | |
d1fd0100 | 46 | |
9f601cf3 TC |
47 | #define FEATURE_IS_ENABLED_MASK(mask) \ |
48 | ((CURRENT_HINTS & HINT_LOCALIZE_HH) \ | |
49 | ? (PL_curcop->cop_features & (mask)) : FALSE) | |
50 | ||
7d058bc9 | 51 | /* The longest string we pass in. */ |
0f2beabb | 52 | #define MAX_FEATURE_LEN (sizeof("bareword_filehandles")-1) |
7d058bc9 | 53 | |
2a4315f8 BF |
54 | #define FEATURE_FC_IS_ENABLED \ |
55 | ( \ | |
2ad792cd | 56 | (CURRENT_FEATURE_BUNDLE >= FEATURE_BUNDLE_515 && \ |
401d2aaa | 57 | CURRENT_FEATURE_BUNDLE <= FEATURE_BUNDLE_527) \ |
2a4315f8 | 58 | || (CURRENT_FEATURE_BUNDLE == FEATURE_BUNDLE_CUSTOM && \ |
9f601cf3 | 59 | FEATURE_IS_ENABLED_MASK(FEATURE_FC_BIT)) \ |
2a4315f8 BF |
60 | ) |
61 | ||
813e85a0 PE |
62 | #define FEATURE_ISA_IS_ENABLED \ |
63 | ( \ | |
64 | CURRENT_FEATURE_BUNDLE == FEATURE_BUNDLE_CUSTOM && \ | |
65 | FEATURE_IS_ENABLED_MASK(FEATURE_ISA_BIT) \ | |
66 | ) | |
67 | ||
03222170 FC |
68 | #define FEATURE_SAY_IS_ENABLED \ |
69 | ( \ | |
70 | (CURRENT_FEATURE_BUNDLE >= FEATURE_BUNDLE_510 && \ | |
401d2aaa | 71 | CURRENT_FEATURE_BUNDLE <= FEATURE_BUNDLE_527) \ |
03222170 | 72 | || (CURRENT_FEATURE_BUNDLE == FEATURE_BUNDLE_CUSTOM && \ |
9f601cf3 | 73 | FEATURE_IS_ENABLED_MASK(FEATURE_SAY_BIT)) \ |
03222170 FC |
74 | ) |
75 | ||
a1325b90 PE |
76 | #define FEATURE_TRY_IS_ENABLED \ |
77 | ( \ | |
78 | CURRENT_FEATURE_BUNDLE == FEATURE_BUNDLE_CUSTOM && \ | |
79 | FEATURE_IS_ENABLED_MASK(FEATURE_TRY_BIT) \ | |
80 | ) | |
81 | ||
03222170 FC |
82 | #define FEATURE_STATE_IS_ENABLED \ |
83 | ( \ | |
84 | (CURRENT_FEATURE_BUNDLE >= FEATURE_BUNDLE_510 && \ | |
401d2aaa | 85 | CURRENT_FEATURE_BUNDLE <= FEATURE_BUNDLE_527) \ |
03222170 | 86 | || (CURRENT_FEATURE_BUNDLE == FEATURE_BUNDLE_CUSTOM && \ |
9f601cf3 | 87 | FEATURE_IS_ENABLED_MASK(FEATURE_STATE_BIT)) \ |
03222170 FC |
88 | ) |
89 | ||
90 | #define FEATURE_SWITCH_IS_ENABLED \ | |
91 | ( \ | |
92 | (CURRENT_FEATURE_BUNDLE >= FEATURE_BUNDLE_510 && \ | |
401d2aaa | 93 | CURRENT_FEATURE_BUNDLE <= FEATURE_BUNDLE_527) \ |
03222170 | 94 | || (CURRENT_FEATURE_BUNDLE == FEATURE_BUNDLE_CUSTOM && \ |
9f601cf3 | 95 | FEATURE_IS_ENABLED_MASK(FEATURE_SWITCH_BIT)) \ |
03222170 FC |
96 | ) |
97 | ||
cec892e7 FC |
98 | #define FEATURE_BITWISE_IS_ENABLED \ |
99 | ( \ | |
401d2aaa FC |
100 | CURRENT_FEATURE_BUNDLE == FEATURE_BUNDLE_527 \ |
101 | || (CURRENT_FEATURE_BUNDLE == FEATURE_BUNDLE_CUSTOM && \ | |
9f601cf3 | 102 | FEATURE_IS_ENABLED_MASK(FEATURE_BITWISE_BIT)) \ |
cec892e7 FC |
103 | ) |
104 | ||
0b657b19 DIM |
105 | #define FEATURE_INDIRECT_IS_ENABLED \ |
106 | ( \ | |
107 | CURRENT_FEATURE_BUNDLE <= FEATURE_BUNDLE_527 \ | |
108 | || (CURRENT_FEATURE_BUNDLE == FEATURE_BUNDLE_CUSTOM && \ | |
109 | FEATURE_IS_ENABLED_MASK(FEATURE_INDIRECT_BIT)) \ | |
110 | ) | |
111 | ||
03222170 FC |
112 | #define FEATURE_EVALBYTES_IS_ENABLED \ |
113 | ( \ | |
2ad792cd | 114 | (CURRENT_FEATURE_BUNDLE >= FEATURE_BUNDLE_515 && \ |
401d2aaa | 115 | CURRENT_FEATURE_BUNDLE <= FEATURE_BUNDLE_527) \ |
03222170 | 116 | || (CURRENT_FEATURE_BUNDLE == FEATURE_BUNDLE_CUSTOM && \ |
9f601cf3 | 117 | FEATURE_IS_ENABLED_MASK(FEATURE_EVALBYTES_BIT)) \ |
03222170 FC |
118 | ) |
119 | ||
30d9c59b Z |
120 | #define FEATURE_SIGNATURES_IS_ENABLED \ |
121 | ( \ | |
122 | CURRENT_FEATURE_BUNDLE == FEATURE_BUNDLE_CUSTOM && \ | |
9f601cf3 | 123 | FEATURE_IS_ENABLED_MASK(FEATURE_SIGNATURES_BIT) \ |
30d9c59b Z |
124 | ) |
125 | ||
03222170 FC |
126 | #define FEATURE___SUB___IS_ENABLED \ |
127 | ( \ | |
2ad792cd | 128 | (CURRENT_FEATURE_BUNDLE >= FEATURE_BUNDLE_515 && \ |
401d2aaa | 129 | CURRENT_FEATURE_BUNDLE <= FEATURE_BUNDLE_527) \ |
03222170 | 130 | || (CURRENT_FEATURE_BUNDLE == FEATURE_BUNDLE_CUSTOM && \ |
9f601cf3 | 131 | FEATURE_IS_ENABLED_MASK(FEATURE___SUB___BIT)) \ |
03222170 FC |
132 | ) |
133 | ||
baabe3fb | 134 | #define FEATURE_REFALIASING_IS_ENABLED \ |
7b1dc818 FC |
135 | ( \ |
136 | CURRENT_FEATURE_BUNDLE == FEATURE_BUNDLE_CUSTOM && \ | |
9f601cf3 | 137 | FEATURE_IS_ENABLED_MASK(FEATURE_REFALIASING_BIT) \ |
7b1dc818 FC |
138 | ) |
139 | ||
158becca FC |
140 | #define FEATURE_POSTDEREF_QQ_IS_ENABLED \ |
141 | ( \ | |
401d2aaa FC |
142 | (CURRENT_FEATURE_BUNDLE >= FEATURE_BUNDLE_523 && \ |
143 | CURRENT_FEATURE_BUNDLE <= FEATURE_BUNDLE_527) \ | |
2ad792cd | 144 | || (CURRENT_FEATURE_BUNDLE == FEATURE_BUNDLE_CUSTOM && \ |
9f601cf3 | 145 | FEATURE_IS_ENABLED_MASK(FEATURE_POSTDEREF_QQ_BIT)) \ |
158becca FC |
146 | ) |
147 | ||
03222170 FC |
148 | #define FEATURE_UNIEVAL_IS_ENABLED \ |
149 | ( \ | |
2ad792cd | 150 | (CURRENT_FEATURE_BUNDLE >= FEATURE_BUNDLE_515 && \ |
401d2aaa | 151 | CURRENT_FEATURE_BUNDLE <= FEATURE_BUNDLE_527) \ |
03222170 | 152 | || (CURRENT_FEATURE_BUNDLE == FEATURE_BUNDLE_CUSTOM && \ |
9f601cf3 | 153 | FEATURE_IS_ENABLED_MASK(FEATURE_UNIEVAL_BIT)) \ |
03222170 FC |
154 | ) |
155 | ||
82d83da3 FC |
156 | #define FEATURE_MYREF_IS_ENABLED \ |
157 | ( \ | |
158 | CURRENT_FEATURE_BUNDLE == FEATURE_BUNDLE_CUSTOM && \ | |
9f601cf3 | 159 | FEATURE_IS_ENABLED_MASK(FEATURE_MYREF_BIT) \ |
82d83da3 FC |
160 | ) |
161 | ||
03222170 FC |
162 | #define FEATURE_UNICODE_IS_ENABLED \ |
163 | ( \ | |
164 | (CURRENT_FEATURE_BUNDLE >= FEATURE_BUNDLE_511 && \ | |
401d2aaa | 165 | CURRENT_FEATURE_BUNDLE <= FEATURE_BUNDLE_527) \ |
03222170 | 166 | || (CURRENT_FEATURE_BUNDLE == FEATURE_BUNDLE_CUSTOM && \ |
9f601cf3 | 167 | FEATURE_IS_ENABLED_MASK(FEATURE_UNICODE_BIT)) \ |
03222170 FC |
168 | ) |
169 | ||
1ad5a39c TC |
170 | #define FEATURE_MULTIDIMENSIONAL_IS_ENABLED \ |
171 | ( \ | |
172 | CURRENT_FEATURE_BUNDLE <= FEATURE_BUNDLE_527 \ | |
173 | || (CURRENT_FEATURE_BUNDLE == FEATURE_BUNDLE_CUSTOM && \ | |
174 | FEATURE_IS_ENABLED_MASK(FEATURE_MULTIDIMENSIONAL_BIT)) \ | |
175 | ) | |
176 | ||
0f2beabb TC |
177 | #define FEATURE_BAREWORD_FILEHANDLES_IS_ENABLED \ |
178 | ( \ | |
179 | CURRENT_FEATURE_BUNDLE <= FEATURE_BUNDLE_527 \ | |
180 | || (CURRENT_FEATURE_BUNDLE == FEATURE_BUNDLE_CUSTOM && \ | |
181 | FEATURE_IS_ENABLED_MASK(FEATURE_BAREWORD_FILEHANDLES_BIT)) \ | |
182 | ) | |
183 | ||
03222170 | 184 | |
9f601cf3 TC |
185 | #define SAVEFEATUREBITS() SAVEI32(PL_compiling.cop_features) |
186 | ||
187 | #define CLEARFEATUREBITS() (PL_compiling.cop_features = 0) | |
188 | ||
189 | #define STOREFEATUREBITSHH(hh) \ | |
190 | (hv_stores((hh), "feature/bits", newSVuv(PL_compiling.cop_features))) | |
191 | ||
192 | #define FETCHFEATUREBITSHH(hh) \ | |
193 | STMT_START { \ | |
194 | SV **fbsv = hv_fetchs((hh), "feature/bits", FALSE); \ | |
195 | PL_compiling.cop_features = fbsv ? SvUV(*fbsv) : 0; \ | |
196 | } STMT_END | |
197 | ||
f2c01b15 FC |
198 | #endif /* PERL_CORE or PERL_EXT */ |
199 | ||
4160ddbd FC |
200 | #ifdef PERL_IN_OP_C |
201 | PERL_STATIC_INLINE void | |
202 | S_enable_feature_bundle(pTHX_ SV *ver) | |
203 | { | |
204 | SV *comp_ver = sv_newmortal(); | |
205 | PL_hints = (PL_hints &~ HINT_FEATURE_MASK) | |
206 | | ( | |
401d2aaa FC |
207 | (sv_setnv(comp_ver, 5.027), |
208 | vcmp(ver, upg_version(comp_ver, FALSE)) >= 0) | |
209 | ? FEATURE_BUNDLE_527 : | |
2ad792cd AC |
210 | (sv_setnv(comp_ver, 5.023), |
211 | vcmp(ver, upg_version(comp_ver, FALSE)) >= 0) | |
212 | ? FEATURE_BUNDLE_523 : | |
4160ddbd FC |
213 | (sv_setnv(comp_ver, 5.015), |
214 | vcmp(ver, upg_version(comp_ver, FALSE)) >= 0) | |
215 | ? FEATURE_BUNDLE_515 : | |
216 | (sv_setnv(comp_ver, 5.011), | |
217 | vcmp(ver, upg_version(comp_ver, FALSE)) >= 0) | |
218 | ? FEATURE_BUNDLE_511 : | |
219 | (sv_setnv(comp_ver, 5.009005), | |
220 | vcmp(ver, upg_version(comp_ver, FALSE)) >= 0) | |
221 | ? FEATURE_BUNDLE_510 : | |
222 | FEATURE_BUNDLE_DEFAULT | |
223 | ) << HINT_FEATURE_SHIFT; | |
6389c777 FC |
224 | /* special case */ |
225 | assert(PL_curcop == &PL_compiling); | |
226 | if (FEATURE_UNICODE_IS_ENABLED) PL_hints |= HINT_UNI_8_BIT; | |
227 | else PL_hints &= ~HINT_UNI_8_BIT; | |
4160ddbd FC |
228 | } |
229 | #endif /* PERL_IN_OP_C */ | |
230 | ||
b34c1a7e TC |
231 | #ifdef PERL_IN_MG_C |
232 | ||
233 | #define magic_sethint_feature(keysv, keypv, keylen, valsv, valbool) \ | |
234 | S_magic_sethint_feature(aTHX_ (keysv), (keypv), (keylen), (valsv), (valbool)) | |
235 | PERL_STATIC_INLINE void | |
236 | S_magic_sethint_feature(pTHX_ SV *keysv, const char *keypv, STRLEN keylen, | |
237 | SV *valsv, bool valbool) { | |
238 | if (keysv) | |
239 | keypv = SvPV_const(keysv, keylen); | |
240 | ||
241 | if (memBEGINs(keypv, keylen, "feature_")) { | |
242 | const char *subf = keypv + (sizeof("feature_")-1); | |
243 | U32 mask = 0; | |
244 | switch (*subf) { | |
245 | case '_': | |
246 | if (keylen == sizeof("feature___SUB__")-1 | |
247 | && memcmp(subf+1, "_SUB__", keylen - sizeof("feature_")) == 0) { | |
248 | mask = FEATURE___SUB___BIT; | |
249 | break; | |
250 | } | |
251 | return; | |
252 | ||
253 | case 'b': | |
0f2beabb TC |
254 | if (keylen == sizeof("feature_bareword_filehandles")-1 |
255 | && memcmp(subf+1, "areword_filehandles", keylen - sizeof("feature_")) == 0) { | |
256 | mask = FEATURE_BAREWORD_FILEHANDLES_BIT; | |
257 | break; | |
258 | } | |
259 | else if (keylen == sizeof("feature_bitwise")-1 | |
b34c1a7e TC |
260 | && memcmp(subf+1, "itwise", keylen - sizeof("feature_")) == 0) { |
261 | mask = FEATURE_BITWISE_BIT; | |
262 | break; | |
263 | } | |
264 | return; | |
265 | ||
266 | case 'e': | |
267 | if (keylen == sizeof("feature_evalbytes")-1 | |
268 | && memcmp(subf+1, "valbytes", keylen - sizeof("feature_")) == 0) { | |
269 | mask = FEATURE_EVALBYTES_BIT; | |
270 | break; | |
271 | } | |
272 | return; | |
273 | ||
274 | case 'f': | |
275 | if (keylen == sizeof("feature_fc")-1 | |
276 | && memcmp(subf+1, "c", keylen - sizeof("feature_")) == 0) { | |
277 | mask = FEATURE_FC_BIT; | |
278 | break; | |
279 | } | |
280 | return; | |
281 | ||
813e85a0 | 282 | case 'i': |
0b657b19 DIM |
283 | if (keylen == sizeof("feature_indirect")-1 |
284 | && memcmp(subf+1, "ndirect", keylen - sizeof("feature_")) == 0) { | |
285 | mask = FEATURE_INDIRECT_BIT; | |
286 | break; | |
287 | } | |
288 | else if (keylen == sizeof("feature_isa")-1 | |
813e85a0 PE |
289 | && memcmp(subf+1, "sa", keylen - sizeof("feature_")) == 0) { |
290 | mask = FEATURE_ISA_BIT; | |
291 | break; | |
292 | } | |
293 | return; | |
294 | ||
b34c1a7e | 295 | case 'm': |
1ad5a39c TC |
296 | if (keylen == sizeof("feature_multidimensional")-1 |
297 | && memcmp(subf+1, "ultidimensional", keylen - sizeof("feature_")) == 0) { | |
298 | mask = FEATURE_MULTIDIMENSIONAL_BIT; | |
299 | break; | |
300 | } | |
301 | else if (keylen == sizeof("feature_myref")-1 | |
b34c1a7e TC |
302 | && memcmp(subf+1, "yref", keylen - sizeof("feature_")) == 0) { |
303 | mask = FEATURE_MYREF_BIT; | |
304 | break; | |
305 | } | |
306 | return; | |
307 | ||
308 | case 'p': | |
309 | if (keylen == sizeof("feature_postderef_qq")-1 | |
310 | && memcmp(subf+1, "ostderef_qq", keylen - sizeof("feature_")) == 0) { | |
311 | mask = FEATURE_POSTDEREF_QQ_BIT; | |
312 | break; | |
313 | } | |
314 | return; | |
315 | ||
316 | case 'r': | |
317 | if (keylen == sizeof("feature_refaliasing")-1 | |
318 | && memcmp(subf+1, "efaliasing", keylen - sizeof("feature_")) == 0) { | |
319 | mask = FEATURE_REFALIASING_BIT; | |
320 | break; | |
321 | } | |
322 | return; | |
323 | ||
324 | case 's': | |
325 | if (keylen == sizeof("feature_say")-1 | |
326 | && memcmp(subf+1, "ay", keylen - sizeof("feature_")) == 0) { | |
327 | mask = FEATURE_SAY_BIT; | |
328 | break; | |
329 | } | |
330 | else if (keylen == sizeof("feature_signatures")-1 | |
331 | && memcmp(subf+1, "ignatures", keylen - sizeof("feature_")) == 0) { | |
332 | mask = FEATURE_SIGNATURES_BIT; | |
333 | break; | |
334 | } | |
335 | else if (keylen == sizeof("feature_state")-1 | |
336 | && memcmp(subf+1, "tate", keylen - sizeof("feature_")) == 0) { | |
337 | mask = FEATURE_STATE_BIT; | |
338 | break; | |
339 | } | |
340 | else if (keylen == sizeof("feature_switch")-1 | |
341 | && memcmp(subf+1, "witch", keylen - sizeof("feature_")) == 0) { | |
342 | mask = FEATURE_SWITCH_BIT; | |
343 | break; | |
344 | } | |
345 | return; | |
346 | ||
a1325b90 PE |
347 | case 't': |
348 | if (keylen == sizeof("feature_try")-1 | |
349 | && memcmp(subf+1, "ry", keylen - sizeof("feature_")) == 0) { | |
350 | mask = FEATURE_TRY_BIT; | |
351 | break; | |
352 | } | |
353 | return; | |
354 | ||
b34c1a7e TC |
355 | case 'u': |
356 | if (keylen == sizeof("feature_unicode")-1 | |
357 | && memcmp(subf+1, "nicode", keylen - sizeof("feature_")) == 0) { | |
358 | mask = FEATURE_UNICODE_BIT; | |
359 | break; | |
360 | } | |
361 | else if (keylen == sizeof("feature_unieval")-1 | |
362 | && memcmp(subf+1, "nieval", keylen - sizeof("feature_")) == 0) { | |
363 | mask = FEATURE_UNIEVAL_BIT; | |
364 | break; | |
365 | } | |
366 | return; | |
367 | ||
368 | default: | |
369 | return; | |
370 | } | |
371 | if (valsv ? SvTRUE(valsv) : valbool) | |
372 | PL_compiling.cop_features |= mask; | |
373 | else | |
374 | PL_compiling.cop_features &= ~mask; | |
375 | } | |
376 | } | |
377 | #endif /* PERL_IN_MG_C */ | |
378 | ||
3dd7db29 JK |
379 | #endif /* PERL_FEATURE_H_ */ |
380 | ||
f2c01b15 | 381 | /* ex: set ro: */ |