- Add LOGE() macro with colored output - use LOGE for all errors (adjust all files) - main.cpp: fix log spam in PAUSED state - log formatting optimizations - fix food tries count - add log output when switching from and too PAUSED
70 lines
1.9 KiB
C
70 lines
1.9 KiB
C
#pragma once
|
|
|
|
#include <stdio.h>
|
|
#include <stdarg.h>
|
|
#include <stdint.h>
|
|
#include "config.h"
|
|
|
|
//===========================
|
|
//========= LOGGING =========
|
|
//===========================
|
|
//conditional logging when DEBUG_OUTPUT_ENABLED is defined in config.h
|
|
//example: LOGD("game: %d", count)
|
|
#ifdef DEBUG_OUTPUT_ENABLED
|
|
#define LOGD(format, ...) printf("[D] " format, ##__VA_ARGS__)
|
|
#else
|
|
#define LOGD(format, ...) do {} while (0)
|
|
#endif
|
|
|
|
//conditional logging when INFO_OUTPUT_ENABLED is defined in config.h
|
|
//example: LOGI("game: %d", count)
|
|
#ifdef INFO_OUTPUT_ENABLED
|
|
#define LOGI(format, ...) printf("[I] " format, ##__VA_ARGS__)
|
|
#else
|
|
#define LOGI(format, ...) do {} while (0)
|
|
#endif
|
|
|
|
//conditional logging when ERROR_OUTPUT_ENABLED is defined in config.h
|
|
//also prints in text in red color
|
|
//example: LOGE("game: %d", count)
|
|
#ifdef ERROR_OUTPUT_ENABLED
|
|
#ifdef _WIN32
|
|
#include <windows.h>
|
|
#define RED_TEXT SetConsoleTextAttribute(GetStdHandle(STD_OUTPUT_HANDLE), FOREGROUND_RED)
|
|
#define RESET_TEXT SetConsoleTextAttribute(GetStdHandle(STD_OUTPUT_HANDLE), FOREGROUND_RED | FOREGROUND_GREEN | FOREGROUND_BLUE)
|
|
#else
|
|
#define RED_TEXT "\033[1;31m"
|
|
#define RESET_TEXT "\033[0m"
|
|
#endif
|
|
#define LOGE(format, ...) printf("[E] " RED_TEXT format RESET_TEXT, ##__VA_ARGS__)
|
|
#else
|
|
#define LOGE(format, ...) do {} while (0)
|
|
#endif
|
|
|
|
|
|
//===========================
|
|
//========== DELAY ==========
|
|
//===========================
|
|
//macro for DELAY(ms) function that works on Windows and Linux
|
|
#ifdef _WIN32
|
|
#include <windows.h>
|
|
#else
|
|
#include <unistd.h>
|
|
#endif
|
|
|
|
#ifdef _WIN32
|
|
#include <windows.h>
|
|
#define DELAY(ms) Sleep(ms)
|
|
#else
|
|
#include <unistd.h>
|
|
#define DELAY(ms) usleep((ms) * 1000)
|
|
#endif
|
|
|
|
|
|
//===========================
|
|
//======= GET_TIME_MS =======
|
|
//===========================
|
|
// macro to get time in milliseconds
|
|
#define GET_TIME_MS() get_current_time()
|
|
// defined in common.c due to differences with windows and other systems
|
|
int64_t get_current_time(); |