Jon Seymour <jon.seymour@xxxxxxxxx> writes: > I understand why ref@{time-spec} might behave this way, but I reckon > that if you ask for ref@{n} for n > N-1, where N is the length of the > reflog, then you should either get empty output and a non-zero status > (preferred) or a ref@{N-1} on the output with a status code of zero > and a warning message (less optimal, IMHO). Yeah, the behaviour of ref@{...} syntax parser is way suboptimal: $ git rev-parse --verify jch@{99999}; echo $? warning: Log for 'jch' only has 1368 entries. cfb88e9a8d4926b0011ae2dd67e1f57a98f4b768 0 It even knows that it is running off the cut-off point; it should just cause the caller to notice that fact. I don't think changing it to error out should cause any harm to existing callers. It may just be the matter of doing something like this (totally untested)... sha1_name.c | 12 +++++------- 1 files changed, 5 insertions(+), 7 deletions(-) diff --git a/sha1_name.c b/sha1_name.c index 4af94fa..c1e51c9 100644 --- a/sha1_name.c +++ b/sha1_name.c @@ -342,7 +342,7 @@ static int get_sha1_1(const char *name, int len, unsigned char *sha1); static int get_sha1_basic(const char *str, int len, unsigned char *sha1) { - static const char *warning = "warning: refname '%.*s' is ambiguous.\n"; + static const char *warn_msg = "warning: refname '%.*s' is ambiguous.\n"; char *real_ref = NULL; int refs_found = 0; int at, reflog_len; @@ -390,7 +390,7 @@ static int get_sha1_basic(const char *str, int len, unsigned char *sha1) return -1; if (warn_ambiguous_refs && refs_found > 1) - fprintf(stderr, warning, len, str); + fprintf(stderr, warn_msg, len, str); if (reflog_len) { int nth, i; @@ -426,14 +426,12 @@ static int get_sha1_basic(const char *str, int len, unsigned char *sha1) if (read_ref_at(real_ref, at_time, nth, sha1, NULL, &co_time, &co_tz, &co_cnt)) { if (at_time) - fprintf(stderr, - "warning: Log for '%.*s' only goes " + warning("Log for '%.*s' only goes " "back to %s.\n", len, str, show_date(co_time, co_tz, DATE_RFC2822)); else - fprintf(stderr, - "warning: Log for '%.*s' only has " - "%d entries.\n", len, str, co_cnt); + return error("Log for '%.*s' only has " + "%d entries.\n", len, str, co_cnt); } } -- To unsubscribe from this list: send the line "unsubscribe git" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html