/* Copyright (C) 2002 Manuel Novoa III * An __assert() function compatible with the modified glibc assert.h * that is used by uClibc. * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Library General Public * License as published by the Free Software Foundation; either * version 2 of the License, or (at your option) any later version. * * This library is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * Library General Public License for more details. * * You should have received a copy of the GNU Library General Public * License along with this library; if not, see * . */ /* Oct 28, 2002 * * ANSI/ISO C99 requires assert() to write to stderr. This means that * writing to STDERR_FILENO is insufficient, as the user could freopen * stderr. It is also insufficient to output to fileno(stderr) since * this would fail in the custom stream case. I didn't remove the * old code though, as it doesn't use stdio stream functionality * and is useful in debugging the stdio code. */ #include #include #include /* Get the prototype from assert.h as a double-check. */ #undef NDEBUG #include #undef assert #define ASSERT_SHOW_PROGNAME 1 static smallint in_assert; /* bss inits to 0. */ void __assert(const char *assertion, const char * filename, unsigned int linenumber, register const char * function) { if (!in_assert) { in_assert = 1; fprintf(stderr, #ifdef ASSERT_SHOW_PROGNAME "%s: %s: %d: %s: Assertion `%s' failed.\n", __uclibc_progname, #else "%s: %d: %s: Assertion `%s' failed.\n", #endif filename, linenumber, /* Function name isn't available with some compilers. */ ((function == NULL) ? "?function?" : function), assertion ); } /* shouldn't we? fflush(stderr); */ abort(); } libc_hidden_def(__assert)