1 | <?php |
||
47 | class PartChoice extends AbstractPartAggregate |
||
48 | { |
||
49 | /** |
||
50 | * Part name wildcard |
||
51 | * |
||
52 | * @var string |
||
53 | */ |
||
54 | const WILDCARD = '*'; |
||
55 | |||
56 | /** |
||
57 | * Assign data to a particular part |
||
58 | * |
||
59 | * @param string $part Part identifier |
||
60 | * @param string $data Part data |
||
61 | * @param null|int $occurrence Occurrence to assign the part data to |
||
62 | */ |
||
63 | 23 | public function assign($part, $data, $occurrence = null) |
|
64 | { |
||
65 | 23 | $occurrence = $this->prepareAssignment($part, $occurrence); |
|
66 | |||
67 | /** @var HydratorInterface $hydrator */ |
||
68 | 23 | $hydrator =& $this->template[$part]; |
|
69 | 23 | $this->occurrences[$occurrence] = [$part => $hydrator->hydrate($data)]; |
|
70 | 23 | } |
|
71 | |||
72 | /** |
||
73 | * Add an occurrence |
||
74 | * |
||
75 | * @return void |
||
76 | */ |
||
77 | 23 | protected function addOccurrence() |
|
81 | |||
82 | /** |
||
83 | * Test if a particular part identifier is known for a particular occurrence |
||
84 | * |
||
85 | * @param int $occurrence Occurrence index |
||
86 | * @param string $part Part identifier |
||
87 | * @return bool Is known part identifier |
||
88 | */ |
||
89 | 6 | protected function isKnownPartIdentifier($occurrence, $part) |
|
96 | |||
97 | /** |
||
98 | * Return a particular part of a particular occurrence |
||
99 | * |
||
100 | * @param int $occurrence Occurrence index |
||
101 | * @param string $part Part identifier |
||
102 | * @return PartInterface Part instance |
||
103 | */ |
||
104 | 6 | protected function getOccurrencePart(&$occurrence, &$part) |
|
114 | } |
||
115 |