refs.c: simplify strbufs in reflog setup and writing
Commit 1a83c24
(git_snpath(): retire and replace with
strbuf_git_path(), 2014-11-30) taught log_ref_setup and
log_ref_write_1 to take a strbuf parameter, rather than a
bare string. It then makes an alias to the strbuf's "buf"
field under the original name.
This made the original diff much shorter, but the resulting
code is more complicated that it needs to be. Since we've
aliased the pointer, we drop our reference to the strbuf to
ensure we don't accidentally change it. But if we simply
drop our alias and use "logfile.buf" directly, we do not
have to worry about this aliasing. It's a larger diff, but
the resulting code is simpler.
Signed-off-by: Jeff King <peff@peff.net>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
parent
07e3070d2a
commit
54b418f698
38
refs.c
38
refs.c
@ -3150,46 +3150,42 @@ static int should_autocreate_reflog(const char *refname)
|
|||||||
* should_autocreate_reflog returns non-zero. Otherwise, create it
|
* should_autocreate_reflog returns non-zero. Otherwise, create it
|
||||||
* regardless of the ref name. Fill in *err and return -1 on failure.
|
* regardless of the ref name. Fill in *err and return -1 on failure.
|
||||||
*/
|
*/
|
||||||
static int log_ref_setup(const char *refname, struct strbuf *sb_logfile, struct strbuf *err, int force_create)
|
static int log_ref_setup(const char *refname, struct strbuf *logfile, struct strbuf *err, int force_create)
|
||||||
{
|
{
|
||||||
int logfd, oflags = O_APPEND | O_WRONLY;
|
int logfd, oflags = O_APPEND | O_WRONLY;
|
||||||
char *logfile;
|
|
||||||
|
|
||||||
strbuf_git_path(sb_logfile, "logs/%s", refname);
|
strbuf_git_path(logfile, "logs/%s", refname);
|
||||||
logfile = sb_logfile->buf;
|
|
||||||
/* make sure the rest of the function can't change "logfile" */
|
|
||||||
sb_logfile = NULL;
|
|
||||||
if (force_create || should_autocreate_reflog(refname)) {
|
if (force_create || should_autocreate_reflog(refname)) {
|
||||||
if (safe_create_leading_directories(logfile) < 0) {
|
if (safe_create_leading_directories(logfile->buf) < 0) {
|
||||||
strbuf_addf(err, "unable to create directory for %s: "
|
strbuf_addf(err, "unable to create directory for %s: "
|
||||||
"%s", logfile, strerror(errno));
|
"%s", logfile->buf, strerror(errno));
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
oflags |= O_CREAT;
|
oflags |= O_CREAT;
|
||||||
}
|
}
|
||||||
|
|
||||||
logfd = open(logfile, oflags, 0666);
|
logfd = open(logfile->buf, oflags, 0666);
|
||||||
if (logfd < 0) {
|
if (logfd < 0) {
|
||||||
if (!(oflags & O_CREAT) && (errno == ENOENT || errno == EISDIR))
|
if (!(oflags & O_CREAT) && (errno == ENOENT || errno == EISDIR))
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
if (errno == EISDIR) {
|
if (errno == EISDIR) {
|
||||||
if (remove_empty_directories(logfile)) {
|
if (remove_empty_directories(logfile->buf)) {
|
||||||
strbuf_addf(err, "There are still logs under "
|
strbuf_addf(err, "There are still logs under "
|
||||||
"'%s'", logfile);
|
"'%s'", logfile->buf);
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
logfd = open(logfile, oflags, 0666);
|
logfd = open(logfile->buf, oflags, 0666);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (logfd < 0) {
|
if (logfd < 0) {
|
||||||
strbuf_addf(err, "unable to append to %s: %s",
|
strbuf_addf(err, "unable to append to %s: %s",
|
||||||
logfile, strerror(errno));
|
logfile->buf, strerror(errno));
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
adjust_shared_perm(logfile);
|
adjust_shared_perm(logfile->buf);
|
||||||
close(logfd);
|
close(logfd);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
@ -3233,36 +3229,32 @@ static int log_ref_write_fd(int fd, const unsigned char *old_sha1,
|
|||||||
|
|
||||||
static int log_ref_write_1(const char *refname, const unsigned char *old_sha1,
|
static int log_ref_write_1(const char *refname, const unsigned char *old_sha1,
|
||||||
const unsigned char *new_sha1, const char *msg,
|
const unsigned char *new_sha1, const char *msg,
|
||||||
struct strbuf *sb_log_file, int flags,
|
struct strbuf *logfile, int flags,
|
||||||
struct strbuf *err)
|
struct strbuf *err)
|
||||||
{
|
{
|
||||||
int logfd, result, oflags = O_APPEND | O_WRONLY;
|
int logfd, result, oflags = O_APPEND | O_WRONLY;
|
||||||
char *log_file;
|
|
||||||
|
|
||||||
if (log_all_ref_updates < 0)
|
if (log_all_ref_updates < 0)
|
||||||
log_all_ref_updates = !is_bare_repository();
|
log_all_ref_updates = !is_bare_repository();
|
||||||
|
|
||||||
result = log_ref_setup(refname, sb_log_file, err, flags & REF_FORCE_CREATE_REFLOG);
|
result = log_ref_setup(refname, logfile, err, flags & REF_FORCE_CREATE_REFLOG);
|
||||||
|
|
||||||
if (result)
|
if (result)
|
||||||
return result;
|
return result;
|
||||||
log_file = sb_log_file->buf;
|
|
||||||
/* make sure the rest of the function can't change "log_file" */
|
|
||||||
sb_log_file = NULL;
|
|
||||||
|
|
||||||
logfd = open(log_file, oflags);
|
logfd = open(logfile->buf, oflags);
|
||||||
if (logfd < 0)
|
if (logfd < 0)
|
||||||
return 0;
|
return 0;
|
||||||
result = log_ref_write_fd(logfd, old_sha1, new_sha1,
|
result = log_ref_write_fd(logfd, old_sha1, new_sha1,
|
||||||
git_committer_info(0), msg);
|
git_committer_info(0), msg);
|
||||||
if (result) {
|
if (result) {
|
||||||
strbuf_addf(err, "unable to append to %s: %s", log_file,
|
strbuf_addf(err, "unable to append to %s: %s", logfile->buf,
|
||||||
strerror(errno));
|
strerror(errno));
|
||||||
close(logfd);
|
close(logfd);
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
if (close(logfd)) {
|
if (close(logfd)) {
|
||||||
strbuf_addf(err, "unable to append to %s: %s", log_file,
|
strbuf_addf(err, "unable to append to %s: %s", logfile->buf,
|
||||||
strerror(errno));
|
strerror(errno));
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user