aboutsummaryrefslogtreecommitdiff
path: root/assert/assert.c
diff options
context:
space:
mode:
Diffstat (limited to 'assert/assert.c')
-rw-r--r--assert/assert.c36
1 files changed, 21 insertions, 15 deletions
diff --git a/assert/assert.c b/assert/assert.c
index df38245..6a9c4de 100644
--- a/assert/assert.c
+++ b/assert/assert.c
@@ -21,6 +21,7 @@
#include <stdio.h>
#include <stdlib.h>
#include <sysdep.h>
+#include <unistd.h>
extern const char *__progname;
@@ -51,25 +52,30 @@ __assert_fail (const char *assertion, const char *file, unsigned int line,
FATAL_PREPARE;
#endif
- (void) __asprintf (&buf, _("%s%s%s:%u: %s%sAssertion `%s' failed.\n"),
- __progname, __progname[0] ? ": " : "",
- file, line,
- function ? function : "", function ? ": " : "",
- assertion);
-
- /* Print the message. */
+ if (__asprintf (&buf, _("%s%s%s:%u: %s%sAssertion `%s' failed.\n"),
+ __progname, __progname[0] ? ": " : "",
+ file, line,
+ function ? function : "", function ? ": " : "",
+ assertion) >= 0)
+ {
+ /* Print the message. */
#ifdef USE_IN_LIBIO
- if (_IO_fwide (stderr, 0) > 0)
- (void) __fwprintf (stderr, L"%s", buf);
- else
+ if (_IO_fwide (stderr, 0) > 0)
+ (void) __fwprintf (stderr, L"%s", buf);
+ else
#endif
- (void) fputs (buf, stderr);
+ (void) fputs (buf, stderr);
- (void) fflush (stderr);
+ (void) fflush (stderr);
- /* We have to free the buffer since the appplication might catch the
- SIGABRT. */
- free (buf);
+ /* We have to free the buffer since the appplication might catch the
+ SIGABRT. */
+ free (buf);
+ }
+ else
+ /* At least print a minimal message. */
+#define STR_N_LEN(str) str, sizeof (str) - 1
+ __libc_write (STDERR_FILENO, STR_N_LEN ("Unexpected error.\n"));
abort ();
}