.
[kopensolaris-gnu/glibc.git] / assert / assert.c
index df38245..0ef4ca6 100644 (file)
@@ -1,4 +1,5 @@
-/* Copyright (C) 1991,1994,1995,1996,1998,2001 Free Software Foundation, Inc.
+/* Copyright (C) 1991,1994-1996,1998,2001,2002,2005
+   Free Software Foundation, Inc.
    This file is part of the GNU C Library.
 
    The GNU C Library is free software; you can redistribute it and/or
@@ -21,6 +22,7 @@
 #include <stdio.h>
 #include <stdlib.h>
 #include <sysdep.h>
+#include <unistd.h>
 
 
 extern const char *__progname;
@@ -28,7 +30,7 @@ extern const char *__progname;
 #ifdef USE_IN_LIBIO
 # include <wchar.h>
 # include <libio/iolibio.h>
-# define fflush(s) _IO_fflush (s)
+# define fflush(s) INTUSE(_IO_fflush) (s)
 #endif
 
 /* This function, when passed a string containing an asserted
@@ -41,6 +43,7 @@ extern const char *__progname;
 # include FATAL_PREPARE_INCLUDE
 #endif
 
+#undef __assert_fail
 void
 __assert_fail (const char *assertion, const char *file, unsigned int line,
               const char *function)
@@ -51,25 +54,27 @@ __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.  */
-#ifdef USE_IN_LIBIO
-  if (_IO_fwide (stderr, 0) > 0)
-    (void) __fwprintf (stderr, L"%s", buf);
+  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.  */
+      (void) __fxprintf (NULL, "%s", buf);
+      (void) fflush (stderr);
+
+      /* We have to free the buffer since the application might catch the
+        SIGABRT.  */
+      free (buf);
+    }
   else
-#endif
-    (void) fputs (buf, stderr);
-
-  (void) fflush (stderr);
-
-  /* We have to free the buffer since the appplication might catch the
-     SIGABRT.  */
-  free (buf);
+    {
+      /* At least print a minimal message.  */
+      static const char errstr[] = "Unexpected error.\n";
+      __libc_write (STDERR_FILENO, errstr, sizeof (errstr) - 1);
+    }
 
   abort ();
 }
+hidden_def(__assert_fail)