1 | <?php |
||
20 | class ItemIdSnakValue { |
||
21 | |||
22 | /** |
||
23 | * @var ItemId|null |
||
24 | */ |
||
25 | private $itemId = null; |
||
26 | |||
27 | /** |
||
28 | * @var bool |
||
29 | */ |
||
30 | |||
31 | private $some = false; |
||
32 | |||
33 | /** |
||
34 | * @var bool |
||
35 | */ |
||
36 | private $no = false; |
||
37 | |||
38 | private function __construct() { |
||
40 | |||
41 | /** |
||
42 | * Get an {@link ItemIdSnakValue} from the given $itemId. |
||
43 | * |
||
44 | * @param ItemId $itemId |
||
45 | * @return self |
||
46 | */ |
||
47 | public static function fromItemId( ItemId $itemId ) { |
||
52 | |||
53 | /** |
||
54 | * Get an {@link ItemIdSnakValue} that wraps an unknown value. |
||
55 | * |
||
56 | * @return self |
||
57 | */ |
||
58 | public static function someValue() { |
||
63 | |||
64 | /** |
||
65 | * Get an {@link ItemIdSnakValue} that wraps no value. |
||
66 | * |
||
67 | * @return self |
||
68 | */ |
||
69 | public static function noValue() { |
||
74 | |||
75 | /** |
||
76 | * Get an {@link ItemIdSnakValue} that matches the given snak. |
||
77 | * |
||
78 | * @param Snak $snak |
||
79 | * |
||
80 | * @throws InvalidArgumentException |
||
81 | * @return self |
||
82 | */ |
||
83 | public static function fromSnak( Snak $snak ) { |
||
102 | |||
103 | /** |
||
104 | * Check whether this {@link ItemIdSnakValue} contains a known value or not. |
||
105 | * |
||
106 | * @return bool |
||
107 | */ |
||
108 | public function isValue() { |
||
111 | |||
112 | /** |
||
113 | * Check whether this {@link ItemIdSnakValue} contains an unknown value or not. |
||
114 | * |
||
115 | * @return bool |
||
116 | */ |
||
117 | public function isSomeValue() { |
||
120 | |||
121 | /** |
||
122 | * Check whether this {@link ItemIdSnakValue} contains no value or not. |
||
123 | * |
||
124 | * @return bool |
||
125 | */ |
||
126 | public function isNoValue() { |
||
129 | |||
130 | /** |
||
131 | * Get the item ID contained in this {@link ItemIdSnakValue}. |
||
132 | * Only valid if {@link isValue} is true. |
||
133 | * |
||
134 | * @throws DomainException if this value does not contain an item ID |
||
135 | * @return ItemId |
||
136 | */ |
||
137 | public function getItemId() { |
||
143 | |||
144 | /** |
||
145 | * Check whether this value matches the given $snak |
||
146 | * (same kind and, if contains known value, same value). |
||
147 | * |
||
148 | * @param Snak $snak |
||
149 | * @return bool |
||
150 | */ |
||
151 | public function matchesSnak( Snak $snak ) { |
||
165 | |||
166 | } |
||
167 |