diff options
author | Junio C Hamano <junkio@cox.net> | 2006-04-27 12:51:08 -0700 |
---|---|---|
committer | Junio C Hamano <junkio@cox.net> | 2006-04-27 12:51:08 -0700 |
commit | c9a11205f73d7d39aab8b70169d73948d4a9f04f (patch) | |
tree | 0c8628c034b9ca4eff6fd093d0e6fc18fc225962 /revision.c | |
parent | Fix mismerged update-index from jc/cache-tree branch. (diff) | |
parent | revision parsing: make "rev -- paths" checks stronger. (diff) | |
download | tgif-c9a11205f73d7d39aab8b70169d73948d4a9f04f.tar.xz |
Merge branch 'jc/pathcheck' into next
* jc/pathcheck:
revision parsing: make "rev -- paths" checks stronger.
Diffstat (limited to 'revision.c')
-rw-r--r-- | revision.c | 14 |
1 files changed, 13 insertions, 1 deletions
diff --git a/revision.c b/revision.c index f2a9f25fe1..b6ed0149a5 100644 --- a/revision.c +++ b/revision.c @@ -740,6 +740,11 @@ int setup_revisions(int argc, const char **argv, struct rev_info *revs, const ch include = get_reference(revs, next, sha1, flags); if (!exclude || !include) die("Invalid revision range %s..%s", arg, next); + + if (!seen_dashdash) { + *dotdot = '.'; + verify_non_filename(revs->prefix, arg); + } add_pending_object(revs, exclude, this); add_pending_object(revs, include, next); continue; @@ -757,13 +762,20 @@ int setup_revisions(int argc, const char **argv, struct rev_info *revs, const ch if (seen_dashdash || local_flags) die("bad revision '%s'", arg); - /* If we didn't have a "--", all filenames must exist */ + /* If we didn't have a "--": + * (1) all filenames must exist; + * (2) all rev-args must not be interpretable + * as a valid filename. + * but the latter we have checked in the main loop. + */ for (j = i; j < argc; j++) verify_filename(revs->prefix, argv[j]); revs->prune_data = get_pathspec(revs->prefix, argv + i); break; } + if (!seen_dashdash) + verify_non_filename(revs->prefix, arg); object = get_reference(revs, arg, sha1, flags ^ local_flags); add_pending_object(revs, object, arg); } |