# HG changeset patch # User Rik # Date 1444709627 25200 # Node ID e54ecb33727e03de2ac4cf6b34ecd9749193a990 # Parent 93d96da9ff3e2a8d2db0ff0806d2bd26479e7c37 lo-array-gripes.cc: Remove FIXME's related to buffer size. * lo-array-gripes.cc: Remove FIXME's related to buffer size. Shorten sprintf buffers from 100 to 64 characters (still well more than 19 required). Use 'const' decorator on constant value for clarity. Remove extra space between variable and array bracket. diff -r 93d96da9ff3e -r e54ecb33727e liboctave/util/lo-array-gripes.cc --- a/liboctave/util/lo-array-gripes.cc Mon Oct 12 17:30:44 2015 -0400 +++ b/liboctave/util/lo-array-gripes.cc Mon Oct 12 21:13:47 2015 -0700 @@ -122,8 +122,7 @@ index_exception:: access (void) const { // FIXME: don't use a fixed size buffer! - - int buf_len = 300; + const int buf_len = 300; char output [buf_len]; char pre [buf_len]; @@ -228,8 +227,8 @@ gripe_invalid_index (octave_idx_type n, octave_idx_type nd, octave_idx_type dim, const char *var) { - // FIXME: don't use a fixed size buffer! - char buf [100]; + // Note: log10 (2^63) = 19 digits. Use 64 for ease of memory alignment. + char buf[64]; sprintf (buf, "%d", n+1); @@ -240,8 +239,7 @@ gripe_invalid_index (double n, octave_idx_type nd, octave_idx_type dim, const char *var) { - // FIXME: don't use a fixed size buffer! - char buf [100]; + char buf[64]; sprintf (buf, "%g", n+1); @@ -275,8 +273,7 @@ } else { - // FIXME: don't use a fixed size buffer! - char buf [100]; + char buf[64]; sprintf (buf, "%d", extent); expl = "out of bound " + std::string (buf); } @@ -296,7 +293,7 @@ private: - dim_vector size; // dimension of object being accessed + dim_vector size; // dimension of object being accessed octave_idx_type extent; // length of dimension being accessed }; @@ -306,12 +303,12 @@ gripe_index_out_of_range (int nd, int dim, octave_idx_type idx, octave_idx_type ext) { - char buf [100]; + char buf[64]; sprintf (buf, "%d", idx); out_of_range e (buf, nd, dim); e.set_extent (ext); - dim_vector d (1,1,1,1,1,1,1); // make explain() give extent not size + dim_vector d (1,1,1,1,1,1,1); // make explain() give extent not size e.set_size (d); throw e; } @@ -321,7 +318,7 @@ gripe_index_out_of_range (int nd, int dim, octave_idx_type idx, octave_idx_type ext, const dim_vector& d) { - char buf [100]; + char buf[64]; sprintf (buf, "%d", idx); out_of_range e (buf, nd, dim);