InheritableItemDecoratorTrait.php 1.41 KB
Newer Older
1
2
<?php
/*
Guillaume Perréal's avatar
CS.    
Guillaume Perréal committed
3
4
 * Copyright (C) 2016-2017 IRSTEA
 * All rights reserved.
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
 */

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.
 */
trait InheritableItemDecoratorTrait
{
    /**
Guillaume Perréal's avatar
CS.    
Guillaume Perréal committed
20
21
     * @param \ReflectionClass      $class
     * @param NodeInterface         $node
22
     * @param ClassVisitorInterface $visitor
Guillaume Perréal's avatar
CS.    
Guillaume Perréal committed
23
     *
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
     * @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);
            }
        }

Guillaume Perréal's avatar
CS.    
Guillaume Perréal committed
41
        foreach ($items as $item) {
42
43
44
45
46
47
48
49
            $this->decorateItem($class, $node, $visitor, $item);
        }
    }

    abstract protected function extractItems(ReflectionClass $class);

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