diff options
author | Junio C Hamano <gitster@pobox.com> | 2010-02-10 12:52:39 -0800 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2010-02-10 12:52:39 -0800 |
commit | c6eba1d5b2fdabda46158a01a80bea2a01ef6016 (patch) | |
tree | c84372b7e1b5e8846d02292177d053cd0f634e2c | |
parent | 8ff883029a97b38b893b15199393d0e4e7190c0d (diff) | |
parent | d5f53d6d6f20bbd1ec5507824eb213463554b36a (diff) | |
download | git-c6eba1d5b2fdabda46158a01a80bea2a01ef6016.tar.gz |
Merge branch 'rs/maint-archive-match-pathspec' into maint
* rs/maint-archive-match-pathspec:
archive: complain about path specs that don't match anything
-rw-r--r-- | archive.c | 25 |
1 files changed, 24 insertions, 1 deletions
@@ -211,10 +211,33 @@ static const struct archiver *lookup_archiver(const char *name) return NULL; } +static int reject_entry(const unsigned char *sha1, const char *base, + int baselen, const char *filename, unsigned mode, + int stage, void *context) +{ + return -1; +} + +static int path_exists(struct tree *tree, const char *path) +{ + const char *pathspec[] = { path, NULL }; + + if (read_tree_recursive(tree, "", 0, 0, pathspec, reject_entry, NULL)) + return 1; + return 0; +} + static void parse_pathspec_arg(const char **pathspec, struct archiver_args *ar_args) { - ar_args->pathspec = get_pathspec("", pathspec); + ar_args->pathspec = pathspec = get_pathspec("", pathspec); + if (pathspec) { + while (*pathspec) { + if (!path_exists(ar_args->tree, *pathspec)) + die("path not found: %s", *pathspec); + pathspec++; + } + } } static void parse_treeish_arg(const char **argv, |