php-src/ext/spl
2003-08-10 15:05:14 +00:00
..
examples Move filter functionality to dedicated function 2003-07-19 09:50:18 +00:00
tests Add foreach/continue test 2003-08-10 13:17:02 +00:00
config.m4 Add directory iterator class 2003-07-16 15:13:23 +00:00
CREDITS Add spl extension 2003-05-01 23:28:28 +00:00
EXPERIMENTAL Add spl extension 2003-05-01 23:28:28 +00:00
php_spl.c - Unset support for spl_array_access by method set($index) 2003-08-04 21:56:05 +00:00
php_spl.h - Unset support for spl_array_access by method set($index) 2003-08-04 21:56:05 +00:00
README Put some brief technically description here 2003-06-23 22:37:12 +00:00
README.PROFILING Add profiling results 2003-06-23 21:59:55 +00:00
spl_array.c Fix refcounting for $var = $obj[$idx] = $value; 2003-08-09 19:24:11 +00:00
spl_array.h - Unset support for spl_array_access by method set($index) 2003-08-04 21:56:05 +00:00
spl_directory.c This is a void funtion 2003-08-10 15:05:14 +00:00
spl_engine.c - Reduce number of c-functions/macros involved in function invocation 2003-08-07 22:43:01 +00:00
spl_engine.h Once ago this was used 2003-08-07 22:50:46 +00:00
spl_foreach.c - Reduce number of c-functions/macros involved in function invocation 2003-08-07 22:43:01 +00:00
spl_foreach.h License update 2003-06-12 19:30:54 +00:00
spl_functions.c Latest zend updates 2003-08-03 22:29:20 +00:00
spl_functions.h Update documentation in source, reflection and docu itself, part II 2003-08-04 23:15:56 +00:00
spl.php You shall not Copy'n'Paste after midnight without checking 3 times 2003-08-04 23:21:27 +00:00
TODO Add spl extension 2003-05-01 23:28:28 +00:00

This is an extension that aims to implement some efficient data access 
interfaces and classes. You'll find the classes documented using php
code in the file spl.php.

There are special SPL interfaces that provides the ability to hook into 
foreach and array reading/writng. By inheriting these interfaces, instances 
of the resulting classes can be iterated using the foreach construct or
use array read write notation.

Look into the examples subdirectory for some basic examples which will
demonstracte this.

Also some classes of extensions like SQLite inherit SPL interfaces so that
they take advantage of the foreach or array overloading.

1) Iterators

Iterator is design pattern that allows to enumerate and list all elements of 
a collection whatsoever using an oo protocol. The minimalistic Iterator needs
a method that returns the current value, a method that moves to the next value
and a method that checks whether or not the Iterator can provide more elements.

In SPL this basich Iterator is defined by the interface spl_forward:

interface spl_forward {
	function current();
	function next();
	function has_more();
}

This basic Iterator does not allow to rewind itself nor does it in anyway 
support to name the values by some kind association as key/value mappings
provided by the standard PHP arrays. All these additions to the basic Iterator
are done in specialized interfaces as described in detail in the file spl.php.

SPL allows to hook into the engine opcodes that realize the foreach construct.
This construct normally works on arrays the following way. First it rewinds 
the current array position to the beginning. Then it loops through the whole
array by first checking whether or not the end of the array is reached and
if not returning the current array value and or key. After that it move the
current array pointer forward and does starts the loop process again. As you 
can see this perfectly maps to the interface spl_forward. So the foreach
hooking simply checks whether or not the variable passed to foreach is an
object of a class implementing the interface spl_forward. The foreach hook
can be activated by --enable-spl-foreach which is on by default.

class it implements spl_forward...
$obj = new it();
foreach($obj as $value) ...

2) Arrays

Arrays in general, not specifically PHP arrays, provide a collection of pairs
normally referred to as key and value. A PHP object consists of properties and
a class type specifing the methods available for the object. SPL now allows
this to be combined using the spl_array_<xy> interfaces.

The minimalistic array interface is spl_array_read which only support reading:

interface spl_array_read {
	function exists($key);
	function get($key);
}

Any instance of a class that implements spl_array_read can be used with array
read notation when the corresponding hook is activated --enable-spl-array-read.

class ar implements spl_array_read...
$obj = new ar();
$value = $obj[$key];

SPL also supports the write notation by the interface spl_array_access:

interface spl_array_access extends spl_array_read {
	function set($value, $index);
}

When the array write hook is activated by --enable-spl-array-write the 
following can be done:

class ar implements spl_array_access...
$obj = new ar();
$value = $obj[$key];
$obj[$key] = $value;

However this hook should only be activated when it is made use of, since it 
slows down noticeable. That is the case because first there is some not used
overhead and second the overhead is in one the most often used opcodes.