summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/offmap.c10
-rw-r--r--src/offmap.h18
-rw-r--r--src/oidmap.h7
-rw-r--r--src/strmap.h16
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);