summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--Zend/tests/bug75426.phpt15
-rw-r--r--Zend/zend_compile.c7
2 files changed, 22 insertions, 0 deletions
diff --git a/Zend/tests/bug75426.phpt b/Zend/tests/bug75426.phpt
new file mode 100644
index 0000000000..69e3f19239
--- /dev/null
+++ b/Zend/tests/bug75426.phpt
@@ -0,0 +1,15 @@
+--TEST--
+Bug #75426: "Cannot use empty array elements" reports wrong position
+--FILE--
+<?php
+$a = [
+ 1,
+ 2,
+ 3,
+ ,
+ 5,
+ 6,
+];
+?>
+--EXPECTF--
+Fatal error: Cannot use empty array elements in arrays in %s on line 5
diff --git a/Zend/zend_compile.c b/Zend/zend_compile.c
index 77702b3fac..23c3b99968 100644
--- a/Zend/zend_compile.c
+++ b/Zend/zend_compile.c
@@ -6920,6 +6920,7 @@ static inline void zend_ct_eval_greater(zval *result, zend_ast_kind kind, zval *
static zend_bool zend_try_ct_eval_array(zval *result, zend_ast *ast) /* {{{ */
{
zend_ast_list *list = zend_ast_get_list(ast);
+ zend_ast *last_elem_ast = NULL;
uint32_t i;
zend_bool is_constant = 1;
@@ -6932,6 +6933,10 @@ static zend_bool zend_try_ct_eval_array(zval *result, zend_ast *ast) /* {{{ */
zend_ast *elem_ast = list->child[i];
if (elem_ast == NULL) {
+ /* Report error at line of last non-empty element */
+ if (last_elem_ast) {
+ CG(zend_lineno) = zend_ast_get_lineno(last_elem_ast);
+ }
zend_error(E_COMPILE_ERROR, "Cannot use empty array elements in arrays");
}
@@ -6943,6 +6948,8 @@ static zend_bool zend_try_ct_eval_array(zval *result, zend_ast *ast) /* {{{ */
) {
is_constant = 0;
}
+
+ last_elem_ast = elem_ast;
}
if (!is_constant) {