Fixes taken from netpbm --- lib/rle_global.c +++ lib/rle_global.c @@ -76,7 +76,7 @@ rle_hdr rle_dflt_hdr = { 8, /* cmaplen (log2 of length of color map) */ NULL, /* pointer to color map */ NULL, /* pointer to comment strings */ - stdout, /* output file */ + NULL, /* output file -- must be set dynamically */ { 7 }, /* RGB channels only */ 0L, /* Can't free name and file fields. */ "Urt", /* Default "program name". */ --- lib/rle_hdr.c +++ lib/rle_hdr.c @@ -269,6 +273,9 @@ { rle_hdr *ret_hdr; + rle_dflt_hdr.rle_file = stdout; + /* The rest of rle_dflt_hdr is set by the loader's data initialization */ + if ( the_hdr == &rle_dflt_hdr ) return the_hdr; --- lib/dither.c +++ lib/dither.c @@ -38,10 +38,10 @@ void make_square(); #endif static int magic4x4[4][4] = { - 0, 14, 3, 13, - 11, 5, 8, 6, - 12, 2, 15, 1, - 7, 9, 4, 10 +{ 0, 14, 3, 13}, +{ 11, 5, 8, 6}, +{ 12, 2, 15, 1}, +{ 7, 9, 4, 10} }; /* basic dithering macro */ --- lib/rle_open_f.c +++ lib/rle_open_f.c @@ -9,7 +9,11 @@ */ #include "rle_config.h" +#define _XOPEN_SOURCE /* Make sure fdopen() is in stdio.h */ + #include <stdio.h> +#include <unistd.h> +#include <fcntl.h> #ifndef NO_OPEN_PIPES /* Need to have a SIGCLD signal catcher. */ @@ -260,7 +260,6 @@ int pipefd[2]; int i; char *argv[4]; - extern int errno; /* Check args. */ if ( *mode != 'r' && *mode != 'w' ) --- lib/rle_getcom.c +++ lib/rle_getcom.c @@ -53,11 +53,12 @@ { for ( ; *n != '\0' && *n != '=' && *n == *v; n++, v++ ) ; - if (*n == '\0' || *n == '=') + if (*n == '\0' || *n == '=') { if ( *v == '\0' ) return v; else if ( *v == '=' ) return ++v; + } return NULL; } --- lib/scanargs.c +++ lib/scanargs.c @@ -128,10 +130,10 @@ va_list argl; { - register check; /* check counter to be sure all argvs + int check; /* check counter to be sure all argvs are processed */ register CONST_DECL char *cp; - register cnt; + int cnt; int optarg = 0; /* where optional args start */ int nopt = 0; char tmpflg, /* temp flag */ @@ -375,11 +377,12 @@ if ( optarg > 0 ) /* end optional args? */ { /* Eat the arg, too, if necessary */ - if ( list_cnt == 0 ) + if ( list_cnt == 0 ) { if ( typchr == 's' ) (void)va_arg( argl, char * ); else (void)va_arg( argl, ptr ); + } break; } else @@ -567,7 +570,7 @@ * Do conversion for n and N types */ tmpflg = typchr; - if (typchr == 'n' || typchr == 'N' ) + if (typchr == 'n' || typchr == 'N' ) { if (*argp != '0') tmpflg = 'd'; else if (*(argp+1) == 'x' || @@ -578,6 +581,7 @@ } else tmpflg = 'o'; + } if (typchr == 'N') tmpflg = toupper( tmpflg ); --- lib/inv_cmap.c +++ lib/inv_cmap.c @@ -42,7 +42,7 @@ static long cbinc, cginc, crinc; static unsigned long *gdp, *rdp, *cdp; static unsigned char *grgbp, *rrgbp, *crgbp; -static gstride, rstride; +static long gstride, rstride; static long x, xsqr, colormax; static int cindex; #ifdef INSTRUMENT_IT --- lib/rle_getrow.c +++ lib/rle_getrow.c @@ -351,7 +351,7 @@ bzero( (char *)scanline[-1] + the_hdr->xmin, the_hdr->xmax - the_hdr->xmin + 1 ); for ( nc = 0; nc < the_hdr->ncolors; nc++ ) - if ( RLE_BIT( *the_hdr, nc ) ) + if ( RLE_BIT( *the_hdr, nc ) ) { /* Unless bg color given explicitly, use 0. */ if ( the_hdr->background != 2 || the_hdr->bg_color[nc] == 0 ) bzero( (char *)scanline[nc] + the_hdr->xmin, @@ -360,6 +360,7 @@ bfill( (char *)scanline[nc] + the_hdr->xmin, the_hdr->xmax - the_hdr->xmin + 1, the_hdr->bg_color[nc] ); + } } /* If skipping, then just return */ @@ -367,7 +368,7 @@ { the_hdr->priv.get.vert_skip--; the_hdr->priv.get.scan_y++; - if ( the_hdr->priv.get.vert_skip > 0 ) + if ( the_hdr->priv.get.vert_skip > 0 ) { if ( the_hdr->priv.get.scan_y >= the_hdr->ymax ) { int y = the_hdr->priv.get.scan_y; @@ -377,6 +378,7 @@ } else return the_hdr->priv.get.scan_y; + } } /* If EOF has been encountered, return also */ @@ -457,11 +459,12 @@ else nc = DATUM(inst); nc++; - if ( debug_f ) + if ( debug_f ) { if ( RLE_BIT( *the_hdr, channel ) ) fprintf( stderr, "Pixel data %d (to %d):", nc, scan_x+nc ); else fprintf( stderr, "Pixel data %d (to %d)\n", nc, scan_x+nc); + } if ( RLE_BIT( *the_hdr, channel ) ) { /* Don't fill past end of scanline! */ --- lib/rle_putcom.c +++ lib/rle_putcom.c @@ -53,11 +53,12 @@ { for ( ; *n != '\0' && *n != '=' && *n == *v; n++, v++ ) ; - if (*n == '\0' || *n == '=') + if (*n == '\0' || *n == '=') { if ( *v == '\0' ) return v; else if ( *v == '=' ) return ++v; + } return NULL; }