wok-current rev 1641
busybox: fix cpio TRAILER!!! with hard links
author | Pascal Bellard <pascal.bellard@slitaz.org> |
---|---|
date | Sat Oct 25 12:09:31 2008 +0000 (2008-10-25) |
parents | 8c8ce3310a17 |
children | d732948e6b0b |
files | busybox/stuff/busybox-1.12.0-cpio-mkdir.u |
line diff
1.1 --- a/busybox/stuff/busybox-1.12.0-cpio-mkdir.u Sat Oct 25 10:50:48 2008 +0000 1.2 +++ b/busybox/stuff/busybox-1.12.0-cpio-mkdir.u Sat Oct 25 12:09:31 2008 +0000 1.3 @@ -19,3 +19,32 @@ 1.4 && !(archive_handle->ah_flags & ARCHIVE_EXTRACT_QUIET) 1.5 ) { 1.6 bb_perror_msg("cannot make dir %s", file_header->name); 1.7 + 1.8 +--- busybox-1.12.0/archival/cpio.c 1.9 ++++ busybox-1.12.0/archival/cpio.c 1.10 +@@ -30,6 +30,7 @@ 1.11 + * It's ok to exit instead of return. */ 1.12 + static int cpio_o(void) 1.13 + { 1.14 ++ static char trailer[] = "TRAILER!!!"; 1.15 + struct name_s { 1.16 + struct name_s *next; 1.17 + char name[1]; 1.18 +@@ -119,7 +120,7 @@ 1.19 + } else { 1.20 + /* If no (more) hardlinks to output, 1.21 + * output "trailer" entry */ 1.22 +- name = "TRAILER!!!"; 1.23 ++ name = trailer; 1.24 + /* st.st_size == 0 is a must, but for uniformity 1.25 + * in the output, we zero out everything */ 1.26 + memset(&st, 0, sizeof(st)); 1.27 +@@ -167,7 +168,7 @@ 1.28 + } 1.29 + 1.30 + if (!line) { 1.31 +- if (links) 1.32 ++ if (name != trailer) 1.33 + goto next_link; 1.34 + /* TODO: GNU cpio pads trailer to 512 bytes, do we want that? */ 1.35 + return EXIT_SUCCESS;