Skip to content

Commit

Permalink
Use _snprintf for snprinf in Microsoft C.
Browse files Browse the repository at this point in the history
More than a decade later, Microsoft C does not support the C99
standard.  It's good that _snprintf has a different name, since it
does not guarantee that the result is null terminated, as does
snprintf.  However where _snprintf is used under Microsoft C, the
destination string is assured to be long enough, so this will not
be a problem.  This occurs in two places, both in gzlib.c.  Where
sprintf functionality is needed by gzprintf, vsnprintf is used in
the case of Microsoft C.
  • Loading branch information
madler committed Jun 3, 2012
1 parent ee026ac commit 25e4a3d
Showing 1 changed file with 8 additions and 0 deletions.
8 changes: 8 additions & 0 deletions gzguts.h
Original file line number Diff line number Diff line change
Expand Up @@ -88,6 +88,14 @@
# endif
#endif

/* unlike snprintf (which is required in C99, yet still not supported by
Microsoft more than a decade later!), _snprintf does not guarantee null
termination of the result -- however this is only used in gzlib.c where
the result is assured to fit in the space provided */
#ifdef _MSC_VER
# define snprintf _snprintf
#endif

#ifndef local
# define local static
#endif
Expand Down

0 comments on commit 25e4a3d

Please sign in to comment.