refs: allow for_each_replace_ref to handle arbitrary repositories
[gitweb.git] / replace-object.h
index 15315311fb892e24129162cef0f61eddfc6fff78..dff57bfa1e20aff152ce4a2acfd2b2c1db144015 100644 (file)
@@ -3,6 +3,7 @@
 
 #include "oidmap.h"
 #include "repository.h"
+#include "object-store.h"
 
 struct replace_object {
        struct oidmap_entry original;
@@ -13,7 +14,8 @@ struct replace_object {
  * This internal function is only declared here for the benefit of
  * lookup_replace_object().  Please do not call it directly.
  */
-extern const struct object_id *do_lookup_replace_object(const struct object_id *oid);
+#define do_lookup_replace_object(r, s) do_lookup_replace_object_##r(s)
+extern const struct object_id *do_lookup_replace_object_the_repository(const struct object_id *oid);
 
 /*
  * If object sha1 should be replaced, return the replacement object's
@@ -21,11 +23,14 @@ extern const struct object_id *do_lookup_replace_object(const struct object_id *
  * either sha1 or a pointer to a permanently-allocated value.  When
  * object replacement is suppressed, always return sha1.
  */
-static inline const struct object_id *lookup_replace_object(const struct object_id *oid)
+#define lookup_replace_object(r, s) lookup_replace_object_##r(s)
+static inline const struct object_id *lookup_replace_object_the_repository(const struct object_id *oid)
 {
-       if (!check_replace_refs)
+       if (!check_replace_refs ||
+           (the_repository->objects->replace_map &&
+            the_repository->objects->replace_map->map.tablesize == 0))
                return oid;
-       return do_lookup_replace_object(oid);
+       return do_lookup_replace_object(the_repository, oid);
 }
 
 #endif /* REPLACE_OBJECT_H */