diff options
author | Nguyễn Thái Ngọc Duy <pclouds@gmail.com> | 2013-08-16 11:52:04 +0200 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2013-08-28 20:51:54 +0200 |
commit | 08ea65ad13faaf24f57732cdc8af3d830d4b367f (patch) | |
tree | c1143ed482a92214c09223fd32914292e4db1dd7 /shallow.c | |
parent | shallow: only add shallow graft points to new shallow file (diff) | |
download | git-08ea65ad13faaf24f57732cdc8af3d830d4b367f.tar.xz git-08ea65ad13faaf24f57732cdc8af3d830d4b367f.zip |
shallow: add setup_temporary_shallow()
This function is like setup_alternate_shallow() except that it does
not lock $GIT_DIR/shallow. It is supposed to be used when a program
generates temporary shallow for use by another program, then throw
the shallow file away.
Signed-off-by: Nguyễn Thái Ngọc Duy <pclouds@gmail.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 'shallow.c')
-rw-r--r-- | shallow.c | 23 |
1 files changed, 23 insertions, 0 deletions
@@ -175,6 +175,29 @@ int write_shallow_commits(struct strbuf *out, int use_pack_protocol) return data.count; } +char *setup_temporary_shallow(void) +{ + struct strbuf sb = STRBUF_INIT; + int fd; + + if (write_shallow_commits(&sb, 0)) { + struct strbuf path = STRBUF_INIT; + strbuf_addstr(&path, git_path("shallow_XXXXXX")); + fd = xmkstemp(path.buf); + if (write_in_full(fd, sb.buf, sb.len) != sb.len) + die_errno("failed to write to %s", + path.buf); + close(fd); + strbuf_release(&sb); + return strbuf_detach(&path, NULL); + } + /* + * is_repository_shallow() sees empty string as "no shallow + * file". + */ + return xstrdup(""); +} + void setup_alternate_shallow(struct lock_file *shallow_lock, const char **alternate_shallow_file) { |