diff options
| author | Jan-Hendrik Willms <tleilax+github@gmail.com> | 2021-07-22 16:07:19 +0200 |
|---|---|---|
| committer | Jan-Hendrik Willms <tleilax+github@gmail.com> | 2021-07-22 16:19:12 +0200 |
| commit | a3da1483a9e689846179159355badfec8073dbec (patch) | |
| tree | 770dcca6bdf5f6f2a11b0e7fcbbeda6919a3fc52 /lib/classes/CSVArrayObject.class.php | |
current code from svn, revision 62608
Diffstat (limited to 'lib/classes/CSVArrayObject.class.php')
| -rw-r--r-- | lib/classes/CSVArrayObject.class.php | 47 |
1 files changed, 47 insertions, 0 deletions
diff --git a/lib/classes/CSVArrayObject.class.php b/lib/classes/CSVArrayObject.class.php new file mode 100644 index 0000000..f075795 --- /dev/null +++ b/lib/classes/CSVArrayObject.class.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()); + } +} |
