diff options
author | Timo Teräs <timo.teras@iki.fi> | 2017-06-26 14:29:29 +0300 |
---|---|---|
committer | Timo Teräs <timo.teras@iki.fi> | 2017-06-26 14:29:29 +0300 |
commit | 677d3240a845833dfb5c76491c0fd05efb934b2b (patch) | |
tree | defc648aaf5b5a7869d0d8ba5da58331a8020a41 /src/archive.c | |
parent | 51ec463e9d9b5e5c20e1e476870b19f14f856456 (diff) | |
download | apk-tools-677d3240a845833dfb5c76491c0fd05efb934b2b.tar.gz apk-tools-677d3240a845833dfb5c76491c0fd05efb934b2b.tar.bz2 apk-tools-677d3240a845833dfb5c76491c0fd05efb934b2b.tar.xz apk-tools-677d3240a845833dfb5c76491c0fd05efb934b2b.zip |
tar: use standard header prefix
APKs have been created with GNU tar so far, which uses the
GNU extensions for long names. In order to increase portability
support the standard header's 'prefix' portion in case
the GNU extensions are not present.
Diffstat (limited to 'src/archive.c')
-rw-r--r-- | src/archive.c | 10 |
1 files changed, 9 insertions, 1 deletions
diff --git a/src/archive.c b/src/archive.c index 438eb94..b1f9c30 100644 --- a/src/archive.c +++ b/src/archive.c @@ -206,10 +206,12 @@ int apk_tar_parse(struct apk_istream *is, apk_archive_entry_parser parser, int end = 0, r; size_t toskip, paxlen = 0; apk_blob_t pax = APK_BLOB_NULL, longname = APK_BLOB_NULL; + char filename[sizeof buf.name + sizeof buf.prefix + 2]; odi = (struct apk_tar_digest_info *) &buf.linkname[3]; EVP_MD_CTX_init(&teis.mdctx); memset(&entry, 0, sizeof(entry)); + entry.name = buf.name; while ((r = apk_istream_read(is, &buf, 512)) == 512) { offset += 512; if (buf.name[0] == '\0') { @@ -224,13 +226,19 @@ int apk_tar_parse(struct apk_istream *is, apk_archive_entry_parser parser, .gid = apk_resolve_gid(idc, buf.gname, GET_OCTAL(buf.gid)), .mode = GET_OCTAL(buf.mode) & 07777, .mtime = GET_OCTAL(buf.mtime), - .name = entry.name ?: buf.name, + .name = entry.name, .uname = buf.uname, .gname = buf.gname, .device = makedev(GET_OCTAL(buf.devmajor), GET_OCTAL(buf.devminor)), .xattrs = entry.xattrs, }; + if (buf.prefix[0] && buf.typeflag != 'x' && buf.typeflag != 'g') { + snprintf(filename, sizeof filename, "%.*s/%.*s", + (int) sizeof buf.prefix, buf.prefix, + (int) sizeof buf.name, buf.name); + entry.name = filename; + } buf.mode[0] = 0; /* to nul terminate 100-byte buf.name */ buf.magic[0] = 0; /* to nul terminate 100-byte buf.linkname */ teis.csum = NULL; |