|  | 
Iterator over bins of a record.
The as_record_iterator can be initialized via:
Both of the function require the record on which it will iterate.
To initialize an as_record_iterator on the stack:
To initialize an as_record_iterator on the heap:
When you no longer require the iterator, you should release it and associated resource via as_record_iterator_destroy():
With an initialized as_record_iterator, you can traverse the bins of a record.
Traversal is usually performed by first checking to see if the there are any bins available to traverse to via as_record_iterator_has_next(), which returns true if there are more bins, or false if there are no more bins.
When you are sure there are more bins, then you will use as_record_iterator_next() to read the next bin. If there are no bins available, then NULL is returned.
If as_record_iterator_next() returns a bin, then you can use the following functions to get information about the bin:
Most often, a traversal is performed in a while loop. The following is a simple example:
Definition at line 116 of file as_record_iterator.h.
#include "as_record_iterator.h"
 Collaboration diagram for as_record_iterator:
 Collaboration diagram for as_record_iterator:| Data Fields | |
| uint32_t | pos | 
| const as_record * | record | 
| Private Attributes | |
| bool | _free | 
| Related Functions | |
| (Note that these are not member functions.) | |
| void | as_record_iterator_destroy (as_record_iterator *iterator) | 
| bool | as_record_iterator_has_next (const as_record_iterator *iterator) | 
| as_record_iterator * | as_record_iterator_init (as_record_iterator *iterator, const as_record *record) | 
| as_record_iterator * | as_record_iterator_new (const as_record *record) | 
| as_bin * | as_record_iterator_next (as_record_iterator *iterator) | 
| 
 | related | 
Destroy the as_record_iterator and associated resources.
| iterator | The iterator to destroy. | 
| 
 | related | 
Test if there are more bins in the iterator.
| iterator | The iterator to test. | 
| 
 | related | 
Initializes a stack allocated as_record_iterator for the specified record.
When you are finished using the as_record instance, you should release the resources allocated to it by calling as_record_destroy().
| iterator | The iterator to initialize. | 
| record | The record to iterate over | 
| 
 | related | 
Create and initialize a heap allocated as_record_iterator for the specified record.
| record | The record to iterate over. | 
| 
 | related | 
Read the next bin from the iterator.
| iterator | The iterator to read from. | 
| 
 | private | 
If true, then as_record_iterator_destroy() will free this object.
Definition at line 122 of file as_record_iterator.h.
| uint32_t as_record_iterator::pos | 
Current position of the iterator
Definition at line 132 of file as_record_iterator.h.
| const as_record* as_record_iterator::record | 
The record being iterated over.
Definition at line 127 of file as_record_iterator.h.