path: root/replace-object.h
diff options
authorStefan Beller <>2018-04-12 00:21:06 (GMT)
committerJunio C Hamano <>2018-04-12 02:38:56 (GMT)
commit47f351e9b328cd828d85c45a736eca252152aa5c (patch)
treebbbd9079f1f94cc617ba49002cda8e5bae0a3ccd /replace-object.h
parentd88f9fdf8b2ccf65993bb977094ab9b2249635ee (diff)
object-store: move lookup_replace_object to replace-object.h
lookup_replace_object is a low-level function that most users of the object store do not need to use directly. Move it to replace-object.h to avoid a dependency loop in an upcoming change to its inline definition that will make use of repository.h. Signed-off-by: Stefan Beller <> Signed-off-by: Jonathan Nieder <> Signed-off-by: Junio C Hamano <>
Diffstat (limited to 'replace-object.h')
1 files changed, 22 insertions, 0 deletions
diff --git a/replace-object.h b/replace-object.h
index f9a2b70..1531531 100644
--- a/replace-object.h
+++ b/replace-object.h
@@ -1,9 +1,31 @@
+#include "oidmap.h"
+#include "repository.h"
struct replace_object {
struct oidmap_entry original;
struct object_id replacement;
+ * 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);
+ * If object sha1 should be replaced, return the replacement object's
+ * name (replaced recursively, if necessary). The return value is
+ * 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)
+ if (!check_replace_refs)
+ return oid;
+ return do_lookup_replace_object(oid);
#endif /* REPLACE_OBJECT_H */