1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071 |
- <?php declare(strict_types=1);
- namespace PhpParser\Internal;
- use PhpParser\Node;
- use PhpParser\Node\Expr;
- /**
- * This node is used internally by the format-preserving pretty printer to print anonymous classes.
- *
- * The normal anonymous class structure violates assumptions about the order of token offsets.
- * Namely, the constructor arguments are part of the Expr\New_ node and follow the class node, even
- * though they are actually interleaved with them. This special node type is used temporarily to
- * restore a sane token offset order.
- *
- * @internal
- */
- class PrintableNewAnonClassNode extends Expr {
- /** @var Node\AttributeGroup[] PHP attribute groups */
- public array $attrGroups;
- /** @var int Modifiers */
- public int $flags;
- /** @var (Node\Arg|Node\VariadicPlaceholder)[] Arguments */
- public array $args;
- /** @var null|Node\Name Name of extended class */
- public ?Node\Name $extends;
- /** @var Node\Name[] Names of implemented interfaces */
- public array $implements;
- /** @var Node\Stmt[] Statements */
- public array $stmts;
- /**
- * @param Node\AttributeGroup[] $attrGroups PHP attribute groups
- * @param (Node\Arg|Node\VariadicPlaceholder)[] $args Arguments
- * @param Node\Name|null $extends Name of extended class
- * @param Node\Name[] $implements Names of implemented interfaces
- * @param Node\Stmt[] $stmts Statements
- * @param array<string, mixed> $attributes Attributes
- */
- public function __construct(
- array $attrGroups, int $flags, array $args, ?Node\Name $extends, array $implements,
- array $stmts, array $attributes
- ) {
- parent::__construct($attributes);
- $this->attrGroups = $attrGroups;
- $this->flags = $flags;
- $this->args = $args;
- $this->extends = $extends;
- $this->implements = $implements;
- $this->stmts = $stmts;
- }
- public static function fromNewNode(Expr\New_ $newNode): self {
- $class = $newNode->class;
- assert($class instanceof Node\Stmt\Class_);
- // We don't assert that $class->name is null here, to allow consumers to assign unique names
- // to anonymous classes for their own purposes. We simplify ignore the name here.
- return new self(
- $class->attrGroups, $class->flags, $newNode->args, $class->extends, $class->implements,
- $class->stmts, $newNode->getAttributes()
- );
- }
- public function getType(): string {
- return 'Expr_PrintableNewAnonClass';
- }
- public function getSubNodeNames(): array {
- return ['attrGroups', 'flags', 'args', 'extends', 'implements', 'stmts'];
- }
- }
|