update util: logging and assertions
This commit is contained in:
parent
6416f0fbfe
commit
ec1ce068ed
47
util.c
Normal file
47
util.c
Normal file
@ -0,0 +1,47 @@
|
|||||||
|
|
||||||
|
#include <stdarg.h>
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <string.h>
|
||||||
|
|
||||||
|
#include "util.h"
|
||||||
|
|
||||||
|
static void xvprintf(const char *, va_list);
|
||||||
|
|
||||||
|
void
|
||||||
|
eprintf(const char *fmt, ...)
|
||||||
|
{
|
||||||
|
va_list ap;
|
||||||
|
|
||||||
|
va_start(ap, fmt);
|
||||||
|
xvprintf(fmt, ap);
|
||||||
|
va_end(ap);
|
||||||
|
|
||||||
|
abort();
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
weprintf(const char *fmt, ...)
|
||||||
|
{
|
||||||
|
va_list ap;
|
||||||
|
|
||||||
|
va_start(ap, fmt);
|
||||||
|
xvprintf(fmt, ap);
|
||||||
|
va_end(ap);
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
xvprintf(const char *fmt, va_list ap)
|
||||||
|
{
|
||||||
|
/**TODO: provide other logging target than stderr */
|
||||||
|
fputs("libbrandt: ", stderr);
|
||||||
|
|
||||||
|
vfprintf(stderr, fmt, ap);
|
||||||
|
|
||||||
|
if (fmt[0] && fmt[strlen(fmt)-1] == ':') {
|
||||||
|
fputc(' ', stderr);
|
||||||
|
perror(NULL);
|
||||||
|
} else {
|
||||||
|
fputc('\n', stderr);
|
||||||
|
}
|
||||||
|
}
|
43
util.h
43
util.h
@ -1,25 +1,28 @@
|
|||||||
/* This file is part of libgotr.
|
|
||||||
* (C) 2014-2015 Markus Teich, Jannik Theiß
|
|
||||||
*
|
|
||||||
* libgotr is free software; you can redistribute it and/or modify
|
|
||||||
* it under the terms of the GNU Lesser General Public License as published
|
|
||||||
* by the Free Software Foundation; either version 3, or (at your
|
|
||||||
* option) any later version.
|
|
||||||
*
|
|
||||||
* libgotr 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
|
|
||||||
* Lesser General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU Lesser General Public License
|
|
||||||
* along with libgotr; see the file LICENSE. If not, write to the
|
|
||||||
* Free Software Foundation, Inc., 59 Temple Place - Suite 330,
|
|
||||||
* Boston, MA 02111-1307, USA.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#ifndef _BRANDT_UTIL_H
|
#ifndef _BRANDT_UTIL_H
|
||||||
#define _BRANDT_UTIL_H
|
#define _BRANDT_UTIL_H
|
||||||
|
|
||||||
void brandt_eprintf(const char *format, ...);
|
void eprintf(const char *fmt, ...);
|
||||||
|
void weprintf(const char *fmt, ...);
|
||||||
|
|
||||||
|
# undef brandt_assert
|
||||||
|
# undef brandt_assert_perror
|
||||||
|
# undef brandt_assert_gpgerr
|
||||||
|
|
||||||
|
#ifdef NDEBUG
|
||||||
|
|
||||||
|
# define brandt_assert(expr) ((void)(0))
|
||||||
|
# define brandt_assert_perror(errnum) ((void)(0))
|
||||||
|
# define brandt_assert_gpgerr(errnum) ((void)(0))
|
||||||
|
|
||||||
|
#else
|
||||||
|
|
||||||
|
# define brandt_assert(expr) ((expr) ? (void)(0) : \
|
||||||
|
eprintf("Assertion failed in file %s line %d function %s: %s", __FILE__, __LINE__, __PRETTY_FUNCTION__, (#expr)))
|
||||||
|
# define brandt_assert_perror(errnum) (!(errnum) ? (void)(0) : \
|
||||||
|
eprintf("Assertion failed in file %s line %d function %s:", __FILE__, __LINE__, __PRETTY_FUNCTION__))
|
||||||
|
# define brandt_assert_gpgerr(errnum) (!(errnum) ? (void)(0) : \
|
||||||
|
eprintf("Assertion failed in file %s line %d function %s: %s", __FILE__, __LINE__, __PRETTY_FUNCTION__, gcry_strerror((errnum))))
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
Loading…
Reference in New Issue
Block a user