Browse Source

commit: allow editing the commit message even in shared repos

It was pointed out by Yaroslav Halchenko that the file containing the
commit message is writable only by the owner, which means that we have
to rewrite it from scratch in a shared repository.

Signed-off-by: Johannes Schindelin <johannes.schindelin@gmx.de>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
maint
Johannes Schindelin 9 years ago committed by Junio C Hamano
parent
commit
79d7582e32
  1. 2
      builtin/commit.c
  2. 1
      git-compat-util.h
  3. 13
      wrapper.c

2
builtin/commit.c

@ -761,7 +761,7 @@ static int prepare_to_commit(const char *index_file, const char *prefix,
hook_arg2 = ""; hook_arg2 = "";
} }


s->fp = fopen(git_path(commit_editmsg), "w"); s->fp = fopen_for_writing(git_path(commit_editmsg));
if (s->fp == NULL) if (s->fp == NULL)
die_errno(_("could not open '%s'"), git_path(commit_editmsg)); die_errno(_("could not open '%s'"), git_path(commit_editmsg));



1
git-compat-util.h

@ -733,6 +733,7 @@ extern int xmkstemp_mode(char *template, int mode);
extern int odb_mkstemp(char *template, size_t limit, const char *pattern); extern int odb_mkstemp(char *template, size_t limit, const char *pattern);
extern int odb_pack_keep(char *name, size_t namesz, const unsigned char *sha1); extern int odb_pack_keep(char *name, size_t namesz, const unsigned char *sha1);
extern char *xgetcwd(void); extern char *xgetcwd(void);
extern FILE *fopen_for_writing(const char *path);


#define REALLOC_ARRAY(x, alloc) (x) = xrealloc((x), (alloc) * sizeof(*(x))) #define REALLOC_ARRAY(x, alloc) (x) = xrealloc((x), (alloc) * sizeof(*(x)))



13
wrapper.c

@ -375,6 +375,19 @@ FILE *xfdopen(int fd, const char *mode)
return stream; return stream;
} }


FILE *fopen_for_writing(const char *path)
{
FILE *ret = fopen(path, "w");

if (!ret && errno == EPERM) {
if (!unlink(path))
ret = fopen(path, "w");
else
errno = EPERM;
}
return ret;
}

int xmkstemp(char *template) int xmkstemp(char *template)
{ {
int fd; int fd;

Loading…
Cancel
Save