summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJoe Watkins <krakjoe@php.net>2016-05-04 10:54:29 +0100
committerJoe Watkins <krakjoe@php.net>2016-05-04 10:54:29 +0100
commitdc78e02ad240094e286174fab84881a32f58d070 (patch)
tree16da212bc82632ca0e433e39a78f9b253bb4b20d
parentc38310f25a418fad80a8a81f8b376553f57be164 (diff)
parent9bbee305e3bb1d85ddad6bad92409818953207d5 (diff)
downloadphp-git-dc78e02ad240094e286174fab84881a32f58d070.tar.gz
Merge branch 'PHP-7.0'
* PHP-7.0: add compiler option to disable builtins (special case function calls)
-rw-r--r--Zend/zend_compile.c10
-rw-r--r--Zend/zend_compile.h3
2 files changed, 11 insertions, 2 deletions
diff --git a/Zend/zend_compile.c b/Zend/zend_compile.c
index 3adcc55f4e..46c057e4f2 100644
--- a/Zend/zend_compile.c
+++ b/Zend/zend_compile.c
@@ -3563,6 +3563,14 @@ int zend_try_compile_special_func(znode *result, zend_string *lcname, zend_ast_l
return FAILURE;
}
+ if (zend_string_equals_literal(lcname, "assert")) {
+ return zend_compile_assert(result, args, lcname, fbc);
+ }
+
+ if (CG(compiler_options) & ZEND_COMPILE_NO_BUILTINS) {
+ return FAILURE;
+ }
+
if (zend_string_equals_literal(lcname, "strlen")) {
return zend_compile_func_strlen(result, args);
} else if (zend_string_equals_literal(lcname, "is_null")) {
@@ -3597,8 +3605,6 @@ int zend_try_compile_special_func(znode *result, zend_string *lcname, zend_ast_l
return zend_compile_func_cufa(result, args, lcname);
} else if (zend_string_equals_literal(lcname, "call_user_func")) {
return zend_compile_func_cuf(result, args, lcname);
- } else if (zend_string_equals_literal(lcname, "assert")) {
- return zend_compile_assert(result, args, lcname, fbc);
} else {
return FAILURE;
}
diff --git a/Zend/zend_compile.h b/Zend/zend_compile.h
index f716dc51ff..f52d22a384 100644
--- a/Zend/zend_compile.h
+++ b/Zend/zend_compile.h
@@ -1019,6 +1019,9 @@ END_EXTERN_C()
/* force IS_OBJ_USE_GUARDS for all classes */
#define ZEND_COMPILE_GUARDS (1<<9)
+/* disable builtin special case function calls */
+#define ZEND_COMPILE_NO_BUILTINS (1<<10)
+
/* The default value for CG(compiler_options) */
#define ZEND_COMPILE_DEFAULT ZEND_COMPILE_HANDLE_OP_ARRAY