summaryrefslogtreecommitdiff
path: root/revision.c
diff options
context:
space:
mode:
authorLibravatar Junio C Hamano <junkio@cox.net>2006-04-27 12:51:08 -0700
committerLibravatar Junio C Hamano <junkio@cox.net>2006-04-27 12:51:08 -0700
commitc9a11205f73d7d39aab8b70169d73948d4a9f04f (patch)
tree0c8628c034b9ca4eff6fd093d0e6fc18fc225962 /revision.c
parentFix mismerged update-index from jc/cache-tree branch. (diff)
parentrevision parsing: make "rev -- paths" checks stronger. (diff)
downloadtgif-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.c14
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);
}