2017-02-11 01:10:13 +01:00
|
|
|
<?php
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Interface to detect if a class is traversable using &foreach;.
|
|
|
|
* @link http://php.net/manual/en/class.traversable.php
|
|
|
|
*
|
|
|
|
* @template TKey
|
|
|
|
* @template TValue
|
|
|
|
*/
|
|
|
|
interface Traversable {
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Interface to create an external Iterator.
|
|
|
|
* @link http://php.net/manual/en/class.iteratoraggregate.php
|
|
|
|
*
|
|
|
|
* @template TKey
|
|
|
|
* @template TValue
|
|
|
|
*
|
|
|
|
* @template-extends Traversable<TKey, TValue>
|
|
|
|
*/
|
|
|
|
interface IteratorAggregate extends Traversable {
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Retrieve an external iterator
|
|
|
|
* @link http://php.net/manual/en/iteratoraggregate.getiterator.php
|
|
|
|
* @return Traversable<TKey, TValue> An instance of an object implementing <b>Iterator</b> or
|
|
|
|
* <b>Traversable</b>
|
|
|
|
* @since 5.0.0
|
|
|
|
*/
|
|
|
|
public function getIterator();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Interface for external iterators or objects that can be iterated
|
|
|
|
* themselves internally.
|
|
|
|
* @link http://php.net/manual/en/class.iterator.php
|
|
|
|
*
|
|
|
|
* @template TKey
|
|
|
|
* @template TValue
|
|
|
|
*
|
|
|
|
* @template-extends Traversable<TKey, TValue>
|
|
|
|
*/
|
|
|
|
interface Iterator extends Traversable {
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Return the current element
|
|
|
|
* @link http://php.net/manual/en/iterator.current.php
|
|
|
|
* @return TValue Can return any type.
|
|
|
|
* @since 5.0.0
|
|
|
|
*/
|
|
|
|
public function current();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Move forward to next element
|
|
|
|
* @link http://php.net/manual/en/iterator.next.php
|
|
|
|
* @return void Any returned value is ignored.
|
|
|
|
* @since 5.0.0
|
|
|
|
*/
|
|
|
|
public function next();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Return the key of the current element
|
|
|
|
* @link http://php.net/manual/en/iterator.key.php
|
|
|
|
* @return TKey scalar on success, or null on failure.
|
|
|
|
* @since 5.0.0
|
|
|
|
*/
|
|
|
|
public function key();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Checks if current position is valid
|
|
|
|
* @link http://php.net/manual/en/iterator.valid.php
|
2017-05-25 04:07:49 +02:00
|
|
|
* @return bool The return value will be casted to boolean and then evaluated.
|
2017-02-11 01:10:13 +01:00
|
|
|
* Returns true on success or false on failure.
|
|
|
|
* @since 5.0.0
|
|
|
|
*/
|
|
|
|
public function valid();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Rewind the Iterator to the first element
|
|
|
|
* @link http://php.net/manual/en/iterator.rewind.php
|
|
|
|
* @return void Any returned value is ignored.
|
|
|
|
* @since 5.0.0
|
|
|
|
*/
|
|
|
|
public function rewind();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Interface to provide accessing objects as arrays.
|
|
|
|
* @link http://php.net/manual/en/class.arrayaccess.php
|
|
|
|
*
|
|
|
|
* @template TKey
|
|
|
|
* @template TValue
|
|
|
|
*/
|
|
|
|
interface ArrayAccess {
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Whether a offset exists
|
|
|
|
* @link http://php.net/manual/en/arrayaccess.offsetexists.php
|
|
|
|
* @param TKey $offset <p>
|
|
|
|
* An offset to check for.
|
|
|
|
* </p>
|
2017-05-25 04:07:49 +02:00
|
|
|
* @return bool true on success or false on failure.
|
2017-02-11 01:10:13 +01:00
|
|
|
* </p>
|
|
|
|
* <p>
|
|
|
|
* The return value will be casted to boolean if non-boolean was returned.
|
|
|
|
* @since 5.0.0
|
|
|
|
*/
|
|
|
|
public function offsetExists($offset);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Offset to retrieve
|
|
|
|
* @link http://php.net/manual/en/arrayaccess.offsetget.php
|
|
|
|
* @param TKey $offset <p>
|
|
|
|
* The offset to retrieve.
|
|
|
|
* </p>
|
|
|
|
* @return TValue Can return all value types.
|
|
|
|
* @since 5.0.0
|
|
|
|
*/
|
|
|
|
public function offsetGet($offset);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Offset to set
|
|
|
|
* @link http://php.net/manual/en/arrayaccess.offsetset.php
|
|
|
|
* @param TKey $offset <p>
|
|
|
|
* The offset to assign the value to.
|
|
|
|
* </p>
|
|
|
|
* @param TValue $value <p>
|
|
|
|
* The value to set.
|
|
|
|
* </p>
|
|
|
|
* @return void
|
|
|
|
* @since 5.0.0
|
|
|
|
*/
|
|
|
|
public function offsetSet($offset, $value);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Offset to unset
|
|
|
|
* @link http://php.net/manual/en/arrayaccess.offsetunset.php
|
|
|
|
* @param TKey $offset <p>
|
|
|
|
* The offset to unset.
|
|
|
|
* </p>
|
|
|
|
* @return void
|
|
|
|
* @since 5.0.0
|
|
|
|
*/
|
|
|
|
public function offsetUnset($offset);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* This class allows objects to work as arrays.
|
|
|
|
* @link http://php.net/manual/en/class.arrayobject.php
|
|
|
|
*
|
|
|
|
* @template TKey
|
|
|
|
* @template TValue
|
|
|
|
*/
|
|
|
|
class ArrayObject implements IteratorAggregate, Traversable, ArrayAccess, Serializable, Countable {
|
|
|
|
/**
|
|
|
|
* Properties of the object have their normal functionality when accessed as list (var_dump, foreach, etc.).
|
|
|
|
*/
|
|
|
|
const STD_PROP_LIST = 1;
|
|
|
|
/**
|
|
|
|
* Entries can be accessed as properties (read and write).
|
|
|
|
*/
|
|
|
|
const ARRAY_AS_PROPS = 2;
|
|
|
|
/**
|
|
|
|
* Construct a new array object
|
|
|
|
* @link http://php.net/manual/en/arrayobject.construct.php
|
|
|
|
* @param array<Tkey, TValue>|object $input The input parameter accepts an array or an Object.
|
|
|
|
* @param int $flags Flags to control the behaviour of the ArrayObject object.
|
|
|
|
* @param string $iterator_class Specify the class that will be used for iteration of the ArrayObject object. ArrayIterator is the default class used.
|
|
|
|
* @since 5.0.0
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
public function __construct($input = null, $flags = 0, $iterator_class = "ArrayIterator") { }
|
|
|
|
/**
|
|
|
|
* Returns whether the requested index exists
|
|
|
|
* @link http://php.net/manual/en/arrayobject.offsetexists.php
|
|
|
|
* @param TKey $index <p>
|
|
|
|
* The index being checked.
|
|
|
|
* </p>
|
|
|
|
* @return bool true if the requested index exists, otherwise false
|
|
|
|
* @since 5.0.0
|
|
|
|
*/
|
|
|
|
public function offsetExists($index) { }
|
|
|
|
/**
|
|
|
|
* Returns the value at the specified index
|
|
|
|
* @link http://php.net/manual/en/arrayobject.offsetget.php
|
|
|
|
* @param TKey $index <p>
|
|
|
|
* The index with the value.
|
|
|
|
* </p>
|
|
|
|
* @return TValue The value at the specified index or false.
|
|
|
|
* @since 5.0.0
|
|
|
|
*/
|
|
|
|
public function offsetGet($index) { }
|
|
|
|
/**
|
|
|
|
* Sets the value at the specified index to newval
|
|
|
|
* @link http://php.net/manual/en/arrayobject.offsetset.php
|
|
|
|
* @param TKey $index <p>
|
|
|
|
* The index being set.
|
|
|
|
* </p>
|
|
|
|
* @param TValue $newval <p>
|
|
|
|
* The new value for the <i>index</i>.
|
|
|
|
* </p>
|
|
|
|
* @return void
|
|
|
|
* @since 5.0.0
|
|
|
|
*/
|
|
|
|
public function offsetSet($index, $newval) { }
|
|
|
|
/**
|
|
|
|
* Unsets the value at the specified index
|
|
|
|
* @link http://php.net/manual/en/arrayobject.offsetunset.php
|
|
|
|
* @param TKey $index <p>
|
|
|
|
* The index being unset.
|
|
|
|
* </p>
|
|
|
|
* @return void
|
|
|
|
* @since 5.0.0
|
|
|
|
*/
|
|
|
|
public function offsetUnset($index) { }
|
|
|
|
/**
|
|
|
|
* Appends the value
|
|
|
|
* @link http://php.net/manual/en/arrayobject.append.php
|
|
|
|
* @param TValue $value <p>
|
|
|
|
* The value being appended.
|
|
|
|
* </p>
|
|
|
|
* @return void
|
|
|
|
* @since 5.0.0
|
|
|
|
*/
|
|
|
|
public function append($value) { }
|
|
|
|
/**
|
|
|
|
* Creates a copy of the ArrayObject.
|
|
|
|
* @link http://php.net/manual/en/arrayobject.getarraycopy.php
|
|
|
|
* @return array<TKey, TValue> a copy of the array. When the <b>ArrayObject</b> refers to an object
|
|
|
|
* an array of the public properties of that object will be returned.
|
|
|
|
* @since 5.0.0
|
|
|
|
*/
|
|
|
|
public function getArrayCopy() { }
|
|
|
|
/**
|
|
|
|
* Get the number of public properties in the ArrayObject
|
|
|
|
* When the <b>ArrayObject</b> is constructed from an array all properties are public.
|
|
|
|
* @link http://php.net/manual/en/arrayobject.count.php
|
|
|
|
* @return int The number of public properties in the ArrayObject.
|
|
|
|
* @since 5.0.0
|
|
|
|
*/
|
|
|
|
public function count() { }
|
|
|
|
/**
|
|
|
|
* Gets the behavior flags.
|
|
|
|
* @link http://php.net/manual/en/arrayobject.getflags.php
|
|
|
|
* @return int the behavior flags of the ArrayObject.
|
|
|
|
* @since 5.1.0
|
|
|
|
*/
|
|
|
|
public function getFlags() { }
|
|
|
|
/**
|
|
|
|
* Sets the behavior flags.
|
|
|
|
* @link http://php.net/manual/en/arrayobject.setflags.php
|
|
|
|
* @param int $flags <p>
|
|
|
|
* The new ArrayObject behavior.
|
|
|
|
* It takes on either a bitmask, or named constants. Using named
|
|
|
|
* constants is strongly encouraged to ensure compatibility for future
|
|
|
|
* versions.
|
|
|
|
* </p>
|
|
|
|
* <p>
|
|
|
|
* The available behavior flags are listed below. The actual
|
|
|
|
* meanings of these flags are described in the
|
|
|
|
* predefined constants.
|
|
|
|
* <table>
|
|
|
|
* ArrayObject behavior flags
|
|
|
|
* <tr valign="top">
|
|
|
|
* <td>value</td>
|
|
|
|
* <td>constant</td>
|
|
|
|
* </tr>
|
|
|
|
* <tr valign="top">
|
|
|
|
* <td>1</td>
|
|
|
|
* <td>
|
|
|
|
* ArrayObject::STD_PROP_LIST
|
|
|
|
* </td>
|
|
|
|
* </tr>
|
|
|
|
* <tr valign="top">
|
|
|
|
* <td>2</td>
|
|
|
|
* <td>
|
|
|
|
* ArrayObject::ARRAY_AS_PROPS
|
|
|
|
* </td>
|
|
|
|
* </tr>
|
|
|
|
* </table>
|
|
|
|
* </p>
|
|
|
|
* @return void
|
|
|
|
* @since 5.1.0
|
|
|
|
*/
|
|
|
|
public function setFlags($flags) { }
|
|
|
|
/**
|
|
|
|
* Sort the entries by value
|
|
|
|
* @link http://php.net/manual/en/arrayobject.asort.php
|
|
|
|
* @return void
|
|
|
|
* @since 5.2.0
|
|
|
|
*/
|
|
|
|
public function asort() { }
|
|
|
|
/**
|
|
|
|
* Sort the entries by key
|
|
|
|
* @link http://php.net/manual/en/arrayobject.ksort.php
|
|
|
|
* @return void
|
|
|
|
* @since 5.2.0
|
|
|
|
*/
|
|
|
|
public function ksort() { }
|
|
|
|
/**
|
|
|
|
* Sort the entries with a user-defined comparison function and maintain key association
|
|
|
|
* @link http://php.net/manual/en/arrayobject.uasort.php
|
|
|
|
* @param callback $cmp_function <p>
|
|
|
|
* Function <i>cmp_function</i> should accept two
|
|
|
|
* parameters which will be filled by pairs of entries.
|
|
|
|
* The comparison function must return an integer less than, equal
|
|
|
|
* to, or greater than zero if the first argument is considered to
|
|
|
|
* be respectively less than, equal to, or greater than the
|
|
|
|
* second.
|
|
|
|
* </p>
|
|
|
|
* @return void
|
|
|
|
* @since 5.2.0
|
|
|
|
*/
|
|
|
|
public function uasort($cmp_function) { }
|
|
|
|
/**
|
|
|
|
* Sort the entries by keys using a user-defined comparison function
|
|
|
|
* @link http://php.net/manual/en/arrayobject.uksort.php
|
|
|
|
* @param callback $cmp_function <p>
|
|
|
|
* The callback comparison function.
|
|
|
|
* </p>
|
|
|
|
* <p>
|
|
|
|
* Function <i>cmp_function</i> should accept two
|
|
|
|
* parameters which will be filled by pairs of entry keys.
|
|
|
|
* The comparison function must return an integer less than, equal
|
|
|
|
* to, or greater than zero if the first argument is considered to
|
|
|
|
* be respectively less than, equal to, or greater than the
|
|
|
|
* second.
|
|
|
|
* </p>
|
|
|
|
* @return void
|
|
|
|
* @since 5.2.0
|
|
|
|
*/
|
|
|
|
public function uksort($cmp_function) { }
|
|
|
|
/**
|
|
|
|
* Sort entries using a "natural order" algorithm
|
|
|
|
* @link http://php.net/manual/en/arrayobject.natsort.php
|
|
|
|
* @return void
|
|
|
|
* @since 5.2.0
|
|
|
|
*/
|
|
|
|
public function natsort() { }
|
|
|
|
/**
|
|
|
|
* Sort an array using a case insensitive "natural order" algorithm
|
|
|
|
* @link http://php.net/manual/en/arrayobject.natcasesort.php
|
|
|
|
* @return void
|
|
|
|
* @since 5.2.0
|
|
|
|
*/
|
|
|
|
public function natcasesort() { }
|
|
|
|
/**
|
|
|
|
* Unserialize an ArrayObject
|
|
|
|
* @link http://php.net/manual/en/arrayobject.unserialize.php
|
|
|
|
* @param string $serialized <p>
|
|
|
|
* The serialized <b>ArrayObject</b>.
|
|
|
|
* </p>
|
|
|
|
* @return void The unserialized <b>ArrayObject</b>.
|
|
|
|
* @since 5.3.0
|
|
|
|
*/
|
|
|
|
public function unserialize($serialized) { }
|
|
|
|
/**
|
|
|
|
* Serialize an ArrayObject
|
|
|
|
* @link http://php.net/manual/en/arrayobject.serialize.php
|
|
|
|
* @return string The serialized representation of the <b>ArrayObject</b>.
|
|
|
|
* @since 5.3.0
|
|
|
|
*/
|
|
|
|
public function serialize() { }
|
|
|
|
/**
|
|
|
|
* Create a new iterator from an ArrayObject instance
|
|
|
|
* @link http://php.net/manual/en/arrayobject.getiterator.php
|
|
|
|
* @return ArrayIterator<TKey, TValue> An iterator from an <b>ArrayObject</b>.
|
|
|
|
* @since 5.0.0
|
|
|
|
*/
|
|
|
|
public function getIterator() { }
|
|
|
|
/**
|
|
|
|
* Exchange the array for another one.
|
|
|
|
* @link http://php.net/manual/en/arrayobject.exchangearray.php
|
|
|
|
* @param mixed $input <p>
|
|
|
|
* The new array or object to exchange with the current array.
|
|
|
|
* </p>
|
|
|
|
* @return array the old array.
|
|
|
|
* @since 5.1.0
|
|
|
|
*/
|
|
|
|
public function exchangeArray($input) { }
|
|
|
|
/**
|
|
|
|
* Sets the iterator classname for the ArrayObject.
|
|
|
|
* @link http://php.net/manual/en/arrayobject.setiteratorclass.php
|
|
|
|
* @param string $iterator_class <p>
|
|
|
|
* The classname of the array iterator to use when iterating over this object.
|
|
|
|
* </p>
|
|
|
|
* @return void
|
|
|
|
* @since 5.1.0
|
|
|
|
*/
|
|
|
|
public function setIteratorClass($iterator_class) { }
|
|
|
|
/**
|
|
|
|
* Gets the iterator classname for the ArrayObject.
|
|
|
|
* @link http://php.net/manual/en/arrayobject.getiteratorclass.php
|
|
|
|
* @return string the iterator class name that is used to iterate over this object.
|
|
|
|
* @since 5.1.0
|
|
|
|
*/
|
|
|
|
public function getIteratorClass() { }
|
|
|
|
}
|