Current Path: > > opt > cloudlinux > alt-php80 > root > usr > include > php > Zend
Operation : Linux premium131.web-hosting.com 4.18.0-553.44.1.lve.el8.x86_64 #1 SMP Thu Mar 13 14:29:12 UTC 2025 x86_64 Software : Apache Server IP : 162.0.232.56 | Your IP: 216.73.216.111 Domains : 1034 Domain(s) Permission : [ 0755 ]
Name | Type | Size | Last Modified | Actions |
---|---|---|---|---|
zend.h | File | 13855 bytes | July 09 2025 08:40:01. | |
zend_API.h | File | 92119 bytes | July 09 2025 08:40:01. | |
zend_alloc.h | File | 19293 bytes | July 09 2025 08:40:01. | |
zend_alloc_sizes.h | File | 2629 bytes | July 09 2025 08:40:01. | |
zend_arena.h | File | 6073 bytes | July 09 2025 08:40:01. | |
zend_ast.h | File | 12616 bytes | July 09 2025 08:40:01. | |
zend_attributes.h | File | 5235 bytes | July 09 2025 08:40:01. | |
zend_attributes_arginfo.h | File | 503 bytes | July 09 2025 08:40:01. | |
zend_bitset.h | File | 7940 bytes | July 09 2025 08:40:01. | |
zend_build.h | File | 1626 bytes | July 09 2025 08:40:01. | |
zend_builtin_functions.h | File | 1513 bytes | July 09 2025 08:40:01. | |
zend_builtin_functions_arginfo.h | File | 13014 bytes | July 09 2025 08:40:01. | |
zend_closures.h | File | 2216 bytes | July 09 2025 08:40:01. | |
zend_closures_arginfo.h | File | 1751 bytes | July 09 2025 08:40:01. | |
zend_compile.h | File | 44860 bytes | July 09 2025 08:40:01. | |
zend_config.h | File | 32 bytes | July 09 2025 08:40:02. | |
zend_constants.h | File | 6485 bytes | July 09 2025 08:40:01. | |
zend_cpuinfo.h | File | 7492 bytes | July 09 2025 08:40:01. | |
zend_dtrace.h | File | 2050 bytes | July 09 2025 08:40:01. | |
zend_errors.h | File | 2400 bytes | July 09 2025 08:40:01. | |
zend_exceptions.h | File | 4114 bytes | July 09 2025 08:40:01. | |
zend_exceptions_arginfo.h | File | 8098 bytes | July 09 2025 08:40:01. | |
zend_execute.h | File | 18683 bytes | July 09 2025 08:40:01. | |
zend_extensions.h | File | 6194 bytes | July 09 2025 08:40:01. | |
zend_float.h | File | 15438 bytes | July 09 2025 08:40:01. | |
zend_gc.h | File | 3942 bytes | July 09 2025 08:40:01. | |
zend_gdb.h | File | 1420 bytes | July 09 2025 08:40:01. | |
zend_generators.h | File | 7433 bytes | July 09 2025 08:40:01. | |
zend_generators_arginfo.h | File | 2015 bytes | July 09 2025 08:40:01. | |
zend_globals.h | File | 8066 bytes | July 09 2025 08:40:01. | |
zend_globals_macros.h | File | 2810 bytes | July 09 2025 08:40:01. | |
zend_hash.h | File | 38614 bytes | July 09 2025 08:40:01. | |
zend_highlight.h | File | 2289 bytes | July 09 2025 08:40:01. | |
zend_inheritance.h | File | 1967 bytes | July 09 2025 08:40:01. | |
zend_ini.h | File | 10117 bytes | July 09 2025 08:40:01. | |
zend_ini_parser.h | File | 2730 bytes | July 09 2025 08:40:01. | |
zend_ini_scanner.h | File | 1889 bytes | July 09 2025 08:40:02. | |
zend_ini_scanner_defs.h | File | 225 bytes | July 09 2025 08:40:02. | |
zend_interfaces.h | File | 4437 bytes | July 09 2025 08:40:02. | |
zend_interfaces_arginfo.h | File | 5287 bytes | July 09 2025 08:40:02. | |
zend_istdiostream.h | File | 1537 bytes | July 09 2025 08:40:02. | |
zend_iterators.h | File | 3581 bytes | July 09 2025 08:40:02. | |
zend_language_parser.h | File | 5960 bytes | July 09 2025 08:40:02. | |
zend_language_scanner.h | File | 3058 bytes | July 09 2025 08:40:02. | |
zend_language_scanner_defs.h | File | 310 bytes | July 09 2025 08:40:02. | |
zend_list.h | File | 3475 bytes | July 09 2025 08:40:02. | |
zend_llist.h | File | 3802 bytes | July 09 2025 08:40:02. | |
zend_long.h | File | 4246 bytes | July 09 2025 08:40:02. | |
zend_map_ptr.h | File | 3474 bytes | July 09 2025 08:40:02. | |
zend_modules.h | File | 4830 bytes | July 09 2025 08:40:02. | |
zend_multibyte.h | File | 4897 bytes | July 09 2025 08:40:02. | |
zend_multiply.h | File | 9846 bytes | July 09 2025 08:40:02. | |
zend_object_handlers.h | File | 13854 bytes | July 09 2025 08:40:02. | |
zend_objects.h | File | 1814 bytes | July 09 2025 08:40:02. | |
zend_objects_API.h | File | 4701 bytes | July 09 2025 08:40:02. | |
zend_observer.h | File | 3419 bytes | July 09 2025 08:40:02. | |
zend_operators.h | File | 31181 bytes | July 09 2025 08:40:02. | |
zend_portability.h | File | 20848 bytes | July 09 2025 08:40:02. | |
zend_ptr_stack.h | File | 4306 bytes | July 09 2025 08:40:02. | |
zend_range_check.h | File | 3000 bytes | July 09 2025 08:40:02. | |
zend_signal.h | File | 4084 bytes | July 09 2025 08:40:02. | |
zend_smart_str.h | File | 5378 bytes | July 09 2025 08:40:02. | |
zend_smart_str_public.h | File | 1127 bytes | July 09 2025 08:40:02. | |
zend_smart_string.h | File | 4237 bytes | July 09 2025 08:40:02. | |
zend_smart_string_public.h | File | 1240 bytes | July 09 2025 08:40:02. | |
zend_sort.h | File | 1535 bytes | July 09 2025 08:40:02. | |
zend_stack.h | File | 2364 bytes | July 09 2025 08:40:02. | |
zend_stream.h | File | 3558 bytes | July 09 2025 08:40:02. | |
zend_string.h | File | 18710 bytes | July 09 2025 08:40:02. | |
zend_strtod.h | File | 1854 bytes | July 09 2025 08:40:02. | |
zend_strtod_int.h | File | 3414 bytes | July 09 2025 08:40:02. | |
zend_system_id.h | File | 1404 bytes | July 09 2025 08:40:02. | |
zend_ts_hash.h | File | 5469 bytes | July 09 2025 08:40:02. | |
zend_type_info.h | File | 3755 bytes | July 09 2025 08:40:02. | |
zend_types.h | File | 44902 bytes | July 09 2025 08:40:02. | |
zend_variables.h | File | 3065 bytes | July 09 2025 08:40:02. | |
zend_virtual_cwd.h | File | 12613 bytes | July 09 2025 08:40:02. | |
zend_vm.h | File | 1952 bytes | July 09 2025 08:40:02. | |
zend_vm_def.h | File | 279918 bytes | July 09 2025 08:40:02. | |
zend_vm_execute.h | File | 2073552 bytes | July 09 2025 08:40:02. | |
zend_vm_handlers.h | File | 91415 bytes | July 09 2025 08:40:02. | |
zend_vm_opcodes.h | File | 12523 bytes | July 09 2025 08:40:02. | |
zend_vm_trace_handlers.h | File | 3212 bytes | July 09 2025 08:40:02. | |
zend_vm_trace_lines.h | File | 1755 bytes | July 09 2025 08:40:02. | |
zend_vm_trace_map.h | File | 2661 bytes | July 09 2025 08:40:02. | |
zend_weakrefs.h | File | 1713 bytes | July 09 2025 08:40:02. | |
zend_weakrefs_arginfo.h | File | 2549 bytes | July 09 2025 08:40:02. |
/* +----------------------------------------------------------------------+ | Zend Engine | +----------------------------------------------------------------------+ | Copyright (c) Zend Technologies Ltd. (http://www.zend.com) | +----------------------------------------------------------------------+ | This source file is subject to version 2.00 of the Zend license, | | that is bundled with this package in the file LICENSE, and is | | available through the world-wide-web at the following url: | | http://www.zend.com/license/2_00.txt. | | If you did not receive a copy of the Zend license and are unable to | | obtain it through the world-wide-web, please send a note to | | license@zend.com so we can mail you a copy immediately. | +----------------------------------------------------------------------+ | Authors: Nikita Popov <nikic@php.net> | | Bob Weinand <bobwei9@hotmail.com> | +----------------------------------------------------------------------+ */ #ifndef ZEND_GENERATORS_H #define ZEND_GENERATORS_H BEGIN_EXTERN_C() extern ZEND_API zend_class_entry *zend_ce_generator; extern ZEND_API zend_class_entry *zend_ce_ClosedGeneratorException; typedef struct _zend_generator_node zend_generator_node; typedef struct _zend_generator zend_generator; /* The concept of `yield from` exposes problems when accessed at different levels of the chain of delegated generators. We need to be able to reference the currently executed Generator in all cases and still being able to access the return values of finished Generators. * The solution to this problem is a doubly-linked tree, which all Generators referenced in maintain a reference to. It should be impossible to avoid walking the tree in all cases. This way, we only need tree walks from leaf to root in case where some part of the `yield from` chain is passed to another `yield from`. (Update of leaf node pointer and list of multi-children nodes needed when leaf gets a child in direct path from leaf to root node.) But only in that case, which should be a fairly rare case (which is then possible, but not totally cheap). * The root of the tree is then the currently executed Generator. The subnodes of the tree (all except the root node) are all Generators which do `yield from`. Each node of the tree knows a pointer to one leaf descendant node. Each node with multiple children needs a list of all leaf descendant nodes paired with pointers to their respective child node. (The stack is determined by leaf node pointers) Nodes with only one child just don't need a list, there it is enough to just have a pointer to the child node. Further, leaf nodes store a pointer to the root node. * That way, when we advance any generator, we just need to look up a leaf node (which all have a reference to a root node). Then we can see at the root node whether current Generator is finished. If it isn't, all is fine and we can just continue. If the Generator finished, there will be two cases. Either it is a simple node with just one child, then go down to child node. Or it has multiple children and we now will remove the current leaf node from the list of nodes (unnecessary, is microoptimization) and go down to the child node whose reference was paired with current leaf node. Child node is then removed its parent reference and becomes new top node. Or the current node references the Generator we're currently executing, then we can continue from the YIELD_FROM opcode. When a node referenced as root node in a leaf node has a parent, then we go the way up until we find a root node without parent. * In case we go into a new `yield from` level, a node is created on top of current root and becomes the new root. Leaf node needs to be updated with new root node then. * When a Generator referenced by a node of the tree is added to `yield from`, that node now gets a list of children (we need to walk the descendants of that node and nodes of the tree of the other Generator down to the first multi-children node and copy all the leaf node pointers from there). In case there was no multi-children node (linear tree), we just add a pair (pointer to leaf node, pointer to child node), with the child node being in a direct path from leaf to this node. */ struct _zend_generator_node { zend_generator *parent; /* NULL for root */ uint32_t children; union { HashTable *ht; /* if multiple children */ struct { /* if one child */ zend_generator *leaf; /* TODO: Unused, remove. */ zend_generator *child; } single; } child; /* One generator can cache a direct pointer to the current root. * The leaf member points back to the generator using the root cache. */ union { zend_generator *leaf; /* if parent != NULL */ zend_generator *root; /* if parent == NULL */ } ptr; }; struct _zend_generator { zend_object std; /* The suspended execution context. */ zend_execute_data *execute_data; /* Frozen call stack for "yield" used in context of other calls */ zend_execute_data *frozen_call_stack; /* Current value */ zval value; /* Current key */ zval key; /* Return value */ zval retval; /* Variable to put sent value into */ zval *send_target; /* Largest used integer key for auto-incrementing keys */ zend_long largest_used_integer_key; /* Values specified by "yield from" to yield from this generator. * This is only used for arrays or non-generator Traversables. * This zval also uses the u2 structure in the same way as * by-value foreach. */ zval values; /* Node of waiting generators when multiple "yield from" expressions * are nested. */ zend_generator_node node; /* Fake execute_data for stacktraces */ zend_execute_data execute_fake; /* ZEND_GENERATOR_* flags */ zend_uchar flags; }; static const zend_uchar ZEND_GENERATOR_CURRENTLY_RUNNING = 0x1; static const zend_uchar ZEND_GENERATOR_FORCED_CLOSE = 0x2; static const zend_uchar ZEND_GENERATOR_AT_FIRST_YIELD = 0x4; static const zend_uchar ZEND_GENERATOR_DO_INIT = 0x8; void zend_register_generator_ce(void); ZEND_API void zend_generator_close(zend_generator *generator, zend_bool finished_execution); ZEND_API void zend_generator_resume(zend_generator *generator); ZEND_API void zend_generator_restore_call_stack(zend_generator *generator); ZEND_API zend_execute_data* zend_generator_freeze_call_stack(zend_execute_data *execute_data); void zend_generator_yield_from(zend_generator *generator, zend_generator *from); ZEND_API zend_execute_data *zend_generator_check_placeholder_frame(zend_execute_data *ptr); ZEND_API zend_generator *zend_generator_update_current(zend_generator *generator); ZEND_API zend_generator *zend_generator_update_root(zend_generator *generator); static zend_always_inline zend_generator *zend_generator_get_current(zend_generator *generator) { if (EXPECTED(generator->node.parent == NULL)) { /* we're not in yield from mode */ return generator; } zend_generator *root = generator->node.ptr.root; if (!root) { root = zend_generator_update_root(generator); } if (EXPECTED(root->execute_data)) { /* generator still running */ return root; } return zend_generator_update_current(generator); } END_EXTERN_C() #endif
SILENT KILLER Tool