172 lines
		
	
	
		
			4.4 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			172 lines
		
	
	
		
			4.4 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
<?php declare(strict_types=1);
 | 
						|
 | 
						|
namespace PhpParser\Builder;
 | 
						|
 | 
						|
use PhpParser;
 | 
						|
use PhpParser\BuilderHelpers;
 | 
						|
use PhpParser\Modifiers;
 | 
						|
use PhpParser\Node;
 | 
						|
 | 
						|
class Param implements PhpParser\Builder {
 | 
						|
    protected string $name;
 | 
						|
    protected ?Node\Expr $default = null;
 | 
						|
    /** @var Node\Identifier|Node\Name|Node\ComplexType|null */
 | 
						|
    protected ?Node $type = null;
 | 
						|
    protected bool $byRef = false;
 | 
						|
    protected int $flags = 0;
 | 
						|
    protected bool $variadic = false;
 | 
						|
    /** @var list<Node\AttributeGroup> */
 | 
						|
    protected array $attributeGroups = [];
 | 
						|
 | 
						|
    /**
 | 
						|
     * Creates a parameter builder.
 | 
						|
     *
 | 
						|
     * @param string $name Name of the parameter
 | 
						|
     */
 | 
						|
    public function __construct(string $name) {
 | 
						|
        $this->name = $name;
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Sets default value for the parameter.
 | 
						|
     *
 | 
						|
     * @param mixed $value Default value to use
 | 
						|
     *
 | 
						|
     * @return $this The builder instance (for fluid interface)
 | 
						|
     */
 | 
						|
    public function setDefault($value) {
 | 
						|
        $this->default = BuilderHelpers::normalizeValue($value);
 | 
						|
 | 
						|
        return $this;
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Sets type for the parameter.
 | 
						|
     *
 | 
						|
     * @param string|Node\Name|Node\Identifier|Node\ComplexType $type Parameter type
 | 
						|
     *
 | 
						|
     * @return $this The builder instance (for fluid interface)
 | 
						|
     */
 | 
						|
    public function setType($type) {
 | 
						|
        $this->type = BuilderHelpers::normalizeType($type);
 | 
						|
        if ($this->type == 'void') {
 | 
						|
            throw new \LogicException('Parameter type cannot be void');
 | 
						|
        }
 | 
						|
 | 
						|
        return $this;
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Make the parameter accept the value by reference.
 | 
						|
     *
 | 
						|
     * @return $this The builder instance (for fluid interface)
 | 
						|
     */
 | 
						|
    public function makeByRef() {
 | 
						|
        $this->byRef = true;
 | 
						|
 | 
						|
        return $this;
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Make the parameter variadic
 | 
						|
     *
 | 
						|
     * @return $this The builder instance (for fluid interface)
 | 
						|
     */
 | 
						|
    public function makeVariadic() {
 | 
						|
        $this->variadic = true;
 | 
						|
 | 
						|
        return $this;
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Makes the (promoted) parameter public.
 | 
						|
     *
 | 
						|
     * @return $this The builder instance (for fluid interface)
 | 
						|
     */
 | 
						|
    public function makePublic() {
 | 
						|
        $this->flags = BuilderHelpers::addModifier($this->flags, Modifiers::PUBLIC);
 | 
						|
 | 
						|
        return $this;
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Makes the (promoted) parameter protected.
 | 
						|
     *
 | 
						|
     * @return $this The builder instance (for fluid interface)
 | 
						|
     */
 | 
						|
    public function makeProtected() {
 | 
						|
        $this->flags = BuilderHelpers::addModifier($this->flags, Modifiers::PROTECTED);
 | 
						|
 | 
						|
        return $this;
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Makes the (promoted) parameter private.
 | 
						|
     *
 | 
						|
     * @return $this The builder instance (for fluid interface)
 | 
						|
     */
 | 
						|
    public function makePrivate() {
 | 
						|
        $this->flags = BuilderHelpers::addModifier($this->flags, Modifiers::PRIVATE);
 | 
						|
 | 
						|
        return $this;
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Makes the (promoted) parameter readonly.
 | 
						|
     *
 | 
						|
     * @return $this The builder instance (for fluid interface)
 | 
						|
     */
 | 
						|
    public function makeReadonly() {
 | 
						|
        $this->flags = BuilderHelpers::addModifier($this->flags, Modifiers::READONLY);
 | 
						|
 | 
						|
        return $this;
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Gives the promoted property private(set) visibility.
 | 
						|
     *
 | 
						|
     * @return $this The builder instance (for fluid interface)
 | 
						|
     */
 | 
						|
    public function makePrivateSet() {
 | 
						|
        $this->flags = BuilderHelpers::addModifier($this->flags, Modifiers::PRIVATE_SET);
 | 
						|
 | 
						|
        return $this;
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Gives the promoted property protected(set) visibility.
 | 
						|
     *
 | 
						|
     * @return $this The builder instance (for fluid interface)
 | 
						|
     */
 | 
						|
    public function makeProtectedSet() {
 | 
						|
        $this->flags = BuilderHelpers::addModifier($this->flags, Modifiers::PROTECTED_SET);
 | 
						|
 | 
						|
        return $this;
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Adds an attribute group.
 | 
						|
     *
 | 
						|
     * @param Node\Attribute|Node\AttributeGroup $attribute
 | 
						|
     *
 | 
						|
     * @return $this The builder instance (for fluid interface)
 | 
						|
     */
 | 
						|
    public function addAttribute($attribute) {
 | 
						|
        $this->attributeGroups[] = BuilderHelpers::normalizeAttribute($attribute);
 | 
						|
 | 
						|
        return $this;
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Returns the built parameter node.
 | 
						|
     *
 | 
						|
     * @return Node\Param The built parameter node
 | 
						|
     */
 | 
						|
    public function getNode(): Node {
 | 
						|
        return new Node\Param(
 | 
						|
            new Node\Expr\Variable($this->name),
 | 
						|
            $this->default, $this->type, $this->byRef, $this->variadic, [], $this->flags, $this->attributeGroups
 | 
						|
        );
 | 
						|
    }
 | 
						|
}
 |