Browse Source

usage.c + gc: add and use a die_message_errno()

Change the "error: " output when we exit with 128 due to gc.log errors
to use a "fatal: " prefix instead. To do this add a
die_message_errno() a sibling function to the die_errno() added in a
preceding commit.

Before this we'd expect report_last_gc_error() to return -1 from
error_errno() in this case. It already treated a status of 0 and 1
specially. Let's just document that anything that's not 0 or 1 should
be returned.

We could also retain the "ret < 0" behavior here without hardcoding
128 by returning -128, and having the caller do a "return -ret", but I
think this makes more sense, and preserves the path from
die_message*()'s return value to the "return" without hardcoding
"128".

Signed-off-by: Ævar Arnfjörð Bjarmason <avarab@gmail.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
maint
Ævar Arnfjörð Bjarmason 3 years ago committed by Junio C Hamano
parent
commit
24f6e6d626
  1. 13
      builtin/gc.c
  2. 1
      git-compat-util.h
  3. 12
      usage.c

13
builtin/gc.c

@ -470,7 +470,8 @@ static const char *lock_repo_for_gc(int force, pid_t* ret_pid) @@ -470,7 +470,8 @@ static const char *lock_repo_for_gc(int force, pid_t* ret_pid)
/*
* Returns 0 if there was no previous error and gc can proceed, 1 if
* gc should not proceed due to an error in the last run. Prints a
* message and returns -1 if an error occurred while reading gc.log
* message and returns with a non-[01] status code if an error occurred
* while reading gc.log
*/
static int report_last_gc_error(void)
{
@ -484,7 +485,7 @@ static int report_last_gc_error(void) @@ -484,7 +485,7 @@ static int report_last_gc_error(void)
if (errno == ENOENT)
goto done;

ret = error_errno(_("cannot stat '%s'"), gc_log_path);
ret = die_message_errno(_("cannot stat '%s'"), gc_log_path);
goto done;
}

@ -493,7 +494,7 @@ static int report_last_gc_error(void) @@ -493,7 +494,7 @@ static int report_last_gc_error(void)

len = strbuf_read_file(&sb, gc_log_path, 0);
if (len < 0)
ret = error_errno(_("cannot read '%s'"), gc_log_path);
ret = die_message_errno(_("cannot read '%s'"), gc_log_path);
else if (len > 0) {
/*
* A previous gc failed. Report the error, and don't
@ -612,12 +613,12 @@ int cmd_gc(int argc, const char **argv, const char *prefix) @@ -612,12 +613,12 @@ int cmd_gc(int argc, const char **argv, const char *prefix)
if (detach_auto) {
int ret = report_last_gc_error();

if (ret < 0)
/* an I/O error occurred, already reported */
return 128;
if (ret == 1)
/* Last gc --auto failed. Skip this one. */
return 0;
else if (ret)
/* an I/O error occurred, already reported */
return ret;

if (lock_repo_for_gc(force, &pid))
return 0;

1
git-compat-util.h

@ -480,6 +480,7 @@ NORETURN void usagef(const char *err, ...) __attribute__((format (printf, 1, 2)) @@ -480,6 +480,7 @@ NORETURN void usagef(const char *err, ...) __attribute__((format (printf, 1, 2))
NORETURN void die(const char *err, ...) __attribute__((format (printf, 1, 2)));
NORETURN void die_errno(const char *err, ...) __attribute__((format (printf, 1, 2)));
int die_message(const char *err, ...) __attribute__((format (printf, 1, 2)));
int die_message_errno(const char *err, ...) __attribute__((format (printf, 1, 2)));
int error(const char *err, ...) __attribute__((format (printf, 1, 2)));
int error_errno(const char *err, ...) __attribute__((format (printf, 1, 2)));
void warning(const char *err, ...) __attribute__((format (printf, 1, 2)));

12
usage.c

@ -233,6 +233,18 @@ int die_message(const char *err, ...) @@ -233,6 +233,18 @@ int die_message(const char *err, ...)
return 128;
}

#undef die_message_errno
int die_message_errno(const char *fmt, ...)
{
char buf[1024];
va_list params;

va_start(params, fmt);
die_message_routine(fmt_with_err(buf, sizeof(buf), fmt), params);
va_end(params);
return 128;
}

#undef error_errno
int error_errno(const char *fmt, ...)
{

Loading…
Cancel
Save