123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108 |
- <?php
- /*
- * This file is part of the Symfony package.
- *
- * (c) Fabien Potencier <fabien@symfony.com>
- *
- * For the full copyright and license information, please view the LICENSE
- * file that was distributed with this source code.
- */
- namespace Symfony\Component\DependencyInjection;
- use Symfony\Component\Config\Util\XmlUtils;
- /**
- * SimpleXMLElement class.
- *
- * @author Fabien Potencier <fabien@symfony.com>
- */
- 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 Boolean $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 '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);
- }
- }
|