diff options
author | deva <deva> | 2010-08-17 11:14:04 +0000 |
---|---|---|
committer | deva <deva> | 2010-08-17 11:14:04 +0000 |
commit | c788e6a1b174afd154e589a76885731c2fc19723 (patch) | |
tree | 761a87ee3941d671dd41d8b6df7a39bd85c993b1 /client/debug.h | |
parent | 2a9d0cf8c52a832c04729a4c65f07e6cd24eb19e (diff) |
First shot at a debug console.
Diffstat (limited to 'client/debug.h')
-rw-r--r-- | client/debug.h | 62 |
1 files changed, 62 insertions, 0 deletions
diff --git a/client/debug.h b/client/debug.h new file mode 100644 index 0000000..0508b31 --- /dev/null +++ b/client/debug.h @@ -0,0 +1,62 @@ +/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */ +/* vim: set et sw=2 ts=2: */ +/*************************************************************************** + * debug.h + * + * Tue Aug 17 10:48:44 CEST 2010 + * Copyright 2010 Bent Bisballe Nyeng + * deva@aasimon.org + ****************************************************************************/ + +/* + * This file is part of Pracro. + * + * Pracro is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; either version 2 of the License, or + * (at your option) any later version. + * + * Pracro 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 General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with Pracro; if not, write to the Free Software + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA. + */ +#ifndef __PRACRO_DEBUG_H__ + +void dbg_init(); +void dbg_free(); + +void dbg_show(); +void dbg_toggle(); +void dbg_hide(); + +typedef enum { + _debug, + _error, + _warn, + _log +} debug_class; + +void dbg_log(const char *func, const char *file, const int line, + debug_class cl, const char *ch, const char *fmt, ...) + __attribute__((format (printf,6,7))); + +#ifdef USE_DEBUG +#define DEBUG(ch, fmt...) \ + dbg_log(__func__, __FILE__, __LINE__, _debug, #ch, fmt); +#else +#define DEBUG(ch, fmt...) +#endif +#define ERROR(ch, fmt...) \ + dbg_log(__func__, __FILE__,__LINE__, _error, #ch, fmt); +#define WARN(ch, fmt...) \ + dbg_log(__func__, __FILE__,__LINE__, _warn, #ch, fmt); +#define LOG(ch, fmt...) \ + dbg_log(__func__, __FILE__,__LINE__, _log, #ch, fmt); + +#define __PRACRO_DEBUG_H__ +#endif/*__PRACRO_DEBUG_H__*/ |