From 1d84217ed97be237d2696c85a997c9e52114b984 Mon Sep 17 00:00:00 2001 From: Silvio Date: Mon, 19 Jul 2010 18:04:40 -0300 Subject: Lots of API changes at IsisConnector and iterators --- classes/iterators/IsisSubfieldIterator.php | 78 ++++++++++++++++++++++++++++++ 1 file changed, 78 insertions(+) create mode 100644 classes/iterators/IsisSubfieldIterator.php (limited to 'classes/iterators/IsisSubfieldIterator.php') diff --git a/classes/iterators/IsisSubfieldIterator.php b/classes/iterators/IsisSubfieldIterator.php new file mode 100644 index 0000000..2e213cf --- /dev/null +++ b/classes/iterators/IsisSubfieldIterator.php @@ -0,0 +1,78 @@ +class = $class; + $this->field = $field; + $this->rows = $class->getRows($field); + $this->fieldset = $class->getSubfieldList($field); + $this->keys = array_keys($this->fieldset); + $this->subfields = count($this->keys); + } + + /** + * Rewind the Iterator to the first element. + */ + function rewind() { + $this->row = 0; + $this->subfield = 0; + } + + /** + * Return the key of the current element. + */ + function key() { + return $this->row; + } + + /** + * Return the current element. + */ + function current() { + return $this->fieldset[$this->keys[$this->subfield]]; + } + + /** + * Move forward to next element. + */ + function next() { + if ($this->subfield >= $this->subfields) { + $this->subfield = 0; + ++$this->row; + } + else { + ++$this->subfield; + } + } + + /** + * Check if there is a current element after calls to rewind() or next(). + */ + function valid() { + return $this->row <= $this->rows; + } +} -- cgit v1.2.3