1 | <?php |
||
16 | class Formatter extends AbstractFormatterProvider |
||
17 | { |
||
18 | /** |
||
19 | * If no formatter is specified, this formatter is used by default |
||
20 | * |
||
21 | * @var string |
||
22 | */ |
||
23 | protected $defaultFormatter; |
||
24 | |||
25 | /** |
||
26 | * The list of available formatter providers. |
||
27 | * The key is the same key that is exposed in the format() method |
||
28 | * The value is either a Closure, a FQC, or an object that implements the |
||
29 | * FormatterProvider interface |
||
30 | * |
||
31 | * @var array list of formatters & providers|closures |
||
32 | */ |
||
33 | private $providers = []; |
||
34 | |||
35 | /** |
||
36 | * A list of all the available formats. If a formatter is an instance of |
||
37 | * FormatterProvider, it's list is exploded using dot notiation. |
||
38 | * |
||
39 | * @var string[] |
||
40 | */ |
||
41 | private $formats = []; |
||
42 | |||
43 | private $formatMethodPrefix = 'as'; |
||
44 | |||
45 | /** |
||
46 | * Constructor |
||
47 | * |
||
48 | * @param array $formatters The formatters to provide, either as instances |
||
49 | * of FormatterProvider or closures |
||
50 | */ |
||
51 | public function __construct(array $formatters = []) |
||
57 | |||
58 | /** |
||
59 | * Set the default formatter to use |
||
60 | * |
||
61 | * @param string $format |
||
62 | */ |
||
63 | public function setDefaultFormatter($format) |
||
72 | |||
73 | /** |
||
74 | * Get the default formatter |
||
75 | * |
||
76 | * @return string |
||
77 | */ |
||
78 | public function getDefaultFormatter() |
||
82 | |||
83 | /** |
||
84 | * Add a new or replace a formatter within the stack |
||
85 | * |
||
86 | * @param string $name The name of the formatter |
||
87 | * @param Closure|FormatterProvider $method the object executes the format |
||
88 | */ |
||
89 | public function addFormatter($name, $method) |
||
113 | |||
114 | /** |
||
115 | * Check the default format and set the default if we have at least |
||
116 | * one formatter |
||
117 | * |
||
118 | * @return nil |
||
|
|||
119 | */ |
||
120 | private function checkDefaultFormatter() |
||
129 | |||
130 | /** |
||
131 | * Get a list of available formats from the supplied formatter |
||
132 | * |
||
133 | * @param Closure|FormatterProvider $formatter |
||
134 | * @param string $name Base name of the formatter |
||
135 | * @return string[] |
||
136 | */ |
||
137 | private function getFormatsFromFormatter($formatter, $name) |
||
148 | |||
149 | /** |
||
150 | * Format the provided value based on the requested formatter |
||
151 | * |
||
152 | * @param mixed $value The value to format |
||
153 | * @param string|array The format + format options, if an array is provided the first value is the formatter |
||
154 | * and the other values are format params |
||
155 | * @return mixed |
||
156 | * @throws InvalidArgumentException |
||
157 | */ |
||
158 | public function format($value, $format = null) |
||
185 | |||
186 | /** |
||
187 | * Get the current list of available formats |
||
188 | * |
||
189 | * @return array |
||
190 | */ |
||
191 | public function formats() |
||
195 | |||
196 | /** |
||
197 | * Allow dynamic calls to be made to the formatter |
||
198 | * |
||
199 | * @todo Is this still needed? |
||
200 | */ |
||
201 | public function __call($method, $params) |
||
208 | |||
209 | /** |
||
210 | * Determine if the format exists within the formatter. |
||
211 | * |
||
212 | * @return boolean |
||
213 | * @throws InvalidArgumentException |
||
214 | */ |
||
215 | public function hasFormat($format) |
||
224 | } |
||
225 |
This check compares the return type specified in the
@return
annotation of a function or method doc comment with the types returned by the function and raises an issue if they mismatch.