45 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			45 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
<?php declare(strict_types=1);
 | 
						|
 | 
						|
namespace PhpParser\Node;
 | 
						|
 | 
						|
use PhpParser\NodeAbstract;
 | 
						|
 | 
						|
class Arg extends NodeAbstract {
 | 
						|
    /** @var Identifier|null Parameter name (for named parameters) */
 | 
						|
    public ?Identifier $name;
 | 
						|
    /** @var Expr Value to pass */
 | 
						|
    public Expr $value;
 | 
						|
    /** @var bool Whether to pass by ref */
 | 
						|
    public bool $byRef;
 | 
						|
    /** @var bool Whether to unpack the argument */
 | 
						|
    public bool $unpack;
 | 
						|
 | 
						|
    /**
 | 
						|
     * Constructs a function call argument node.
 | 
						|
     *
 | 
						|
     * @param Expr $value Value to pass
 | 
						|
     * @param bool $byRef Whether to pass by ref
 | 
						|
     * @param bool $unpack Whether to unpack the argument
 | 
						|
     * @param array<string, mixed> $attributes Additional attributes
 | 
						|
     * @param Identifier|null $name Parameter name (for named parameters)
 | 
						|
     */
 | 
						|
    public function __construct(
 | 
						|
        Expr $value, bool $byRef = false, bool $unpack = false, array $attributes = [],
 | 
						|
        ?Identifier $name = null
 | 
						|
    ) {
 | 
						|
        $this->attributes = $attributes;
 | 
						|
        $this->name = $name;
 | 
						|
        $this->value = $value;
 | 
						|
        $this->byRef = $byRef;
 | 
						|
        $this->unpack = $unpack;
 | 
						|
    }
 | 
						|
 | 
						|
    public function getSubNodeNames(): array {
 | 
						|
        return ['name', 'value', 'byRef', 'unpack'];
 | 
						|
    }
 | 
						|
 | 
						|
    public function getType(): string {
 | 
						|
        return 'Arg';
 | 
						|
    }
 | 
						|
}
 |