diff options
author | Kimplul <kimi.h.kuparinen@gmail.com> | 2025-03-22 16:04:58 +0200 |
---|---|---|
committer | Kimplul <kimi.h.kuparinen@gmail.com> | 2025-03-22 16:04:58 +0200 |
commit | 56edd66ae3e8661d40d499bd7c72f3ffc7aac4e7 (patch) | |
tree | d2a99da089e9ec6c7e611c64376dae8a05d524a1 /include | |
parent | 2d186619c6aefac9d006a360a508f94dfe1c331c (diff) | |
download | conts-56edd66ae3e8661d40d499bd7c72f3ffc7aac4e7.tar.gz conts-56edd66ae3e8661d40d499bd7c72f3ffc7aac4e7.zip |
fix map iteration
Diffstat (limited to 'include')
-rw-r--r-- | include/conts/map.h | 6 |
1 files changed, 3 insertions, 3 deletions
diff --git a/include/conts/map.h b/include/conts/map.h index 5ffdff1..0d30897 100644 --- a/include/conts/map.h +++ b/include/conts/map.h @@ -197,14 +197,14 @@ static inline struct MAP_TUPLE *MAP(find_next)(struct MAP_BUCKET *bucket, struct { struct MAP_NODE *node = CONTAINER_OF(tuple, struct MAP_NODE, t); size_t idx = node - bucket->nodes; - for (idx += 1; idx < bucket->size; ++idx) { + for (; idx < bucket->size; ++idx) { struct MAP_NODE *candidate = &bucket->nodes[idx]; if (candidate->bucket) return &candidate->t; } struct MAP_BUCKET *next = bucket->next; - if (next) + if (!next) return NULL; return MAP(find_next)(next, &next->nodes[0].t); @@ -222,7 +222,7 @@ static inline struct MAP_TUPLE *MAP(begin)(struct MAP_ROOT *root) static inline struct MAP_TUPLE *MAP(next)(struct MAP_TUPLE *t) { struct MAP_NODE *node = CONTAINER_OF(t, struct MAP_NODE, t); - return MAP(find_next)(node->bucket, t); + return MAP(find_next)(node->bucket, &(node + 1)->t); } static inline bool MAP(end)(struct MAP_ROOT *root, struct MAP_TUPLE *t) |