diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/offmap.c | 10 | ||||
-rw-r--r-- | src/offmap.h | 18 | ||||
-rw-r--r-- | src/oidmap.h | 7 | ||||
-rw-r--r-- | src/strmap.h | 16 |
4 files changed, 46 insertions, 5 deletions
diff --git a/src/offmap.c b/src/offmap.c index 2ab485589..e6e5cfef5 100644 --- a/src/offmap.c +++ b/src/offmap.c @@ -44,6 +44,16 @@ int git_offmap_exists(git_offmap *map, const git_off_t key) return kh_get(off, map, key) != kh_end(map); } +int git_offmap_has_data(git_offmap *map, size_t idx) +{ + return kh_exist(map, idx); +} + +git_off_t git_offmap_key_at(git_offmap *map, size_t idx) +{ + return kh_key(map, idx); +} + void *git_offmap_value_at(git_offmap *map, size_t idx) { return kh_val(map, idx); diff --git a/src/offmap.h b/src/offmap.h index bf2b13de4..82ebfb780 100644 --- a/src/offmap.h +++ b/src/offmap.h @@ -31,7 +31,9 @@ size_t git_offmap_lookup_index(git_offmap *map, const git_off_t key); int git_offmap_valid_index(git_offmap *map, size_t idx); int git_offmap_exists(git_offmap *map, const git_off_t key); +int git_offmap_has_data(git_offmap *map, size_t idx); +git_off_t git_offmap_key_at(git_offmap *map, size_t idx); void *git_offmap_value_at(git_offmap *map, size_t idx); void git_offmap_set_value_at(git_offmap *map, size_t idx, void *value); void git_offmap_delete_at(git_offmap *map, size_t idx); @@ -43,7 +45,19 @@ void git_offmap_delete(git_offmap *map, const git_off_t key); size_t git_offmap_begin(git_offmap *map); size_t git_offmap_end(git_offmap *map); -#define git_offmap_foreach kh_foreach -#define git_offmap_foreach_value kh_foreach_value +#define git_offmap_foreach(h, kvar, vvar, code) { size_t __i; \ + for (__i = git_offmap_begin(h); __i != git_offmap_end(h); ++__i) { \ + if (!git_offmap_has_data(h,__i)) continue; \ + (kvar) = git_offmap_key_at(h,__i); \ + (vvar) = git_offmap_value_at(h,__i); \ + code; \ + } } + +#define git_offmap_foreach_value(h, vvar, code) { size_t __i; \ + for (__i = git_offmap_begin(h); __i != git_offmap_end(h); ++__i) { \ + if (!git_offmap_has_data(h,__i)) continue; \ + (vvar) = git_offmap_value_at(h,__i); \ + code; \ + } } #endif diff --git a/src/oidmap.h b/src/oidmap.h index 8f6016af9..f34c03420 100644 --- a/src/oidmap.h +++ b/src/oidmap.h @@ -46,6 +46,11 @@ void git_oidmap_delete(git_oidmap *map, const git_oid *key); size_t git_oidmap_begin(git_oidmap *map); size_t git_oidmap_end(git_oidmap *map); -#define git_oidmap_foreach_value kh_foreach_value +#define git_oidmap_foreach_value(h, vvar, code) { size_t __i; \ + for (__i = git_oidmap_begin(h); __i != git_oidmap_end(h); ++__i) { \ + if (!git_oidmap_has_data(h,__i)) continue; \ + (vvar) = git_oidmap_value_at(h,__i); \ + code; \ + } } #endif diff --git a/src/strmap.h b/src/strmap.h index 6d999e141..51a720f1c 100644 --- a/src/strmap.h +++ b/src/strmap.h @@ -42,8 +42,20 @@ int git_strmap_put(git_strmap *map, const char *key, int *err); void git_strmap_insert(git_strmap *map, const char *key, void *value, int *rval); void git_strmap_delete(git_strmap *map, const char *key); -#define git_strmap_foreach kh_foreach -#define git_strmap_foreach_value kh_foreach_value +#define git_strmap_foreach(h, kvar, vvar, code) { size_t __i; \ + for (__i = git_strmap_begin(h); __i != git_strmap_end(h); ++__i) { \ + if (!git_strmap_has_data(h,__i)) continue; \ + (kvar) = git_strmap_key(h,__i); \ + (vvar) = git_strmap_value_at(h,__i); \ + code; \ + } } + +#define git_strmap_foreach_value(h, vvar, code) { size_t __i; \ + for (__i = git_strmap_begin(h); __i != git_strmap_end(h); ++__i) { \ + if (!git_strmap_has_data(h,__i)) continue; \ + (vvar) = git_strmap_value_at(h,__i); \ + code; \ + } } size_t git_strmap_begin(git_strmap *map); size_t git_strmap_end(git_strmap *map); |