diff options
author | Jeff Johnston <jjohnstn@redhat.com> | 2007-03-12 20:30:08 +0000 |
---|---|---|
committer | Jeff Johnston <jjohnstn@redhat.com> | 2007-03-12 20:30:08 +0000 |
commit | 99304ce6c4067c1ad11d9c4723580cb09bf1d853 (patch) | |
tree | 036546660dab37a67da4adc69fbe41610e64fdf8 /newlib/libc/stdio/asiprintf.c | |
parent | 9c28809c0f505ea1969523aad89b3a7df045bb7c (diff) | |
download | cygnal-99304ce6c4067c1ad11d9c4723580cb09bf1d853.tar.gz cygnal-99304ce6c4067c1ad11d9c4723580cb09bf1d853.tar.bz2 cygnal-99304ce6c4067c1ad11d9c4723580cb09bf1d853.zip |
2007-03-12 Eric Blake <ebb9@byu.net>
* libc/stdio/fvwrite.c (__sfvwrite_r): Fix reentrancy.
* libc/stdio/vasprintf.c (vasprintf, _vasprintf_r): Pass failed
allocation to caller.
* libc/stdio/asprintf.c (_asprintf_r, asprintf): Likewise.
* libc/stdio/asiprintf.c (_asiprintf_r, asiprintf): Likewise.
* libc/stdio/vasiprintf.c (vasiprintf, _vasiprintf_r): Likewise.
Diffstat (limited to 'newlib/libc/stdio/asiprintf.c')
-rw-r--r-- | newlib/libc/stdio/asiprintf.c | 18 |
1 files changed, 12 insertions, 6 deletions
diff --git a/newlib/libc/stdio/asiprintf.c b/newlib/libc/stdio/asiprintf.c index e8e10bf38..afb1f7c33 100644 --- a/newlib/libc/stdio/asiprintf.c +++ b/newlib/libc/stdio/asiprintf.c @@ -1,5 +1,5 @@ /* - * Copyright (c) 1990 The Regents of the University of California. + * Copyright (c) 1990, 2007 The Regents of the University of California. * All rights reserved. * * Redistribution and use in source and binary forms are permitted @@ -57,8 +57,11 @@ _asiprintf_r(ptr, strp, fmt, va_alist) #endif ret = vfiprintf (&f, fmt, ap); va_end (ap); - *f._p = 0; - *strp = f._bf._base; + if (ret >= 0) + { + *f._p = 0; + *strp = f._bf._base; + } return (ret); } @@ -79,7 +82,7 @@ asiprintf(strp, fmt, va_alist) int ret; va_list ap; FILE f; - + /* mark a zero-length reallocatable buffer */ f._flags = __SWR | __SSTR | __SMBF; f._bf._base = f._p = NULL; @@ -92,8 +95,11 @@ asiprintf(strp, fmt, va_alist) #endif ret = vfiprintf (&f, fmt, ap); va_end (ap); - *f._p = 0; - *strp = f._bf._base; + if (ret >= 0) + { + *f._p = 0; + *strp = f._bf._base; + } return (ret); } |