本文整理汇总了PHP中gen_executor_code函数的典型用法代码示例。如果您正苦于以下问题:PHP gen_executor_code函数的具体用法?PHP gen_executor_code怎么用?PHP gen_executor_code使用的例子?那么, 这里精选的函数代码示例或许可以为您提供帮助。
在下文中一共展示了gen_executor_code函数的3个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的PHP代码示例。
示例1: gen_executor
//.........这里部分代码省略.........
out($f, "#endif\n");
out($f, "#ifdef ZEND_VM_FP_GLOBAL_REG\n");
out($f, $m[1] . "zend_execute_data *orig_execute_data = execute_data;\n");
out($f, $m[1] . "execute_data = ex;\n");
out($f, "#else\n");
out($f, $m[1] . "zend_execute_data *execute_data = ex;\n");
out($f, "#endif\n");
}
break;
case "INTERNAL_LABELS":
if ($kind == ZEND_VM_KIND_GOTO) {
// Emit array of labels of opcode handlers and code for
// zend_opcode_handlers initialization
$prolog = $m[1];
out($f, $prolog . "if (UNEXPECTED(execute_data == NULL)) {\n");
out($f, $prolog . "\tstatic const void* labels[] = {\n");
gen_labels($f, $spec, $kind, $prolog . "\t\t");
out($f, $prolog . "\t};\n");
out($f, $prolog . "\tzend_opcode_handlers = (const void **)labels;\n");
out($f, $prolog . "\treturn;\n");
out($f, $prolog . "}\n");
} else {
skip_blanks($f, $m[1], $m[3]);
}
break;
case "ZEND_VM_CONTINUE_LABEL":
if ($kind == ZEND_VM_KIND_CALL) {
// Only SWITCH dispatch method use it
out($f, "#if !defined(ZEND_VM_FP_GLOBAL_REG) || !defined(ZEND_VM_IP_GLOBAL_REG)\n");
out($f, $m[1] . "\tint ret;" . $m[3] . "\n");
out($f, "#endif\n");
} else {
if ($kind == ZEND_VM_KIND_SWITCH) {
// Only SWITCH dispatch method use it
out($f, "zend_vm_continue:" . $m[3] . "\n");
} else {
skip_blanks($f, $m[1], $m[3]);
}
}
break;
case "ZEND_VM_DISPATCH":
// Emit code that dispatches to opcode handler
switch ($kind) {
case ZEND_VM_KIND_CALL:
out($f, "#if defined(ZEND_VM_FP_GLOBAL_REG) && defined(ZEND_VM_IP_GLOBAL_REG)\n");
out($f, $m[1] . "((opcode_handler_t)OPLINE->handler)(ZEND_OPCODE_HANDLER_ARGS_PASSTHRU);\n");
out($f, $m[1] . "if (UNEXPECTED(!OPLINE))" . $m[3] . "\n");
out($f, "#else\n");
out($f, $m[1] . "if (UNEXPECTED((ret = ((opcode_handler_t)OPLINE->handler)(ZEND_OPCODE_HANDLER_ARGS_PASSTHRU)) != 0))" . $m[3] . "\n");
out($f, "#endif\n");
break;
case ZEND_VM_KIND_SWITCH:
out($f, $m[1] . "dispatch_handler = OPLINE->handler;\nzend_vm_dispatch:\n" . $m[1] . "switch ((int)(uintptr_t)dispatch_handler)" . $m[3] . "\n");
break;
case ZEND_VM_KIND_GOTO:
out($f, $m[1] . "goto *(void**)(OPLINE->handler);" . $m[3] . "\n");
break;
}
break;
case "INTERNAL_EXECUTOR":
if ($kind == ZEND_VM_KIND_CALL) {
// Executor is defined as a set of functions
out($f, "#ifdef ZEND_VM_FP_GLOBAL_REG\n" . $m[1] . "execute_data = orig_execute_data;\n" . "# ifdef ZEND_VM_IP_GLOBAL_REG\n" . $m[1] . "opline = orig_opline;\n" . "# endif\n" . $m[1] . "return;\n" . "#else\n" . $m[1] . "if (EXPECTED(ret > 0)) {\n" . $m[1] . "\texecute_data = EG(current_execute_data);\n" . $m[1] . "} else {\n" . "# ifdef ZEND_VM_IP_GLOBAL_REG\n" . $m[1] . "\topline = orig_opline;\n" . "# endif\n" . $m[1] . "\treturn;\n" . $m[1] . "}\n" . "#endif\n");
} else {
// Emit executor code
gen_executor_code($f, $spec, $kind, $m[1]);
}
break;
case "EXTERNAL_EXECUTOR":
if ($kind == ZEND_VM_KIND_CALL) {
gen_executor_code($f, $spec, $kind, $m[1]);
}
break;
case "INITIALIZER_NAME":
out($f, $m[1] . $initializer_name . $m[3] . "\n");
break;
case "EXTERNAL_LABELS":
// Emit code that initializes zend_opcode_handlers array
$prolog = $m[1];
if ($kind == ZEND_VM_KIND_GOTO) {
// Labels are defined in the executor itself, so we call it
// with execute_data NULL and it sets zend_opcode_handlers array
out($f, $prolog . "");
out($f, $prolog . $executor_name . "_ex(NULL);\n");
} else {
out($f, $prolog . "static const void *labels[] = {\n");
gen_labels($f, $spec, $kind, $prolog . "\t");
out($f, $prolog . "};\n");
out($f, $prolog . "zend_opcode_handlers = labels;\n");
}
break;
default:
die("ERROR: Unknown keyword " . $m[2] . " in skeleton file.\n");
}
} else {
// Copy the line as is
out($f, $line);
}
}
}
示例2: gen_executor
//.........这里部分代码省略.........
break;
case "INTERNAL_LABELS":
if ($kind == ZEND_VM_KIND_GOTO) {
// Emit array of labels of opcode handlers and code for
// zend_opcode_handlers initialization
$prolog = $m[1];
out($f, $prolog . "if (execute_data == NULL) {\n");
out($f, $prolog . "\tstatic const opcode_handler_t labels[] = {\n");
gen_labels($f, $spec, $kind, $prolog . "\t\t");
out($f, $prolog . "\t};\n");
out($f, $prolog . "\tzend_opcode_handlers = (opcode_handler_t*)labels;\n");
out($f, $prolog . "\treturn;\n");
out($f, $prolog . "}\n");
} else {
skip_blanks($f, $m[1], $m[3]);
}
break;
case "ZEND_VM_CONTINUE_LABEL":
if ($kind == ZEND_VM_KIND_CALL) {
// Only SWITCH dispatch method use it
out($f, $m[1] . "\tint ret;" . $m[3] . "\n");
} else {
if ($kind == ZEND_VM_KIND_SWITCH) {
// Only SWITCH dispatch method use it
out($f, "zend_vm_continue:" . $m[3] . "\n");
} else {
skip_blanks($f, $m[1], $m[3]);
}
}
break;
case "ZEND_VM_DISPATCH":
// Emit code that dispatches to opcode handler
switch ($kind) {
case ZEND_VM_KIND_CALL:
out($f, $m[1] . "if ((ret = OPLINE->handler(execute_data TSRMLS_CC)) > 0)" . $m[3] . "\n");
break;
case ZEND_VM_KIND_SWITCH:
out($f, $m[1] . "dispatch_handler = OPLINE->handler;\nzend_vm_dispatch:\n" . $m[1] . "switch ((int)dispatch_handler)" . $m[3] . "\n");
break;
case ZEND_VM_KIND_GOTO:
out($f, $m[1] . "goto *(void**)(OPLINE->handler);" . $m[3] . "\n");
break;
}
break;
case "INTERNAL_EXECUTOR":
if ($kind == ZEND_VM_KIND_CALL) {
// Executor is defined as a set of functions
out($f, $m[1] . "switch (ret) {\n" . $m[1] . "\tcase 1:\n" . $m[1] . "\t\tEG(in_execution) = original_in_execution;\n" . $m[1] . "\t\treturn;\n" . $m[1] . "\tcase 2:\n" . $m[1] . "\t\tgoto zend_vm_enter;\n" . $m[1] . "\t\tbreak;\n" . $m[1] . "\tcase 3:\n" . $m[1] . "\t\texecute_data = EG(current_execute_data);\n" . $m[1] . "\t\tbreak;\n" . $m[1] . "\tdefault:\n" . $m[1] . "\t\tbreak;\n" . $m[1] . "}" . $m[3] . "\n");
} else {
// Emit executor code
gen_executor_code($f, $spec, $kind, $m[1]);
}
break;
case "EXTERNAL_EXECUTOR":
if ($kind == ZEND_VM_KIND_CALL) {
// Unspecialized executor with CALL threading is the same as the
// old one, so we don't need to produce code twitch
if (!$old || ZEND_VM_SPEC || ZEND_VM_KIND != ZEND_VM_KIND_CALL) {
// Emit executor code
gen_executor_code($f, $spec, $kind, $m[1]);
}
}
break;
case "INITIALIZER_NAME":
out($f, $m[1] . $initializer_name . $m[3] . "\n");
break;
case "EXTERNAL_LABELS":
// Emit code that initializes zend_opcode_handlers array
$prolog = $m[1];
if ($kind == ZEND_VM_KIND_GOTO) {
// Labels are defined in the executor itself, so we call it
// with execute_data NULL and it sets zend_opcode_handlers array
out($f, $prolog . "TSRMLS_FETCH();\n");
out($f, $prolog . $executor_name . "_ex(NULL TSRMLS_CC);\n");
} else {
if ($old) {
// Reserving space for user-defined opcodes
out($f, $prolog . "static opcode_handler_t labels[512] = {\n");
} else {
out($f, $prolog . "static const opcode_handler_t labels[] = {\n");
}
gen_labels($f, $spec, $kind, $prolog . "\t");
out($f, $prolog . "};\n");
out($f, $prolog . "zend_opcode_handlers = (opcode_handler_t*)labels;\n");
if ($old) {
// Setup old executor
out($f, $prolog . "zend_vm_old_executor = 1;\n");
out($f, $prolog . "zend_execute = old_execute;\n");
}
}
break;
default:
die("ERROR: Unknown keyword " . $m[2] . " in skeleton file.\n");
}
} else {
// Copy the line as is
out($f, $line);
}
}
}
示例3: gen_executor
//.........这里部分代码省略.........
$prolog = $m[1];
out($f, $prolog . "if (op_array == NULL) {\n");
out($f, $prolog . "\tstatic const opcode_handler_t labels[] = {\n");
gen_labels($f, $spec, $kind, $prolog . "\t\t");
out($f, $prolog . "\t};\n");
out($f, $prolog . "\tzend_opcode_handlers = (opcode_handler_t*)labels;\n");
out($f, $prolog . "\treturn;\n");
out($f, $prolog . "}\n");
} else {
skip_blanks($f, $m[1], $m[3]);
}
break;
case "ZEND_VM_CONTINUE_LABEL":
if ($kind == ZEND_VM_KIND_SWITCH) {
// Only SWITCH dispatch method use it
out($f, "zend_vm_continue:" . $m[3] . "\n");
} else {
skip_blanks($f, $m[1], $m[3]);
}
break;
case "ZEND_VM_DISPATCH":
// Emit code that dispatches to opcode handler
switch ($kind) {
case ZEND_VM_KIND_CALL:
out($f, $m[1] . "if (EX(opline)->handler(&execute_data TSRMLS_CC) > 0)" . $m[3] . "\n");
break;
case ZEND_VM_KIND_SWITCH:
out($f, $m[1] . "dispatch_handler = EX(opline)->handler;\nzend_vm_dispatch:\n" . $m[1] . "switch ((int)dispatch_handler)" . $m[3] . "\n");
break;
case ZEND_VM_KIND_GOTO:
case ZEND_VM_KIND_GOTO2:
out($f, $m[1] . "goto *(void**)(EX(opline)->handler);" . $m[3] . "\n");
break;
}
break;
case "INTERNAL_EXECUTOR":
if ($kind == ZEND_VM_KIND_CALL) {
// Executor is defined as a set of functions
out($f, $m[1] . "return;" . $m[3] . "\n");
} else {
// Emit executor code
gen_executor_code($f, $spec, $kind, $m[1]);
}
break;
case "EXTERNAL_EXECUTOR":
if ($kind == ZEND_VM_KIND_CALL) {
// Unspecialized executor with CALL threading is the same as the
// old one, so we don't need to produce code twitch
if (!$old || ZEND_VM_SPEC || ZEND_VM_KIND != ZEND_VM_KIND_CALL) {
out($f, "#undef EX\n");
out($f, "#define EX(element) execute_data->element\n\n");
// Emit executor code
gen_executor_code($f, $spec, $kind, $m[1]);
}
}
break;
case "EXECUTE_DATA_ASSIGN":
if ($kind == ZEND_VM_KIND_GOTO2) {
out($f, $m[1] . "EG(current_execute_data) = execute_data;" . $m[3] . "\n");
} else {
out($f, $m[1] . "EG(current_execute_data) = &execute_data;" . $m[3] . "\n");
}
break;
case "INITIALIZER_NAME":
out($f, $m[1] . $initializer_name . $m[3] . "\n");
break;
case "EXTERNAL_LABELS":
// Emit code that initializes zend_opcode_handlers array
$prolog = $m[1];
if ($kind == ZEND_VM_KIND_GOTO || $kind == ZEND_VM_KIND_GOTO2) {
// Labels are defined in the executor itself, so we call it
// with op_array NULL and it sets zend_opcode_handlers array
out($f, $prolog . "TSRMLS_FETCH();\n");
out($f, $prolog . "zend_execute(NULL TSRMLS_CC);\n");
} else {
if ($old) {
// Reserving space for user-defined opcodes
out($f, $prolog . "static opcode_handler_t labels[512] = {\n");
} else {
out($f, $prolog . "static const opcode_handler_t labels[] = {\n");
}
gen_labels($f, $spec, $kind, $prolog . "\t");
out($f, $prolog . "};\n");
out($f, $prolog . "zend_opcode_handlers = (opcode_handler_t*)labels;\n");
if ($old) {
// Setup old executor
out($f, $prolog . "zend_vm_old_executor = 1;\n");
out($f, $prolog . "zend_execute = old_execute;\n");
}
}
break;
default:
die("ERROR: Unknown keyword " . $m[2] . " in skeleton file.\n");
}
} else {
// Copy the line as is
out($f, $line);
}
}
}