InheritableItemDecoratorTrait.php 1.5 KB
Newer Older
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
<?php

/*
 * © 2016 IRSTEA
 * Guillaume Perréal <guillaume.perreal@irstea.fr>
 * Tous droits réservés.
 */

namespace Irstea\PlantUmlBundle\Model\Decorator;

use Irstea\PlantUmlBundle\Model\ClassVisitorInterface;
use Irstea\PlantUmlBundle\Model\NodeInterface;
use ReflectionClass;

/**
 * Décorateur abstrait pour les éléments d'une classe qui peuvent être hérités d'une classe base.
 *
 * Ce décorateur s'assure de n'afficher que les éléments propres à la classe.
 *
 * @author Guillaume Perréal <guillaume.perreal@irstea.fr>
 */
trait InheritableItemDecoratorTrait
{
    /**
     *
     * @param \ReflectionClass $class
     * @param NodeInterface $node
     * @param ClassVisitorInterface $visitor
     * @return self
     */
    public function decorate(ReflectionClass $class, NodeInterface $node, ClassVisitorInterface $visitor)
    {
        $items = $this->extractItems($class);
        if (empty($items)) {
            return;
        }

        $parent = $class->getParentClass();
        if ($parent) {
            $parentItems = $this->extractItems($parent);
            if (!empty($parentItems)) {
                $items = array_diff_key($items, $parentItems);
            }
        }

        foreach($items as $item) {
            $this->decorateItem($class, $node, $visitor, $item);
        }
    }

    abstract protected function extractItems(ReflectionClass $class);

    abstract protected function decorateItem(ReflectionClass $class, NodeInterface $node, ClassVisitorInterface $visitor, $item);
}