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

Breadcrumb

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

class Context

Same name in this branch
  1. 11.1.x vendor/open-telemetry/api/Instrumentation/AutoInstrumentation/Context.php \OpenTelemetry\API\Instrumentation\AutoInstrumentation\Context
  2. 11.1.x vendor/open-telemetry/context/Context.php \OpenTelemetry\Context\Context
  3. 11.1.x vendor/symfony/serializer/Attribute/Context.php \Symfony\Component\Serializer\Attribute\Context
  4. 11.1.x vendor/phpdocumentor/type-resolver/src/Types/Context.php \phpDocumentor\Reflection\Types\Context
  5. 11.1.x core/lib/Drupal/Core/Plugin/Context/Context.php \Drupal\Core\Plugin\Context\Context
  6. 11.1.x core/lib/Drupal/Component/Plugin/Context/Context.php \Drupal\Component\Plugin\Context\Context

Hierarchy

  • class \SebastianBergmann\RecursionContext\Context

Expanded class hierarchy of Context

7 files declare their use of Context
Enumerator.php in vendor/sebastian/object-enumerator/src/Enumerator.php
ExcludeList.php in vendor/phpunit/phpunit/src/Util/ExcludeList.php
Exporter.php in vendor/phpunit/phpunit/src/Util/Exporter.php
Exporter.php in vendor/sebastian/exporter/src/Exporter.php
ExportUtil.php in vendor/phpspec/prophecy/src/Prophecy/Util/ExportUtil.php

... See full list

18 string references to 'Context'
CompiledUrlMatcherDumper::compileRoute in vendor/symfony/routing/Matcher/Dumper/CompiledUrlMatcherDumper.php
Compiles a single Route to PHP code used to match it against the path info.
ConditionManagerCreateInstanceContextConfigurationRule::processNode in vendor/mglaman/phpstan-drupal/src/Rules/Deprecations/ConditionManagerCreateInstanceContextConfigurationRule.php
LocaleConfigManager::processTranslatableData in core/modules/locale/src/LocaleConfigManager.php
Process the translatable data array with a given language.
LocaleConfigSubscriber::processTranslatableData in core/modules/locale/src/LocaleConfigSubscriber.php
Process the translatable data array with a given language.
LocaleConfigSubscriber::resetExistingTranslations in core/modules/locale/src/LocaleConfigSubscriber.php
Reset existing locale translations to their source values.

... See full list

File

vendor/sebastian/recursion-context/src/Context.php, line 23

Namespace

SebastianBergmann\RecursionContext
View source
final class Context {
    private array $arrays = [];
    private SplObjectStorage $objects;
    public function __construct() {
        $this->objects = new SplObjectStorage();
    }
    
    /**
     * @codeCoverageIgnore
     */
    public function __destruct() {
        foreach ($this->arrays as &$array) {
            if (is_array($array)) {
                array_pop($array);
                array_pop($array);
            }
        }
    }
    
    /**
     * @psalm-template T
     *
     * @psalm-param T $value
     *
     * @param-out T $value
     */
    public function add(object|array &$value) : int|string|false {
        if (is_array($value)) {
            return $this->addArray($value);
        }
        return $this->addObject($value);
    }
    
    /**
     * @psalm-template T
     *
     * @psalm-param T $value
     *
     * @param-out T $value
     */
    public function contains(object|array &$value) : int|string|false {
        if (is_array($value)) {
            return $this->containsArray($value);
        }
        return $this->containsObject($value);
    }
    private function addArray(array &$array) : int {
        $key = $this->containsArray($array);
        if ($key !== false) {
            return $key;
        }
        $key = count($this->arrays);
        $this->arrays[] =& $array;
        if (!array_key_exists(PHP_INT_MAX, $array) && !array_key_exists(PHP_INT_MAX - 1, $array)) {
            $array[] = $key;
            $array[] = $this->objects;
        }
        else {
            
            /* Cover the improbable case, too.
             *
             * Note that array_slice() (used in containsArray()) will return the
             * last two values added, *not necessarily* the highest integer keys
             * in the array. Therefore, the order of these writes to $array is
             * important, but the actual keys used is not. */
            do {
                
                /** @noinspection PhpUnhandledExceptionInspection */
                $key = random_int(PHP_INT_MIN, PHP_INT_MAX);
            } while (array_key_exists($key, $array));
            $array[$key] = $key;
            do {
                
                /** @noinspection PhpUnhandledExceptionInspection */
                $key = random_int(PHP_INT_MIN, PHP_INT_MAX);
            } while (array_key_exists($key, $array));
            $array[$key] = $this->objects;
        }
        return $key;
    }
    private function addObject(object $object) : string {
        if (!$this->objects
            ->contains($object)) {
            $this->objects
                ->attach($object);
        }
        return spl_object_hash($object);
    }
    private function containsArray(array $array) : int|false {
        $end = array_slice($array, -2);
        return isset($end[1]) && $end[1] === $this->objects ? $end[0] : false;
    }
    private function containsObject(object $value) : string|false {
        if ($this->objects
            ->contains($value)) {
            return spl_object_hash($value);
        }
        return false;
    }

}

Members

Title Sort descending Modifiers Object type Summary
Context::$arrays private property
Context::$objects private property
Context::add public function @psalm-template T
Context::addArray private function
Context::addObject private function
Context::contains public function @psalm-template T
Context::containsArray private function
Context::containsObject private function
Context::__construct public function
Context::__destruct public function @codeCoverageIgnore
RSS feed
Powered by Drupal