771eac6015
LOG_ERROR should be used in places where though recoverable (or at least something that can be handled safely), was unexpected, and may affect the user/application. LOG_WARNING should be used in places where it's not entirely unexpected, is recoverable, and doesn't really affect the user/application.
83 lines
2.1 KiB
C
83 lines
2.1 KiB
C
/*
|
|
* Copyright (c) 2013 Hugh Bailey <obs.jim@gmail.com>
|
|
*
|
|
* Permission to use, copy, modify, and distribute this software for any
|
|
* purpose with or without fee is hereby granted, provided that the above
|
|
* copyright notice and this permission notice appear in all copies.
|
|
*
|
|
* THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
|
|
* WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
|
|
* MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
|
|
* ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
|
|
* WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
|
|
* ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
|
|
* OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
|
*/
|
|
|
|
#pragma once
|
|
|
|
#include <stdarg.h>
|
|
|
|
#include "c99defs.h"
|
|
|
|
/*
|
|
* Just contains logging/crash related stuff
|
|
*/
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
enum {
|
|
/**
|
|
* Use if there's a problem that can potentially affect the program,
|
|
* but isn't enough to require termination of the program.
|
|
*
|
|
* Use in creation functions and core subsystem functions. Places that
|
|
* should definitely not fail.
|
|
*/
|
|
LOG_ERROR = 100,
|
|
|
|
/**
|
|
* Use if a problem occurs that doesn't affect the program and is
|
|
* recoverable.
|
|
*
|
|
* Use in places where where failure isn't entirely unexpected, and can
|
|
* be handled safely.
|
|
*/
|
|
LOG_WARNING = 200,
|
|
|
|
/**
|
|
* Informative essage to be displayed in the log.
|
|
*/
|
|
LOG_INFO = 300,
|
|
|
|
/**
|
|
* Debug message to be used mostly by developers.
|
|
*/
|
|
LOG_DEBUG = 400
|
|
};
|
|
|
|
EXPORT void base_set_log_handler(
|
|
void (*handler)(int log_level, const char *, va_list));
|
|
EXPORT void base_set_crash_handler(void (*handler)(const char *, va_list));
|
|
|
|
EXPORT void blogva(int log_level, const char *format, va_list args);
|
|
|
|
#ifndef _MSC_VER
|
|
#define PRINTFATTR(f, a) __attribute__((__format__(__printf__, f, a)))
|
|
#else
|
|
#define PRINTFATTR(f, a)
|
|
#endif
|
|
|
|
PRINTFATTR(2, 3)
|
|
EXPORT void blog(int log_level, const char *format, ...);
|
|
PRINTFATTR(1, 2)
|
|
EXPORT void bcrash(const char *format, ...);
|
|
|
|
#undef PRINTFATTR
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|