first commit
This commit is contained in:
3
vendor/nikic/php-parser/lib/PhpParser/Node/Scalar/DNumber.php
vendored
Normal file
3
vendor/nikic/php-parser/lib/PhpParser/Node/Scalar/DNumber.php
vendored
Normal file
@ -0,0 +1,3 @@
|
||||
<?php declare(strict_types=1);
|
||||
|
||||
require __DIR__ . '/Float_.php';
|
3
vendor/nikic/php-parser/lib/PhpParser/Node/Scalar/Encapsed.php
vendored
Normal file
3
vendor/nikic/php-parser/lib/PhpParser/Node/Scalar/Encapsed.php
vendored
Normal file
@ -0,0 +1,3 @@
|
||||
<?php declare(strict_types=1);
|
||||
|
||||
require __DIR__ . '/InterpolatedString.php';
|
3
vendor/nikic/php-parser/lib/PhpParser/Node/Scalar/EncapsedStringPart.php
vendored
Normal file
3
vendor/nikic/php-parser/lib/PhpParser/Node/Scalar/EncapsedStringPart.php
vendored
Normal file
@ -0,0 +1,3 @@
|
||||
<?php declare(strict_types=1);
|
||||
|
||||
require __DIR__ . '/../InterpolatedStringPart.php';
|
78
vendor/nikic/php-parser/lib/PhpParser/Node/Scalar/Float_.php
vendored
Normal file
78
vendor/nikic/php-parser/lib/PhpParser/Node/Scalar/Float_.php
vendored
Normal file
@ -0,0 +1,78 @@
|
||||
<?php declare(strict_types=1);
|
||||
|
||||
namespace PhpParser\Node\Scalar;
|
||||
|
||||
use PhpParser\Node\Scalar;
|
||||
|
||||
class Float_ extends Scalar {
|
||||
/** @var float Number value */
|
||||
public float $value;
|
||||
|
||||
/**
|
||||
* Constructs a float number scalar node.
|
||||
*
|
||||
* @param float $value Value of the number
|
||||
* @param array<string, mixed> $attributes Additional attributes
|
||||
*/
|
||||
public function __construct(float $value, array $attributes = []) {
|
||||
$this->attributes = $attributes;
|
||||
$this->value = $value;
|
||||
}
|
||||
|
||||
public function getSubNodeNames(): array {
|
||||
return ['value'];
|
||||
}
|
||||
|
||||
/**
|
||||
* @param mixed[] $attributes
|
||||
*/
|
||||
public static function fromString(string $str, array $attributes = []): Float_ {
|
||||
$attributes['rawValue'] = $str;
|
||||
$float = self::parse($str);
|
||||
|
||||
return new Float_($float, $attributes);
|
||||
}
|
||||
|
||||
/**
|
||||
* @internal
|
||||
*
|
||||
* Parses a DNUMBER token like PHP would.
|
||||
*
|
||||
* @param string $str A string number
|
||||
*
|
||||
* @return float The parsed number
|
||||
*/
|
||||
public static function parse(string $str): float {
|
||||
$str = str_replace('_', '', $str);
|
||||
|
||||
// Check whether this is one of the special integer notations.
|
||||
if ('0' === $str[0]) {
|
||||
// hex
|
||||
if ('x' === $str[1] || 'X' === $str[1]) {
|
||||
return hexdec($str);
|
||||
}
|
||||
|
||||
// bin
|
||||
if ('b' === $str[1] || 'B' === $str[1]) {
|
||||
return bindec($str);
|
||||
}
|
||||
|
||||
// oct, but only if the string does not contain any of '.eE'.
|
||||
if (false === strpbrk($str, '.eE')) {
|
||||
// substr($str, 0, strcspn($str, '89')) cuts the string at the first invalid digit
|
||||
// (8 or 9) so that only the digits before that are used.
|
||||
return octdec(substr($str, 0, strcspn($str, '89')));
|
||||
}
|
||||
}
|
||||
|
||||
// dec
|
||||
return (float) $str;
|
||||
}
|
||||
|
||||
public function getType(): string {
|
||||
return 'Scalar_Float';
|
||||
}
|
||||
}
|
||||
|
||||
// @deprecated compatibility alias
|
||||
class_alias(Float_::class, DNumber::class);
|
82
vendor/nikic/php-parser/lib/PhpParser/Node/Scalar/Int_.php
vendored
Normal file
82
vendor/nikic/php-parser/lib/PhpParser/Node/Scalar/Int_.php
vendored
Normal file
@ -0,0 +1,82 @@
|
||||
<?php declare(strict_types=1);
|
||||
|
||||
namespace PhpParser\Node\Scalar;
|
||||
|
||||
use PhpParser\Error;
|
||||
use PhpParser\Node\Scalar;
|
||||
|
||||
class Int_ extends Scalar {
|
||||
/* For use in "kind" attribute */
|
||||
public const KIND_BIN = 2;
|
||||
public const KIND_OCT = 8;
|
||||
public const KIND_DEC = 10;
|
||||
public const KIND_HEX = 16;
|
||||
|
||||
/** @var int Number value */
|
||||
public int $value;
|
||||
|
||||
/**
|
||||
* Constructs an integer number scalar node.
|
||||
*
|
||||
* @param int $value Value of the number
|
||||
* @param array<string, mixed> $attributes Additional attributes
|
||||
*/
|
||||
public function __construct(int $value, array $attributes = []) {
|
||||
$this->attributes = $attributes;
|
||||
$this->value = $value;
|
||||
}
|
||||
|
||||
public function getSubNodeNames(): array {
|
||||
return ['value'];
|
||||
}
|
||||
|
||||
/**
|
||||
* Constructs an Int node from a string number literal.
|
||||
*
|
||||
* @param string $str String number literal (decimal, octal, hex or binary)
|
||||
* @param array<string, mixed> $attributes Additional attributes
|
||||
* @param bool $allowInvalidOctal Whether to allow invalid octal numbers (PHP 5)
|
||||
*
|
||||
* @return Int_ The constructed LNumber, including kind attribute
|
||||
*/
|
||||
public static function fromString(string $str, array $attributes = [], bool $allowInvalidOctal = false): Int_ {
|
||||
$attributes['rawValue'] = $str;
|
||||
|
||||
$str = str_replace('_', '', $str);
|
||||
|
||||
if ('0' !== $str[0] || '0' === $str) {
|
||||
$attributes['kind'] = Int_::KIND_DEC;
|
||||
return new Int_((int) $str, $attributes);
|
||||
}
|
||||
|
||||
if ('x' === $str[1] || 'X' === $str[1]) {
|
||||
$attributes['kind'] = Int_::KIND_HEX;
|
||||
return new Int_(hexdec($str), $attributes);
|
||||
}
|
||||
|
||||
if ('b' === $str[1] || 'B' === $str[1]) {
|
||||
$attributes['kind'] = Int_::KIND_BIN;
|
||||
return new Int_(bindec($str), $attributes);
|
||||
}
|
||||
|
||||
if (!$allowInvalidOctal && strpbrk($str, '89')) {
|
||||
throw new Error('Invalid numeric literal', $attributes);
|
||||
}
|
||||
|
||||
// Strip optional explicit octal prefix.
|
||||
if ('o' === $str[1] || 'O' === $str[1]) {
|
||||
$str = substr($str, 2);
|
||||
}
|
||||
|
||||
// use intval instead of octdec to get proper cutting behavior with malformed numbers
|
||||
$attributes['kind'] = Int_::KIND_OCT;
|
||||
return new Int_(intval($str, 8), $attributes);
|
||||
}
|
||||
|
||||
public function getType(): string {
|
||||
return 'Scalar_Int';
|
||||
}
|
||||
}
|
||||
|
||||
// @deprecated compatibility alias
|
||||
class_alias(Int_::class, LNumber::class);
|
34
vendor/nikic/php-parser/lib/PhpParser/Node/Scalar/InterpolatedString.php
vendored
Normal file
34
vendor/nikic/php-parser/lib/PhpParser/Node/Scalar/InterpolatedString.php
vendored
Normal file
@ -0,0 +1,34 @@
|
||||
<?php declare(strict_types=1);
|
||||
|
||||
namespace PhpParser\Node\Scalar;
|
||||
|
||||
use PhpParser\Node\Expr;
|
||||
use PhpParser\Node\InterpolatedStringPart;
|
||||
use PhpParser\Node\Scalar;
|
||||
|
||||
class InterpolatedString extends Scalar {
|
||||
/** @var (Expr|InterpolatedStringPart)[] list of string parts */
|
||||
public array $parts;
|
||||
|
||||
/**
|
||||
* Constructs an interpolated string node.
|
||||
*
|
||||
* @param (Expr|InterpolatedStringPart)[] $parts Interpolated string parts
|
||||
* @param array<string, mixed> $attributes Additional attributes
|
||||
*/
|
||||
public function __construct(array $parts, array $attributes = []) {
|
||||
$this->attributes = $attributes;
|
||||
$this->parts = $parts;
|
||||
}
|
||||
|
||||
public function getSubNodeNames(): array {
|
||||
return ['parts'];
|
||||
}
|
||||
|
||||
public function getType(): string {
|
||||
return 'Scalar_InterpolatedString';
|
||||
}
|
||||
}
|
||||
|
||||
// @deprecated compatibility alias
|
||||
class_alias(InterpolatedString::class, Encapsed::class);
|
3
vendor/nikic/php-parser/lib/PhpParser/Node/Scalar/LNumber.php
vendored
Normal file
3
vendor/nikic/php-parser/lib/PhpParser/Node/Scalar/LNumber.php
vendored
Normal file
@ -0,0 +1,3 @@
|
||||
<?php declare(strict_types=1);
|
||||
|
||||
require __DIR__ . '/Int_.php';
|
27
vendor/nikic/php-parser/lib/PhpParser/Node/Scalar/MagicConst.php
vendored
Normal file
27
vendor/nikic/php-parser/lib/PhpParser/Node/Scalar/MagicConst.php
vendored
Normal file
@ -0,0 +1,27 @@
|
||||
<?php declare(strict_types=1);
|
||||
|
||||
namespace PhpParser\Node\Scalar;
|
||||
|
||||
use PhpParser\Node\Scalar;
|
||||
|
||||
abstract class MagicConst extends Scalar {
|
||||
/**
|
||||
* Constructs a magic constant node.
|
||||
*
|
||||
* @param array<string, mixed> $attributes Additional attributes
|
||||
*/
|
||||
public function __construct(array $attributes = []) {
|
||||
$this->attributes = $attributes;
|
||||
}
|
||||
|
||||
public function getSubNodeNames(): array {
|
||||
return [];
|
||||
}
|
||||
|
||||
/**
|
||||
* Get name of magic constant.
|
||||
*
|
||||
* @return string Name of magic constant
|
||||
*/
|
||||
abstract public function getName(): string;
|
||||
}
|
15
vendor/nikic/php-parser/lib/PhpParser/Node/Scalar/MagicConst/Class_.php
vendored
Normal file
15
vendor/nikic/php-parser/lib/PhpParser/Node/Scalar/MagicConst/Class_.php
vendored
Normal file
@ -0,0 +1,15 @@
|
||||
<?php declare(strict_types=1);
|
||||
|
||||
namespace PhpParser\Node\Scalar\MagicConst;
|
||||
|
||||
use PhpParser\Node\Scalar\MagicConst;
|
||||
|
||||
class Class_ extends MagicConst {
|
||||
public function getName(): string {
|
||||
return '__CLASS__';
|
||||
}
|
||||
|
||||
public function getType(): string {
|
||||
return 'Scalar_MagicConst_Class';
|
||||
}
|
||||
}
|
15
vendor/nikic/php-parser/lib/PhpParser/Node/Scalar/MagicConst/Dir.php
vendored
Normal file
15
vendor/nikic/php-parser/lib/PhpParser/Node/Scalar/MagicConst/Dir.php
vendored
Normal file
@ -0,0 +1,15 @@
|
||||
<?php declare(strict_types=1);
|
||||
|
||||
namespace PhpParser\Node\Scalar\MagicConst;
|
||||
|
||||
use PhpParser\Node\Scalar\MagicConst;
|
||||
|
||||
class Dir extends MagicConst {
|
||||
public function getName(): string {
|
||||
return '__DIR__';
|
||||
}
|
||||
|
||||
public function getType(): string {
|
||||
return 'Scalar_MagicConst_Dir';
|
||||
}
|
||||
}
|
15
vendor/nikic/php-parser/lib/PhpParser/Node/Scalar/MagicConst/File.php
vendored
Normal file
15
vendor/nikic/php-parser/lib/PhpParser/Node/Scalar/MagicConst/File.php
vendored
Normal file
@ -0,0 +1,15 @@
|
||||
<?php declare(strict_types=1);
|
||||
|
||||
namespace PhpParser\Node\Scalar\MagicConst;
|
||||
|
||||
use PhpParser\Node\Scalar\MagicConst;
|
||||
|
||||
class File extends MagicConst {
|
||||
public function getName(): string {
|
||||
return '__FILE__';
|
||||
}
|
||||
|
||||
public function getType(): string {
|
||||
return 'Scalar_MagicConst_File';
|
||||
}
|
||||
}
|
15
vendor/nikic/php-parser/lib/PhpParser/Node/Scalar/MagicConst/Function_.php
vendored
Normal file
15
vendor/nikic/php-parser/lib/PhpParser/Node/Scalar/MagicConst/Function_.php
vendored
Normal file
@ -0,0 +1,15 @@
|
||||
<?php declare(strict_types=1);
|
||||
|
||||
namespace PhpParser\Node\Scalar\MagicConst;
|
||||
|
||||
use PhpParser\Node\Scalar\MagicConst;
|
||||
|
||||
class Function_ extends MagicConst {
|
||||
public function getName(): string {
|
||||
return '__FUNCTION__';
|
||||
}
|
||||
|
||||
public function getType(): string {
|
||||
return 'Scalar_MagicConst_Function';
|
||||
}
|
||||
}
|
15
vendor/nikic/php-parser/lib/PhpParser/Node/Scalar/MagicConst/Line.php
vendored
Normal file
15
vendor/nikic/php-parser/lib/PhpParser/Node/Scalar/MagicConst/Line.php
vendored
Normal file
@ -0,0 +1,15 @@
|
||||
<?php declare(strict_types=1);
|
||||
|
||||
namespace PhpParser\Node\Scalar\MagicConst;
|
||||
|
||||
use PhpParser\Node\Scalar\MagicConst;
|
||||
|
||||
class Line extends MagicConst {
|
||||
public function getName(): string {
|
||||
return '__LINE__';
|
||||
}
|
||||
|
||||
public function getType(): string {
|
||||
return 'Scalar_MagicConst_Line';
|
||||
}
|
||||
}
|
15
vendor/nikic/php-parser/lib/PhpParser/Node/Scalar/MagicConst/Method.php
vendored
Normal file
15
vendor/nikic/php-parser/lib/PhpParser/Node/Scalar/MagicConst/Method.php
vendored
Normal file
@ -0,0 +1,15 @@
|
||||
<?php declare(strict_types=1);
|
||||
|
||||
namespace PhpParser\Node\Scalar\MagicConst;
|
||||
|
||||
use PhpParser\Node\Scalar\MagicConst;
|
||||
|
||||
class Method extends MagicConst {
|
||||
public function getName(): string {
|
||||
return '__METHOD__';
|
||||
}
|
||||
|
||||
public function getType(): string {
|
||||
return 'Scalar_MagicConst_Method';
|
||||
}
|
||||
}
|
15
vendor/nikic/php-parser/lib/PhpParser/Node/Scalar/MagicConst/Namespace_.php
vendored
Normal file
15
vendor/nikic/php-parser/lib/PhpParser/Node/Scalar/MagicConst/Namespace_.php
vendored
Normal file
@ -0,0 +1,15 @@
|
||||
<?php declare(strict_types=1);
|
||||
|
||||
namespace PhpParser\Node\Scalar\MagicConst;
|
||||
|
||||
use PhpParser\Node\Scalar\MagicConst;
|
||||
|
||||
class Namespace_ extends MagicConst {
|
||||
public function getName(): string {
|
||||
return '__NAMESPACE__';
|
||||
}
|
||||
|
||||
public function getType(): string {
|
||||
return 'Scalar_MagicConst_Namespace';
|
||||
}
|
||||
}
|
15
vendor/nikic/php-parser/lib/PhpParser/Node/Scalar/MagicConst/Trait_.php
vendored
Normal file
15
vendor/nikic/php-parser/lib/PhpParser/Node/Scalar/MagicConst/Trait_.php
vendored
Normal file
@ -0,0 +1,15 @@
|
||||
<?php declare(strict_types=1);
|
||||
|
||||
namespace PhpParser\Node\Scalar\MagicConst;
|
||||
|
||||
use PhpParser\Node\Scalar\MagicConst;
|
||||
|
||||
class Trait_ extends MagicConst {
|
||||
public function getName(): string {
|
||||
return '__TRAIT__';
|
||||
}
|
||||
|
||||
public function getType(): string {
|
||||
return 'Scalar_MagicConst_Trait';
|
||||
}
|
||||
}
|
161
vendor/nikic/php-parser/lib/PhpParser/Node/Scalar/String_.php
vendored
Normal file
161
vendor/nikic/php-parser/lib/PhpParser/Node/Scalar/String_.php
vendored
Normal file
@ -0,0 +1,161 @@
|
||||
<?php declare(strict_types=1);
|
||||
|
||||
namespace PhpParser\Node\Scalar;
|
||||
|
||||
use PhpParser\Error;
|
||||
use PhpParser\Node\Scalar;
|
||||
|
||||
class String_ extends Scalar {
|
||||
/* For use in "kind" attribute */
|
||||
public const KIND_SINGLE_QUOTED = 1;
|
||||
public const KIND_DOUBLE_QUOTED = 2;
|
||||
public const KIND_HEREDOC = 3;
|
||||
public const KIND_NOWDOC = 4;
|
||||
|
||||
/** @var string String value */
|
||||
public string $value;
|
||||
|
||||
/** @var array<string, string> Escaped character to its decoded value */
|
||||
protected static array $replacements = [
|
||||
'\\' => '\\',
|
||||
'$' => '$',
|
||||
'n' => "\n",
|
||||
'r' => "\r",
|
||||
't' => "\t",
|
||||
'f' => "\f",
|
||||
'v' => "\v",
|
||||
'e' => "\x1B",
|
||||
];
|
||||
|
||||
/**
|
||||
* Constructs a string scalar node.
|
||||
*
|
||||
* @param string $value Value of the string
|
||||
* @param array<string, mixed> $attributes Additional attributes
|
||||
*/
|
||||
public function __construct(string $value, array $attributes = []) {
|
||||
$this->attributes = $attributes;
|
||||
$this->value = $value;
|
||||
}
|
||||
|
||||
public function getSubNodeNames(): array {
|
||||
return ['value'];
|
||||
}
|
||||
|
||||
/**
|
||||
* @param array<string, mixed> $attributes
|
||||
* @param bool $parseUnicodeEscape Whether to parse PHP 7 \u escapes
|
||||
*/
|
||||
public static function fromString(string $str, array $attributes = [], bool $parseUnicodeEscape = true): self {
|
||||
$attributes['kind'] = ($str[0] === "'" || ($str[1] === "'" && ($str[0] === 'b' || $str[0] === 'B')))
|
||||
? Scalar\String_::KIND_SINGLE_QUOTED
|
||||
: Scalar\String_::KIND_DOUBLE_QUOTED;
|
||||
|
||||
$attributes['rawValue'] = $str;
|
||||
|
||||
$string = self::parse($str, $parseUnicodeEscape);
|
||||
|
||||
return new self($string, $attributes);
|
||||
}
|
||||
|
||||
/**
|
||||
* @internal
|
||||
*
|
||||
* Parses a string token.
|
||||
*
|
||||
* @param string $str String token content
|
||||
* @param bool $parseUnicodeEscape Whether to parse PHP 7 \u escapes
|
||||
*
|
||||
* @return string The parsed string
|
||||
*/
|
||||
public static function parse(string $str, bool $parseUnicodeEscape = true): string {
|
||||
$bLength = 0;
|
||||
if ('b' === $str[0] || 'B' === $str[0]) {
|
||||
$bLength = 1;
|
||||
}
|
||||
|
||||
if ('\'' === $str[$bLength]) {
|
||||
return str_replace(
|
||||
['\\\\', '\\\''],
|
||||
['\\', '\''],
|
||||
substr($str, $bLength + 1, -1)
|
||||
);
|
||||
} else {
|
||||
return self::parseEscapeSequences(
|
||||
substr($str, $bLength + 1, -1), '"', $parseUnicodeEscape
|
||||
);
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* @internal
|
||||
*
|
||||
* Parses escape sequences in strings (all string types apart from single quoted).
|
||||
*
|
||||
* @param string $str String without quotes
|
||||
* @param null|string $quote Quote type
|
||||
* @param bool $parseUnicodeEscape Whether to parse PHP 7 \u escapes
|
||||
*
|
||||
* @return string String with escape sequences parsed
|
||||
*/
|
||||
public static function parseEscapeSequences(string $str, ?string $quote, bool $parseUnicodeEscape = true): string {
|
||||
if (null !== $quote) {
|
||||
$str = str_replace('\\' . $quote, $quote, $str);
|
||||
}
|
||||
|
||||
$extra = '';
|
||||
if ($parseUnicodeEscape) {
|
||||
$extra = '|u\{([0-9a-fA-F]+)\}';
|
||||
}
|
||||
|
||||
return preg_replace_callback(
|
||||
'~\\\\([\\\\$nrtfve]|[xX][0-9a-fA-F]{1,2}|[0-7]{1,3}' . $extra . ')~',
|
||||
function ($matches) {
|
||||
$str = $matches[1];
|
||||
|
||||
if (isset(self::$replacements[$str])) {
|
||||
return self::$replacements[$str];
|
||||
}
|
||||
if ('x' === $str[0] || 'X' === $str[0]) {
|
||||
return chr(hexdec(substr($str, 1)));
|
||||
}
|
||||
if ('u' === $str[0]) {
|
||||
$dec = hexdec($matches[2]);
|
||||
// If it overflowed to float, treat as INT_MAX, it will throw an error anyway.
|
||||
return self::codePointToUtf8(\is_int($dec) ? $dec : \PHP_INT_MAX);
|
||||
} else {
|
||||
return chr(octdec($str));
|
||||
}
|
||||
},
|
||||
$str
|
||||
);
|
||||
}
|
||||
|
||||
/**
|
||||
* Converts a Unicode code point to its UTF-8 encoded representation.
|
||||
*
|
||||
* @param int $num Code point
|
||||
*
|
||||
* @return string UTF-8 representation of code point
|
||||
*/
|
||||
private static function codePointToUtf8(int $num): string {
|
||||
if ($num <= 0x7F) {
|
||||
return chr($num);
|
||||
}
|
||||
if ($num <= 0x7FF) {
|
||||
return chr(($num >> 6) + 0xC0) . chr(($num & 0x3F) + 0x80);
|
||||
}
|
||||
if ($num <= 0xFFFF) {
|
||||
return chr(($num >> 12) + 0xE0) . chr((($num >> 6) & 0x3F) + 0x80) . chr(($num & 0x3F) + 0x80);
|
||||
}
|
||||
if ($num <= 0x1FFFFF) {
|
||||
return chr(($num >> 18) + 0xF0) . chr((($num >> 12) & 0x3F) + 0x80)
|
||||
. chr((($num >> 6) & 0x3F) + 0x80) . chr(($num & 0x3F) + 0x80);
|
||||
}
|
||||
throw new Error('Invalid UTF-8 codepoint escape sequence: Codepoint too large');
|
||||
}
|
||||
|
||||
public function getType(): string {
|
||||
return 'Scalar_String';
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user