lv_iter.h
Typedefs
-
typedef lv_result_t (*lv_iter_next_cb)(void *instance, void *context, void *elem)
-
typedef void (*lv_iter_inspect_cb)(void *elem)
Functions
-
lv_iter_t *lv_iter_create(void *instance, uint32_t elem_size, uint32_t context_size, lv_iter_next_cb next_cb)
Create an iterator based on an instance, and then the next element of the iterator can be obtained through lv_iter_next, In order to obtain the next operation in a unified and abstract way.
- Parameters:
instance -- The instance to be iterated
elem_size -- The size of the element to be iterated in bytes
context_size -- The size of the context to be passed to the next_cb in bytes
next_cb -- The callback function to get the next element
- Returns:
The iterator object
-
void *lv_iter_get_context(lv_iter_t *iter)
Get the context of the iterator. You can use it to store some temporary variables associated with current iterator..
- Parameters:
iter --
lv_iter_t
object create before- Returns:
the iter context
-
void lv_iter_destroy(lv_iter_t *iter)
Destroy the iterator object, and release the context. Other resources allocated by the user are not released. The user needs to release it by itself.
- Parameters:
iter --
lv_iter_t
object create before
-
lv_result_t lv_iter_next(lv_iter_t *iter, void *elem)
Get the next element of the iterator.
- Parameters:
iter --
lv_iter_t
object create beforeelem -- The pointer to store the next element
- Returns:
LV_RESULT_OK: Get the next element successfully LV_RESULT_INVALID: The next element is invalid
-
void lv_iter_make_peekable(lv_iter_t *iter, uint32_t capacity)
Make the iterator peekable, which means that the user can peek the next element without advancing the iterator.
- Parameters:
iter --
lv_iter_t
object create beforecapacity -- The capacity of the peek buffer
-
lv_result_t lv_iter_peek(lv_iter_t *iter, void *elem)
Peek the next element of the iterator without advancing the iterator.
- Parameters:
iter --
lv_iter_t
object create beforeelem -- The pointer to store the next element
- Returns:
LV_RESULT_OK: Peek the next element successfully LV_RESULT_INVALID: The next element is invalid
-
lv_result_t lv_iter_peek_advance(lv_iter_t *iter)
Only advance the iterator without getting the next element.
- Parameters:
iter --
lv_iter_t
object create before- Returns:
LV_RESULT_OK: Peek the next element successfully LV_RESULT_INVALID: The next element is invalid
-
lv_result_t lv_iter_peek_reset(lv_iter_t *iter)
Reset the peek cursor to the
next
cursor.- Parameters:
iter --
lv_iter_t
object create before- Returns:
LV_RESULT_OK: Reset the peek buffer successfully LV_RESULT_INVALID: The peek buffer is invalid
-
void lv_iter_inspect(lv_iter_t *iter, lv_iter_inspect_cb inspect_cb)
Inspect the element of the iterator. The callback function will be called for each element of the iterator.
- Parameters:
iter --
lv_iter_t
object create beforeinspect_cb -- The callback function to inspect the element