You are here

class SimpleXMLElement in Service Container 7

Same name and namespace in other branches
  1. 7.2 modules/providers/service_container_symfony/lib/Symfony/Component/DependencyInjection/SimpleXMLElement.php \Symfony\Component\DependencyInjection\SimpleXMLElement

SimpleXMLElement class.

@author Fabien Potencier <fabien@symfony.com>

Hierarchy

Expanded class hierarchy of SimpleXMLElement

Deprecated

since version 2.5, to be removed in 3.0.

File

modules/providers/service_container_symfony/lib/Symfony/Component/DependencyInjection/SimpleXMLElement.php, line 26

Namespace

Symfony\Component\DependencyInjection
View source
class SimpleXMLElement extends \SimpleXMLElement {

  /**
   * Converts an attribute as a PHP type.
   *
   * @param string $name
   *
   * @return mixed
   */
  public function getAttributeAsPhp($name) {
    return self::phpize($this[$name]);
  }

  /**
   * Returns arguments as valid PHP types.
   *
   * @param string $name
   * @param bool   $lowercase
   *
   * @return mixed
   */
  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 'expression':
          $arguments[$key] = new Expression((string) $arg);
          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;
  }

  /**
   * Converts an xml value to a PHP type.
   *
   * @param mixed $value
   *
   * @return mixed
   */
  public static function phpize($value) {
    return XmlUtils::phpize($value);
  }

}

Members

Namesort descending Modifiers Type Description Overrides
SimpleXMLElement::getArgumentsAsPhp public function Returns arguments as valid PHP types. Overrides SimpleXMLElement::getArgumentsAsPhp 1
SimpleXMLElement::getAttributeAsPhp public function Converts an attribute as a PHP type. Overrides SimpleXMLElement::getAttributeAsPhp 1
SimpleXMLElement::phpize public static function Converts an xml value to a PHP type. Overrides SimpleXMLElement::phpize 1