Merge branch 'rs/maint-archive-prefix'

* rs/maint-archive-prefix:
  Git archive and trailing "/" in prefix
This commit is contained in:
Junio C Hamano 2009-10-09 16:27:16 -07:00
commit a17a9606e4
2 changed files with 16 additions and 3 deletions

View File

@ -115,6 +115,7 @@ static int write_archive_entry(const unsigned char *sha1, const char *base,
strbuf_reset(&path); strbuf_reset(&path);
strbuf_grow(&path, PATH_MAX); strbuf_grow(&path, PATH_MAX);
strbuf_add(&path, args->base, args->baselen);
strbuf_add(&path, base, baselen); strbuf_add(&path, base, baselen);
strbuf_addstr(&path, filename); strbuf_addstr(&path, filename);
path_without_prefix = path.buf + args->baselen; path_without_prefix = path.buf + args->baselen;
@ -187,8 +188,8 @@ int write_archive_entries(struct archiver_args *args,
git_attr_set_direction(GIT_ATTR_INDEX, &the_index); git_attr_set_direction(GIT_ATTR_INDEX, &the_index);
} }
err = read_tree_recursive(args->tree, args->base, args->baselen, 0, err = read_tree_recursive(args->tree, "", 0, 0, args->pathspec,
args->pathspec, write_archive_entry, &context); write_archive_entry, &context);
if (err == READ_TREE_RECURSIVE) if (err == READ_TREE_RECURSIVE)
err = 0; err = 0;
return err; return err;
@ -211,7 +212,7 @@ static const struct archiver *lookup_archiver(const char *name)
static void parse_pathspec_arg(const char **pathspec, static void parse_pathspec_arg(const char **pathspec,
struct archiver_args *ar_args) struct archiver_args *ar_args)
{ {
ar_args->pathspec = get_pathspec(ar_args->base, pathspec); ar_args->pathspec = get_pathspec("", pathspec);
} }
static void parse_treeish_arg(const char **argv, static void parse_treeish_arg(const char **argv,

View File

@ -230,4 +230,16 @@ test_expect_success \
'git archive --list outside of a git repo' \ 'git archive --list outside of a git repo' \
'GIT_DIR=some/non-existing/directory git archive --list' 'GIT_DIR=some/non-existing/directory git archive --list'
test_expect_success 'git-archive --prefix=olde-' '
git archive --prefix=olde- >h.tar HEAD &&
(
mkdir h &&
cd h &&
"$TAR" xf - <../h.tar
) &&
test -d h/olde-a &&
test -d h/olde-a/bin &&
test -f h/olde-a/bin/sh
'
test_done test_done