summaryrefslogtreecommitdiffstats
path: root/Utilities/cmcompress/cmcompress.c
diff options
context:
space:
mode:
Diffstat (limited to 'Utilities/cmcompress/cmcompress.c')
-rw-r--r--Utilities/cmcompress/cmcompress.c54
1 files changed, 32 insertions, 22 deletions
diff --git a/Utilities/cmcompress/cmcompress.c b/Utilities/cmcompress/cmcompress.c
index 6ac4956..2038799 100644
--- a/Utilities/cmcompress/cmcompress.c
+++ b/Utilities/cmcompress/cmcompress.c
@@ -68,10 +68,11 @@ static const char_type magic_header[] = { "\037\235" }; /* 1F 9D */
#define CLEAR 256 /* table clear output code */
static void cl_hash(struct cmcompress_stream* cdata, count_int hsize); /* reset code table */
-static void cl_block (struct cmcompress_stream* cdata); /* table clear for block compress */
+static int cl_block (struct cmcompress_stream* cdata); /* table clear for block compress */
+static int output(struct cmcompress_stream* cdata, code_int code);
+#ifdef DEBUG
static void prratio( FILE *stream, long int num, long int den);
-static void output(struct cmcompress_stream* cdata, code_int code);
-static void writeerr();
+#endif
int cmcompress_compress_initialize(struct cmcompress_stream* cdata)
{
@@ -204,7 +205,10 @@ probe:
goto probe;
}
nomatch:
- output(cdata, (code_int) cdata->ent );
+ if ( !output(cdata, (code_int) cdata->ent ) )
+ {
+ return 0;
+ }
cdata->out_count++;
cdata->ent = c;
if (
@@ -220,7 +224,10 @@ nomatch:
}
else if ( (count_int)cdata->in_count >= cdata->checkpoint && cdata->block_compress )
{
- cl_block (cdata);
+ if ( !cl_block (cdata) )
+ {
+ return 0;
+ }
}
}
@@ -232,9 +239,15 @@ int cmcompress_compress_finalize(struct cmcompress_stream* cdata)
/*
* Put out the final code.
*/
- output(cdata, (code_int)cdata->ent );
+ if ( !output(cdata, (code_int)cdata->ent ) )
+ {
+ return 0;
+ }
cdata->out_count++;
- output(cdata, (code_int)-1 );
+ if ( !output(cdata, (code_int)-1 ) )
+ {
+ return 0;
+ }
if(cdata->bytes_out > cdata->in_count) /* exit(2) if no savings */
{
@@ -243,7 +256,7 @@ int cmcompress_compress_finalize(struct cmcompress_stream* cdata)
return 1;
}
-void cl_block (struct cmcompress_stream* cdata) /* table clear for block compress */
+int cl_block (struct cmcompress_stream* cdata) /* table clear for block compress */
{
register long int rat;
@@ -289,7 +302,10 @@ void cl_block (struct cmcompress_stream* cdata) /* table clear for block comp
cl_hash (cdata, (count_int) cdata->hsize );
cdata->free_ent = FIRST;
cdata->clear_flg = 1;
- output (cdata, (code_int) CLEAR );
+ if ( !output (cdata, (code_int) CLEAR ) )
+ {
+ return 0;
+ }
#ifdef DEBUG
if(cdata->debug)
{
@@ -297,6 +313,7 @@ void cl_block (struct cmcompress_stream* cdata) /* table clear for block comp
}
#endif /* DEBUG */
}
+ return 1;
}
void cl_hash(struct cmcompress_stream* cdata, count_int hsize) /* reset code table */
@@ -377,7 +394,7 @@ char_type lmask[9] = {0xff, 0xfe, 0xfc, 0xf8, 0xf0, 0xe0, 0xc0, 0x80, 0x00};
char_type rmask[9] = {0x00, 0x01, 0x03, 0x07, 0x0f, 0x1f, 0x3f, 0x7f, 0xff};
#endif /* vax */
-void output(struct cmcompress_stream* cdata, code_int code)
+int output(struct cmcompress_stream* cdata, code_int code)
{
#ifdef DEBUG
static int col = 0;
@@ -451,7 +468,7 @@ void output(struct cmcompress_stream* cdata, code_int code)
//putchar(*bp++);
//if (ferror(stdout))
{
- writeerr();
+ return 0;
}
bp++;
}
@@ -474,7 +491,7 @@ void output(struct cmcompress_stream* cdata, code_int code)
if ( cdata->output_stream(cdata, buf, cdata->n_bits) != cdata->n_bits )
//if( fwrite( buf, 1, cdata->n_bits, stdout ) != cdata->n_bits)
{
- writeerr();
+ return 0;
}
cdata->bytes_out += cdata->n_bits;
}
@@ -517,7 +534,7 @@ void output(struct cmcompress_stream* cdata, code_int code)
if ( cdata->output_stream(cdata, buf, cdata->offset ) != cdata->offset )
//if( fwrite( buf, 1, cdata->offset, stdout ) != cdata->offset )
{
- writeerr();
+ return 0;
}
cdata->bytes_out += cdata->offset;
}
@@ -525,7 +542,7 @@ void output(struct cmcompress_stream* cdata, code_int code)
(void)fflush( stdout );
if( ferror( stdout ) )
{
- writeerr();
+ return 0;
}
#ifdef DEBUG
if ( verbose )
@@ -534,12 +551,5 @@ void output(struct cmcompress_stream* cdata, code_int code)
}
#endif
}
+ return 1;
}
-
-void writeerr()
-{
- (void)fprintf(stderr, "compress: %s\n",
- strerror(errno));
- exit(1);
-}
-