source: trunk/processor/processor.m4 @ 189

Last change on this file since 189 was 189, checked in by moo, 8 years ago

call op_array_ctor handler on restore to be more compatible with other zend_extension

File size: 17.9 KB
Line 
1dnl ================
2/* {{{ Pre-declare */
3DECL_STRUCT_P_FUNC(`zval')
4DECL_STRUCT_P_FUNC(`zval_ptr')
5DECL_STRUCT_P_FUNC(`zend_op_array')
6DECL_STRUCT_P_FUNC(`zend_class_entry')
7#ifdef HAVE_XCACHE_CONSTANT
8DECL_STRUCT_P_FUNC(`zend_constant')
9#endif
10DECL_STRUCT_P_FUNC(`zend_function')
11DECL_STRUCT_P_FUNC(`xc_entry_t')
12#ifdef ZEND_ENGINE_2
13DECL_STRUCT_P_FUNC(`zend_property_info')
14#endif
15/* }}} */
16dnl ====================================================
17dnl {{{ zend_compiled_variable
18#ifdef IS_CV
19DEF_STRUCT_P_FUNC(`zend_compiled_variable', , `
20    DISPATCH(int, name_len)
21    PROC_ZSTRING_L(, name, name_len)
22    DISPATCH(ulong, hash_value)
23')
24#endif
25dnl }}}
26dnl {{{ zend_uint
27DEF_STRUCT_P_FUNC(`zend_uint', , `
28    IFCOPY(`dst[0] = src[0];')
29    IFDPRINT(`
30        INDENT()
31        fprintf(stderr, "%u\n", src[0]);
32    ')
33    DONE_SIZE(sizeof(src[0]))
34')
35dnl }}}
36dnl {{{ int
37#ifndef ZEND_ENGINE_2
38DEF_STRUCT_P_FUNC(`int', , `
39    IFCOPY(`*dst = *src;')
40    IFDPRINT(`
41        INDENT()
42        fprintf(stderr, "%d\n", src[0]);
43    ')
44    DONE_SIZE(sizeof(src[0]))
45')
46#endif
47dnl }}}
48dnl {{{ zend_try_catch_element
49#ifdef ZEND_ENGINE_2
50DEF_STRUCT_P_FUNC(`zend_try_catch_element', , `
51    DISPATCH(zend_uint, try_op)
52    DISPATCH(zend_uint, catch_op)
53')
54#endif /* ifdef ZEND_ENGINE_2 */
55dnl }}}
56dnl {{{ zend_brk_cont_element
57DEF_STRUCT_P_FUNC(`zend_brk_cont_element', , `
58    DISPATCH(int, cont)
59    DISPATCH(int, brk)
60    DISPATCH(int, parent)
61')
62dnl }}}
63DEF_HASH_TABLE_FUNC(`HashTable_zval_ptr',           `zval_ptr')
64#ifdef HAVE_XCACHE_CONSTANT
65DEF_HASH_TABLE_FUNC(`HashTable_zend_constant',      `zend_constant')
66#endif
67DEF_HASH_TABLE_FUNC(`HashTable_zend_function',      `zend_function')
68#ifdef ZEND_ENGINE_2
69DEF_HASH_TABLE_FUNC(`HashTable_zend_property_info', `zend_property_info')
70#endif
71DEF_STRUCT_P_FUNC(`zval', , `dnl {{{
72    IFDASM(`do {
73        zval_dtor(dst);
74        *dst = *src;
75        zval_copy_ctor(dst);
76        ZVAL_REFCOUNT(dst) = 1;
77        DONE(value)
78        DONE(refcount)
79        DONE(type)
80        DONE(is_ref)
81    } while(0);
82    return;
83    ', `
84        dnl IFDASM else
85        /* Variable information */
86dnl {{{ zvalue_value
87        DISABLECHECK(`
88        switch (src->type & ~IS_CONSTANT_INDEX) {
89            case IS_LONG:
90            case IS_RESOURCE:
91            case IS_BOOL:
92                DISPATCH(long, value.lval)
93                break;
94            case IS_DOUBLE:
95                DISPATCH(double, value.dval)
96                break;
97            case IS_NULL:
98                IFDPRINT(`INDENT()`'fprintf(stderr, "\tNULL\n");')
99                break;
100
101            case IS_CONSTANT:
102#ifdef IS_UNICODE
103                if (UG(unicode)) {
104                    goto proc_unicode;
105                }
106#endif
107            case IS_STRING:
108#ifdef FLAG_IS_BC
109            case FLAG_IS_BC:
110#endif
111                DISPATCH(int, value.str.len)
112                PROC_STRING_L(value.str.val, value.str.len)
113                break;
114#ifdef IS_UNICODE
115            case IS_UNICODE:
116proc_unicode:
117                DISPATCH(int32_t, value.uni.len)
118                PROC_ZSTRING_L(1, value.uni.val, value.uni.len)
119                break;
120#endif
121
122            case IS_ARRAY:
123            case IS_CONSTANT_ARRAY:
124                STRUCT_P(HashTable, value.ht, HashTable_zval_ptr)
125                break;
126
127            case IS_OBJECT:
128                IFNOTMEMCPY(`IFCOPY(`memcpy(dst, src, sizeof(src[0]));')')
129                dnl STRUCT(value.obj)
130#ifndef ZEND_ENGINE_2
131                STRUCT_P(zend_class_entry, value.obj.ce)
132                STRUCT_P(HashTable, value.obj.properties, HashTable_zval_ptr)
133#endif
134                break;
135
136            default:
137                assert(0);
138        }
139        ')
140dnl }}}
141        DONE(value)
142        DISPATCH(zval_data_type, type)
143        DISPATCH(zend_uchar, is_ref)
144        DISPATCH(zend_ushort, refcount)
145    ')dnl IFDASM
146')
147dnl }}}
148DEF_STRUCT_P_FUNC(`zval_ptr', , `dnl {{{
149    IFDASM(`
150        pushdefFUNC_NAME(`zval')
151        FUNC_NAME (dst, src[0] TSRMLS_CC);
152        popdef(`FUNC_NAME')
153    ', `
154        do {
155            IFCALCCOPY(`
156                if (processor->reference) {
157                    zval_ptr *ppzv;
158                    if (zend_hash_find(&processor->zvalptrs, (char *)src[0], sizeof(src[0]), (void**)&ppzv) == SUCCESS) {
159                        IFCOPY(`
160                            dst[0] = *ppzv;
161                            /* *dst is updated */
162                            dnl fprintf(stderr, "*dst is set to %p\n", dst[0]);
163                        ')
164                        IFSTORE(`assert(xc_is_shm(dst[0]));')
165                        IFRESTORE(`assert(!xc_is_shm(dst[0]));')
166                        break;
167                    }
168                }
169            ')
170           
171            ALLOC(dst[0], zval)
172            IFCALCCOPY(`
173                if (processor->reference) {
174                    IFCALC(`
175                        /* make dummy */
176                        zval_ptr pzv = (zval_ptr)-1;
177                    ', `
178                        zval_ptr pzv = dst[0];
179                    ')
180                    if (zend_hash_add(&processor->zvalptrs, (char *)src[0], sizeof(src[0]), (void*)&pzv, sizeof(pzv), NULL) == SUCCESS) {
181                        /* first add, go on */
182                        dnl fprintf(stderr, "mark[%p] = %p\n", src[0], pzv);
183                    }
184                    else {
185                        assert(0);
186                    }
187                }
188            ')
189            IFCOPY(`
190                dnl fprintf(stderr, "copy from %p to %p\n", src[0], dst[0]);
191            ')
192            STRUCT_P_EX(zval, dst[0], src[0], `[0]', `', ` ')
193        } while (0);
194    ')
195    DONE_SIZE(sizeof(zval_ptr))
196')
197dnl }}}
198dnl {{{ zend_arg_info
199#ifdef ZEND_ENGINE_2
200DEF_STRUCT_P_FUNC(`zend_arg_info', , `
201    DISPATCH(zend_uint, name_len)
202    PROC_ZSTRING_L(, name, name_len)
203    DISPATCH(zend_uint, class_name_len)
204    PROC_ZSTRING_L(, class_name, class_name_len)
205    DISPATCH(zend_bool, array_type_hint)
206    DISPATCH(zend_bool, allow_null)
207    DISPATCH(zend_bool, pass_by_reference)
208    DISPATCH(zend_bool, return_reference)
209    DISPATCH(int, required_num_args)
210')
211#endif
212dnl }}}
213#ifdef HAVE_XCACHE_CONSTANT
214DEF_STRUCT_P_FUNC(`zend_constant', , `dnl {{{
215    STRUCT(zval, value)
216    DISPATCH(int, flags)
217    DISPATCH(uint, name_len)
218    PROC_ZSTRING_L(, name, name_len)
219    DISPATCH(int, module_number)
220')
221dnl }}}
222#endif
223DEF_STRUCT_P_FUNC(`zend_function', , `dnl {{{
224    DISABLECHECK(`
225    switch (src->type) {
226    case ZEND_INTERNAL_FUNCTION:
227    case ZEND_OVERLOADED_FUNCTION:
228        IFNOTMEMCPY(`IFCOPY(`memcpy(dst, src, sizeof(src[0]));')')
229        break;
230
231    case ZEND_USER_FUNCTION:
232    case ZEND_EVAL_CODE:
233        DONE(type)
234        STRUCT(zend_op_array, op_array)
235        break;
236
237    default:
238        assert(0);
239    }
240    ')
241    DONE_SIZE(sizeof(src[0]))
242')
243dnl }}}
244dnl {{{ zend_property_info
245#ifdef ZEND_ENGINE_2
246DEF_STRUCT_P_FUNC(`zend_property_info', , `
247    DISPATCH(zend_uint, flags)
248    DISPATCH(int, name_length)
249    PROC_ZSTRING_L(, name, name_length)
250    DISPATCH(ulong, h)
251#ifdef ZEND_ENGINE_2_1
252    DISPATCH(int, doc_comment_len)
253    PROC_STRING_L(doc_comment, doc_comment_len)
254#endif
255    dnl isnt in php6 yet
256#if defined(ZEND_ENGINE_2_2) && !defined(IS_UNICODE)
257    PROC_CLASS_ENTRY_P(ce)
258#endif
259')
260#endif
261dnl }}}
262DEF_STRUCT_P_FUNC(`zend_class_entry', , `dnl {{{
263    IFCOPY(`
264        processor->active_class_entry_src = src;
265        processor->active_class_entry_dst = dst;
266    ')
267    DISPATCH(char, type)
268    DISPATCH(zend_uint, name_length)
269    PROC_ZSTRING_L(, name, name_length)
270    IFRESTORE(`
271#ifndef ZEND_ENGINE_2
272        /* just copy parent and resolve on install_class */
273        COPY(parent)
274#else
275        PROC_CLASS_ENTRY_P(parent)
276#endif
277    ', `
278        PROC_CLASS_ENTRY_P(parent)
279    ')
280#ifdef ZEND_ENGINE_2
281    DISPATCH(int, refcount)
282#else
283    STRUCT_P(int, refcount)
284#endif
285    DISPATCH(zend_bool, constants_updated)
286#ifdef ZEND_ENGINE_2
287    DISPATCH(zend_uint, ce_flags)
288#endif
289
290    STRUCT(HashTable, default_properties, HashTable_zval_ptr)
291    IFCOPY(`dst->builtin_functions = src->builtin_functions;')
292    DONE(builtin_functions)
293#ifdef ZEND_ENGINE_2
294    STRUCT(HashTable, properties_info, HashTable_zend_property_info)
295#   ifdef ZEND_ENGINE_2_1
296    STRUCT(HashTable, default_static_members, HashTable_zval_ptr)
297    IFCOPY(`dst->static_members = &dst->default_static_members;')
298    DONE(static_members)
299#   else
300    STRUCT_P(HashTable, static_members, HashTable_zval_ptr)
301#   endif
302    STRUCT(HashTable, constants_table, HashTable_zval_ptr)
303
304    dnl runtime binding: ADD_INTERFACE will deal with it
305    IFRESTORE(`
306        if (src->num_interfaces) {
307            CALLOC(dst->interfaces, zend_class_entry*, src->num_interfaces)
308            DONE(`interfaces')
309        }
310        else {
311            COPYNULL(interfaces)
312        }
313    ')
314    IFDASM(`
315        if (src->num_interfaces) {
316            /*
317            zval *arr;
318            ALLOC_INIT_ZVAL(arr);
319            array_init(arr);
320            for (i = 0; i < src->num_interfaces; i ++) {
321                zval *zv;
322                ALLOC_INIT_ZVAL(zv);
323                ZVAL_STRING(src->num_interfaces);
324            }
325            add_assoc_zval_ex(dst, ZEND_STRS("interfaces"), arr);
326            */
327            DONE(`interfaces')
328        }
329        else {
330            COPYNULL(interfaces)
331        }
332    ')
333    IFRESTORE(`', `
334        IFDASM(`', `
335            DONE(`interfaces')
336        ')
337    ')
338    DISPATCH(zend_uint, num_interfaces)
339
340    IFRESTORE(`COPY(filename)', `PROC_STRING(filename)')
341    DISPATCH(zend_uint, line_start)
342    DISPATCH(zend_uint, line_end)
343#ifdef ZEND_ENGINE_2_1
344    DISPATCH(zend_uint, doc_comment_len)
345    PROC_STRING_L(doc_comment, doc_comment_len)
346#endif
347    /* # NOT DONE */
348    COPY(serialize_func)
349    COPY(unserialize_func)
350    COPY(iterator_funcs)
351    COPY(create_object)
352    COPY(get_iterator)
353    COPY(interface_gets_implemented)
354    COPY(serialize)
355    COPY(unserialize)
356    /* deal with it inside xc_fix_method */
357    SETNULL(constructor)
358    COPY(destructor)
359    COPY(clone)
360    COPY(__get)
361    COPY(__set)
362/* should be >5.1 */
363#ifdef ZEND_ENGINE_2_1
364    COPY(__unset)
365    COPY(__isset)
366# if defined(ZEND_ENGINE_2_2) || PHP_MAJOR_VERSION >= 6
367    COPY(__tostring)
368# endif
369#endif
370    COPY(__call)
371    /* # NOT DONE */
372    COPY(module)
373#else
374    COPY(handle_function_call)
375    COPY(handle_property_get)
376    COPY(handle_property_set)
377#endif
378    dnl must do after SETNULL(constructor) and dst->parent
379    STRUCT(HashTable, function_table, HashTable_zend_function)
380    IFRESTORE(`dst->function_table.pDestructor = ZEND_FUNCTION_DTOR;')
381    IFCOPY(`
382        processor->active_class_entry_src = NULL;
383        processor->active_class_entry_dst = NULL;
384    ')
385')
386dnl }}}
387DEF_STRUCT_P_FUNC(`znode', , `dnl {{{
388    DISPATCH(int, op_type)
389
390#ifdef IS_CV
391#   define XCACHE_IS_CV IS_CV
392#else
393/* compatible with zend optimizer */
394#   define XCACHE_IS_CV 16
395#endif
396    assert(src->op_type == IS_CONST ||
397        src->op_type == IS_VAR ||
398        src->op_type == XCACHE_IS_CV ||
399        src->op_type == IS_TMP_VAR ||
400        src->op_type == IS_UNUSED);
401#undef XCACHE_IS_CV
402    dnl dirty dispatch
403    DISABLECHECK(`
404    switch (src->op_type) {
405        case IS_CONST:
406            STRUCT(zval, u.constant)
407            break;
408        IFCOPY(`
409            IFNOTMEMCPY(`
410                default:
411                    memcpy(&dst->u, &src->u, sizeof(src->u));
412            ')
413        ', `
414        case IS_VAR:
415        case IS_TMP_VAR:
416#ifdef IS_CV
417        case IS_CV:
418#else
419        case 16:
420#endif
421            DISPATCH(zend_uint, u.var)
422            DISPATCH(zend_uint, u.EA.type)
423            break;
424        case IS_UNUSED:
425            IFDASM(`DISPATCH(zend_uint, u.var)')
426            DISPATCH(zend_uint, u.opline_num)
427#ifndef ZEND_ENGINE_2
428            DISPATCH(zend_uint, u.fetch_type)
429#endif
430            DISPATCH(zend_uint, u.EA.type)
431            break;
432        ')
433    }
434    ')
435    DONE(u)
436')
437dnl }}}
438DEF_STRUCT_P_FUNC(`zend_op', , `dnl {{{
439    DISPATCH(zend_uchar, opcode)
440    STRUCT(znode, result)
441    STRUCT(znode, op1)
442    STRUCT(znode, op2)
443    DISPATCH(ulong, extended_value)
444    DISPATCH(uint, lineno)
445#ifdef ZEND_ENGINE_2_1
446    IFCOPY(`
447        switch (src->opcode) {
448            case ZEND_JMP:
449                dst->op1.u.jmp_addr = processor->active_opcodes_dst + (src->op1.u.jmp_addr - processor->active_opcodes_src);
450                break;
451
452            case ZEND_JMPZ:
453            case ZEND_JMPNZ:
454            case ZEND_JMPZ_EX:
455            case ZEND_JMPNZ_EX:
456                dst->op2.u.jmp_addr = processor->active_opcodes_dst + (src->op2.u.jmp_addr - processor->active_opcodes_src);
457                break;
458
459            default:
460                break;
461        }
462    ')
463    DISPATCH(opcode_handler_t, handler)
464#endif
465')
466dnl }}}
467DEF_STRUCT_P_FUNC(`zend_op_array', , `dnl {{{
468    IFRESTORE(`
469    if (!processor->readonly_protection) {
470        /* really fast shallow copy */
471        memcpy(dst, src, sizeof(src[0]));
472        dst->refcount[0] = 1000;
473        /* deep */
474        STRUCT_P(HashTable, static_variables, HashTable_zval_ptr)
475        define(`SKIPASSERT_ONCE')
476    }
477    else
478    ')
479    do {
480    dnl RESTORE is done above!
481    zend_uint ii;
482    int i;
483
484    /* Common elements */
485    DISPATCH(zend_uchar, type)
486    PROC_ZSTRING(, function_name)
487#ifdef ZEND_ENGINE_2
488    DISPATCH(zend_uint, fn_flags)
489    dnl mark it as -1 on store, and lookup parent on restore
490    IFSTORE(`dst->prototype = (processor->active_class_entry_src && src->prototype) ? (zend_function *) -1 : NULL; DONE(prototype)', `
491            IFRESTORE(`do {
492                zend_function *parent;
493                if (src->prototype != NULL
494                 && zend_u_hash_find(&(processor->active_class_entry_dst->parent->function_table),
495                        UG(unicode) ? IS_UNICODE : IS_STRING,
496                        src->function_name, xc_zstrlen(UG(unicode), src->function_name) + 1,
497                        (void **) &parent) == SUCCESS) {
498                    /* see do_inherit_method_check() */
499                    if ((parent->common.fn_flags & ZEND_ACC_ABSTRACT)) {
500                      dst->prototype = parent;
501                    }
502                    else {
503                        dst->prototype = parent->common.prototype;
504                    }
505                }
506                else {
507                    dst->prototype = NULL;
508                }
509                DONE(prototype)
510            } while (0);
511            ', `
512                COPYNULL(prototype)
513            ')
514    ')
515    STRUCT_ARRAY_I(num_args, zend_arg_info, arg_info)
516    DISPATCH(zend_uint, num_args)
517    DISPATCH(zend_uint, required_num_args)
518    DISPATCH(zend_bool, pass_rest_by_reference)
519#else
520    if (src->arg_types) {
521        ALLOC(dst->arg_types, zend_uchar, src->arg_types[0] + 1)
522        IFCOPY(`memcpy(dst->arg_types, src->arg_types, sizeof(src->arg_types[0]) * (src->arg_types[0]+1));')
523        IFDASM(`do {
524            zend_uint ii;
525            int i;
526            zval *zv;
527            ALLOC_INIT_ZVAL(zv);
528            array_init(zv);
529            for (i = 0; i < src->arg_types[0]; i ++) {
530                add_next_index_long(zv, src->arg_types[i + 1]);
531            }
532            add_assoc_zval_ex(dst, ZEND_STRS("arg_types"), zv);
533        } while (0);')
534        DONE(arg_types)
535    }
536    else {
537        IFDASM(`do {
538            /* empty array */
539            zval *zv;
540            ALLOC_INIT_ZVAL(zv);
541            array_init(zv);
542            add_assoc_zval_ex(dst, ZEND_STRS("arg_types"), zv);
543        } while (0);
544        DONE(arg_types)
545        ', `
546        COPYNULL(arg_types)
547        ')
548    }
549#endif
550    DISPATCH(unsigned char, return_reference)
551    /* END of common elements */
552#ifdef IS_UNICODE
553    dnl SETNULL(u_twin)
554#endif
555
556    STRUCT_P(zend_uint, refcount)
557    UNFIXPOINTER(zend_uint, refcount)
558
559    pushdef(`AFTER_ALLOC', `IFCOPY(`
560        processor->active_opcodes_dst = dst->opcodes;
561        processor->active_opcodes_src = src->opcodes;
562    ')')
563    STRUCT_ARRAY_I(last, zend_op, opcodes)
564    popdef(`AFTER_ALLOC')
565    DISPATCH(zend_uint, last)
566    IFCOPY(`dst->size = src->last;DONE(size)', `DISPATCH(zend_uint, size)')
567
568#ifdef IS_CV
569    STRUCT_ARRAY(last_var, zend_compiled_variable, vars)
570    DISPATCH(int, last_var)
571    IFCOPY(`dst->size_var = src->last_var;DONE(size_var)', `DISPATCH(zend_uint, size_var)')
572#else
573    dnl zend_cv.m4 is illegal to be made public, don not ask me for it
574    IFDASM(`
575        sinclude(srcdir`/processor/zend_cv.m4')
576        ')
577#endif
578
579    DISPATCH(zend_uint, T)
580
581    STRUCT_ARRAY_I(last_brk_cont, zend_brk_cont_element, brk_cont_array)
582    DISPATCH(zend_uint, last_brk_cont)
583    DISPATCH(zend_uint, current_brk_cont)
584#ifndef ZEND_ENGINE_2
585    DISPATCH(zend_bool, uses_globals)
586#endif
587
588#ifdef ZEND_ENGINE_2
589    STRUCT_ARRAY(last_try_catch, zend_try_catch_element, try_catch_array)
590    DISPATCH(int, last_try_catch)
591#endif
592
593    STRUCT_P(HashTable, static_variables, HashTable_zval_ptr)
594
595    COPY(start_op)
596    DISPATCH(int, backpatch_count)
597
598    DISPATCH(zend_bool, done_pass_two)
599#ifdef ZEND_ENGINE_2
600    DISPATCH(zend_bool, uses_this)
601#endif
602
603    IFRESTORE(`COPY(filename)', `PROC_STRING(filename)')
604#ifdef IS_UNICODE
605    PROC_STRING(script_encoding)
606#endif
607#ifdef ZEND_ENGINE_2
608    DISPATCH(zend_uint, line_start)
609    DISPATCH(zend_uint, line_end)
610    DISPATCH(int, doc_comment_len)
611    PROC_STRING_L(doc_comment, doc_comment_len)
612#endif
613
614    /* reserved */
615    DONE(reserved)
616#if defined(HARDENING_PATCH) && HARDENING_PATCH
617    DISPATCH(zend_bool, created_by_eval)
618#endif
619    } while (0);
620
621    IFRESTORE(`
622#ifdef ZEND_ENGINE_2
623        if (dst->scope) {
624            dst->scope = xc_get_class(processor, (zend_ulong) dst->scope);
625            xc_fix_method(processor, dst);
626        }
627        DONE(scope)
628#endif
629    ', `
630#ifdef ZEND_ENGINE_2
631        PROC_CLASS_ENTRY_P(scope)
632#endif
633    ')
634
635    IFRESTORE(`
636        if (xc_have_op_array_ctor) {
637            zend_llist_apply_with_argument(&zend_extensions, (llist_apply_with_arg_func_t) xc_zend_extension_op_array_ctor_handler, dst TSRMLS_CC);
638        }
639    ')
640')
641dnl }}}
642
643#ifdef HAVE_XCACHE_CONSTANT
644DEF_STRUCT_P_FUNC(`xc_constinfo_t', , `dnl {{{
645    DISPATCH(zend_uint, key_size)
646#ifdef IS_UNICODE
647    DISPATCH(zend_uchar, type)
648#endif
649    IFRESTORE(`COPY(key)', `
650        PROC_ZSTRING_N(type, key, key_size)
651    ')
652    STRUCT(zend_constant, constant)
653')
654dnl }}}
655#endif
656DEF_STRUCT_P_FUNC(`xc_funcinfo_t', , `dnl {{{
657    DISPATCH(zend_uint, key_size)
658#ifdef IS_UNICODE
659    DISPATCH(zend_uchar, type)
660#endif
661    IFRESTORE(`COPY(key)', `
662        PROC_ZSTRING_N(type, key, key_size)
663    ')
664    STRUCT(zend_function, func)
665')
666dnl }}}
667DEF_STRUCT_P_FUNC(`xc_classinfo_t', , `dnl {{{
668    DISPATCH(zend_uint, key_size)
669#ifdef IS_UNICODE
670    DISPATCH(zend_uchar, type)
671#endif
672    IFRESTORE(`COPY(key)', `
673        PROC_ZSTRING_N(type, key, key_size)
674    ')
675#ifdef ZEND_ENGINE_2
676    STRUCT_P(zend_class_entry, cest)
677#else
678    STRUCT(zend_class_entry, cest)
679#endif
680')
681dnl }}}
682DEF_STRUCT_P_FUNC(`xc_entry_data_php_t', , `dnl {{{
683    zend_uint i;
684
685#ifdef HAVE_INODE
686    DISPATCH(int, device)
687    DISPATCH(int, inode)
688#endif
689    DISPATCH(size_t, sourcesize)
690
691    DISPATCH(time_t, mtime)
692
693    STRUCT_P(zend_op_array, op_array)
694
695#ifdef HAVE_XCACHE_CONSTANT
696    DISPATCH(zend_uint, constinfo_cnt)
697    STRUCT_ARRAY(constinfo_cnt, xc_constinfo_t, constinfos)
698#endif
699
700    DISPATCH(zend_uint, funcinfo_cnt)
701    STRUCT_ARRAY(funcinfo_cnt, xc_funcinfo_t, funcinfos)
702
703    DISPATCH(zend_uint, classinfo_cnt)
704    pushdef(`BEFORE_LOOP', `
705        IFCOPY(`
706            processor->active_class_num = i + 1;
707        ')
708    ')
709    STRUCT_ARRAY(classinfo_cnt, xc_classinfo_t, classinfos)
710    popdef(`BEFORE_LOOP')
711')
712dnl }}}
713DEF_STRUCT_P_FUNC(`xc_entry_data_var_t', , `dnl {{{
714    IFSTORE(`
715        if (processor->reference) {
716            if (zend_hash_add(&processor->zvalptrs, (char *)&src->value, sizeof(&src->value), (void*)&src->value, sizeof(src->value), NULL) == SUCCESS) {
717                dnl fprintf(stderr, "mark[%p] = %p\n", &src->value, &dst->value);
718            }
719            else {
720                assert(0);
721            }
722        }
723    ')
724    STRUCT_P_EX(zval_ptr, dst->value, src->value, `value', `', `&')
725    DONE(value)
726')
727dnl }}}
728dnl {{{ xc_entry_t
729DEF_STRUCT_P_FUNC(`xc_entry_t', , `
730    IFCOPY(`
731        processor->xce_dst = dst;
732        processor->xce_src = src;
733    ')
734    DISPATCH(xc_entry_type_t, type)
735    DISPATCH(size_t, size)
736
737    DISPATCH(xc_hash_value_t, hvalue)
738    COPY(cache)
739    /* skip */
740    DONE(next)
741
742    IFSTORE(`dst->refcount = 0; DONE(refcount)', `DISPATCH(long, refcount)')
743
744    DISPATCH(time_t, ctime)
745    DISPATCH(time_t, atime)
746    DISPATCH(time_t, dtime)
747    DISPATCH(long, ttl)
748    DISPATCH(zend_ulong, hits)
749#ifdef IS_UNICODE
750    DISPATCH(zend_uchar, name_type)
751#endif
752    dnl {{{ name
753    DISABLECHECK(`
754#ifdef IS_UNICODE
755        if (src->name_type == IS_UNICODE) {
756            DISPATCH(int32_t, name.ustr.len)
757        }
758        else {
759            DISPATCH(int, name.str.len)
760        }
761#else
762        DISPATCH(int, name.str.len)
763#endif
764        IFRESTORE(`COPY(name.str.val)', `
765#ifdef IS_UNICODE
766            PROC_ZSTRING_L(name_type, name.uni.val, name.uni.len)
767#else
768            PROC_STRING_L(name.str.val, name.str.len)
769#endif
770        ')
771    ')
772    DONE(name)
773    dnl }}}
774
775    dnl {{{ data
776    DISABLECHECK(`
777        switch (src->type) {
778        case XC_TYPE_PHP:
779            STRUCT_P(xc_entry_data_php_t, data.php)
780            break;
781        case XC_TYPE_VAR:
782            STRUCT_P(xc_entry_data_var_t, data.var)
783            break;
784        default:
785            assert(0);
786        }
787    ')
788    DONE(data)
789    dnl }}}
790')
791dnl }}}
792dnl ====================================================
Note: See TracBrowser for help on using the repository browser.