Qore Programming Language Reference Manual 1.17.0
Loading...
Searching...
No Matches
Qore::AbstractIterator Class Referenceabstract

This class defines an abstract interface for iterators. More...

#include <QC_AbstractIterator.dox.h>

Inheritance diagram for Qore::AbstractIterator:
[legend]

Public Member Methods

abstract auto getValue ()
 returns the current value More...
 
abstract bool next ()
 Moves the current position to the next element; returns False if there are no more elements. More...
 
abstract bool valid ()
 returns True if the iterator is currently pointing at a valid element, False if not More...
 

Detailed Description

This class defines an abstract interface for iterators.

Classes inheriting this class can be used to iterate abstract or complex objects with while Statements (using AbstractIterator::next()) or directly in the following language constructs:

Member Function Documentation

◆ getValue()

◆ next()

abstract bool Qore::AbstractIterator::next ( )
pure virtual

Moves the current position to the next element; returns False if there are no more elements.

This method will return True again after it returns False once if the object being iterated is not empty, otherwise it will always return False. The iterator object should not be used after this method returns False

Returns
False if there are no more elements (in which case the iterator object is invalid and should not be used); True if successful (meaning that the iterator object is valid)
Example:
while (i.next()) {
printf(" + %y\n", i.getValue());
}

Implemented in Qore::AbstractLineIterator, Qore::SQL::AbstractSQLStatement, Qore::DataLineIterator, Qore::FileLineIterator, Qore::HashIterator, Qore::HashListIterator, Qore::HashListReverseIterator, Qore::HashReverseIterator, Qore::InputStreamLineIterator, Qore::ListHashIterator, Qore::ListHashReverseIterator, Qore::ListIterator, Qore::ListReverseIterator, Qore::ObjectReverseIterator, Qore::RangeIterator, Qore::SingleValueIterator, and Qore::SQL::SQLStatement.

◆ valid()

abstract bool Qore::AbstractIterator::valid ( )
pure virtual

returns True if the iterator is currently pointing at a valid element, False if not

Returns
True if the iterator is currently pointing at a valid element, False if not
Example:
if (i.valid())
printf("current value: %y\n", i.getValue());

Implemented in Qore::AbstractLineIterator, Qore::SQL::AbstractSQLStatement, Qore::DataLineIterator, Qore::FileLineIterator, Qore::HashIterator, Qore::HashListIterator, Qore::InputStreamLineIterator, Qore::ListHashIterator, Qore::ListIterator, Qore::RangeIterator, Qore::SingleValueIterator, and Qore::SQL::SQLStatement.