mirror of
https://github.com/ddnet/ddnet.git
synced 2024-11-14 03:58:18 +00:00
Merge #4118
4118: Add colors for console windows r=def- a=BloodWod-513 <!-- What is the motivation for the changes of this pull request --> ![image](https://user-images.githubusercontent.com/33897884/130944303-8640ef77-4ff5-4ef0-853e-74bbc3955210.png) ## Checklist - [x] Tested the change ingame - [x] Provided screenshots if it is a visual change - [ ] Tested in combination with possibly related configuration options - [ ] Written a unit test if it works standalone, system.c especially - [ ] Considered possible null pointers and out of bounds array indexing - [x] Changed no physics that affect existing maps - [ ] Tested the change with [ASan+UBSan or valgrind's memcheck](https://github.com/ddnet/ddnet/#using-addresssanitizer--undefinedbehavioursanitizer-or-valgrinds-memcheck) (optional) Co-authored-by: BloodWod <dayn_2013@mail.ru>
This commit is contained in:
commit
b3e3e59d14
|
@ -2,8 +2,8 @@
|
||||||
#ifndef BASE_COLOR_H
|
#ifndef BASE_COLOR_H
|
||||||
#define BASE_COLOR_H
|
#define BASE_COLOR_H
|
||||||
|
|
||||||
#include "math.h"
|
#include <base/math.h>
|
||||||
#include "vmath.h"
|
#include <base/vmath.h>
|
||||||
|
|
||||||
/*
|
/*
|
||||||
Title: Color handling
|
Title: Color handling
|
||||||
|
|
|
@ -9,7 +9,9 @@
|
||||||
#include <time.h>
|
#include <time.h>
|
||||||
|
|
||||||
#include "system.h"
|
#include "system.h"
|
||||||
|
#if !defined(CONF_PLATFORM_MACOS)
|
||||||
|
#include <base/color.h>
|
||||||
|
#endif
|
||||||
#include <sys/stat.h>
|
#include <sys/stat.h>
|
||||||
#include <sys/types.h>
|
#include <sys/types.h>
|
||||||
|
|
||||||
|
@ -93,8 +95,13 @@ typedef struct
|
||||||
} DBG_LOGGER_DATA;
|
} DBG_LOGGER_DATA;
|
||||||
|
|
||||||
static DBG_LOGGER_DATA loggers[16];
|
static DBG_LOGGER_DATA loggers[16];
|
||||||
|
static int has_stdout_logger = 0;
|
||||||
static int num_loggers = 0;
|
static int num_loggers = 0;
|
||||||
|
|
||||||
|
#ifndef CONF_FAMILY_WINDOWS
|
||||||
|
static DBG_LOGGER_DATA stdout_nonewline_logger;
|
||||||
|
#endif
|
||||||
|
|
||||||
static NETSTATS network_stats = {0};
|
static NETSTATS network_stats = {0};
|
||||||
|
|
||||||
static NETSOCKET invalid_socket = {NETTYPE_INVALID, -1, -1};
|
static NETSOCKET invalid_socket = {NETTYPE_INVALID, -1, -1};
|
||||||
|
@ -169,6 +176,14 @@ static void logger_file(const char *line, void *user)
|
||||||
aio_unlock(logfile);
|
aio_unlock(logfile);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void logger_file_no_newline(const char *line, void *user)
|
||||||
|
{
|
||||||
|
ASYNCIO *logfile = (ASYNCIO *)user;
|
||||||
|
aio_lock(logfile);
|
||||||
|
aio_write_unlocked(logfile, line, str_length(line));
|
||||||
|
aio_unlock(logfile);
|
||||||
|
}
|
||||||
|
|
||||||
#if defined(CONF_FAMILY_WINDOWS)
|
#if defined(CONF_FAMILY_WINDOWS)
|
||||||
static void logger_stdout_sync(const char *line, void *user)
|
static void logger_stdout_sync(const char *line, void *user)
|
||||||
{
|
{
|
||||||
|
@ -252,8 +267,13 @@ void dbg_logger_stdout()
|
||||||
#if defined(CONF_FAMILY_WINDOWS)
|
#if defined(CONF_FAMILY_WINDOWS)
|
||||||
dbg_logger(logger_stdout_sync, 0, 0);
|
dbg_logger(logger_stdout_sync, 0, 0);
|
||||||
#else
|
#else
|
||||||
dbg_logger(logger_file, logger_stdout_finish, aio_new(io_stdout()));
|
ASYNCIO *logger_obj = aio_new(io_stdout());
|
||||||
|
dbg_logger(logger_file, logger_stdout_finish, logger_obj);
|
||||||
|
dbg_logger(logger_file_no_newline, 0, logger_obj);
|
||||||
|
stdout_nonewline_logger = loggers[num_loggers - 1];
|
||||||
|
--num_loggers;
|
||||||
#endif
|
#endif
|
||||||
|
has_stdout_logger = 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
void dbg_logger_debugger()
|
void dbg_logger_debugger()
|
||||||
|
@ -3602,4 +3622,70 @@ int secure_rand_below(int below)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#if defined(CONF_FAMILY_WINDOWS)
|
||||||
|
static int color_hsv_to_windows_console_color(const ColorHSVA *hsv)
|
||||||
|
{
|
||||||
|
int h = hsv->h * 255.0f;
|
||||||
|
int s = hsv->s * 255.0f;
|
||||||
|
int v = hsv->v * 255.0f;
|
||||||
|
if(s >= 0 && s <= 10)
|
||||||
|
{
|
||||||
|
if(v <= 150)
|
||||||
|
return 8;
|
||||||
|
return 15;
|
||||||
|
}
|
||||||
|
else if(h >= 0 && h < 15)
|
||||||
|
return 12;
|
||||||
|
else if(h >= 15 && h < 30)
|
||||||
|
return 6;
|
||||||
|
else if(h >= 30 && h < 60)
|
||||||
|
return 14;
|
||||||
|
else if(h >= 60 && h < 110)
|
||||||
|
return 10;
|
||||||
|
else if(h >= 110 && h < 140)
|
||||||
|
return 11;
|
||||||
|
else if(h >= 140 && h < 170)
|
||||||
|
return 9;
|
||||||
|
else if(h >= 170 && h < 195)
|
||||||
|
return 5;
|
||||||
|
else if(h >= 195 && h < 240)
|
||||||
|
return 13;
|
||||||
|
else if(h >= 240)
|
||||||
|
return 12;
|
||||||
|
else
|
||||||
|
return 15;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
void set_console_msg_color(const void *rgbvoid)
|
||||||
|
{
|
||||||
|
#if defined(CONF_FAMILY_WINDOWS)
|
||||||
|
const ColorRGBA *rgb = (const ColorRGBA *)rgbvoid;
|
||||||
|
int color = 15;
|
||||||
|
if(rgb)
|
||||||
|
{
|
||||||
|
ColorHSVA hsv = color_cast<ColorHSVA>(*rgb);
|
||||||
|
color = color_hsv_to_windows_console_color(&hsv);
|
||||||
|
}
|
||||||
|
HANDLE console = GetStdHandle(STD_OUTPUT_HANDLE);
|
||||||
|
SetConsoleTextAttribute(console, color);
|
||||||
|
#elif CONF_PLATFORM_LINUX
|
||||||
|
const ColorRGBA *rgb = (const ColorRGBA *)rgbvoid;
|
||||||
|
// set true color terminal escape codes refering
|
||||||
|
// https://en.wikipedia.org/wiki/ANSI_escape_code#24-bit
|
||||||
|
int esc_seq = 0x1B;
|
||||||
|
char buff[32];
|
||||||
|
if(rgb == NULL)
|
||||||
|
// reset foreground color
|
||||||
|
str_format(buff, sizeof(buff), "%c[39m", esc_seq);
|
||||||
|
else
|
||||||
|
// set rgb foreground color
|
||||||
|
// if not used by a true color terminal it is still converted refering
|
||||||
|
// https://wiki.archlinux.org/title/Color_output_in_console#True_color_support
|
||||||
|
str_format(buff, sizeof(buff), "%c[38;2;%d;%d;%dm", esc_seq, (int)uint8_t(rgb->r * 255.0f), (int)uint8_t(rgb->g * 255.0f), (int)uint8_t(rgb->b * 255.0f));
|
||||||
|
if(has_stdout_logger)
|
||||||
|
stdout_nonewline_logger.logger(buff, stdout_nonewline_logger.user);
|
||||||
|
#endif
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -2194,6 +2194,14 @@ int secure_rand();
|
||||||
*/
|
*/
|
||||||
int secure_rand_below(int below);
|
int secure_rand_below(int below);
|
||||||
|
|
||||||
|
/*
|
||||||
|
Function: set_console_msg_color
|
||||||
|
Sets the console color.
|
||||||
|
Parameters:
|
||||||
|
rgb - If NULL it will reset the console color to default, else it will transform the rgb color to a console color
|
||||||
|
*/
|
||||||
|
void set_console_msg_color(const void *rgbvoid);
|
||||||
|
|
||||||
#if defined(__cplusplus)
|
#if defined(__cplusplus)
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -315,7 +315,9 @@ char *CConsole::Format(char *pBuf, int Size, const char *pFrom, const char *pStr
|
||||||
|
|
||||||
void CConsole::Print(int Level, const char *pFrom, const char *pStr, ColorRGBA PrintColor)
|
void CConsole::Print(int Level, const char *pFrom, const char *pStr, ColorRGBA PrintColor)
|
||||||
{
|
{
|
||||||
|
set_console_msg_color(&PrintColor);
|
||||||
dbg_msg(pFrom, "%s", pStr);
|
dbg_msg(pFrom, "%s", pStr);
|
||||||
|
set_console_msg_color(NULL);
|
||||||
char aBuf[1024];
|
char aBuf[1024];
|
||||||
Format(aBuf, sizeof(aBuf), pFrom, pStr);
|
Format(aBuf, sizeof(aBuf), pFrom, pStr);
|
||||||
for(int i = 0; i < m_NumPrintCB; ++i)
|
for(int i = 0; i < m_NumPrintCB; ++i)
|
||||||
|
|
Loading…
Reference in a new issue