diff options
-rw-r--r-- | 165.patch | 41 | ||||
-rw-r--r-- | ast-upstream.patch | 552 | ||||
-rw-r--r-- | php-ast.spec | 7 |
3 files changed, 557 insertions, 43 deletions
diff --git a/165.patch b/165.patch deleted file mode 100644 index aa0ee41..0000000 --- a/165.patch +++ /dev/null @@ -1,41 +0,0 @@ -From f3523b85992ac1803294882e320c1111d0b9e055 Mon Sep 17 00:00:00 2001 -From: Remi Collet <remi@remirepo.net> -Date: Fri, 17 Jul 2020 11:14:25 +0200 -Subject: [PATCH] relax tests for 8.0 master - ---- - tests/parse_code_parse_error.phpt | 4 ++-- - tests/parse_file_parse_error.phpt | 2 +- - 2 files changed, 3 insertions(+), 3 deletions(-) - -diff --git a/tests/parse_code_parse_error.phpt b/tests/parse_code_parse_error.phpt -index 57504cf..d82c043 100644 ---- a/tests/parse_code_parse_error.phpt -+++ b/tests/parse_code_parse_error.phpt -@@ -18,11 +18,11 @@ try { - - ?> - --EXPECTF-- --ParseError: syntax error, unexpected '&', expecting end of file in string code:1 -+ParseError: syntax error, unexpected %s&%s expecting end of file in string code:1 - Stack trace: - #0 %s(%d): ast\parse_code('%s', %d) - #1 {main} --ParseError: syntax error, unexpected '&', expecting end of file in file.php:1 -+ParseError: syntax error, unexpected %s&%s expecting end of file in file.php:1 - Stack trace: - #0 %s(%d): ast\parse_code('%s', %d, 'file.php') - #1 {main} -diff --git a/tests/parse_file_parse_error.phpt b/tests/parse_file_parse_error.phpt -index 88c0678..8e4a003 100644 ---- a/tests/parse_file_parse_error.phpt -+++ b/tests/parse_file_parse_error.phpt -@@ -11,7 +11,7 @@ try { - - ?> - --EXPECTF-- --ParseError: syntax error, unexpected ')' in %stests/invalid_file.php:3 -+ParseError: syntax error, unexpected %s)%s in %stests/invalid_file.php:3 - Stack trace: - #0 %s(%d): ast\parse_file('%s', %d) - #1 {main} diff --git a/ast-upstream.patch b/ast-upstream.patch new file mode 100644 index 0000000..47e64fa --- /dev/null +++ b/ast-upstream.patch @@ -0,0 +1,552 @@ +diff --git a/README.md b/README.md +index 1017536..adbe819 100644 +--- a/README.md ++++ b/README.md +@@ -256,9 +256,9 @@ ast\flags\CLASS_ANONYMOUS + // Used by ast\AST_PARAM (combinable) + ast\flags\PARAM_REF + ast\flags\PARAM_VARIADIC +-ast\flags\MODIFIER_PUBLIC (only in php 8.0+) +-ast\flags\MODIFIER_PROTECTED (only in php 8.0+) +-ast\flags\MODIFIER_PRIVATE (only in php 8.0+) ++ast\flags\PARAM_MODIFIER_PUBLIC (available since 1.0.8, same as ast\flags\MODIFIER_* in PHP >= 8.0) ++ast\flags\PARAM_MODIFIER_PROTECTED (available since 1.0.8) ++ast\flags\PARAM_MODIFIER_PRIVATE (available since 1.0.8) + + // Used by ast\AST_TYPE (exclusive) + ast\flags\TYPE_ARRAY +@@ -412,6 +412,7 @@ AST_METHOD: name, docComment, params, stmts, returnType, attributes + AST_METHOD_CALL: expr, method, args + AST_METHOD_REFERENCE: class, method + AST_NAME: name ++AST_NAMED_ARG: name, expr // php 8.0 named parameters + AST_NAMESPACE: name, stmts + AST_NEW: class, args + AST_NULLABLE_TYPE: type // Used only since PHP 7.1 +diff --git a/ast.c b/ast.c +index 540a8d8..eeb6b5a 100644 +--- a/ast.c ++++ b/ast.c +@@ -65,6 +65,14 @@ + #if PHP_VERSION_ID < 80000 + # define IS_STATIC 20 + # define IS_MIXED 21 ++/* In PHP 7.0-7.4, PARAM_REF and PARAM_VARIADIC were 1 and 2. */ ++# define PARAM_MODIFIER_PUBLIC (1 << 2) ++# define PARAM_MODIFIER_PROTECTED (1 << 3) ++# define PARAM_MODIFIER_PRIVATE (1 << 4) ++#else ++# define PARAM_MODIFIER_PUBLIC ZEND_ACC_PUBLIC ++# define PARAM_MODIFIER_PROTECTED ZEND_ACC_PROTECTED ++# define PARAM_MODIFIER_PRIVATE ZEND_ACC_PRIVATE + #endif + + /* This contains state of the ast Node creator. */ +@@ -107,11 +115,9 @@ static const char *class_flags[] = { + static const char *param_flags[] = { + AST_FLAG(PARAM_REF), + AST_FLAG(PARAM_VARIADIC), +-#if PHP_VERSION_ID >= 80000 +- AST_FLAG(MODIFIER_PUBLIC), +- AST_FLAG(MODIFIER_PROTECTED), +- AST_FLAG(MODIFIER_PRIVATE), +-#endif ++ AST_FLAG(PARAM_MODIFIER_PUBLIC), ++ AST_FLAG(PARAM_MODIFIER_PROTECTED), ++ AST_FLAG(PARAM_MODIFIER_PRIVATE), + NULL + }; + +@@ -1368,6 +1374,10 @@ PHP_MINIT_FUNCTION(ast) { + ast_register_flag_constant("MODIFIER_ABSTRACT", ZEND_ACC_ABSTRACT); + ast_register_flag_constant("MODIFIER_FINAL", ZEND_ACC_FINAL); + ++ ast_register_flag_constant("PARAM_MODIFIER_PUBLIC", PARAM_MODIFIER_PUBLIC); ++ ast_register_flag_constant("PARAM_MODIFIER_PROTECTED", PARAM_MODIFIER_PROTECTED); ++ ast_register_flag_constant("PARAM_MODIFIER_PRIVATE", PARAM_MODIFIER_PRIVATE); ++ + ast_register_flag_constant("RETURNS_REF", ZEND_ACC_RETURN_REFERENCE); + ast_register_flag_constant("FUNC_RETURNS_REF", ZEND_ACC_RETURN_REFERENCE); + ast_register_flag_constant("FUNC_GENERATOR", ZEND_ACC_GENERATOR); +diff --git a/ast_data.c b/ast_data.c +index 9b6ce55..8538572 100644 +--- a/ast_data.c ++++ b/ast_data.c +@@ -63,6 +63,7 @@ const zend_ast_kind ast_kinds[] = { + ZEND_AST_CLASS_CONST_GROUP, + ZEND_AST_DIM, + ZEND_AST_PROP, ++ ZEND_AST_NULLSAFE_PROP, + ZEND_AST_STATIC_PROP, + ZEND_AST_CALL, + ZEND_AST_CLASS_CONST, +@@ -94,7 +95,9 @@ const zend_ast_kind ast_kinds[] = { + ZEND_AST_ATTRIBUTE, + ZEND_AST_MATCH, + ZEND_AST_MATCH_ARM, ++ ZEND_AST_NAMED_ARG, + ZEND_AST_METHOD_CALL, ++ ZEND_AST_NULLSAFE_METHOD_CALL, + ZEND_AST_STATIC_CALL, + ZEND_AST_CONDITIONAL, + ZEND_AST_TRY, +@@ -170,6 +173,7 @@ const char *ast_kind_to_name(zend_ast_kind kind) { + case ZEND_AST_CLASS_CONST_GROUP: return "AST_CLASS_CONST_GROUP"; + case ZEND_AST_DIM: return "AST_DIM"; + case ZEND_AST_PROP: return "AST_PROP"; ++ case ZEND_AST_NULLSAFE_PROP: return "AST_NULLSAFE_PROP"; + case ZEND_AST_STATIC_PROP: return "AST_STATIC_PROP"; + case ZEND_AST_CALL: return "AST_CALL"; + case ZEND_AST_CLASS_CONST: return "AST_CLASS_CONST"; +@@ -201,7 +205,9 @@ const char *ast_kind_to_name(zend_ast_kind kind) { + case ZEND_AST_ATTRIBUTE: return "AST_ATTRIBUTE"; + case ZEND_AST_MATCH: return "AST_MATCH"; + case ZEND_AST_MATCH_ARM: return "AST_MATCH_ARM"; ++ case ZEND_AST_NAMED_ARG: return "AST_NAMED_ARG"; + case ZEND_AST_METHOD_CALL: return "AST_METHOD_CALL"; ++ case ZEND_AST_NULLSAFE_METHOD_CALL: return "AST_NULLSAFE_METHOD_CALL"; + case ZEND_AST_STATIC_CALL: return "AST_STATIC_CALL"; + case ZEND_AST_CONDITIONAL: return "AST_CONDITIONAL"; + case ZEND_AST_TRY: return "AST_TRY"; +@@ -442,6 +448,12 @@ zend_string *ast_kind_child_name(zend_ast_kind kind, uint32_t child) { + case 1: return AST_STR(str_prop); + } + return NULL; ++ case ZEND_AST_NULLSAFE_PROP: ++ switch (child) { ++ case 0: return AST_STR(str_expr); ++ case 1: return AST_STR(str_prop); ++ } ++ return NULL; + case ZEND_AST_STATIC_PROP: + switch (child) { + case 0: return AST_STR(str_class); +@@ -631,6 +643,12 @@ zend_string *ast_kind_child_name(zend_ast_kind kind, uint32_t child) { + case 1: return AST_STR(str_expr); + } + return NULL; ++ case ZEND_AST_NAMED_ARG: ++ switch (child) { ++ case 0: return AST_STR(str_name); ++ case 1: return AST_STR(str_expr); ++ } ++ return NULL; + case ZEND_AST_METHOD_CALL: + switch (child) { + case 0: return AST_STR(str_expr); +@@ -638,6 +656,13 @@ zend_string *ast_kind_child_name(zend_ast_kind kind, uint32_t child) { + case 2: return AST_STR(str_args); + } + return NULL; ++ case ZEND_AST_NULLSAFE_METHOD_CALL: ++ switch (child) { ++ case 0: return AST_STR(str_expr); ++ case 1: return AST_STR(str_method); ++ case 2: return AST_STR(str_args); ++ } ++ return NULL; + case ZEND_AST_STATIC_CALL: + switch (child) { + case 0: return AST_STR(str_class); +@@ -759,6 +784,7 @@ void ast_register_kind_constants(INIT_FUNC_ARGS) { + REGISTER_NS_LONG_CONSTANT("ast", "AST_CLASS_CONST_GROUP", ZEND_AST_CLASS_CONST_GROUP, CONST_CS | CONST_PERSISTENT); + REGISTER_NS_LONG_CONSTANT("ast", "AST_DIM", ZEND_AST_DIM, CONST_CS | CONST_PERSISTENT); + REGISTER_NS_LONG_CONSTANT("ast", "AST_PROP", ZEND_AST_PROP, CONST_CS | CONST_PERSISTENT); ++ REGISTER_NS_LONG_CONSTANT("ast", "AST_NULLSAFE_PROP", ZEND_AST_NULLSAFE_PROP, CONST_CS | CONST_PERSISTENT); + REGISTER_NS_LONG_CONSTANT("ast", "AST_STATIC_PROP", ZEND_AST_STATIC_PROP, CONST_CS | CONST_PERSISTENT); + REGISTER_NS_LONG_CONSTANT("ast", "AST_CALL", ZEND_AST_CALL, CONST_CS | CONST_PERSISTENT); + REGISTER_NS_LONG_CONSTANT("ast", "AST_CLASS_CONST", ZEND_AST_CLASS_CONST, CONST_CS | CONST_PERSISTENT); +@@ -790,7 +816,9 @@ void ast_register_kind_constants(INIT_FUNC_ARGS) { + REGISTER_NS_LONG_CONSTANT("ast", "AST_ATTRIBUTE", ZEND_AST_ATTRIBUTE, CONST_CS | CONST_PERSISTENT); + REGISTER_NS_LONG_CONSTANT("ast", "AST_MATCH", ZEND_AST_MATCH, CONST_CS | CONST_PERSISTENT); + REGISTER_NS_LONG_CONSTANT("ast", "AST_MATCH_ARM", ZEND_AST_MATCH_ARM, CONST_CS | CONST_PERSISTENT); ++ REGISTER_NS_LONG_CONSTANT("ast", "AST_NAMED_ARG", ZEND_AST_NAMED_ARG, CONST_CS | CONST_PERSISTENT); + REGISTER_NS_LONG_CONSTANT("ast", "AST_METHOD_CALL", ZEND_AST_METHOD_CALL, CONST_CS | CONST_PERSISTENT); ++ REGISTER_NS_LONG_CONSTANT("ast", "AST_NULLSAFE_METHOD_CALL", ZEND_AST_NULLSAFE_METHOD_CALL, CONST_CS | CONST_PERSISTENT); + REGISTER_NS_LONG_CONSTANT("ast", "AST_STATIC_CALL", ZEND_AST_STATIC_CALL, CONST_CS | CONST_PERSISTENT); + REGISTER_NS_LONG_CONSTANT("ast", "AST_CONDITIONAL", ZEND_AST_CONDITIONAL, CONST_CS | CONST_PERSISTENT); + REGISTER_NS_LONG_CONSTANT("ast", "AST_TRY", ZEND_AST_TRY, CONST_CS | CONST_PERSISTENT); +diff --git a/ast_stub.php b/ast_stub.php +index a38f0f6..fb71a54 100644 +--- a/ast_stub.php ++++ b/ast_stub.php +@@ -66,45 +66,48 @@ const AST_GOTO = 285; + const AST_BREAK = 286; + const AST_CONTINUE = 287; + const AST_CLASS_NAME = 276; +-const AST_CLASS_CONST_GROUP = 545; ++const AST_CLASS_CONST_GROUP = 546; + const AST_DIM = 512; + const AST_PROP = 513; +-const AST_STATIC_PROP = 514; +-const AST_CALL = 515; +-const AST_CLASS_CONST = 516; +-const AST_ASSIGN = 517; +-const AST_ASSIGN_REF = 518; +-const AST_ASSIGN_OP = 519; +-const AST_BINARY_OP = 520; +-const AST_ARRAY_ELEM = 525; +-const AST_NEW = 526; +-const AST_INSTANCEOF = 527; +-const AST_YIELD = 528; +-const AST_STATIC = 531; +-const AST_WHILE = 532; +-const AST_DO_WHILE = 533; +-const AST_IF_ELEM = 534; +-const AST_SWITCH = 535; +-const AST_SWITCH_CASE = 536; +-const AST_DECLARE = 537; +-const AST_PROP_ELEM = 774; +-const AST_PROP_GROUP = 773; +-const AST_CONST_ELEM = 775; +-const AST_USE_TRAIT = 538; +-const AST_TRAIT_PRECEDENCE = 539; +-const AST_METHOD_REFERENCE = 540; +-const AST_NAMESPACE = 541; +-const AST_USE_ELEM = 542; +-const AST_TRAIT_ALIAS = 543; +-const AST_GROUP_USE = 544; +-const AST_ATTRIBUTE = 546; +-const AST_MATCH = 547; +-const AST_MATCH_ARM = 548; ++const AST_NULLSAFE_PROP = 514; ++const AST_STATIC_PROP = 515; ++const AST_CALL = 516; ++const AST_CLASS_CONST = 517; ++const AST_ASSIGN = 518; ++const AST_ASSIGN_REF = 519; ++const AST_ASSIGN_OP = 520; ++const AST_BINARY_OP = 521; ++const AST_ARRAY_ELEM = 526; ++const AST_NEW = 527; ++const AST_INSTANCEOF = 528; ++const AST_YIELD = 529; ++const AST_STATIC = 532; ++const AST_WHILE = 533; ++const AST_DO_WHILE = 534; ++const AST_IF_ELEM = 535; ++const AST_SWITCH = 536; ++const AST_SWITCH_CASE = 537; ++const AST_DECLARE = 538; ++const AST_PROP_ELEM = 775; ++const AST_PROP_GROUP = 774; ++const AST_CONST_ELEM = 776; ++const AST_USE_TRAIT = 539; ++const AST_TRAIT_PRECEDENCE = 540; ++const AST_METHOD_REFERENCE = 541; ++const AST_NAMESPACE = 542; ++const AST_USE_ELEM = 543; ++const AST_TRAIT_ALIAS = 544; ++const AST_GROUP_USE = 545; ++const AST_ATTRIBUTE = 547; ++const AST_MATCH = 548; ++const AST_MATCH_ARM = 549; ++const AST_NAMED_ARG = 550; + const AST_METHOD_CALL = 768; +-const AST_STATIC_CALL = 769; +-const AST_CONDITIONAL = 770; +-const AST_TRY = 771; +-const AST_CATCH = 772; ++const AST_NULLSAFE_METHOD_CALL = 769; ++const AST_STATIC_CALL = 770; ++const AST_CONDITIONAL = 771; ++const AST_TRY = 772; ++const AST_CATCH = 773; + const AST_FOR = 1024; + const AST_FOREACH = 1025; + const AST_PARAM = 1280; +@@ -121,6 +124,9 @@ const MODIFIER_PRIVATE = 4; + const MODIFIER_STATIC = 16; + const MODIFIER_ABSTRACT = 64; + const MODIFIER_FINAL = 32; ++const PARAM_MODIFIER_PUBLIC = 1; ++const PARAM_MODIFIER_PROTECTED = 2; ++const PARAM_MODIFIER_PRIVATE = 4; + const RETURNS_REF = 4096; + const FUNC_RETURNS_REF = 4096; + const FUNC_GENERATOR = 16777216; +@@ -184,14 +190,14 @@ const EXEC_REQUIRE_ONCE = 16; + const USE_NORMAL = 1; + const USE_FUNCTION = 2; + const USE_CONST = 4; +-const MAGIC_LINE = 372; +-const MAGIC_FILE = 373; +-const MAGIC_DIR = 374; +-const MAGIC_NAMESPACE = 379; +-const MAGIC_FUNCTION = 378; +-const MAGIC_METHOD = 377; +-const MAGIC_CLASS = 375; +-const MAGIC_TRAIT = 376; ++const MAGIC_LINE = 375; ++const MAGIC_FILE = 376; ++const MAGIC_DIR = 377; ++const MAGIC_NAMESPACE = 382; ++const MAGIC_FUNCTION = 381; ++const MAGIC_METHOD = 380; ++const MAGIC_CLASS = 378; ++const MAGIC_TRAIT = 379; + const ARRAY_SYNTAX_LIST = 1; + const ARRAY_SYNTAX_LONG = 2; + const ARRAY_SYNTAX_SHORT = 3; +diff --git a/php_ast.h b/php_ast.h +index d3c0550..3324275 100644 +--- a/php_ast.h ++++ b/php_ast.h +@@ -62,10 +62,15 @@ extern ast_str_globals str_globals; + # define ZEND_AST_TYPE_UNION ((1 << (ZEND_AST_IS_LIST_SHIFT + 1)) - 2) + # define ZEND_AST_ATTRIBUTE_LIST ((1 << (ZEND_AST_IS_LIST_SHIFT + 1)) - 3) + # define ZEND_AST_MATCH_ARM_LIST ((1 << (ZEND_AST_IS_LIST_SHIFT + 1)) - 4) ++/* 2 child nodes */ + # define ZEND_AST_CLASS_CONST_GROUP 0x2fe + # define ZEND_AST_ATTRIBUTE 0x2fd + # define ZEND_AST_MATCH 0x2fc + # define ZEND_AST_MATCH_ARM 0x2fb ++# define ZEND_AST_NAMED_ARG 0x2fa ++# define ZEND_AST_NULLSAFE_PROP 0x2f9 ++/* 3 child nodes */ ++# define ZEND_AST_NULLSAFE_METHOD_CALL 0x3ff + // NOTE: The first hex digit is the number of child nodes a given kind has + #endif + +diff --git a/tests/attributes_01.phpt b/tests/attributes_01.phpt +index c66cc97..da04cb7 100644 +--- a/tests/attributes_01.phpt ++++ b/tests/attributes_01.phpt +@@ -11,13 +11,13 @@ $code = <<<'PHP' + <?php + namespace NS; + +-<<SomeAttribute>> +-function test(<<namespace\SomeAttribute(2+2)>> Type $arg) { ++@@SomeAttribute ++function test(@@namespace\SomeAttribute(2+2) Type $arg) { + } + +-$x = <<SomeAttribute>> function () {}; ++$x = @@SomeAttribute function () {}; + +-$y = <<SomeAttribute>> fn (<<\SomeAttribute>> $a) => $x; ++$y = @@SomeAttribute fn (@@\SomeAttribute $a) => $x; + PHP; + + echo ast_dump(ast\parse_code($code, $version=70)); +diff --git a/tests/attributes_02.phpt b/tests/attributes_02.phpt +index 117f1f0..c6c7c8c 100644 +--- a/tests/attributes_02.phpt ++++ b/tests/attributes_02.phpt +@@ -11,16 +11,16 @@ $code = <<<'PHP' + <?php + namespace NS; + +-<<\SomeAttribute()>> ++@@\SomeAttribute() + class X { +- <<Attr1>> +- <<Attr2(true)>> ++ @@Attr1 ++ @@Attr2(true) + public $prop; + +- <<Attr3>> ++ @@Attr3 + public const CONST_WITH_ATTRIBUTE = 123; + +- <<Attr4>> ++ @@Attr4 + public static function hasAttribute() {} + } + PHP; +diff --git a/tests/metadata.phpt b/tests/metadata.phpt +index 6dead6e..8eee972 100644 +--- a/tests/metadata.phpt ++++ b/tests/metadata.phpt +@@ -88,6 +88,7 @@ AST_CLASS_NAME: [] + AST_CLASS_CONST_GROUP: (combinable) [MODIFIER_PUBLIC, MODIFIER_PROTECTED, MODIFIER_PRIVATE] + AST_DIM: (combinable) [DIM_ALTERNATIVE_SYNTAX] + AST_PROP: [] ++AST_NULLSAFE_PROP: [] + AST_STATIC_PROP: [] + AST_CALL: [] + AST_CLASS_CONST: [] +@@ -119,11 +120,13 @@ AST_GROUP_USE: [USE_NORMAL, USE_FUNCTION, USE_CONST] + AST_ATTRIBUTE: [] + AST_MATCH: [] + AST_MATCH_ARM: [] ++AST_NAMED_ARG: [] + AST_METHOD_CALL: [] ++AST_NULLSAFE_METHOD_CALL: [] + AST_STATIC_CALL: [] + AST_CONDITIONAL: (combinable) [PARENTHESIZED_CONDITIONAL] + AST_TRY: [] + AST_CATCH: [] + AST_FOR: [] + AST_FOREACH: [] +-AST_PARAM: (combinable) [PARAM_REF, PARAM_VARIADIC%S] ++AST_PARAM: (combinable) [PARAM_REF, PARAM_VARIADIC, PARAM_MODIFIER_PUBLIC, PARAM_MODIFIER_PROTECTED, PARAM_MODIFIER_PRIVATE] +diff --git a/tests/parse_code_parse_error.phpt b/tests/parse_code_parse_error.phpt +index 57504cf..d82c043 100644 +--- a/tests/parse_code_parse_error.phpt ++++ b/tests/parse_code_parse_error.phpt +@@ -18,11 +18,11 @@ try { + + ?> + --EXPECTF-- +-ParseError: syntax error, unexpected '&', expecting end of file in string code:1 ++ParseError: syntax error, unexpected %s&%s expecting end of file in string code:1 + Stack trace: + #0 %s(%d): ast\parse_code('%s', %d) + #1 {main} +-ParseError: syntax error, unexpected '&', expecting end of file in file.php:1 ++ParseError: syntax error, unexpected %s&%s expecting end of file in file.php:1 + Stack trace: + #0 %s(%d): ast\parse_code('%s', %d, 'file.php') + #1 {main} +diff --git a/tests/parse_file_parse_error.phpt b/tests/parse_file_parse_error.phpt +index 88c0678..8e4a003 100644 +--- a/tests/parse_file_parse_error.phpt ++++ b/tests/parse_file_parse_error.phpt +@@ -11,7 +11,7 @@ try { + + ?> + --EXPECTF-- +-ParseError: syntax error, unexpected ')' in %stests/invalid_file.php:3 ++ParseError: syntax error, unexpected %s)%s in %stests/invalid_file.php:3 + Stack trace: + #0 %s(%d): ast\parse_file('%s', %d) + #1 {main} +diff --git a/tests/php80_named_params.phpt b/tests/php80_named_params.phpt +new file mode 100644 +index 0000000..8ecffaf +--- /dev/null ++++ b/tests/php80_named_params.phpt +@@ -0,0 +1,52 @@ ++--TEST-- ++Named parameters in PHP 8.0 ++--SKIPIF-- ++<?php if (PHP_VERSION_ID < 80000) die('skip PHP >= 8.0 only'); ?> ++--FILE-- ++<?php ++ ++require __DIR__ . '/../util.php'; ++ ++$code = <<<'PHP' ++<?php ++$foo(first: 1, second: 2); ++count(var: $argv); ++$other->count(1, myVar:$foo, myVar: 1); // error ++PHP; ++ ++$node = ast\parse_code($code, $version=70); ++echo ast_dump($node), "\n"; ++--EXPECTF-- ++AST_STMT_LIST ++ 0: AST_CALL ++ expr: AST_VAR ++ name: "foo" ++ args: AST_ARG_LIST ++ 0: AST_NAMED_ARG ++ name: "first" ++ expr: 1 ++ 1: AST_NAMED_ARG ++ name: "second" ++ expr: 2 ++ 1: AST_CALL ++ expr: AST_NAME ++ flags: NAME_NOT_FQ (%d) ++ name: "count" ++ args: AST_ARG_LIST ++ 0: AST_NAMED_ARG ++ name: "var" ++ expr: AST_VAR ++ name: "argv" ++ 2: AST_METHOD_CALL ++ expr: AST_VAR ++ name: "other" ++ method: "count" ++ args: AST_ARG_LIST ++ 0: 1 ++ 1: AST_NAMED_ARG ++ name: "myVar" ++ expr: AST_VAR ++ name: "foo" ++ 2: AST_NAMED_ARG ++ name: "myVar" ++ expr: 1 +diff --git a/tests/php80_nullsafe_operator.phpt b/tests/php80_nullsafe_operator.phpt +new file mode 100644 +index 0000000..38e253f +--- /dev/null ++++ b/tests/php80_nullsafe_operator.phpt +@@ -0,0 +1,42 @@ ++--TEST-- ++Nullsafe operator in PHP 8.0 ++--SKIPIF-- ++<?php if (PHP_VERSION_ID < 80000) die('skip PHP >= 8.0 only'); ?> ++--FILE-- ++<?php ++ ++require __DIR__ . '/../util.php'; ++ ++$code = <<<'PHP' ++<?php ++$foo?->bar(2); ++$a = $b?->c; ++$a = new $b?->c; ++PHP; ++ ++$node = ast\parse_code($code, $version=70); ++echo ast_dump($node), "\n"; ++--EXPECTF-- ++AST_STMT_LIST ++ 0: AST_NULLSAFE_METHOD_CALL ++ expr: AST_VAR ++ name: "foo" ++ method: "bar" ++ args: AST_ARG_LIST ++ 0: 2 ++ 1: AST_ASSIGN ++ var: AST_VAR ++ name: "a" ++ expr: AST_NULLSAFE_PROP ++ expr: AST_VAR ++ name: "b" ++ prop: "c" ++ 2: AST_ASSIGN ++ var: AST_VAR ++ name: "a" ++ expr: AST_NEW ++ class: AST_NULLSAFE_PROP ++ expr: AST_VAR ++ name: "b" ++ prop: "c" ++ args: AST_ARG_LIST +\ No newline at end of file +diff --git a/tests/php80_promotion.phpt b/tests/php80_promotion.phpt +index 5c58380..b9a91d6 100644 +--- a/tests/php80_promotion.phpt ++++ b/tests/php80_promotion.phpt +@@ -38,13 +38,13 @@ AST_STMT_LIST + docComment: "/** Doc comment for __construct */" + params: AST_PARAM_LIST + 0: AST_PARAM +- flags: MODIFIER_PUBLIC (%d) ++ flags: PARAM_MODIFIER_PUBLIC (%d) + type: AST_TYPE + flags: TYPE_LONG (4) + name: "a" + default: null + 1: AST_PARAM +- flags: PARAM_REF | MODIFIER_PRIVATE (%d) ++ flags: PARAM_REF | PARAM_MODIFIER_PRIVATE (%d) + type: AST_NAME + flags: NAME_NOT_FQ (1) + name: "stdClass" +@@ -54,7 +54,7 @@ AST_STMT_LIST + flags: NAME_NOT_FQ (1) + name: "null" + 2: AST_PARAM +- flags: MODIFIER_PROTECTED (%d) ++ flags: PARAM_MODIFIER_PROTECTED (%d) + type: AST_TYPE + flags: TYPE_ITERABLE (13) + name: "c" diff --git a/php-ast.spec b/php-ast.spec index 9b852d6..6416530 100644 --- a/php-ast.spec +++ b/php-ast.spec @@ -24,7 +24,7 @@ Version: 1.0.7 %if 0%{?gh_date:1} Release: 0.6.%{gh_date}git%{gh_short}%{?dist}%{!?scl:%{!?nophptag:%(%{__php} -r 'echo ".".PHP_MAJOR_VERSION.".".PHP_MINOR_VERSION;')}} %else -Release: 3%{?dist}%{!?scl:%{!?nophptag:%(%{__php} -r 'echo ".".PHP_MAJOR_VERSION.".".PHP_MINOR_VERSION;')}} +Release: 4%{?dist}%{!?scl:%{!?nophptag:%(%{__php} -r 'echo ".".PHP_MAJOR_VERSION.".".PHP_MINOR_VERSION;')}} %endif License: BSD URL: https://github.com/%{gh_owner}/%{gh_project} @@ -34,7 +34,7 @@ Source0: https://github.com/%{gh_owner}/%{gh_project}/archive/%{gh_commit} Source0: http://pecl.php.net/get/%{pecl_name}-%{version}%{?prever}.tgz %endif -Patch0: https://patch-diff.githubusercontent.com/raw/nikic/php-ast/pull/165.patch +Patch0: %{pecl_name}-upstream.patch BuildRequires: %{?dtsprefix}gcc BuildRequires: %{?scl_prefix}php-devel > 7 @@ -235,6 +235,9 @@ fi %changelog +* Wed Aug 5 2020 Remi Collet <remi@remirepo.net> - 1.0.7-4 +- rebuild for 8.0.0beta1 + * Fri Jul 24 2020 Remi Collet <remi@remirepo.net> - 1.0.7-3 - EL-8 rebuild |