2015-08-17 17:00:26 -07:00
< ? 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\Compiler ;
use Symfony\Component\DependencyInjection\Exception\InvalidArgumentException ;
/**
* This is a directed graph of your services .
*
* This information can be used by your compiler passes instead of collecting
* it themselves which improves performance quite a lot .
*
* @ author Johannes M . Schmitt < schmittjoh @ gmail . com >
2018-11-23 12:29:20 +00:00
*
* @ final since version 3.4
2015-08-17 17:00:26 -07:00
*/
class ServiceReferenceGraph
{
/**
* @ var ServiceReferenceGraphNode []
*/
private $nodes = array ();
/**
* Checks if the graph has a specific node .
*
* @ param string $id Id to check
*
* @ return bool
*/
public function hasNode ( $id )
{
return isset ( $this -> nodes [ $id ]);
}
/**
* Gets a node by identifier .
*
* @ param string $id The id to retrieve
*
2017-02-02 16:28:38 -08:00
* @ return ServiceReferenceGraphNode
2015-08-17 17:00:26 -07:00
*
* @ throws InvalidArgumentException if no node matches the supplied identifier
*/
public function getNode ( $id )
{
if ( ! isset ( $this -> nodes [ $id ])) {
throw new InvalidArgumentException ( sprintf ( 'There is no node with id "%s".' , $id ));
}
return $this -> nodes [ $id ];
}
/**
* Returns all nodes .
*
2017-02-02 16:28:38 -08:00
* @ return ServiceReferenceGraphNode []
2015-08-17 17:00:26 -07:00
*/
public function getNodes ()
{
return $this -> nodes ;
}
/**
* Clears all nodes .
*/
public function clear ()
{
2018-11-23 12:29:20 +00:00
foreach ( $this -> nodes as $node ) {
$node -> clear ();
}
2015-08-17 17:00:26 -07:00
$this -> nodes = array ();
}
/**
* Connects 2 nodes together in the Graph .
*
* @ param string $sourceId
2018-11-23 12:29:20 +00:00
* @ param mixed $sourceValue
2015-08-17 17:00:26 -07:00
* @ param string $destId
2018-11-23 12:29:20 +00:00
* @ param mixed $destValue
2015-08-17 17:00:26 -07:00
* @ param string $reference
2018-11-23 12:29:20 +00:00
* @ param bool $lazy
* @ param bool $weak
2015-08-17 17:00:26 -07:00
*/
2018-11-23 12:29:20 +00:00
public function connect ( $sourceId , $sourceValue , $destId , $destValue = null , $reference = null /*, bool $lazy = false, bool $weak = false*/ )
2015-08-17 17:00:26 -07:00
{
2018-11-23 12:29:20 +00:00
$lazy = \func_num_args () >= 6 ? func_get_arg ( 5 ) : false ;
$weak = \func_num_args () >= 7 ? func_get_arg ( 6 ) : false ;
if ( null === $sourceId || null === $destId ) {
return ;
}
2015-08-17 17:00:26 -07:00
$sourceNode = $this -> createNode ( $sourceId , $sourceValue );
$destNode = $this -> createNode ( $destId , $destValue );
2018-11-23 12:29:20 +00:00
$edge = new ServiceReferenceGraphEdge ( $sourceNode , $destNode , $reference , $lazy , $weak );
2015-08-17 17:00:26 -07:00
$sourceNode -> addOutEdge ( $edge );
$destNode -> addInEdge ( $edge );
}
/**
* Creates a graph node .
*
* @ param string $id
2018-11-23 12:29:20 +00:00
* @ param mixed $value
2015-08-17 17:00:26 -07:00
*
* @ return ServiceReferenceGraphNode
*/
private function createNode ( $id , $value )
{
if ( isset ( $this -> nodes [ $id ]) && $this -> nodes [ $id ] -> getValue () === $value ) {
return $this -> nodes [ $id ];
}
return $this -> nodes [ $id ] = new ServiceReferenceGraphNode ( $id , $value );
}
}