X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=flower%2Flibc-extension.cc;h=31c280abe704b388d51d316d38e8cd69582136bc;hb=87eedcd59f4082cb0841528ad5bc82cb1d1191e3;hp=3fa6e9b2d8e29f01dd3868d8f3c1dbcdce3d1cc4;hpb=bdf4ab13203502e7ec7cf9cf5896527643a07c1f;p=lilypond.git diff --git a/flower/libc-extension.cc b/flower/libc-extension.cc index 3fa6e9b2d8..31c280abe7 100644 --- a/flower/libc-extension.cc +++ b/flower/libc-extension.cc @@ -3,7 +3,7 @@ source file of the flowerlib - (c) 1997--2005 Han-Wen Nienhuys + (c) 1997--2007 Han-Wen Nienhuys Jan Nieuwenhuizen */ @@ -11,6 +11,9 @@ #include #include #include +#include + +using namespace std; #include "libc-extension.hh" @@ -36,25 +39,6 @@ strnupr (char *start, int n) return start; } -/* - There are some strange problems with round() on early glibcs. -*/ -double -my_round (double x) -{ - return floor (x -0.5)+ 1.0; -} - -#ifndef isinf -#if !HAVE_ISINF -int -isinf (double x) -{ - return x && (x == x/ 2); -} -#endif -#endif - #if !HAVE_MEMMEM /** locate a substring. #memmem# finds the first occurrence of @@ -121,7 +105,7 @@ my_swap (T &t1, T &t2, T &tmp) } unsigned char * -strrev (unsigned char *byte, int length) +memrev (unsigned char *byte, int length) { unsigned char tmp_byte; unsigned char *left = byte; @@ -132,13 +116,36 @@ strrev (unsigned char *byte, int length) return byte; } +/* + There are some strange problems with round() on early glibcs. +*/ +double +my_round (double x) +{ + return floor (x -0.5)+ 1.0; +} + +/* namespace std { */ + +#ifndef isinf +#if !HAVE_ISINF +int +isinf (double x) +{ + return x && (x == x/ 2); +} +#endif +#endif + #if ! HAVE_SNPRINTF int -snprintf (char *str, size_t, char const *format, ...) +snprintf (char *str, size_t n, char const *format, ...) { va_list ap; va_start (ap, format); int i = vsprintf (str, format, ap); + if (i > 0 && (unsigned) i > n) + assert (false); va_end (ap); return i; } @@ -146,98 +153,13 @@ snprintf (char *str, size_t, char const *format, ...) #if ! HAVE_VSNPRINTF int -vsnprintf (char *str, size_t, char const *format, va_list args) +vsnprintf (char *str, size_t n, char const *format, va_list args) { int i = vsprintf (str, format, args); + if (i > 0 && (unsigned) i > n) + assert (false); return i; } #endif -#include - -extern "C" { - -#if ! HAVE_FOPENCOOKIE -#if HAVE_FUNOPEN - - FILE * - fopencookie (void *cookie, char const *mode, cookie_io_functions_t fun) - { - (void) mode; -#if 0 - return funopen (cookie, fun.read, fun.write, fun.seek, fun.close); -#else - return funopen (cookie, - (int (*) (void *, char *, int)) fun.read, - (int (*) (void *, char const *, int)) fun.write, - (fpos_t (*) (void *, fpos_t, int)) fun.seek, - (int (*) (void *)) fun.close); - -#endif - } - -#else /* ! HAVE_FUNOPEN */ - -#include -#include "memory-stream.hh" - - static bool - is_memory_stream (void *foo) - { - Memory_out_stream *cookie = (Memory_out_stream *) foo; - return dynamic_cast (cookie); - } - - FILE * - fopencookie (void *cookie, char const *modes, cookie_io_functions_t io_funcs) - { - (void) cookie; - (void) modes; - (void) io_funcs; - if (is_memory_stream (cookie)) - return (FILE *) cookie; - assert (false); - return 0; - } - - int - handle_cookie_io_fclose (FILE *file) - { - if (is_memory_stream (file)) - return Memory_out_stream::cleaner (file); - return fclose (file); - } - - int - handle_cookie_io_fprintf (FILE *file, char const *format, ...) - { - va_list ap; - va_start (ap, format); - if (is_memory_stream (file)) - { - static char buf[1024]; - int i = vsnprintf (buf, sizeof (buf), format, ap); - if (i == -1) - assert (false); - return Memory_out_stream::writer (file, buf, i); - } - int i = vfprintf (file, format, ap); - va_end (ap); - return i; - } - - int - handle_cookie_io_putc (int c, FILE *file) - { - if (is_memory_stream (file)) - { - char buf[1]; - buf[0] = (char) c; - return Memory_out_stream::writer (file, buf, 1); - } - return putc (c, file); - } - -#endif /* ! HAVE_FUNOPEN */ -#endif /* ! HAVE_FOPENCOOKIE */ -} /* extern C */ +/* } namespace std */