2018-02-16 18:11:26 +01:00
|
|
|
/*
|
|
|
|
* BreakHack - A dungeone crawler RPG
|
|
|
|
* Copyright (C) 2018 Linus Probert <linus.probert@gmail.com>
|
|
|
|
*
|
|
|
|
* This program 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 3 of the License, or
|
|
|
|
* (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This program 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 this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
*/
|
|
|
|
|
2017-11-30 21:00:47 +01:00
|
|
|
#ifndef UTIL_H_
|
|
|
|
#define UTIL_H_
|
|
|
|
|
2018-04-21 22:56:48 +02:00
|
|
|
#include <stdio.h>
|
2018-03-20 07:33:02 +01:00
|
|
|
#include <stdlib.h>
|
2018-03-07 16:02:56 +01:00
|
|
|
#include <stdarg.h>
|
|
|
|
|
2018-04-21 22:56:48 +02:00
|
|
|
#ifndef __FNAME__
|
|
|
|
#define __FNAME__ __FILE__
|
|
|
|
#endif // __FNAME__
|
2018-01-23 22:54:02 +01:00
|
|
|
|
2018-04-21 22:56:48 +02:00
|
|
|
#ifdef DEBUG
|
|
|
|
#define debug(...) log_print(stdout, "DEBUG", __FNAME__, __LINE__, __func__, __VA_ARGS__)
|
|
|
|
#define info(...) log_print(stdout, "INFO", __FNAME__, __LINE__, __func__, __VA_ARGS__)
|
|
|
|
#else // DEBUG
|
|
|
|
#define debug(...) do {} while(0)
|
|
|
|
#define info(...) do {} while(0)
|
|
|
|
#endif // DEBUG
|
2018-08-15 07:19:44 +02:00
|
|
|
|
2018-08-16 14:09:54 +02:00
|
|
|
#define error(...) log_print(stderr, "ERROR", __FNAME__, __LINE__, __func__, __VA_ARGS__)
|
2018-08-15 07:19:44 +02:00
|
|
|
#ifdef DEBUG
|
|
|
|
#define fatal(...) \
|
|
|
|
{ \
|
|
|
|
log_print(stderr, "FATAL", __FNAME__, __LINE__, __func__, __VA_ARGS__); \
|
|
|
|
printf("\n- Press any key to close -\n"); \
|
|
|
|
getchar(); \
|
|
|
|
exit(-1); \
|
|
|
|
}
|
2018-08-16 14:09:54 +02:00
|
|
|
#else // DEBUG
|
2018-04-21 22:56:48 +02:00
|
|
|
#define fatal(...) \
|
|
|
|
{ \
|
|
|
|
log_print(stderr, "FATAL", __FNAME__, __LINE__, __func__, __VA_ARGS__); \
|
|
|
|
exit(-1); \
|
|
|
|
}
|
2018-08-15 07:19:44 +02:00
|
|
|
#endif // DEBUG
|
2018-01-23 22:54:02 +01:00
|
|
|
|
|
|
|
void
|
2018-04-21 22:56:48 +02:00
|
|
|
log_print(FILE *out,
|
|
|
|
const char *prefix,
|
|
|
|
const char *file,
|
|
|
|
int line,
|
|
|
|
const char *func,
|
|
|
|
const char *fmt,
|
|
|
|
...);
|
2017-11-30 21:00:47 +01:00
|
|
|
|
2018-01-23 21:03:43 +01:00
|
|
|
void *
|
2018-02-22 09:44:27 +01:00
|
|
|
ec_malloc(unsigned long size);
|
2017-11-30 21:00:47 +01:00
|
|
|
|
2018-08-08 00:14:24 +02:00
|
|
|
void *
|
|
|
|
ec_calloc(size_t count, unsigned long size);
|
|
|
|
|
2018-01-23 21:03:43 +01:00
|
|
|
void
|
2018-02-24 07:13:28 +01:00
|
|
|
m_strcpy(char *dest, size_t destsz, const char *src);
|
2017-12-19 21:00:02 +01:00
|
|
|
|
|
|
|
void
|
2017-12-19 22:51:00 +01:00
|
|
|
m_strncat(char *dest, size_t destsz, char *src, size_t srcsz);
|
2017-12-19 21:00:02 +01:00
|
|
|
|
2018-01-23 21:03:43 +01:00
|
|
|
void
|
|
|
|
m_sprintf(char *dest, size_t destsz, const char *format, ...);
|
|
|
|
|
2018-03-07 16:02:56 +01:00
|
|
|
void
|
|
|
|
m_vsprintf(char *dest, size_t sz, const char *fmt, va_list args);
|
|
|
|
|
2018-01-24 09:35:21 +01:00
|
|
|
void
|
|
|
|
timestamp(char *tstamp, size_t sz);
|
|
|
|
|
2018-01-25 10:45:05 +01:00
|
|
|
char *
|
|
|
|
to_lower(const char *str);
|
|
|
|
|
2017-11-30 21:00:47 +01:00
|
|
|
#endif // UTIL_H_
|