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

Breadcrumb

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

class ArrayExpression

Same name in this branch
  1. 11.1.x vendor/mck89/peast/lib/Peast/Syntax/Node/ArrayExpression.php \Peast\Syntax\Node\ArrayExpression

Hierarchy

  • class \Twig\Node\Node implements \Twig\Node\Countable, \Twig\Node\IteratorAggregate
    • class \Twig\Node\Expression\AbstractExpression extends \Twig\Node\Node
      • class \Twig\Node\Expression\ArrayExpression extends \Twig\Node\Expression\AbstractExpression

Expanded class hierarchy of ArrayExpression

8 files declare their use of ArrayExpression
CallableArgumentsExtractor.php in vendor/twig/twig/src/Util/CallableArgumentsExtractor.php
DefinedTest.php in vendor/twig/twig/src/Node/Expression/Test/DefinedTest.php
ExpressionParser.php in vendor/twig/twig/src/ExpressionParser.php
MacroNode.php in vendor/twig/twig/src/Node/MacroNode.php
MacroTokenParser.php in vendor/twig/twig/src/TokenParser/MacroTokenParser.php

... See full list

2 string references to 'ArrayExpression'
Parser::parseArrayLiteral in vendor/mck89/peast/lib/Peast/Syntax/Parser.php
Parses an array literal
Renderer::renderNode in vendor/mck89/peast/lib/Peast/Renderer.php
Renders a node

File

vendor/twig/twig/src/Node/Expression/ArrayExpression.php, line 17

Namespace

Twig\Node\Expression
View source
class ArrayExpression extends AbstractExpression {
    private $index;
    public function __construct(array $elements, int $lineno) {
        parent::__construct($elements, [], $lineno);
        $this->index = -1;
        foreach ($this->getKeyValuePairs() as $pair) {
            if ($pair['key'] instanceof ConstantExpression && ctype_digit((string) $pair['key']->getAttribute('value')) && $pair['key']->getAttribute('value') > $this->index) {
                $this->index = $pair['key']->getAttribute('value');
            }
        }
    }
    public function getKeyValuePairs() : array {
        $pairs = [];
        foreach (array_chunk($this->nodes, 2) as $pair) {
            $pairs[] = [
                'key' => $pair[0],
                'value' => $pair[1],
            ];
        }
        return $pairs;
    }
    public function hasElement(AbstractExpression $key) : bool {
        foreach ($this->getKeyValuePairs() as $pair) {
            // we compare the string representation of the keys
            // to avoid comparing the line numbers which are not relevant here.
            if ((string) $key === (string) $pair['key']) {
                return true;
            }
        }
        return false;
    }
    public function addElement(AbstractExpression $value, ?AbstractExpression $key = null) : void {
        if (null === $key) {
            $key = new ConstantExpression(++$this->index, $value->getTemplateLine());
        }
        array_push($this->nodes, $key, $value);
    }
    public function compile(Compiler $compiler) : void {
        $keyValuePairs = $this->getKeyValuePairs();
        $needsArrayMergeSpread = \PHP_VERSION_ID < 80100 && $this->hasSpreadItem($keyValuePairs);
        if ($needsArrayMergeSpread) {
            $compiler->raw('CoreExtension::merge(');
        }
        $compiler->raw('[');
        $first = true;
        $reopenAfterMergeSpread = false;
        $nextIndex = 0;
        foreach ($keyValuePairs as $pair) {
            if ($reopenAfterMergeSpread) {
                $compiler->raw(', [');
                $reopenAfterMergeSpread = false;
            }
            if ($needsArrayMergeSpread && $pair['value']->hasAttribute('spread')) {
                $compiler->raw('], ')
                    ->subcompile($pair['value']);
                $first = true;
                $reopenAfterMergeSpread = true;
                continue;
            }
            if (!$first) {
                $compiler->raw(', ');
            }
            $first = false;
            if ($pair['value']->hasAttribute('spread') && !$needsArrayMergeSpread) {
                $compiler->raw('...')
                    ->subcompile($pair['value']);
                ++$nextIndex;
            }
            else {
                $key = null;
                if ($pair['key'] instanceof NameExpression) {
                    $pair['key'] = new StringCastUnary($pair['key'], $pair['key']->getTemplateLine());
                }
                if ($pair['key'] instanceof TempNameExpression) {
                    $key = $pair['key']->getAttribute('name');
                    $pair['key'] = new ConstantExpression($key, $pair['key']->getTemplateLine());
                }
                if ($pair['key'] instanceof ConstantExpression) {
                    $key = $pair['key']->getAttribute('value');
                }
                if ($nextIndex !== $key) {
                    if (\is_int($key)) {
                        $nextIndex = $key + 1;
                    }
                    $compiler->subcompile($pair['key'])
                        ->raw(' => ');
                }
                else {
                    ++$nextIndex;
                }
                $compiler->subcompile($pair['value']);
            }
        }
        if (!$reopenAfterMergeSpread) {
            $compiler->raw(']');
        }
        if ($needsArrayMergeSpread) {
            $compiler->raw(')');
        }
    }
    private function hasSpreadItem(array $pairs) : bool {
        foreach ($pairs as $pair) {
            if ($pair['value']->hasAttribute('spread')) {
                return true;
            }
        }
        return false;
    }

}

Members

Title Sort descending Modifiers Object type Summary Overriden Title Overrides
AbstractExpression::hasExplicitParentheses public function
AbstractExpression::isGenerator public function
AbstractExpression::setExplicitParentheses public function
ArrayExpression::$index private property
ArrayExpression::addElement public function
ArrayExpression::compile public function Overrides Node::compile 1
ArrayExpression::getKeyValuePairs public function
ArrayExpression::hasElement public function
ArrayExpression::hasSpreadItem private function
ArrayExpression::__construct public function Overrides Node::__construct
Node::$attributeNameDeprecations private property @var array&lt;string, NameDeprecation&gt;
Node::$attributes protected property
Node::$lineno protected property
Node::$nodeNameDeprecations private property @var array&lt;string, NameDeprecation&gt;
Node::$nodes protected property
Node::$sourceContext private property
Node::$tag protected property
Node::count public function
Node::deprecateAttribute public function
Node::deprecateNode public function
Node::getAttribute public function
Node::getIterator public function
Node::getNode public function
Node::getNodeTag public function
Node::getSourceContext public function
Node::getTemplateLine public function
Node::getTemplateName public function
Node::hasAttribute public function
Node::hasNode public function
Node::removeAttribute public function
Node::removeNode public function
Node::setAttribute public function
Node::setNode public function 1
Node::setNodeTag public function @internal
Node::setSourceContext public function
Node::__toString public function

API Navigation

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