summaryrefslogtreecommitdiffstats
path: root/unzcrash.cc
diff options
context:
space:
mode:
Diffstat (limited to 'unzcrash.cc')
-rw-r--r--unzcrash.cc51
1 files changed, 26 insertions, 25 deletions
diff --git a/unzcrash.cc b/unzcrash.cc
index 107189f..b0c4871 100644
--- a/unzcrash.cc
+++ b/unzcrash.cc
@@ -26,7 +26,7 @@
#include <algorithm>
#include <cerrno>
-#include <climits> // SSIZE_MAX
+#include <climits> // CHAR_BIT, SSIZE_MAX
#include <csignal>
#include <cstdio>
#include <cstdlib>
@@ -54,8 +54,6 @@ namespace {
const char * const program_name = "unzcrash";
const char * invocation_name = program_name; // default value
-int verbosity = 0;
-
void show_help()
{
@@ -142,28 +140,29 @@ uint8_t * read_file( const char * const filename, long * const file_sizep )
long buffer_size = 65536;
uint8_t * buffer = (uint8_t *)std::malloc( buffer_size );
- if( !buffer ) { show_error( mem_msg ); return 0; }
+ if( !buffer ) { show_file_error( filename, mem_msg ); return 0; }
long file_size = std::fread( buffer, 1, buffer_size, f );
while( file_size >= buffer_size || ( !std::ferror( f ) && !std::feof( f ) ) )
{
if( file_size >= buffer_size ) // may be false because of EINTR
{
if( buffer_size >= LONG_MAX )
- { show_file_error( filename, "Input file is larger than LONG_MAX." );
+ { show_file_error( filename, large_file_msg );
std::free( buffer ); return 0; }
buffer_size = ( buffer_size <= LONG_MAX / 2 ) ? 2 * buffer_size : LONG_MAX;
uint8_t * const tmp = (uint8_t *)std::realloc( buffer, buffer_size );
- if( !tmp ) { show_error( mem_msg ); std::free( buffer ); return 0; }
+ if( !tmp )
+ { show_file_error( filename, mem_msg ); std::free( buffer ); return 0; }
buffer = tmp;
}
file_size += std::fread( buffer + file_size, 1, buffer_size - file_size, f );
}
if( std::ferror( f ) || !std::feof( f ) )
- {
- show_file_error( filename, "Error reading input file", errno );
- std::free( buffer ); return 0;
- }
- std::fclose( f );
+ { show_file_error( filename, read_error_msg, errno );
+ std::free( buffer ); return 0; }
+ if( std::fclose( f ) != 0 )
+ { show_file_error( filename, "Error closing input file", errno );
+ std::free( buffer ); return 0; }
*file_sizep = file_size;
return buffer;
}
@@ -173,13 +172,13 @@ class Bitset8 // 8 value bitset (1 to 8)
{
bool data[8];
static bool valid_digit( const unsigned char ch )
- { return ( ch >= '1' && ch <= '8' ); }
+ { return ch >= '1' && ch <= '8'; }
public:
Bitset8() { for( int i = 0; i < 8; ++i ) data[i] = true; }
bool includes( const int i ) const
- { return ( i >= 1 && i <= 8 && data[i-1] ); }
+ { return i >= 1 && i <= 8 && data[i-1]; }
// Recognized formats: 1 1,2,3 1-4 1,3-5,8 1-3,5-8
void parse_bs( const char * const arg, const char * const option_name )
@@ -383,7 +382,7 @@ int main( const int argc, const char * const argv[] )
{ 'v', "verbose", Arg_parser::no },
{ 'V', "version", Arg_parser::no },
{ 'z', "zcmp", Arg_parser::yes },
- { 0 , 0, Arg_parser::no } };
+ { 0, 0, Arg_parser::no } };
const Arg_parser parser( argc, argv, options );
if( parser.error().size() ) // bad option
@@ -398,15 +397,15 @@ int main( const int argc, const char * const argv[] )
const char * const arg = parser.argument( argind ).c_str();
switch( code )
{
- case 'h': show_help(); return 0;
case 'b': bits.parse_bs( arg, pn ); program_mode = m_byte; break;
case 'B': if( arg[0] ) parse_block( arg, pn, block_size, block_value );
program_mode = m_block; break;
case 'd': delta = getnum( arg, pn, block_size, 1, INT_MAX ); break;
case 'e': bad_byte.parse_bb( arg, pn ); break;
+ case 'h': show_help(); return 0;
case 'n': check = false; break;
case 'p': pos = getnum( arg, pn, block_size, -LONG_MAX, LONG_MAX ); break;
- case 'q': verbosity = -1; break;
+ case 'q': cl_verbosity = verbosity = -1; break;
case 's': max_size = getnum( arg, pn, block_size, -LONG_MAX, LONG_MAX ); break;
case 't': program_mode = m_truncate; break;
case 'v': if( verbosity < 4 ) ++verbosity; break;
@@ -419,7 +418,8 @@ int main( const int argc, const char * const argv[] )
if( parser.arguments() - argind != 2 )
{
if( verbosity >= 0 )
- std::fprintf( stderr, "Usage: %s 'lzip -t' file.lz\n", invocation_name );
+ std::fprintf( stderr, "Usage: %s [options] 'lzip -t' file.lz\n",
+ invocation_name );
return 1;
}
@@ -532,7 +532,7 @@ int main( const int argc, const char * const argv[] )
}
else if( program_mode == m_block )
{
- uint8_t * block = (uint8_t *)std::malloc( block_size );
+ uint8_t * const block = (uint8_t *)std::malloc( block_size );
if( !block ) { show_error( mem_msg ); return 1; }
for( long i = pos; i < end; i += std::min( delta, end - i ) )
{
@@ -611,17 +611,18 @@ int main( const int argc, const char * const argv[] )
if( verbosity >= 0 )
{
- std::fprintf( stderr, "\n%9ld %ss tested\n%9ld total decompressions"
- "\n%9ld decompressions returned with zero status",
- positions, mode_str[program_mode], decompressions, successes );
+ std::fprintf( stderr, "\n%11s %ss tested\n%11s total decompressions"
+ "\n%11s decompressions returned with zero status",
+ format_num3( positions ), mode_str[program_mode],
+ format_num3( decompressions ), format_num3( successes ) );
if( successes > 0 )
{
if( zcmp_command.empty() )
- std::fputs( "\n comparisons disabled\n", stderr );
+ std::fputs( "\n comparisons disabled\n", stderr );
else if( failed_comparisons > 0 )
- std::fprintf( stderr, ", of which\n%9ld comparisons failed\n",
- failed_comparisons );
- else std::fputs( "\n all comparisons passed\n", stderr );
+ std::fprintf( stderr, ", of which\n%11s comparisons failed\n",
+ format_num3( failed_comparisons ) );
+ else std::fputs( "\n all comparisons passed\n", stderr );
}
else std::fputc( '\n', stderr );
}