Skip to content

Commit

Permalink
feat: add support for dynamic class constant fetch
Browse files Browse the repository at this point in the history
  • Loading branch information
calebdw committed Jan 25, 2024
1 parent 5a779d3 commit 1100478
Show file tree
Hide file tree
Showing 6 changed files with 131,977 additions and 128,995 deletions.
11 changes: 10 additions & 1 deletion common/define-grammar.js
Original file line number Diff line number Diff line change
Expand Up @@ -939,11 +939,20 @@ module.exports = function defineGrammar(dialect) {

parenthesized_expression: $ => seq('(', $._expression, ')'),

class_constant_access_expression: $ => seq(
class_constant_access_expression: $ => choice(
$._class_constant_access_expression,
$._dynamic_class_constant_access_expression,
),
_class_constant_access_expression: $ => seq(
$._scope_resolution_qualifier,
'::',
choice($.name, alias($._reserved_identifier, $.name)),
),
_dynamic_class_constant_access_expression: $ => seq(
$._scope_resolution_qualifier,
'::',
alias(seq('{', $._expression, '}'), $.name),
),

print_intrinsic: $ => seq(
keyword('print'), $._expression,
Expand Down
17 changes: 17 additions & 0 deletions common/test/corpus/expressions.txt
Original file line number Diff line number Diff line change
Expand Up @@ -1543,3 +1543,20 @@ $statement = match ($a) {
)
)

===============================================
Dynamic class constant access
===============================================

<?php
Foo::{$bar};

---

(program
(php_tag)
(expression_statement
(class_constant_access_expression
(name)
(name)
(name (variable_name (name)))
(name))))
48 changes: 48 additions & 0 deletions php/src/grammar.json
Original file line number Diff line number Diff line change
Expand Up @@ -4856,6 +4856,19 @@
]
},
"class_constant_access_expression": {
"type": "CHOICE",
"members": [
{
"type": "SYMBOL",
"name": "_class_constant_access_expression"
},
{
"type": "SYMBOL",
"name": "_dynamic_class_constant_access_expression"
}
]
},
"_class_constant_access_expression": {
"type": "SEQ",
"members": [
{
Expand Down Expand Up @@ -4886,6 +4899,41 @@
}
]
},
"_dynamic_class_constant_access_expression": {
"type": "SEQ",
"members": [
{
"type": "SYMBOL",
"name": "_scope_resolution_qualifier"
},
{
"type": "STRING",
"value": "::"
},
{
"type": "ALIAS",
"content": {
"type": "SEQ",
"members": [
{
"type": "STRING",
"value": "{"
},
{
"type": "SYMBOL",
"name": "_expression"
},
{
"type": "STRING",
"value": "}"
}
]
},
"named": true,
"value": "name"
}
]
},
"print_intrinsic": {
"type": "SEQ",
"members": [
Expand Down
Loading

0 comments on commit 1100478

Please sign in to comment.