Skip to content

Commit 7efcbec

Browse files
committed
Merge branch 'PHP-5.4' into PHP-5.5
* PHP-5.4: Fixed ability to build non-specialized GOTO VM Conflicts: Zend/zend_vm_gen.php
2 parents 02dca18 + 9ed6058 commit 7efcbec

File tree

1 file changed

+9
-3
lines changed

1 file changed

+9
-3
lines changed

Zend/zend_vm_gen.php

Lines changed: 9 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -884,9 +884,15 @@ function gen_executor($f, $skl, $spec, $kind, $executor_name, $initializer_name,
884884
out($f,"#undef CHECK_EXCEPTION\n");
885885
out($f,"#undef HANDLE_EXCEPTION\n");
886886
out($f,"#undef HANDLE_EXCEPTION_LEAVE\n");
887-
out($f,"#define CHECK_EXCEPTION() if (UNEXPECTED(EG(exception) != NULL)) goto ZEND_HANDLE_EXCEPTION_SPEC_HANDLER\n");
888-
out($f,"#define HANDLE_EXCEPTION() goto ZEND_HANDLE_EXCEPTION_SPEC_HANDLER\n");
889-
out($f,"#define HANDLE_EXCEPTION_LEAVE() goto ZEND_HANDLE_EXCEPTION_SPEC_HANDLER\n");
887+
if (ZEND_VM_SPEC) {
888+
out($f,"#define CHECK_EXCEPTION() if (UNEXPECTED(EG(exception) != NULL)) goto ZEND_HANDLE_EXCEPTION_SPEC_HANDLER\n");
889+
out($f,"#define HANDLE_EXCEPTION() goto ZEND_HANDLE_EXCEPTION_SPEC_HANDLER\n");
890+
out($f,"#define HANDLE_EXCEPTION_LEAVE() goto ZEND_HANDLE_EXCEPTION_SPEC_HANDLER\n");
891+
} else {
892+
out($f,"#define CHECK_EXCEPTION() if (UNEXPECTED(EG(exception) != NULL)) goto ZEND_HANDLE_EXCEPTION_HANDLER\n");
893+
out($f,"#define HANDLE_EXCEPTION() goto ZEND_HANDLE_EXCEPTION_HANDLER\n");
894+
out($f,"#define HANDLE_EXCEPTION_LEAVE() goto ZEND_HANDLE_EXCEPTION_HANDLER\n");
895+
}
890896
out($f,"#define LOAD_REGS()\n");
891897
out($f,"#define ZEND_VM_CONTINUE() goto *(void**)(OPLINE->handler)\n");
892898
out($f,"#define ZEND_VM_RETURN() EG(in_execution) = original_in_execution; return\n");

0 commit comments

Comments
 (0)