mirror of
https://github.com/nikic/PHP-Parser.git
synced 2025-01-17 23:28:15 +01:00
2d3dd4e23e
I did this to start with, but then alignment kept being broken during refactorings, and at some point I switched to not aligning, and now we have a big mess. Add a php-cs-fixer rule to consistently not align phpdoc tags.
48 lines
1.4 KiB
PHP
48 lines
1.4 KiB
PHP
<?php declare(strict_types=1);
|
|
|
|
namespace PhpParser\Node\Stmt;
|
|
|
|
use PhpParser\Node\Stmt;
|
|
use PhpParser\Node\UseItem;
|
|
|
|
class Use_ extends Stmt {
|
|
/**
|
|
* Unknown type. Both Stmt\Use_ / Stmt\GroupUse and Stmt\UseUse have a $type property, one of them will always be
|
|
* TYPE_UNKNOWN while the other has one of the three other possible types. For normal use statements the type on the
|
|
* Stmt\UseUse is unknown. It's only the other way around for mixed group use declarations.
|
|
*/
|
|
public const TYPE_UNKNOWN = 0;
|
|
/** Class or namespace import */
|
|
public const TYPE_NORMAL = 1;
|
|
/** Function import */
|
|
public const TYPE_FUNCTION = 2;
|
|
/** Constant import */
|
|
public const TYPE_CONSTANT = 3;
|
|
|
|
/** @var self::TYPE_* Type of alias */
|
|
public int $type;
|
|
/** @var UseItem[] Aliases */
|
|
public array $uses;
|
|
|
|
/**
|
|
* Constructs an alias (use) list node.
|
|
*
|
|
* @param UseItem[] $uses Aliases
|
|
* @param Stmt\Use_::TYPE_* $type Type of alias
|
|
* @param array<string, mixed> $attributes Additional attributes
|
|
*/
|
|
public function __construct(array $uses, int $type = self::TYPE_NORMAL, array $attributes = []) {
|
|
$this->attributes = $attributes;
|
|
$this->type = $type;
|
|
$this->uses = $uses;
|
|
}
|
|
|
|
public function getSubNodeNames(): array {
|
|
return ['type', 'uses'];
|
|
}
|
|
|
|
public function getType(): string {
|
|
return 'Stmt_Use';
|
|
}
|
|
}
|