diff options
| author | Marcus Eibrink-Lunzenauer <lunzenauer@elan-ev.de> | 2024-06-18 13:18:06 +0000 |
|---|---|---|
| committer | Marcus Eibrink-Lunzenauer <lunzenauer@elan-ev.de> | 2024-06-18 13:18:06 +0000 |
| commit | 33fd1358507b4a5abb3dcebe78d407d0567717c1 (patch) | |
| tree | 6bd8f6959da4c3fc1b8907c0bbc28eb9e10d4a5a /lib/classes/CSVArrayObject.php | |
| parent | 42d46671c0309bddb71a91bbfdc5f2fa2e44384e (diff) | |
Deprecate `StudipAutoloader` and use composer's `autoload`
Closes #4282
Merge request studip/studip!3099
Diffstat (limited to 'lib/classes/CSVArrayObject.php')
| -rw-r--r-- | lib/classes/CSVArrayObject.php | 47 |
1 files changed, 47 insertions, 0 deletions
diff --git a/lib/classes/CSVArrayObject.php b/lib/classes/CSVArrayObject.php new file mode 100644 index 0000000..f075795 --- /dev/null +++ b/lib/classes/CSVArrayObject.php @@ -0,0 +1,47 @@ +<?php +/** + * This class works like an array. + * The internal array is constructed from a comma separated string + * When used in an string context, it is automatically converted to a comma + * separated string + * + * Usage: + * @code + * $csvarray = new CSVArrayObject('eins,zwei,drei'); + * $csvarray[] = 'vier'; + * echo $csvarray; // prints out "eins,zwei,drei,vier" + * @endcode + * + * This program is free software; you can redistribute it and/or + * modify it under the terms of the GNU General Public License as + * published by the Free Software Foundation; either version 2 of + * the License, or (at your option) any later version. + * + * @author André Noack <noack@data-quest.de> + * @link http://www.php.net/manual/en/class.arrayobject.php + */ +class CSVArrayObject extends StudipArrayObject +{ + /** + * Construct an array object from a string of comma separated items + * + * @param string $input a string of comma separated items + */ + function __construct($input) + { + if (is_string($input)) { + $input = mb_strlen($input) ? array_map('trim', explode(',', $input)) : []; + } + parent::__construct((array)$input); + } + + /** + * magic method for use of object in string context + * + * @return string internal array itmes converted to a comma separated list + */ + function __toString() + { + return implode(',', $this->getArrayCopy()); + } +} |
