Merge branch 'rs/zip'

* rs/zip:
  git-archive --format=zip: add symlink support
  git-archive --format=zip: use default version ID
This commit is contained in:
Junio C Hamano 2006-10-18 22:08:24 -07:00
commit 6847e56c9e
2 changed files with 46 additions and 6 deletions

View File

@ -145,6 +145,7 @@ static int write_zip_entry(const unsigned char *sha1,
{ {
struct zip_local_header header; struct zip_local_header header;
struct zip_dir_header dirent; struct zip_dir_header dirent;
unsigned long attr2;
unsigned long compressed_size; unsigned long compressed_size;
unsigned long uncompressed_size; unsigned long uncompressed_size;
unsigned long crc; unsigned long crc;
@ -172,12 +173,16 @@ static int write_zip_entry(const unsigned char *sha1,
if (S_ISDIR(mode)) { if (S_ISDIR(mode)) {
method = 0; method = 0;
attr2 = 16;
result = READ_TREE_RECURSIVE; result = READ_TREE_RECURSIVE;
out = NULL; out = NULL;
uncompressed_size = 0; uncompressed_size = 0;
compressed_size = 0; compressed_size = 0;
} else if (S_ISREG(mode)) { } else if (S_ISREG(mode) || S_ISLNK(mode)) {
method = zlib_compression_level == 0 ? 0 : 8; method = 0;
attr2 = S_ISLNK(mode) ? ((mode | 0777) << 16) : 0;
if (S_ISREG(mode) && zlib_compression_level != 0)
method = 8;
result = 0; result = 0;
buffer = read_sha1_file(sha1, type, &size); buffer = read_sha1_file(sha1, type, &size);
if (!buffer) if (!buffer)
@ -213,8 +218,8 @@ static int write_zip_entry(const unsigned char *sha1,
} }
copy_le32(dirent.magic, 0x02014b50); copy_le32(dirent.magic, 0x02014b50);
copy_le16(dirent.creator_version, 0); copy_le16(dirent.creator_version, S_ISLNK(mode) ? 0x0317 : 0);
copy_le16(dirent.version, 20); copy_le16(dirent.version, 10);
copy_le16(dirent.flags, 0); copy_le16(dirent.flags, 0);
copy_le16(dirent.compression_method, method); copy_le16(dirent.compression_method, method);
copy_le16(dirent.mtime, zip_time); copy_le16(dirent.mtime, zip_time);
@ -227,7 +232,7 @@ static int write_zip_entry(const unsigned char *sha1,
copy_le16(dirent.comment_length, 0); copy_le16(dirent.comment_length, 0);
copy_le16(dirent.disk, 0); copy_le16(dirent.disk, 0);
copy_le16(dirent.attr1, 0); copy_le16(dirent.attr1, 0);
copy_le32(dirent.attr2, 0); copy_le32(dirent.attr2, attr2);
copy_le32(dirent.offset, zip_offset); copy_le32(dirent.offset, zip_offset);
memcpy(zip_dir + zip_dir_offset, &dirent, sizeof(struct zip_dir_header)); memcpy(zip_dir + zip_dir_offset, &dirent, sizeof(struct zip_dir_header));
zip_dir_offset += sizeof(struct zip_dir_header); zip_dir_offset += sizeof(struct zip_dir_header);
@ -236,7 +241,7 @@ static int write_zip_entry(const unsigned char *sha1,
zip_dir_entries++; zip_dir_entries++;
copy_le32(header.magic, 0x04034b50); copy_le32(header.magic, 0x04034b50);
copy_le16(header.version, 20); copy_le16(header.version, 10);
copy_le16(header.flags, 0); copy_le16(header.flags, 0);
copy_le16(header.compression_method, method); copy_le16(header.compression_method, method);
copy_le16(header.mtime, zip_time); copy_le16(header.mtime, zip_time);

View File

@ -26,6 +26,7 @@ commit id embedding:
. ./test-lib.sh . ./test-lib.sh
TAR=${TAR:-tar} TAR=${TAR:-tar}
UNZIP=${UNZIP:-unzip}
test_expect_success \ test_expect_success \
'populate workdir' \ 'populate workdir' \
@ -95,4 +96,38 @@ test_expect_success \
'validate file contents with prefix' \ 'validate file contents with prefix' \
'diff -r a c/prefix/a' 'diff -r a c/prefix/a'
test_expect_success \
'git-archive --format=zip' \
'git-archive --format=zip HEAD >d.zip'
test_expect_success \
'extract ZIP archive' \
'(mkdir d && cd d && $UNZIP ../d.zip)'
test_expect_success \
'validate filenames' \
'(cd d/a && find .) | sort >d.lst &&
diff a.lst d.lst'
test_expect_success \
'validate file contents' \
'diff -r a d/a'
test_expect_success \
'git-archive --format=zip with prefix' \
'git-archive --format=zip --prefix=prefix/ HEAD >e.zip'
test_expect_success \
'extract ZIP archive with prefix' \
'(mkdir e && cd e && $UNZIP ../e.zip)'
test_expect_success \
'validate filenames with prefix' \
'(cd e/prefix/a && find .) | sort >e.lst &&
diff a.lst e.lst'
test_expect_success \
'validate file contents with prefix' \
'diff -r a e/prefix/a'
test_done test_done