From 6d6fadeb0d9923c3dd99a9381bd26a26bf28ccec Mon Sep 17 00:00:00 2001 From: Bogdan Ungureanu Date: Tue, 3 Nov 2020 00:18:12 +0200 Subject: [PATCH] Improved error message for typed class properties with null as default value Closes GH-6396. --- .../union_nullable_property_fails.phpt | 15 +++++++++++++++ Zend/zend_compile.c | 7 +++++-- 2 files changed, 20 insertions(+), 2 deletions(-) create mode 100644 Zend/tests/nullable_types/union_nullable_property_fails.phpt diff --git a/Zend/tests/nullable_types/union_nullable_property_fails.phpt b/Zend/tests/nullable_types/union_nullable_property_fails.phpt new file mode 100644 index 0000000000..809f7d3032 --- /dev/null +++ b/Zend/tests/nullable_types/union_nullable_property_fails.phpt @@ -0,0 +1,15 @@ +--TEST-- +Nullable default property error message +--FILE-- +b; + +?> +--EXPECTF-- +Fatal error: Default value for property of type string|int may not be null. Use the nullable type string|int|null to allow null default value in %s on line %d diff --git a/Zend/zend_compile.c b/Zend/zend_compile.c index 60b0948a47..0fd9c04330 100644 --- a/Zend/zend_compile.c +++ b/Zend/zend_compile.c @@ -7042,10 +7042,13 @@ void zend_compile_prop_decl(zend_ast *ast, zend_ast *type_ast, uint32_t flags, z && !zend_is_valid_default_value(type, &value_zv)) { zend_string *str = zend_type_to_string(type); if (Z_TYPE(value_zv) == IS_NULL) { + ZEND_TYPE_FULL_MASK(type) |= MAY_BE_NULL; + zend_string *nullable_str = zend_type_to_string(type); + zend_error_noreturn(E_COMPILE_ERROR, "Default value for property of type %s may not be null. " - "Use the nullable type ?%s to allow null default value", - ZSTR_VAL(str), ZSTR_VAL(str)); + "Use the nullable type %s to allow null default value", + ZSTR_VAL(str), ZSTR_VAL(nullable_str)); } else { zend_error_noreturn(E_COMPILE_ERROR, "Cannot use %s as default value for property %s::$%s of type %s", -- 2.40.0