72 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
		
		
			
		
	
	
			72 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| 
								 | 
							
								<?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'];
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								}
							 |