Skip to main content
Drupal API
User account menu
  • Log in

Breadcrumb

  1. Drupal Core 11.1.x
  2. Float_.php

class Float_

Same name in this branch
  1. 11.1.x vendor/phpdocumentor/type-resolver/src/Types/Float_.php \phpDocumentor\Reflection\Types\Float_

Hierarchy

  • class \PhpParser\NodeAbstract implements \PhpParser\Node, \PhpParser\JsonSerializable
    • class \PhpParser\Node\Expr extends \PhpParser\NodeAbstract
      • class \PhpParser\Node\Scalar extends \PhpParser\Node\Expr
        • class \PhpParser\Node\Scalar\Float_ extends \PhpParser\Node\Scalar

Expanded class hierarchy of Float_

File

vendor/nikic/php-parser/lib/PhpParser/Node/Scalar/Float_.php, line 7

Namespace

PhpParser\Node\Scalar
View source
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 (double) $str;
    }
    public function getType() : string {
        return 'Scalar_Float';
    }

}

Members

Title Sort descending Modifiers Object type Summary
Float_::$value public property @var float Number value
Float_::fromString public static function
Float_::getSubNodeNames public function
Float_::getType public function
Float_::parse public static function @internal
Float_::__construct public function Constructs a float number scalar node.

API Navigation

  • Drupal Core 11.1.x
  • Topics
  • Classes
  • Functions
  • Constants
  • Globals
  • Files
  • Namespaces
  • Deprecated
  • Services
RSS feed
Powered by Drupal