File "MethodInjection.php"
Full path: /home/capoeirajd/www/wp-content/plugins/wp-migrate-db/vendor/php-di/php-di/src/DI/Definition/ObjectDefinition/MethodInjection.php
File
size: 1.72 B
MIME-type: text/x-php
Charset: utf-8
Download Open Edit Advanced Editor Back
<?php
namespace DeliciousBrains\WPMDB\Container\DI\Definition\ObjectDefinition;
use DeliciousBrains\WPMDB\Container\DI\Definition\Definition;
use DeliciousBrains\WPMDB\Container\DI\Scope;
/**
* Describe an injection in an object method.
*
* @author Matthieu Napoli <matthieu@mnapoli.fr>
*/
class MethodInjection implements Definition
{
/**
* @var string
*/
private $methodName;
/**
* @var array
*/
private $parameters = [];
/**
* @param string $methodName
* @param array $parameters
*/
public function __construct($methodName, array $parameters = [])
{
$this->methodName = (string) $methodName;
$this->parameters = $parameters;
}
public static function constructor(array $parameters = [])
{
return new self('__construct', $parameters);
}
/**
* @return string Method name
*/
public function getMethodName()
{
return $this->methodName;
}
/**
* @return array
*/
public function getParameters()
{
return $this->parameters;
}
/**
* Replace the parameters of the definition by a new array of parameters.
*
* @param array $parameters
*/
public function replaceParameters(array $parameters)
{
$this->parameters = $parameters;
}
public function merge(MethodInjection $definition)
{
// In case of conflicts, the current definition prevails.
$this->parameters = $this->parameters + $definition->parameters;
}
/**
* {@inheritdoc}
*/
public function getName()
{
return null;
}
/**
* {@inheritdoc}
*/
public function getScope()
{
return Scope::PROTOTYPE;
}
}