From cc0867956cd631abd9e441a4a487cb0748e6889a Mon Sep 17 00:00:00 2001 From: giraffedata Date: Sun, 2 Mar 2008 22:51:16 +0000 Subject: fix uninitialized output array git-svn-id: http://svn.code.sf.net/p/netpbm/code/trunk@591 9d0c8265-081b-0410-96cb-a4ca84ce46f8 --- doc/HISTORY | 2 ++ editor/pgmbentley.c | 98 +++++++++++++++++++++++++++++------------------------ 2 files changed, 56 insertions(+), 44 deletions(-) diff --git a/doc/HISTORY b/doc/HISTORY index 577b69dc..627ab934 100644 --- a/doc/HISTORY +++ b/doc/HISTORY @@ -6,6 +6,8 @@ CHANGE HISTORY not yet BJH Release 10.42.00 + pgmbentley: fix output; black areas not black. + pamtosvg: fix various bugs: crash, poor tracing, memory leaks. pamtosvg: fix log file name with Standard Input. diff --git a/editor/pgmbentley.c b/editor/pgmbentley.c index 9cc86a91..aed92074 100644 --- a/editor/pgmbentley.c +++ b/editor/pgmbentley.c @@ -11,54 +11,64 @@ */ #include + +#include "pm_c_util.h" #include "pgm.h" + +static unsigned int const N = 4; + + int -main( argc, argv ) - int argc; - char* argv[]; - { - FILE* ifp; +main(int argc, const char * argv[]) { + + FILE * ifP; + int rows, cols; gray maxval; - gray** gin; - gray** gout; - int argn, rows, cols, row; - register int brow, col; - const char* const usage = "[pgmfile]"; - - - pgm_init( &argc, argv ); - - argn = 1; - - if ( argn < argc ) - { - ifp = pm_openr( argv[argn] ); - ++argn; - } - else - ifp = stdin; - - if ( argn != argc ) - pm_usage( usage ); - - gin = pgm_readpgm( ifp, &cols, &rows, &maxval ); - pm_close( ifp ); - gout = pgm_allocarray( cols, rows ); - -#define N 4 - for ( row = 0; row < rows; ++row ) - for ( col = 0; col < cols; ++col ) - { - brow = row + (int) (gin[row][col]) / N; - if ( brow >= rows ) - brow = rows - 1; - gout[brow][col] = gin[row][col]; - } + gray ** gin; + gray ** gout; + unsigned int row; + const char * inputFileName; + + pm_proginit(&argc, argv); - pgm_writepgm( stdout, gout, cols, rows, maxval, 0 ); - pm_close( stdout ); - pgm_freearray( gout, rows ); + if (argc-1 < 1) + inputFileName = "-"; + else { + inputFileName = argv[1]; - exit( 0 ); + if (argc-1 > 1) + pm_error("There are no options and only one argument. " + "You specified %u", argc-1); } + ifP = pm_openr(inputFileName); + + gin = pgm_readpgm(ifP, &cols, &rows, &maxval); + + pm_close(ifP); + + gout = pgm_allocarray(cols, rows); + + for (row = 0; row < rows; ++row) { + unsigned int col; + for (col = 0; col < cols; ++col) + gout[row][col] = 0; + } + + for (row = 0; row < rows; ++row) { + unsigned int col; + + for (col = 0; col < cols; ++col) { + unsigned int const brow = MIN(rows-1, row + gin[row][col] / N); + + gout[brow][col] = gin[row][col]; + } + } + + pgm_writepgm(stdout, gout, cols, rows, maxval, 0); + + pm_close(stdout); + pgm_freearray(gout, rows); + + return 0; +} -- cgit 1.4.1