X-Git-Url: https://git.dogcows.com/gitweb?a=blobdiff_plain;f=src%2Fdelete.c;h=3e6adddbf245e68b68ef1787bcb64549e4af3791;hb=631de61428b8b840f3f87022de661f5468576bde;hp=b4cdd3be8a400befc6adc26eb7bbedf96ff00026;hpb=829b1dc328a92d7a6ca8f8a43909794fe854a325;p=chaz%2Ftar diff --git a/src/delete.c b/src/delete.c index b4cdd3b..3e6addd 100644 --- a/src/delete.c +++ b/src/delete.c @@ -1,7 +1,7 @@ /* Delete entries from a tar archive. - Copyright (C) 1988, 1992, 1994, 1996, 1997, 2000, 2001, 2003 Free - Software Foundation, Inc. + Copyright (C) 1988, 1992, 1994, 1996, 1997, 2000, 2001, 2003, 2004, + 2005, 2006 Free Software Foundation, Inc. This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the @@ -15,12 +15,13 @@ You should have received a copy of the GNU General Public License along with this program; if not, write to the Free Software Foundation, Inc., - 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */ + 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. */ -#include "system.h" +#include +#include #include "common.h" -#include "rmt.h" +#include static union block *new_record; static int new_blocks; @@ -33,7 +34,7 @@ extern union block *record_end; extern union block *current_block; extern union block *recent_long_name; extern union block *recent_long_link; -extern off_t records_read; +extern off_t records_read; extern off_t records_written; /* The number of records skipped at the start of the archive, when @@ -173,7 +174,7 @@ delete_archive_members (void) abort (); case HEADER_SUCCESS: - if ((name = name_scan (current_stat_info.file_name)) == NULL) + if ((name = name_scan (current_stat_info.file_name, false)) == NULL) { skip_member (); break; @@ -184,7 +185,7 @@ delete_archive_members (void) skip_member (); break; } - + /* Fall through. */ case HEADER_SUCCESS_EXTENDED: logical_status = status; @@ -261,10 +262,9 @@ delete_archive_members (void) if (current_block == record_end) flush_archive (); status = read_header (false); - - if (extended_header.size) - xheader_decode (¤t_stat_info); - + + xheader_decode (¤t_stat_info); + if (status == HEADER_ZERO_BLOCK && ignore_zeros_option) { set_next_block_after (current_header); @@ -285,7 +285,7 @@ delete_archive_members (void) /* Found another header. */ - if ((name = name_scan (current_stat_info.file_name)) != NULL) + if ((name = name_scan (current_stat_info.file_name, false)) != NULL) { name->found_count++; if (ISFOUND(name)) @@ -360,33 +360,32 @@ delete_archive_members (void) write_record (1); } } - } - if (logical_status == HEADER_END_OF_FILE) - { - /* Write the end of tape. FIXME: we can't use write_eot here, - as it gets confused when the input is at end of file. */ + if (logical_status == HEADER_END_OF_FILE) + { + /* Write the end of tape. FIXME: we can't use write_eot here, + as it gets confused when the input is at end of file. */ - int total_zero_blocks = 0; + int total_zero_blocks = 0; - do + do + { + int zero_blocks = blocking_factor - new_blocks; + memset (new_record + new_blocks, 0, BLOCKSIZE * zero_blocks); + total_zero_blocks += zero_blocks; + write_record (total_zero_blocks < 2); + } + while (total_zero_blocks < 2); + } + + if (! acting_as_filter && ! _isrmt (archive)) { - int zero_blocks = blocking_factor - new_blocks; - memset (new_record + new_blocks, 0, BLOCKSIZE * zero_blocks); - total_zero_blocks += zero_blocks; - write_record (total_zero_blocks < 2); + if (sys_truncate (archive)) + truncate_warn (archive_name_array[0]); } - while (total_zero_blocks < 2); } - free (new_record); - if (! acting_as_filter && ! _isrmt (archive)) - { - if (sys_truncate (archive)) - truncate_warn (archive_name_array[0]); - } - close_archive (); names_notfound (); }