summaryrefslogtreecommitdiff
path: root/replace-object.h
diff options
context:
space:
mode:
authorStefan Beller <sbeller@google.com>2018-04-12 00:21:06 (GMT)
committerJunio C Hamano <gitster@pobox.com>2018-04-12 02:38:56 (GMT)
commit47f351e9b328cd828d85c45a736eca252152aa5c (patch)
treebbbd9079f1f94cc617ba49002cda8e5bae0a3ccd /replace-object.h
parentd88f9fdf8b2ccf65993bb977094ab9b2249635ee (diff)
downloadgit-47f351e9b328cd828d85c45a736eca252152aa5c.zip
git-47f351e9b328cd828d85c45a736eca252152aa5c.tar.gz
git-47f351e9b328cd828d85c45a736eca252152aa5c.tar.bz2
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 <sbeller@google.com> Signed-off-by: Jonathan Nieder <jrnieder@gmail.com> Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 'replace-object.h')
-rw-r--r--replace-object.h22
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 @@
#ifndef REPLACE_OBJECT_H
#define REPLACE_OBJECT_H
+#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 */