@@ -17,7 +17,7 @@ |
||
17 | 17 | private static $AVERAGE_COMPRESSION_RATIO = 2; |
18 | 18 | public static $forceTmpFile = false; |
19 | 19 | /** High limit. unit: MBytes. |
20 | - */ |
|
20 | + */ |
|
21 | 21 | public static $highLimit = 512; |
22 | 22 | |
23 | 23 | private $mode; |
@@ -11,8 +11,9 @@ discard block |
||
11 | 11 | */ |
12 | 12 | public static function registerWrapper() |
13 | 13 | { |
14 | - if (!self::$registered) |
|
15 | - stream_wrapper_register('compress.lzw', __CLASS__); |
|
14 | + if (!self::$registered) { |
|
15 | + stream_wrapper_register('compress.lzw', __CLASS__); |
|
16 | + } |
|
16 | 17 | self::$registered = true; |
17 | 18 | } |
18 | 19 | |
@@ -43,12 +44,14 @@ discard block |
||
43 | 44 | { |
44 | 45 | // check for compress & uncompress utility |
45 | 46 | $this->checkBinary(); |
46 | - if (self::$installed === false) |
|
47 | - throw new \Exception('compress and uncompress commands are required'); |
|
47 | + if (self::$installed === false) { |
|
48 | + throw new \Exception('compress and uncompress commands are required'); |
|
49 | + } |
|
48 | 50 | |
49 | 51 | $schema = 'compress.lzw://'; |
50 | - if (strncasecmp($schema, $path, strlen($schema)) == 0) |
|
51 | - $path = substr($path, strlen($schema)); |
|
52 | + if (strncasecmp($schema, $path, strlen($schema)) == 0) { |
|
53 | + $path = substr($path, strlen($schema)); |
|
54 | + } |
|
52 | 55 | |
53 | 56 | if (file_exists($path)) { |
54 | 57 | $this->path = realpath($path); |
@@ -62,14 +65,16 @@ discard block |
||
62 | 65 | $this->read(); |
63 | 66 | } else { |
64 | 67 | $prefix = basename(__FILE__, '.php'); |
65 | - if (($tmp = tempnam(sys_get_temp_dir(), $prefix)) === false) |
|
66 | - throw new \Exception(__CLASS__.', line '.__LINE__. |
|
68 | + if (($tmp = tempnam(sys_get_temp_dir(), $prefix)) === false) { |
|
69 | + throw new \Exception(__CLASS__.', line '.__LINE__. |
|
67 | 70 | ': Could not create temporary file in '. |
68 | 71 | sys_get_temp_dir()); |
69 | - if (($tmp2 = tempnam(sys_get_temp_dir(), $prefix)) === false) |
|
70 | - throw new \Exception(__CLASS__.', line '.__LINE__. |
|
72 | + } |
|
73 | + if (($tmp2 = tempnam(sys_get_temp_dir(), $prefix)) === false) { |
|
74 | + throw new \Exception(__CLASS__.', line '.__LINE__. |
|
71 | 75 | ': Could not create temporary file in '. |
72 | 76 | sys_get_temp_dir()); |
77 | + } |
|
73 | 78 | $this->tmp = $tmp; |
74 | 79 | $this->tmp2 = $tmp2; |
75 | 80 | $this->read(); |
@@ -78,14 +83,16 @@ discard block |
||
78 | 83 | $this->path = $path; |
79 | 84 | if (self::$forceTmpFile) { |
80 | 85 | $prefix = basename(__FILE__, '.php'); |
81 | - if (($tmp = tempnam(sys_get_temp_dir(), $prefix)) === false) |
|
82 | - throw new \Exception(__CLASS__.', line '.__LINE__. |
|
86 | + if (($tmp = tempnam(sys_get_temp_dir(), $prefix)) === false) { |
|
87 | + throw new \Exception(__CLASS__.', line '.__LINE__. |
|
83 | 88 | ': Could not create temporary file in '. |
84 | 89 | sys_get_temp_dir()); |
85 | - if (($tmp2 = tempnam(sys_get_temp_dir(), $prefix)) === false) |
|
86 | - throw new \Exception(__CLASS__.', line '.__LINE__. |
|
90 | + } |
|
91 | + if (($tmp2 = tempnam(sys_get_temp_dir(), $prefix)) === false) { |
|
92 | + throw new \Exception(__CLASS__.', line '.__LINE__. |
|
87 | 93 | ': Could not create temporary file in '. |
88 | 94 | sys_get_temp_dir()); |
95 | + } |
|
89 | 96 | $this->tmp = $tmp; |
90 | 97 | $this->tmp2 = $tmp2; |
91 | 98 | $this->pointer = 0; |
@@ -266,7 +273,9 @@ discard block |
||
266 | 273 | } |
267 | 274 | if ($this->tmp !== null) { |
268 | 275 | unlink($this->tmp); |
269 | - if (file_exists($this->tmp2)) unlink($this->tmp2); |
|
276 | + if (file_exists($this->tmp2)) { |
|
277 | + unlink($this->tmp2); |
|
278 | + } |
|
270 | 279 | } else { |
271 | 280 | $this->data = null; |
272 | 281 | } |
@@ -237,8 +237,8 @@ |
||
237 | 237 | if ($code == 0 || $code == 2 || is_null($code)) { |
238 | 238 | // rewrite original file |
239 | 239 | if (rename($this->tmp2, $this->path) !== true) { |
240 | - throw new \RuntimeException(__FILE__ . ', line ' . __LINE__ . |
|
241 | - ': Could not replace original file ' . $this->path); |
|
240 | + throw new \RuntimeException(__FILE__.', line '.__LINE__. |
|
241 | + ': Could not replace original file '.$this->path); |
|
242 | 242 | } |
243 | 243 | } else { |
244 | 244 | throw new \RuntimeException(__FILE__.', line '.__LINE__. |
@@ -10,13 +10,13 @@ discard block |
||
10 | 10 | */ |
11 | 11 | public static function getBinaryVersion() |
12 | 12 | { |
13 | - if (method_exists(__CLASS__, 'makeBinary7z')) |
|
14 | - try { |
|
13 | + if (method_exists(__CLASS__, 'makeBinary7z')) { |
|
14 | + try { |
|
15 | 15 | $binary = static::makeBinary7z(); |
16 | + } |
|
16 | 17 | } catch (\Exception $e) { |
17 | 18 | return false; |
18 | - } |
|
19 | - else { |
|
19 | + } else { |
|
20 | 20 | // some hack for gemorroj/archive7z 4.x version |
21 | 21 | try { |
22 | 22 | $seven_zip = new self(null); |
@@ -29,8 +29,9 @@ discard block |
||
29 | 29 | |
30 | 30 | $process = new Process([str_replace('\\', '/', $binary)]); |
31 | 31 | $result = $process->mustRun()->getOutput(); |
32 | - if (!preg_match('~7-Zip (\([a-z]\) )?(\[[\d]+\] )?(?<version>\d+\.\d+)~i', $result, $version)) |
|
33 | - return false; |
|
32 | + if (!preg_match('~7-Zip (\([a-z]\) )?(\[[\d]+\] )?(?<version>\d+\.\d+)~i', $result, $version)) { |
|
33 | + return false; |
|
34 | + } |
|
34 | 35 | |
35 | 36 | return $version['version']; |
36 | 37 | } |
@@ -203,8 +203,9 @@ |
||
203 | 203 | $deleted = 0; |
204 | 204 | |
205 | 205 | foreach ($files as $i => $file) { |
206 | - if ($this->tar->delete($file)) |
|
207 | - $deleted++; |
|
206 | + if ($this->tar->delete($file)) { |
|
207 | + $deleted++; |
|
208 | + } |
|
208 | 209 | } |
209 | 210 | |
210 | 211 | $this->tar = null; |
@@ -190,7 +190,7 @@ |
||
190 | 190 | */ |
191 | 191 | public function getFileStream($fileName) |
192 | 192 | { |
193 | - return fopen('phar://'.$this->archiveFileName . '/' . $fileName, 'rb'); |
|
193 | + return fopen('phar://'.$this->archiveFileName.'/'.$fileName, 'rb'); |
|
194 | 194 | } |
195 | 195 | |
196 | 196 | /** |
@@ -60,8 +60,9 @@ |
||
60 | 60 | */ |
61 | 61 | public function __construct($archiveFileName, $format, $password = null) |
62 | 62 | { |
63 | - if ($password !== null) |
|
64 | - throw new UnsupportedOperationException('Cab archive does not support password!'); |
|
63 | + if ($password !== null) { |
|
64 | + throw new UnsupportedOperationException('Cab archive does not support password!'); |
|
65 | + } |
|
65 | 66 | $this->open($archiveFileName); |
66 | 67 | } |
67 | 68 |
@@ -120,11 +120,11 @@ discard block |
||
120 | 120 | $this->files[$file->Location] = $directory.$file->strd_FileId; |
121 | 121 | $this->filesSize += $file->DataLen; |
122 | 122 | |
123 | - $this->filesData[$directory . $file->strd_FileId] = |
|
123 | + $this->filesData[$directory.$file->strd_FileId] = |
|
124 | 124 | [ |
125 | 125 | 'size' => $file->DataLen, |
126 | 126 | 'mtime' => |
127 | - strtotime((string)$file->isoRecDate), |
|
127 | + strtotime((string) $file->isoRecDate), |
|
128 | 128 | ]; |
129 | 129 | } |
130 | 130 | } |
@@ -172,7 +172,7 @@ discard block |
||
172 | 172 | return false; |
173 | 173 | |
174 | 174 | return new ArchiveEntry($fileName, $this->filesData[$fileName]['size'], |
175 | - $this->filesData[$fileName]['size'], $this->filesData[$fileName]['mtime'],false); |
|
175 | + $this->filesData[$fileName]['size'], $this->filesData[$fileName]['mtime'], false); |
|
176 | 176 | } |
177 | 177 | |
178 | 178 | /** |
@@ -69,8 +69,9 @@ discard block |
||
69 | 69 | public function __construct($archiveFileName, $format, $password = null) |
70 | 70 | { |
71 | 71 | $this->open($archiveFileName); |
72 | - if ($password !== null) |
|
73 | - throw new UnsupportedOperationException('Iso archive does not support password!'); |
|
72 | + if ($password !== null) { |
|
73 | + throw new UnsupportedOperationException('Iso archive does not support password!'); |
|
74 | + } |
|
74 | 75 | } |
75 | 76 | |
76 | 77 | /** |
@@ -93,8 +94,9 @@ discard block |
||
93 | 94 | |
94 | 95 | /** @var \CVolumeDescriptor $usedDesc */ |
95 | 96 | $usedDesc = $this->iso->GetDescriptor(SUPPLEMENTARY_VOLUME_DESC); |
96 | - if (!$usedDesc) |
|
97 | - $usedDesc = $this->iso->GetDescriptor(PRIMARY_VOLUME_DESC); |
|
97 | + if (!$usedDesc) { |
|
98 | + $usedDesc = $this->iso->GetDescriptor(PRIMARY_VOLUME_DESC); |
|
99 | + } |
|
98 | 100 | $this->blockSize = $usedDesc->iBlockSize; |
99 | 101 | $directories = $usedDesc->LoadMPathTable($this->iso); |
100 | 102 | // iterate over all directories |
@@ -115,8 +117,9 @@ discard block |
||
115 | 117 | if ($files) { |
116 | 118 | /** @var \CFileDirDescriptors $file */ |
117 | 119 | foreach ($files as $file) { |
118 | - if (in_array($file->strd_FileId, ['.', '..']) || $file->IsDirectory()) |
|
119 | - continue; |
|
120 | + if (in_array($file->strd_FileId, ['.', '..']) || $file->IsDirectory()) { |
|
121 | + continue; |
|
122 | + } |
|
120 | 123 | $this->files[$file->Location] = $directory.$file->strd_FileId; |
121 | 124 | $this->filesSize += $file->DataLen; |
122 | 125 | |
@@ -168,8 +171,9 @@ discard block |
||
168 | 171 | */ |
169 | 172 | public function getFileData($fileName) |
170 | 173 | { |
171 | - if (!isset($this->filesData[$fileName])) |
|
172 | - return false; |
|
174 | + if (!isset($this->filesData[$fileName])) { |
|
175 | + return false; |
|
176 | + } |
|
173 | 177 | |
174 | 178 | return new ArchiveEntry($fileName, $this->filesData[$fileName]['size'], |
175 | 179 | $this->filesData[$fileName]['size'], $this->filesData[$fileName]['mtime'],false); |
@@ -204,11 +208,14 @@ discard block |
||
204 | 208 | protected function prepareForFileExtracting($fileName) |
205 | 209 | { |
206 | 210 | $Location = array_search($fileName, $this->files, true); |
207 | - if (!isset($this->filesData[$fileName])) return false; |
|
211 | + if (!isset($this->filesData[$fileName])) { |
|
212 | + return false; |
|
213 | + } |
|
208 | 214 | $data = $this->filesData[$fileName]; |
209 | 215 | $Location_Real = $Location * $this->blockSize; |
210 | - if ($this->iso->Seek($Location_Real, SEEK_SET) === false) |
|
211 | - return false; |
|
216 | + if ($this->iso->Seek($Location_Real, SEEK_SET) === false) { |
|
217 | + return false; |
|
218 | + } |
|
212 | 219 | return $data; |
213 | 220 | } |
214 | 221 |
@@ -100,7 +100,9 @@ discard block |
||
100 | 100 | { |
101 | 101 | $information = new ArchiveInformation(); |
102 | 102 | foreach ($this->rar->getEntries() as $i => $entry) { |
103 | - if ($entry->isDirectory()) continue; |
|
103 | + if ($entry->isDirectory()) { |
|
104 | + continue; |
|
105 | + } |
|
104 | 106 | $information->files[] = $entry->getName(); |
105 | 107 | $information->compressedFilesSize += $entry->getPackedSize(); |
106 | 108 | $information->uncompressedFilesSize += $entry->getUnpackedSize(); |
@@ -115,7 +117,9 @@ discard block |
||
115 | 117 | { |
116 | 118 | $files = []; |
117 | 119 | foreach ($this->rar->getEntries() as $i => $entry) { |
118 | - if ($entry->isDirectory()) continue; |
|
120 | + if ($entry->isDirectory()) { |
|
121 | + continue; |
|
122 | + } |
|
119 | 123 | $files[] = $entry->getName(); |
120 | 124 | } |
121 | 125 | return $files; |
@@ -151,7 +155,9 @@ discard block |
||
151 | 155 | public function getFileContent($fileName) |
152 | 156 | { |
153 | 157 | $entry = $this->rar->getEntry($fileName); |
154 | - if ($entry->isDirectory()) return false; |
|
158 | + if ($entry->isDirectory()) { |
|
159 | + return false; |
|
160 | + } |
|
155 | 161 | return stream_get_contents($entry->getStream()); |
156 | 162 | } |
157 | 163 | |
@@ -163,7 +169,9 @@ discard block |
||
163 | 169 | public function getFileStream($fileName) |
164 | 170 | { |
165 | 171 | $entry = $this->rar->getEntry($fileName); |
166 | - if ($entry->isDirectory()) return false; |
|
172 | + if ($entry->isDirectory()) { |
|
173 | + return false; |
|
174 | + } |
|
167 | 175 | return $entry->getStream(); |
168 | 176 | } |
169 | 177 |
@@ -51,7 +51,7 @@ discard block |
||
51 | 51 | */ |
52 | 52 | public static function getDescription() |
53 | 53 | { |
54 | - return 'adapter for ext-rar' . (extension_loaded('rar') ? ' (' . phpversion('rar') . ')' : null); |
|
54 | + return 'adapter for ext-rar'.(extension_loaded('rar') ? ' ('.phpversion('rar').')' : null); |
|
55 | 55 | } |
56 | 56 | |
57 | 57 | /** |
@@ -60,7 +60,7 @@ discard block |
||
60 | 60 | public static function getInstallationInstruction() |
61 | 61 | { |
62 | 62 | return !extension_loaded('rar') |
63 | - ? 'install [rar] extension.' . "\n" . 'Can be installed with pecl: `pecl install rar`' |
|
63 | + ? 'install [rar] extension.'."\n".'Can be installed with pecl: `pecl install rar`' |
|
64 | 64 | : null; |
65 | 65 | } |
66 | 66 |
@@ -47,7 +47,7 @@ |
||
47 | 47 | |
48 | 48 | public static function getDescription() |
49 | 49 | { |
50 | - return 'adapter for ext-zip'.(extension_loaded('zip') && defined('\ZipArchive::LIBZIP_VERSION') ? ' ('. ZipArchive::LIBZIP_VERSION.')' : null); |
|
50 | + return 'adapter for ext-zip'.(extension_loaded('zip') && defined('\ZipArchive::LIBZIP_VERSION') ? ' ('.ZipArchive::LIBZIP_VERSION.')' : null); |
|
51 | 51 | } |
52 | 52 | |
53 | 53 | public static function getInstallationInstruction() |
@@ -66,8 +66,9 @@ discard block |
||
66 | 66 | public function __construct($archiveFileName, $format, $password = null) |
67 | 67 | { |
68 | 68 | $this->open($archiveFileName); |
69 | - if ($password !== null) |
|
70 | - $this->zip->setPassword($password); |
|
69 | + if ($password !== null) { |
|
70 | + $this->zip->setPassword($password); |
|
71 | + } |
|
71 | 72 | } |
72 | 73 | |
73 | 74 | /** |
@@ -101,8 +102,9 @@ discard block |
||
101 | 102 | for ($i = 0; $i < $this->zip->numFiles; $i++) { |
102 | 103 | $file = $this->zip->statIndex($i); |
103 | 104 | // skip directories |
104 | - if (in_array(substr($file['name'], -1), ['/', '\\'], true)) |
|
105 | - continue; |
|
105 | + if (in_array(substr($file['name'], -1), ['/', '\\'], true)) { |
|
106 | + continue; |
|
107 | + } |
|
106 | 108 | $this->pureFilesNumber++; |
107 | 109 | $information->files[$i] = $file['name']; |
108 | 110 | $information->compressedFilesSize += $file['comp_size']; |
@@ -137,8 +139,9 @@ discard block |
||
137 | 139 | for ($i = 0; $i < $this->zip->numFiles; $i++) { |
138 | 140 | $file_name = $this->zip->getNameIndex($i); |
139 | 141 | // skip directories |
140 | - if (in_array(substr($file_name, -1), ['/', '\\'], true)) |
|
141 | - continue; |
|
142 | + if (in_array(substr($file_name, -1), ['/', '\\'], true)) { |
|
143 | + continue; |
|
144 | + } |
|
142 | 145 | $files[] = $file_name; |
143 | 146 | } |
144 | 147 | return $files; |
@@ -175,8 +178,9 @@ discard block |
||
175 | 178 | public function getFileContent($fileName) |
176 | 179 | { |
177 | 180 | $result = $this->zip->getFromName($fileName); |
178 | - if ($result === false) |
|
179 | - throw new Exception('Could not get file information: '.$result.'. May use password?'); |
|
181 | + if ($result === false) { |
|
182 | + throw new Exception('Could not get file information: '.$result.'. May use password?'); |
|
183 | + } |
|
180 | 184 | return $result; |
181 | 185 | } |
182 | 186 | |
@@ -197,8 +201,9 @@ discard block |
||
197 | 201 | */ |
198 | 202 | public function extractFiles($outputFolder, array $files) |
199 | 203 | { |
200 | - if ($this->zip->extractTo($outputFolder, $files) === false) |
|
201 | - throw new ArchiveExtractionException($this->zip->getStatusString(), $this->zip->status); |
|
204 | + if ($this->zip->extractTo($outputFolder, $files) === false) { |
|
205 | + throw new ArchiveExtractionException($this->zip->getStatusString(), $this->zip->status); |
|
206 | + } |
|
202 | 207 | |
203 | 208 | return count($files); |
204 | 209 | } |
@@ -210,8 +215,9 @@ discard block |
||
210 | 215 | */ |
211 | 216 | public function extractArchive($outputFolder) |
212 | 217 | { |
213 | - if ($this->zip->extractTo($outputFolder) === false) |
|
214 | - throw new ArchiveExtractionException($this->zip->getStatusString(), $this->zip->status); |
|
218 | + if ($this->zip->extractTo($outputFolder) === false) { |
|
219 | + throw new ArchiveExtractionException($this->zip->getStatusString(), $this->zip->status); |
|
220 | + } |
|
215 | 221 | |
216 | 222 | return $this->pureFilesNumber; |
217 | 223 | } |
@@ -226,8 +232,9 @@ discard block |
||
226 | 232 | { |
227 | 233 | $count = 0; |
228 | 234 | foreach ($files as $file) { |
229 | - if ($this->zip->deleteName($file) === false) |
|
230 | - throw new ArchiveModificationException($this->zip->getStatusString(), $this->zip->status); |
|
235 | + if ($this->zip->deleteName($file) === false) { |
|
236 | + throw new ArchiveModificationException($this->zip->getStatusString(), $this->zip->status); |
|
237 | + } |
|
231 | 238 | $count++; |
232 | 239 | } |
233 | 240 | |
@@ -250,11 +257,13 @@ discard block |
||
250 | 257 | $added_files = 0; |
251 | 258 | foreach ($files as $localName => $fileName) { |
252 | 259 | if (is_null($fileName)) { |
253 | - if ($this->zip->addEmptyDir($localName) === false) |
|
254 | - throw new ArchiveModificationException($this->zip->getStatusString(), $this->zip->status); |
|
260 | + if ($this->zip->addEmptyDir($localName) === false) { |
|
261 | + throw new ArchiveModificationException($this->zip->getStatusString(), $this->zip->status); |
|
262 | + } |
|
255 | 263 | } else { |
256 | - if ($this->zip->addFile($fileName, $localName) === false) |
|
257 | - throw new ArchiveModificationException($this->zip->getStatusString(), $this->zip->status); |
|
264 | + if ($this->zip->addFile($fileName, $localName) === false) { |
|
265 | + throw new ArchiveModificationException($this->zip->getStatusString(), $this->zip->status); |
|
266 | + } |
|
258 | 267 | $added_files++; |
259 | 268 | } |
260 | 269 | } |
@@ -307,8 +316,9 @@ discard block |
||
307 | 316 | $zip = new ZipArchive(); |
308 | 317 | $result = $zip->open($archiveFileName, ZipArchive::CREATE); |
309 | 318 | |
310 | - if ($result !== true) |
|
311 | - throw new ArchiveCreationException('ZipArchive error: '.$result); |
|
319 | + if ($result !== true) { |
|
320 | + throw new ArchiveCreationException('ZipArchive error: '.$result); |
|
321 | + } |
|
312 | 322 | |
313 | 323 | $can_set_compression_level = method_exists($zip, 'setCompressionName'); |
314 | 324 | $can_encrypt = static::canEncrypt(Formats::ZIP); |
@@ -326,11 +336,13 @@ discard block |
||
326 | 336 | |
327 | 337 | foreach ($files as $localName => $fileName) { |
328 | 338 | if ($fileName === null) { |
329 | - if ($zip->addEmptyDir($localName) === false) |
|
330 | - throw new ArchiveCreationException('Could not archive directory "'.$localName.'": '.$zip->getStatusString(), $zip->status); |
|
339 | + if ($zip->addEmptyDir($localName) === false) { |
|
340 | + throw new ArchiveCreationException('Could not archive directory "'.$localName.'": '.$zip->getStatusString(), $zip->status); |
|
341 | + } |
|
331 | 342 | } else { |
332 | - if ($zip->addFile($fileName, $localName) === false) |
|
333 | - throw new ArchiveCreationException('Could not archive file "'.$fileName.'": '.$zip->getStatusString(), $zip->status); |
|
343 | + if ($zip->addFile($fileName, $localName) === false) { |
|
344 | + throw new ArchiveCreationException('Could not archive file "'.$fileName.'": '.$zip->getStatusString(), $zip->status); |
|
345 | + } |
|
334 | 346 | if ($can_set_compression_level) { |
335 | 347 | $zip->setCompressionName($localName, $compressionLevelMap[$compressionLevel]); |
336 | 348 | } |
@@ -15,7 +15,7 @@ |
||
15 | 15 | { |
16 | 16 | $fp = fopen($file, 'rb'); |
17 | 17 | if (filesize($file) < 18 || strcmp(fread($fp, 2), "\x1f\x8b")) { |
18 | - return false; // Not GZIP format (See RFC 1952) |
|
18 | + return false; // Not GZIP format (See RFC 1952) |
|
19 | 19 | } |
20 | 20 | $method = fread($fp, 1); |
21 | 21 | $flags = fread($fp, 1); |
@@ -5,7 +5,7 @@ |
||
5 | 5 | |
6 | 6 | class Bzip extends OneFileDriver |
7 | 7 | { |
8 | - const FORMAT_SUFFIX = 'bz2'; |
|
8 | + const FORMAT_SUFFIX = 'bz2'; |
|
9 | 9 | |
10 | 10 | /** |
11 | 11 | * @return array |