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'];
 | 
						|
    }
 | 
						|
}
 |