Code Coverage |
||||||||||
Classes and Traits |
Functions and Methods |
Lines |
||||||||
Total | |
100.00% |
1 / 1 |
|
100.00% |
10 / 10 |
CRAP | |
100.00% |
22 / 22 |
Graph | |
100.00% |
1 / 1 |
|
100.00% |
10 / 10 |
12 | |
100.00% |
22 / 22 |
__construct | |
100.00% |
1 / 1 |
1 | |
100.00% |
5 / 5 |
|||
createNestedGraph | |
100.00% |
1 / 1 |
1 | |
100.00% |
1 / 1 |
|||
getNodeById | |
100.00% |
1 / 1 |
2 | |
100.00% |
3 / 3 |
|||
getEdgeById | |
100.00% |
1 / 1 |
2 | |
100.00% |
3 / 3 |
|||
getAllNodes | |
100.00% |
1 / 1 |
1 | |
100.00% |
2 / 2 |
|||
getAllEdges | |
100.00% |
1 / 1 |
1 | |
100.00% |
2 / 2 |
|||
getNodesByAttr | |
100.00% |
1 / 1 |
1 | |
100.00% |
1 / 1 |
|||
getEdgesByAttr | |
100.00% |
1 / 1 |
1 | |
100.00% |
1 / 1 |
|||
indexNodeAttr | |
100.00% |
1 / 1 |
1 | |
100.00% |
2 / 2 |
|||
indexEdgeAttr | |
100.00% |
1 / 1 |
1 | |
100.00% |
2 / 2 |
<?php declare(strict_types = 1); | |
/* | |
* Copyright (c) 2018, Josef Kufner <josef@kufner.cz> | |
* | |
* Licensed under the Apache License, Version 2.0 (the "License"); | |
* you may not use this file except in compliance with the License. | |
* You may obtain a copy of the License at | |
* | |
* http://www.apache.org/licenses/LICENSE-2.0 | |
* | |
* Unless required by applicable law or agreed to in writing, software | |
* distributed under the License is distributed on an "AS IS" BASIS, | |
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | |
* See the License for the specific language governing permissions and | |
* limitations under the License. | |
* | |
*/ | |
namespace Smalldb\Graph; | |
class Graph extends NestedGraph | |
{ | |
public function __construct(array $attrs = []) | |
{ | |
parent::__construct(null, $attrs); | |
$this->rootGraph = $this; | |
$this->nodeAttrIndex = new ElementAttrIndex(Node::class); | |
$this->edgeAttrIndex = new ElementAttrIndex(Edge::class); | |
} | |
public function createNestedGraph(Node $parentNode): NestedGraph | |
{ | |
return new NestedGraph($parentNode); | |
} | |
public function getNodeById(string $id): Node | |
{ | |
$node = $this->nodeAttrIndex->getElementById($id); | |
if ($node instanceof Node) { | |
return $node; | |
} else { | |
throw new \LogicException("The requested element is not a node: $id"); //@codeCoverageIgnore | |
} | |
} | |
public function getEdgeById(string $id): Edge | |
{ | |
$edge = $this->edgeAttrIndex->getElementById($id); | |
if ($edge instanceof Edge) { | |
return $edge; | |
} else { | |
throw new \LogicException("The requested element is not an edge: $id"); //@codeCoverageIgnore | |
} | |
} | |
/** | |
* Get all nodes in the graph, including nodes in nested graphs. | |
* | |
* @return Node[] | |
*/ | |
public function getAllNodes(): array | |
{ | |
/** @var Node[] $nodes */ | |
$nodes = $this->nodeAttrIndex->getAllElements(); | |
return $nodes; | |
} | |
/** | |
* Get all edges in the graph, including edges in nested graphs. | |
* | |
* @return Edge[] | |
*/ | |
public function getAllEdges(): array | |
{ | |
/** @var Edge[] $edges */ | |
$edges = $this->edgeAttrIndex->getAllElements(); | |
return $edges; | |
} | |
/** | |
* Get nodes which have attribute $key equal to $value | |
* | |
* @param string $key | |
* @param mixed $value | |
* @return Node[] | |
*/ | |
public function getNodesByAttr(string $key, $value = true): array | |
{ | |
return $this->nodeAttrIndex->getElements($key, $value); | |
} | |
/** | |
* Get edges which have attribute $key equal to $value | |
* | |
* @param string $key | |
* @param mixed $value | |
* @return Node[] | |
*/ | |
public function getEdgesByAttr(string $key, $value = true): array | |
{ | |
return $this->edgeAttrIndex->getElements($key, $value); | |
} | |
public function indexNodeAttr($key): NestedGraph | |
{ | |
$this->nodeAttrIndex->createAttrIndex($key); | |
return $this; | |
} | |
public function indexEdgeAttr($key): NestedGraph | |
{ | |
$this->edgeAttrIndex->createAttrIndex($key); | |
return $this; | |
} | |
} |