mirror of
https://github.com/danog/PHP-Parser.git
synced 2025-01-06 04:58:28 +01:00
a2d7e8977a
Instead of storing subnodes in a subNodes dictionary, they are now stored as simple properties. This requires declarating the properties, assigning them in the constructor, overriding the getSubNodeNames() method and passing NULL to the first argument of the NodeAbstract constructor. [Deprecated: It's still possible to use the old mode of operation for custom nodes by passing an array of subnodes to the constructor.] The only behavior difference this should cause is that getSubNodeNames() will always return the original subnode names and skip any additional properties that were dynamically added. E.g. this means that the "namespacedName" node added by the NameResolver visitor is not treated as a subnode, but as a dynamic property instead. This change improves performance and memory usage.
65 lines
1.6 KiB
PHP
65 lines
1.6 KiB
PHP
<?php
|
|
|
|
namespace PhpParser\Node\Scalar;
|
|
|
|
use PhpParser\Node\Scalar;
|
|
|
|
class DNumber extends Scalar
|
|
{
|
|
/** @var float Number value */
|
|
public $value;
|
|
|
|
/**
|
|
* Constructs a float number scalar node.
|
|
*
|
|
* @param float $value Value of the number
|
|
* @param array $attributes Additional attributes
|
|
*/
|
|
public function __construct($value = 0.0, array $attributes = array()) {
|
|
parent::__construct(null, $attributes);
|
|
$this->value = $value;
|
|
}
|
|
|
|
public function getSubNodeNames() {
|
|
return array('value');
|
|
}
|
|
|
|
/**
|
|
* @internal
|
|
*
|
|
* Parses a DNUMBER token like PHP would.
|
|
*
|
|
* @param string $str A string number
|
|
*
|
|
* @return float The parsed number
|
|
*/
|
|
public static function parse($str) {
|
|
// if string contains any of .eE just cast it to float
|
|
if (false !== strpbrk($str, '.eE')) {
|
|
return (float) $str;
|
|
}
|
|
|
|
// otherwise it's an integer notation that overflowed into a float
|
|
// if it starts with 0 it's 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
|
|
// 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;
|
|
}
|
|
}
|