]> granicus.if.org Git - php/commitdiff
Add opcodes to zend_wrong_string_offset()
authorNikita Popov <nikic@php.net>
Sun, 10 Jul 2016 13:13:21 +0000 (15:13 +0200)
committerNikita Popov <nikic@php.net>
Sun, 10 Jul 2016 13:15:34 +0000 (15:15 +0200)
Zend/tests/string_offset_errors.phpt [new file with mode: 0644]
Zend/zend_execute.c
ext/opcache/Optimizer/zend_inference.c

diff --git a/Zend/tests/string_offset_errors.phpt b/Zend/tests/string_offset_errors.phpt
new file mode 100644 (file)
index 0000000..b709408
--- /dev/null
@@ -0,0 +1,27 @@
+--TEST--
+Some string offset errors
+--FILE--
+<?php
+
+function &test() : string {
+    $str = "foo";
+    return $str[0];
+}
+
+try {
+    test();
+} catch (Error $e) {
+    echo $e->getMessage(), "\n";
+}
+
+try {
+    $str = "foo";
+    $str[0] =& $str[1];
+} catch (Error $e) {
+    echo $e->getMessage(), "\n";
+}
+
+?>
+--EXPECT--
+Cannot return string offsets by reference
+Cannot create references to/from string offsets
index 7c8621fe64ed2384c43656b96ffeab64e29f42ca..d1c73917ca09ac4d100dfb9fc815c14e31a8d270 100644 (file)
@@ -1262,9 +1262,11 @@ static zend_never_inline ZEND_COLD void zend_wrong_string_offset(void)
                                                case ZEND_ASSIGN_REF:
                                                case ZEND_ADD_ARRAY_ELEMENT:
                                                case ZEND_INIT_ARRAY:
+                                               case ZEND_MAKE_REF:
                                                        msg = "Cannot create references to/from string offsets";
                                                        break;
                                                case ZEND_RETURN_BY_REF:
+                                               case ZEND_VERIFY_RETURN_TYPE:
                                                        msg = "Cannot return string offsets by reference";
                                                        break;
                                                case ZEND_UNSET_DIM:
index 4760076f05c529575cb6503579cebeb9f236aed5..c8dd1004d7a3e4a58e9d07ec8d792a18fa46ce40 100644 (file)
@@ -3229,6 +3229,7 @@ static void zend_update_type_info(const zend_op_array *op_array,
                                                case ZEND_ADD_ARRAY_ELEMENT:
                                                case ZEND_RETURN_BY_REF:
                                                case ZEND_VERIFY_RETURN_TYPE:
+                                               case ZEND_MAKE_REF:
                                                        tmp |= MAY_BE_ARRAY_OF_ANY | MAY_BE_ARRAY_OF_REF;
                                                        break;
                                                case ZEND_PRE_INC: