From 2408cff9f738459019709c8c12d0bd8a5605566f Mon Sep 17 00:00:00 2001 From: Linus Torvalds Date: Wed, 13 Jul 2005 17:27:48 -0700 Subject: Make "git-checkout" create files with O_EXCL We should always have unlinked any old ones before, but this just makes sure that we never over-write any old file. A quick "grep" now shows that all the core tools that open files for writing use O_EXCL, ie we never overwrite an existing file in place. --- entry.c | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) (limited to 'entry.c') diff --git a/entry.c b/entry.c index ded83103a9..792ea733e8 100644 --- a/entry.c +++ b/entry.c @@ -62,11 +62,11 @@ static int create_file(const char *path, unsigned int mode, int force) int fd; mode = (mode & 0100) ? 0777 : 0666; - fd = open(path, O_WRONLY | O_TRUNC | O_CREAT, mode); + fd = open(path, O_WRONLY | O_TRUNC | O_CREAT | O_EXCL, mode); if (fd < 0) { if (errno == EISDIR && force) { remove_subtree(path); - fd = open(path, O_WRONLY | O_TRUNC | O_CREAT, mode); + fd = open(path, O_WRONLY | O_TRUNC | O_CREAT | O_EXCL, mode); } } return fd; -- cgit v1.2.3