summaryrefslogtreecommitdiff
path: root/cache.h
diff options
context:
space:
mode:
authorJunio C Hamano <gitster@pobox.com>2017-03-28 13:52:25 -0700
committerJunio C Hamano <gitster@pobox.com>2017-03-28 13:52:25 -0700
commitba5e05ffeff03c4835d0618ab34acb97ef753d0c (patch)
treecebbf61ffff3b9556ba381bd8cdd61b71b81f962 /cache.h
parent8f71209d1e447daf9db643df7ad01a8b49b9bcb7 (diff)
parentf20754802a280c57a1e5886605b6805bbf040c63 (diff)
downloadgit-ba5e05ffeff03c4835d0618ab34acb97ef753d0c.tar.gz
Merge branch 'jk/pack-name-cleanups' into maint
Code clean-up. * jk/pack-name-cleanups: index-pack: make pointer-alias fallbacks safer replace snprintf with odb_pack_name() odb_pack_keep(): stop generating keepfile name sha1_file.c: make pack-name helper globally accessible move odb_* declarations out of git-compat-util.h
Diffstat (limited to 'cache.h')
-rw-r--r--cache.h21
1 files changed, 21 insertions, 0 deletions
diff --git a/cache.h b/cache.h
index b3cf851b59..900796c155 100644
--- a/cache.h
+++ b/cache.h
@@ -1591,6 +1591,27 @@ extern struct packed_git *find_sha1_pack(const unsigned char *sha1,
extern void pack_report(void);
/*
+ * Create a temporary file rooted in the object database directory.
+ */
+extern int odb_mkstemp(char *template, size_t limit, const char *pattern);
+
+/*
+ * Generate the filename to be used for a pack file with checksum "sha1" and
+ * extension "ext". The result is written into the strbuf "buf", overwriting
+ * any existing contents. A pointer to buf->buf is returned as a convenience.
+ *
+ * Example: odb_pack_name(out, sha1, "idx") => ".git/objects/pack/pack-1234..idx"
+ */
+extern char *odb_pack_name(struct strbuf *buf, const unsigned char *sha1, const char *ext);
+
+/*
+ * Create a pack .keep file named "name" (which should generally be the output
+ * of odb_pack_name). Returns a file descriptor opened for writing, or -1 on
+ * error.
+ */
+extern int odb_pack_keep(const char *name);
+
+/*
* mmap the index file for the specified packfile (if it is not
* already mmapped). Return 0 on success.
*/