Skip to content

Commit

Permalink
archive: add baselen member to struct archiver_args
Browse files Browse the repository at this point in the history
Calculate the length of base and save it in a new member of struct
archiver_args.  This way we don't have to compute it in each of the
format backends.

Note: parse_archive_args() guarantees that ->base won't ever be NULL.

Signed-off-by: Rene Scharfe <[email protected]>
Signed-off-by: Junio C Hamano <[email protected]>
  • Loading branch information
René Scharfe authored and gitster committed Jul 15, 2008
1 parent 671f070 commit d53fe81
Show file tree
Hide file tree
Showing 4 changed files with 8 additions and 10 deletions.
8 changes: 3 additions & 5 deletions archive-tar.c
Original file line number Diff line number Diff line change
Expand Up @@ -268,19 +268,17 @@ static int write_tar_entry(const unsigned char *sha1, const char *base,

int write_tar_archive(struct archiver_args *args)
{
int plen = args->base ? strlen(args->base) : 0;

git_config(git_tar_config, NULL);

archive_time = args->time;
verbose = args->verbose;
commit = args->commit;
base_len = args->base ? strlen(args->base) : 0;
base_len = args->baselen;

if (args->commit_sha1)
write_global_extended_header(args->commit_sha1);

if (args->base && plen > 0 && args->base[plen - 1] == '/') {
if (args->baselen > 0 && args->base[args->baselen - 1] == '/') {
char *base = xstrdup(args->base);
int baselen = strlen(base);

Expand All @@ -290,7 +288,7 @@ int write_tar_archive(struct archiver_args *args)
0, NULL);
free(base);
}
read_tree_recursive(args->tree, args->base, plen, 0,
read_tree_recursive(args->tree, args->base, args->baselen, 0,
args->pathspec, write_tar_entry, NULL);
write_trailer();

Expand Down
8 changes: 3 additions & 5 deletions archive-zip.c
Original file line number Diff line number Diff line change
Expand Up @@ -316,17 +316,15 @@ static void dos_time(time_t *time, int *dos_date, int *dos_time)

int write_zip_archive(struct archiver_args *args)
{
int plen = strlen(args->base);

dos_time(&args->time, &zip_date, &zip_time);

zip_dir = xmalloc(ZIP_DIRECTORY_MIN_SIZE);
zip_dir_size = ZIP_DIRECTORY_MIN_SIZE;
verbose = args->verbose;
commit = args->commit;
base_len = args->base ? strlen(args->base) : 0;
base_len = args->baselen;

if (args->base && plen > 0 && args->base[plen - 1] == '/') {
if (args->baselen > 0 && args->base[args->baselen - 1] == '/') {
char *base = xstrdup(args->base);
int baselen = strlen(base);

Expand All @@ -336,7 +334,7 @@ int write_zip_archive(struct archiver_args *args)
0, NULL);
free(base);
}
read_tree_recursive(args->tree, args->base, plen, 0,
read_tree_recursive(args->tree, args->base, args->baselen, 0,
args->pathspec, write_zip_entry, NULL);
write_zip_trailer(args->commit_sha1);

Expand Down
1 change: 1 addition & 0 deletions archive.h
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,7 @@

struct archiver_args {
const char *base;
size_t baselen;
struct tree *tree;
const unsigned char *commit_sha1;
const struct commit *commit;
Expand Down
1 change: 1 addition & 0 deletions builtin-archive.c
Original file line number Diff line number Diff line change
Expand Up @@ -192,6 +192,7 @@ int parse_archive_args(int argc, const char **argv, const struct archiver **ar,
}
args->verbose = verbose;
args->base = base;
args->baselen = strlen(base);

return i;
}
Expand Down

0 comments on commit d53fe81

Please sign in to comment.