aboutsummaryrefslogtreecommitdiff
path: root/archival
diff options
context:
space:
mode:
authorDenys Vlasenko <vda.linux@googlemail.com>2010-01-08 18:07:33 +0100
committerDenys Vlasenko <vda.linux@googlemail.com>2010-01-08 18:07:33 +0100
commit6fd42b3d00bb35d38eaa0fc64409992a4760f749 (patch)
treeddb6d431df1e46cc48a7956560400eeb4cdbd014 /archival
parent866710a05616be518d9d32261b52c9f81a025fe1 (diff)
downloadbusybox-w32-6fd42b3d00bb35d38eaa0fc64409992a4760f749.tar.gz
busybox-w32-6fd42b3d00bb35d38eaa0fc64409992a4760f749.tar.bz2
busybox-w32-6fd42b3d00bb35d38eaa0fc64409992a4760f749.zip
dpkg: fix handling of names with leading dots. Closes bug 783
Signed-off-by: Denys Vlasenko <vda.linux@googlemail.com>
Diffstat (limited to 'archival')
-rw-r--r--archival/dpkg.c13
1 files changed, 12 insertions, 1 deletions
diff --git a/archival/dpkg.c b/archival/dpkg.c
index 616bce977..9f58b54e6 100644
--- a/archival/dpkg.c
+++ b/archival/dpkg.c
@@ -1493,7 +1493,18 @@ static void FAST_FUNC data_extract_all_prefix(archive_handle_t *archive_handle)
1493{ 1493{
1494 char *name_ptr = archive_handle->file_header->name; 1494 char *name_ptr = archive_handle->file_header->name;
1495 1495
1496 name_ptr += strspn(name_ptr, "./"); 1496 /* Skip all leading "/" */
1497 while (*name_ptr == '/')
1498 name_ptr++;
1499 /* Skip all leading "./" and "../" */
1500 while (name_ptr[0] == '.') {
1501 if (name_ptr[1] == '.' && name_ptr[2] == '/')
1502 name_ptr++;
1503 if (name_ptr[1] != '/')
1504 break;
1505 name_ptr += 2;
1506 }
1507
1497 if (name_ptr[0] != '\0') { 1508 if (name_ptr[0] != '\0') {
1498 archive_handle->file_header->name = xasprintf("%s%s", archive_handle->dpkg__buffer, name_ptr); 1509 archive_handle->file_header->name = xasprintf("%s%s", archive_handle->dpkg__buffer, name_ptr);
1499 data_extract_all(archive_handle); 1510 data_extract_all(archive_handle);