1 /* Copyright (C) 2002 Manuel Novoa III
2 * An __assert() function compatible with the modified glibc assert.h
3 * that is used by uClibc.
5 * This library is free software; you can redistribute it and/or
6 * modify it under the terms of the GNU Library General Public
7 * License as published by the Free Software Foundation; either
8 * version 2 of the License, or (at your option) any later version.
10 * This library is distributed in the hope that it will be useful,
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13 * Library General Public License for more details.
15 * You should have received a copy of the GNU Library General Public
16 * License along with this library; if not, see
17 * <http://www.gnu.org/licenses/>.
22 * ANSI/ISO C99 requires assert() to write to stderr. This means that
23 * writing to STDERR_FILENO is insufficient, as the user could freopen
24 * stderr. It is also insufficient to output to fileno(stderr) since
25 * this would fail in the custom stream case. I didn't remove the
26 * old code though, as it doesn't use stdio stream functionality
27 * and is useful in debugging the stdio code.
34 /* Get the prototype from assert.h as a double-check. */
40 #define ASSERT_SHOW_PROGNAME 1
42 static smallint in_assert; /* bss inits to 0. */
44 void __assert(const char *assertion, const char * filename,
45 unsigned int linenumber, register const char * function)
51 #ifdef ASSERT_SHOW_PROGNAME
52 "%s: %s: %d: %s: Assertion `%s' failed.\n", __uclibc_progname,
54 "%s: %d: %s: Assertion `%s' failed.\n",
58 /* Function name isn't available with some compilers. */
59 ((function == NULL) ? "?function?" : function),
63 /* shouldn't we? fflush(stderr); */
66 libc_hidden_def(__assert)