iterator: mandate `advance_over` Since the three iterators implement `advance_over` differently, mandate it and implement each.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46
diff --git a/src/iterator.c b/src/iterator.c
index 720a3d1..cf3e29b 100644
--- a/src/iterator.c
+++ b/src/iterator.c
@@ -1070,6 +1070,15 @@ static int tree_iterator_advance_into(
return tree_iterator_advance(out, i);
}
+static int tree_iterator_advance_over(
+ const git_index_entry **out,
+ git_iterator_status_t *status,
+ git_iterator *i)
+{
+ *status = GIT_ITERATOR_STATUS_NORMAL;
+ return git_iterator_advance(out, i);
+}
+
static void tree_iterator_clear(tree_iterator *iter)
{
while (iter->frames.size)
@@ -1143,7 +1152,7 @@ int git_iterator_for_tree(
tree_iterator_current,
tree_iterator_advance,
tree_iterator_advance_into,
- NULL, /* advance_over */
+ tree_iterator_advance_over,
tree_iterator_reset,
tree_iterator_reset_range,
tree_iterator_at_end,
diff --git a/src/iterator.h b/src/iterator.h
index 460f947..51ba3f7 100644
--- a/src/iterator.h
+++ b/src/iterator.h
@@ -217,11 +217,7 @@ GIT_INLINE(int) git_iterator_advance_over(
git_iterator_status_t *status,
git_iterator *iter)
{
- if (iter->cb->advance_over)
- return iter->cb->advance_over(entry, status, iter);
-
- *status = GIT_ITERATOR_STATUS_NORMAL;
- return git_iterator_advance(entry, iter);
+ return iter->cb->advance_over(entry, status, iter);
}
/**