2012-06-26 02:32:43 +04:00
|
|
|
/* $NetBSD: assert.c,v 1.17 2012/06/25 22:32:43 abs Exp $ */
|
1995-02-25 11:50:56 +03:00
|
|
|
|
1994-05-17 04:07:23 +04:00
|
|
|
/*-
|
|
|
|
* Copyright (c) 1992, 1993
|
|
|
|
* The Regents of the University of California. All rights reserved.
|
1993-06-17 03:18:35 +04:00
|
|
|
*
|
|
|
|
* Redistribution and use in source and binary forms, with or without
|
|
|
|
* modification, are permitted provided that the following conditions
|
|
|
|
* are met:
|
|
|
|
* 1. Redistributions of source code must retain the above copyright
|
|
|
|
* notice, this list of conditions and the following disclaimer.
|
|
|
|
* 2. Redistributions in binary form must reproduce the above copyright
|
|
|
|
* notice, this list of conditions and the following disclaimer in the
|
|
|
|
* documentation and/or other materials provided with the distribution.
|
2003-08-07 20:42:00 +04:00
|
|
|
* 3. Neither the name of the University nor the names of its contributors
|
1994-05-17 04:07:23 +04:00
|
|
|
* may be used to endorse or promote products derived from this software
|
|
|
|
* without specific prior written permission.
|
1993-06-17 03:18:35 +04:00
|
|
|
*
|
1994-05-17 04:07:23 +04:00
|
|
|
* THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
|
|
|
|
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
|
|
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
|
|
* ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
|
|
|
|
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
|
|
|
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
|
|
|
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
|
|
|
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
|
|
|
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
|
|
|
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
|
|
|
* SUCH DAMAGE.
|
1993-06-17 03:18:35 +04:00
|
|
|
*/
|
|
|
|
|
1997-07-13 23:45:36 +04:00
|
|
|
#include <sys/cdefs.h>
|
1993-07-30 12:21:41 +04:00
|
|
|
#if defined(LIBC_SCCS) && !defined(lint)
|
1995-02-25 11:50:56 +03:00
|
|
|
#if 0
|
|
|
|
static char sccsid[] = "@(#)assert.c 8.1 (Berkeley) 6/4/93";
|
|
|
|
#else
|
2012-06-26 02:32:43 +04:00
|
|
|
__RCSID("$NetBSD: assert.c,v 1.17 2012/06/25 22:32:43 abs Exp $");
|
1995-02-25 11:50:56 +03:00
|
|
|
#endif
|
1993-07-30 12:21:41 +04:00
|
|
|
#endif /* LIBC_SCCS and not lint */
|
|
|
|
|
A little libc namespace housekeeping exercise:
* Make vfprintf_unlocked() an internal function, c.f. __svfscanf_unlocked().
* Add internal names for arc4random(), endnetpath(), fhstatvfs(),
fstatvfs(), mkstemp(), shquote(), statvfs(), taddr2uaddr(), uaddr2taddr(),
uuid_create_nil(), uuid_is_nil(), and wcwidth().
* Include namespace.h where supposed to.
2005-02-10 00:35:46 +03:00
|
|
|
#include "namespace.h"
|
1994-05-17 04:07:23 +04:00
|
|
|
#include <sys/types.h>
|
1999-09-16 03:57:21 +04:00
|
|
|
|
1994-05-17 04:07:23 +04:00
|
|
|
#include <assert.h>
|
1993-06-17 03:18:35 +04:00
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdlib.h>
|
1999-09-16 03:57:21 +04:00
|
|
|
#include <syslog.h>
|
1993-06-17 03:18:35 +04:00
|
|
|
|
2000-12-19 17:32:59 +03:00
|
|
|
void
|
2012-06-26 02:32:43 +04:00
|
|
|
__assert13(const char *file, int line, const char *function,
|
|
|
|
const char *failedexpr)
|
2000-12-19 17:32:59 +03:00
|
|
|
{
|
2001-01-03 15:44:53 +03:00
|
|
|
|
2000-12-19 17:32:59 +03:00
|
|
|
(void)fprintf(stderr,
|
|
|
|
"assertion \"%s\" failed: file \"%s\", line %d%s%s%s\n",
|
|
|
|
failedexpr, file, line,
|
|
|
|
function ? ", function \"" : "",
|
|
|
|
function ? function : "",
|
|
|
|
function ? "\"" : "");
|
|
|
|
abort();
|
|
|
|
/* NOTREACHED */
|
|
|
|
}
|
|
|
|
|
1993-06-17 03:18:35 +04:00
|
|
|
void
|
2012-06-26 02:32:43 +04:00
|
|
|
__assert(const char *file, int line, const char *failedexpr)
|
1993-06-17 03:18:35 +04:00
|
|
|
{
|
2001-01-03 15:44:53 +03:00
|
|
|
|
|
|
|
__assert13(file, line, NULL, failedexpr);
|
1994-05-17 04:07:23 +04:00
|
|
|
/* NOTREACHED */
|
1993-06-17 03:18:35 +04:00
|
|
|
}
|
1999-09-16 03:57:21 +04:00
|
|
|
|
2001-01-03 15:44:53 +03:00
|
|
|
|
|
|
|
enum {
|
|
|
|
DIAGASSERT_ABORT = 1<<0,
|
|
|
|
DIAGASSERT_STDERR = 1<<1,
|
|
|
|
DIAGASSERT_SYSLOG = 1<<2
|
|
|
|
};
|
|
|
|
|
|
|
|
static int diagassert_flags = -1;
|
|
|
|
|
2000-12-19 17:32:59 +03:00
|
|
|
void
|
2012-06-26 02:32:43 +04:00
|
|
|
__diagassert13(const char *file, int line, const char *function,
|
|
|
|
const char *failedexpr)
|
2000-12-19 17:32:59 +03:00
|
|
|
{
|
2001-01-03 15:44:53 +03:00
|
|
|
char buf[1024];
|
|
|
|
|
|
|
|
if (diagassert_flags == -1) {
|
|
|
|
char *p;
|
|
|
|
|
|
|
|
diagassert_flags = DIAGASSERT_SYSLOG;
|
|
|
|
|
|
|
|
for (p = getenv("LIBC_DIAGASSERT"); p && *p; p++) {
|
|
|
|
switch (*p) {
|
|
|
|
case 'a':
|
|
|
|
diagassert_flags |= DIAGASSERT_ABORT;
|
|
|
|
break;
|
|
|
|
case 'A':
|
|
|
|
diagassert_flags &= ~DIAGASSERT_ABORT;
|
|
|
|
break;
|
|
|
|
case 'e':
|
|
|
|
diagassert_flags |= DIAGASSERT_STDERR;
|
|
|
|
break;
|
|
|
|
case 'E':
|
|
|
|
diagassert_flags &= ~DIAGASSERT_STDERR;
|
|
|
|
break;
|
|
|
|
case 'l':
|
|
|
|
diagassert_flags |= DIAGASSERT_SYSLOG;
|
|
|
|
break;
|
|
|
|
case 'L':
|
|
|
|
diagassert_flags &= ~DIAGASSERT_SYSLOG;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
snprintf(buf, sizeof(buf),
|
2000-12-19 17:32:59 +03:00
|
|
|
"assertion \"%s\" failed: file \"%s\", line %d%s%s%s",
|
|
|
|
failedexpr, file, line,
|
|
|
|
function ? ", function \"" : "",
|
|
|
|
function ? function : "",
|
|
|
|
function ? "\"" : "");
|
2001-01-03 15:44:53 +03:00
|
|
|
if (diagassert_flags & DIAGASSERT_STDERR)
|
2001-02-20 01:22:16 +03:00
|
|
|
(void)fprintf(stderr, "%s: %s\n", getprogname(), buf);
|
2001-01-03 15:44:53 +03:00
|
|
|
if (diagassert_flags & DIAGASSERT_SYSLOG)
|
|
|
|
syslog(LOG_DEBUG | LOG_USER, "%s", buf);
|
|
|
|
if (diagassert_flags & DIAGASSERT_ABORT)
|
|
|
|
abort();
|
2000-12-19 17:32:59 +03:00
|
|
|
}
|
|
|
|
|
1999-09-16 03:57:21 +04:00
|
|
|
void
|
2012-06-26 02:32:43 +04:00
|
|
|
__diagassert(const char *file, int line, const char *failedexpr)
|
1999-09-16 03:57:21 +04:00
|
|
|
{
|
2001-01-03 15:44:53 +03:00
|
|
|
|
|
|
|
__diagassert13(file, line, NULL, failedexpr);
|
1999-09-16 03:57:21 +04:00
|
|
|
}
|