$darkmode
|
Elektra 0.11.0
|
The deprecated internal iterator are removed and replaced with external iteration.
Developers of plugins should already use the external iterators instead of the internal ones. However, following functions will be removed:
Every occurrence of using the internal iterator has to be replaced with the external iterator (see #4281). The functions of the internal iterator are listed in #3171. There are also some uses of the internal iterator found in the SWIG bindings (Lua, Ruby, Python) that also need removal (see #4279).
When the client (i.e. the programmer) controls the iteration, the iterator is called external iterator. Otherwise, when the iterator controls the iteration, it is called internal iterator. Due to the fact that external iterators are more flexible the internal iterators are the way to go.
An example for using an external iterator is:
You can obtain the Key at a specific position in the KeySet and the overall size of the KeySet.
If you want to delete Keys during the iteration of a KeySet, be aware that all keys after the deleted Key are moved one slot forward, so maybe you have to change to value of it after deleting a Key:
For such scenarios, it is also important that you recalculate the size with ksGetSize () within the loop-header or explicitly after changing the KeySet, e.g. by deleting a Key.
That should be all you need for iterating over keys. For future releases, the function ksAtCursor will be renamed to ksAt. (see issue #3976)
You can iterate over metakeys in a similar fashion as long as you iterate over a KeySet, e.g., keyMeta("my_key") returns a KeySet of metakeys.
The following is a comprehension of how to use iterators in various languages.
C-style fashioned loop:
Real iterators the C++ interface supports: