public function SimpleXMLElement::getArgumentsAsPhp

Returns arguments as valid php types.

Parameters

string $name:

Boolean $lowercase:

Return value

mixed

Overrides SimpleXMLElement::getArgumentsAsPhp

1 method overrides SimpleXMLElement::getArgumentsAsPhp()
SimpleXMLElement::getArgumentsAsPhp in drupal/core/vendor/symfony/dependency-injection/Symfony/Component/DependencyInjection/SimpleXMLElement.php
Returns arguments as valid php types.

File

drupal/core/vendor/symfony/dependency-injection/Symfony/Component/DependencyInjection/SimpleXMLElement.php, line 41

Class

SimpleXMLElement
SimpleXMLElement class.

Namespace

Symfony\Component\DependencyInjection

Code

public function getArgumentsAsPhp($name, $lowercase = true) {
  $arguments = array();
  foreach ($this->{$name} as $arg) {
    if (isset($arg['name'])) {
      $arg['key'] = (string) $arg['name'];
    }
    $key = isset($arg['key']) ? (string) $arg['key'] : (!$arguments ? 0 : max(array_keys($arguments)) + 1);

    // parameter keys are case insensitive
    if ('parameter' == $name && $lowercase) {
      $key = strtolower($key);
    }

    // this is used by DefinitionDecorator to overwrite a specific
    // argument of the parent definition
    if (isset($arg['index'])) {
      $key = 'index_' . $arg['index'];
    }
    switch ($arg['type']) {
      case 'service':
        $invalidBehavior = ContainerInterface::EXCEPTION_ON_INVALID_REFERENCE;
        if (isset($arg['on-invalid']) && 'ignore' == $arg['on-invalid']) {
          $invalidBehavior = ContainerInterface::IGNORE_ON_INVALID_REFERENCE;
        }
        elseif (isset($arg['on-invalid']) && 'null' == $arg['on-invalid']) {
          $invalidBehavior = ContainerInterface::NULL_ON_INVALID_REFERENCE;
        }
        if (isset($arg['strict'])) {
          $strict = self::phpize($arg['strict']);
        }
        else {
          $strict = true;
        }
        $arguments[$key] = new Reference((string) $arg['id'], $invalidBehavior, $strict);
        break;
      case 'collection':
        $arguments[$key] = $arg
          ->getArgumentsAsPhp($name, false);
        break;
      case 'string':
        $arguments[$key] = (string) $arg;
        break;
      case 'constant':
        $arguments[$key] = constant((string) $arg);
        break;
      default:
        $arguments[$key] = self::phpize($arg);
    }
  }
  return $arguments;
}