mirror of
https://github.com/nikic/PHP-Parser.git
synced 2025-01-17 23:28:15 +01:00
62 lines
1.4 KiB
PHP
62 lines
1.4 KiB
PHP
<?php
|
|
|
|
namespace PhpParser\Node\Scalar;
|
|
|
|
use PhpParser\Node\Scalar;
|
|
|
|
class LNumber extends Scalar
|
|
{
|
|
/** @var int Number value */
|
|
public $value;
|
|
|
|
/**
|
|
* Constructs an integer number scalar node.
|
|
*
|
|
* @param int $value Value of the number
|
|
* @param array $attributes Additional attributes
|
|
*/
|
|
public function __construct($value, array $attributes = array()) {
|
|
parent::__construct($attributes);
|
|
$this->value = $value;
|
|
}
|
|
|
|
public function getSubNodeNames() {
|
|
return array('value');
|
|
}
|
|
|
|
/**
|
|
* @internal
|
|
*
|
|
* Parses an LNUMBER token (dec, hex, oct and bin notations) like PHP would.
|
|
*
|
|
* @param string $str A string number
|
|
*
|
|
* @return int The parsed number
|
|
*/
|
|
public static function parse($str) {
|
|
// handle plain 0 specially
|
|
if ('0' === $str) {
|
|
return 0;
|
|
}
|
|
|
|
// if first char is 0 (and number isn't 0) it's a special syntax
|
|
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 (intval instead of octdec to get proper cutting behavior with malformed numbers)
|
|
return intval($str, 8);
|
|
}
|
|
|
|
// dec
|
|
return (int) $str;
|
|
}
|
|
}
|