2014-12-15 16:47:30 +01:00
|
|
|
/*
|
|
|
|
* =====================================================================================
|
|
|
|
*
|
|
|
|
* Filename: Debug.hpp
|
|
|
|
*
|
2018-06-05 01:24:54 +02:00
|
|
|
* Description:
|
2014-12-15 16:47:30 +01:00
|
|
|
*
|
|
|
|
* Created: 14/12/2014 05:02:30
|
|
|
|
*
|
2018-06-14 03:19:35 +02:00
|
|
|
* Author: Quentin Bazin, <quent42340@gmail.com>
|
2014-12-15 16:47:30 +01:00
|
|
|
*
|
|
|
|
* =====================================================================================
|
|
|
|
*/
|
|
|
|
#ifndef DEBUG_HPP_
|
|
|
|
#define DEBUG_HPP_
|
|
|
|
|
|
|
|
#include <cstring>
|
|
|
|
#include <iostream>
|
|
|
|
#include <sstream>
|
|
|
|
#include <string>
|
2018-06-21 05:45:17 +02:00
|
|
|
#include <vector>
|
2014-12-15 16:47:30 +01:00
|
|
|
|
|
|
|
#include "Types.hpp"
|
|
|
|
|
|
|
|
#define DEBUG_ENABLED
|
|
|
|
#define DEBUG_COLOR
|
|
|
|
|
|
|
|
#define _FILE (strrchr(__FILE__, '/') ? strrchr(__FILE__, '/') + 1 : strrchr(__FILE__, '\\') ? strrchr(__FILE__, '\\') + 1 : __FILE__)
|
|
|
|
|
|
|
|
#ifdef DEBUG_ENABLED
|
|
|
|
#define DEBUG(args...) { std::cout << Debug::textColor(Debug::TextColor::Red, true) << _FILE << ":" << __LINE__ << ":" << Debug::textColor(); Debug::print(args); }
|
|
|
|
#else
|
|
|
|
#define DEBUG(args...) {}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
namespace Debug {
|
|
|
|
enum TextColor {
|
|
|
|
White = 0,
|
|
|
|
Red = 31,
|
|
|
|
Blue = 36
|
|
|
|
};
|
2018-06-05 01:24:54 +02:00
|
|
|
|
2014-12-15 16:47:30 +01:00
|
|
|
inline std::string textColor(u8 color = TextColor::White, bool bold = false) {
|
|
|
|
#ifdef DEBUG_COLOR
|
|
|
|
return std::string("\33[0;") + ((color < 10) ? "0" : "") + std::to_string(color) + ";0" + ((bold) ? "1" : "0") + "m";
|
|
|
|
#else
|
|
|
|
return std::string("");
|
|
|
|
#endif
|
|
|
|
}
|
2018-06-05 01:24:54 +02:00
|
|
|
|
2018-06-21 05:45:17 +02:00
|
|
|
template<typename... Args>
|
|
|
|
std::string makeString(Args &&...args) {
|
|
|
|
std::ostringstream stream;
|
|
|
|
std::vector<int> tmp{0, ((void)(stream << args << " "), 0)...};
|
2018-06-05 01:24:54 +02:00
|
|
|
|
2018-06-21 05:45:17 +02:00
|
|
|
return stream.str();
|
2014-12-15 16:47:30 +01:00
|
|
|
}
|
2018-06-05 01:24:54 +02:00
|
|
|
|
2014-12-15 16:47:30 +01:00
|
|
|
template<typename... Args>
|
2018-06-21 05:45:17 +02:00
|
|
|
void print(Args &&...args) {
|
|
|
|
std::cerr << makeString(std::forward<Args>(args)...) << std::endl;
|
2014-12-15 16:47:30 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif // DEBUG_HPP_
|