81 lines
1.8 KiB
PHP
81 lines
1.8 KiB
PHP
|
|
<?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;
|
||
|
|
|
||
|
|
/**
|
||
|
|
* Represents an edge in your service graph.
|
||
|
|
*
|
||
|
|
* Value is typically a reference.
|
||
|
|
*
|
||
|
|
* @author Johannes M. Schmitt <schmittjoh@gmail.com>
|
||
|
|
*/
|
||
|
|
class ServiceReferenceGraphEdge
|
||
|
|
{
|
||
|
|
public function __construct(
|
||
|
|
private ServiceReferenceGraphNode $sourceNode,
|
||
|
|
private ServiceReferenceGraphNode $destNode,
|
||
|
|
private mixed $value = null,
|
||
|
|
private bool $lazy = false,
|
||
|
|
private bool $weak = false,
|
||
|
|
private bool $byConstructor = false,
|
||
|
|
) {
|
||
|
|
}
|
||
|
|
|
||
|
|
/**
|
||
|
|
* Returns the value of the edge.
|
||
|
|
*/
|
||
|
|
public function getValue(): mixed
|
||
|
|
{
|
||
|
|
return $this->value;
|
||
|
|
}
|
||
|
|
|
||
|
|
/**
|
||
|
|
* Returns the source node.
|
||
|
|
*/
|
||
|
|
public function getSourceNode(): ServiceReferenceGraphNode
|
||
|
|
{
|
||
|
|
return $this->sourceNode;
|
||
|
|
}
|
||
|
|
|
||
|
|
/**
|
||
|
|
* Returns the destination node.
|
||
|
|
*/
|
||
|
|
public function getDestNode(): ServiceReferenceGraphNode
|
||
|
|
{
|
||
|
|
return $this->destNode;
|
||
|
|
}
|
||
|
|
|
||
|
|
/**
|
||
|
|
* Returns true if the edge is lazy, meaning it's a dependency not requiring direct instantiation.
|
||
|
|
*/
|
||
|
|
public function isLazy(): bool
|
||
|
|
{
|
||
|
|
return $this->lazy;
|
||
|
|
}
|
||
|
|
|
||
|
|
/**
|
||
|
|
* Returns true if the edge is weak, meaning it shouldn't prevent removing the target service.
|
||
|
|
*/
|
||
|
|
public function isWeak(): bool
|
||
|
|
{
|
||
|
|
return $this->weak;
|
||
|
|
}
|
||
|
|
|
||
|
|
/**
|
||
|
|
* Returns true if the edge links with a constructor argument.
|
||
|
|
*/
|
||
|
|
public function isReferencedByConstructor(): bool
|
||
|
|
{
|
||
|
|
return $this->byConstructor;
|
||
|
|
}
|
||
|
|
}
|