From: Nicolas Pitre Date: Wed, 1 Nov 2006 22:06:24 +0000 (-0500) Subject: have index-pack create .keep file more carefully X-Git-Tag: v1.4.4-rc1~5^2~1 X-Git-Url: https://git.tokkee.org/?a=commitdiff_plain;h=9ca4a201eaf0c58dbc7184cb2d5ab01c48cb7447;p=git.git have index-pack create .keep file more carefully If by chance we receive a pack which content (list of objects) matches another pack that we already have, and if that pack is marked with a .keep file, then we should not overwrite it. Signed-off-by: Nicolas Pitre Signed-off-by: Junio C Hamano --- diff --git a/index-pack.c b/index-pack.c index a3b55f9b0..8d64a883a 100644 --- a/index-pack.c +++ b/index-pack.c @@ -788,14 +788,17 @@ static void final(const char *final_pack_name, const char *curr_pack_name, get_object_directory(), sha1_to_hex(sha1)); keep_name = name; } - keep_fd = open(keep_name, O_RDWR | O_CREAT, 0600); - if (keep_fd < 0) - die("cannot write keep file"); - if (keep_msg_len > 0) { - write_or_die(keep_fd, keep_msg, keep_msg_len); - write_or_die(keep_fd, "\n", 1); + keep_fd = open(keep_name, O_RDWR|O_CREAT|O_EXCL, 0600); + if (keep_fd < 0) { + if (errno != EEXIST) + die("cannot write keep file"); + } else { + if (keep_msg_len > 0) { + write_or_die(keep_fd, keep_msg, keep_msg_len); + write_or_die(keep_fd, "\n", 1); + } + close(keep_fd); } - close(keep_fd); } if (final_pack_name != curr_pack_name) {