Refactor color functions

This commit is contained in:
Maxime Coste 2014-12-27 12:09:28 +00:00
parent 248c1bda02
commit 71bfe5498d

View File

@ -1,5 +1,6 @@
#include "color.hh" #include "color.hh"
#include "containers.hh"
#include "exception.hh" #include "exception.hh"
#include "regex.hh" #include "regex.hh"
@ -8,30 +9,28 @@
namespace Kakoune namespace Kakoune
{ {
static constexpr const char* color_names[] = {
"default",
"black",
"red",
"green",
"yellow",
"blue",
"magenta",
"cyan",
"white",
};
bool is_color_name(StringView color) bool is_color_name(StringView color)
{ {
return color == "default" or return contains(color_names, color);
color == "black" or
color == "red" or
color == "green" or
color == "yellow" or
color == "blue" or
color == "magenta" or
color == "cyan" or
color == "white";
} }
Color str_to_color(StringView color) Color str_to_color(StringView color)
{ {
if (color == "default") return Colors::Default; auto it = find_if(color_names, [&](const char* c){ return color == c; });
if (color == "black") return Colors::Black; if (it != std::end(color_names))
if (color == "red") return Colors::Red; return static_cast<Colors>(it - color_names);
if (color == "green") return Colors::Green;
if (color == "yellow") return Colors::Yellow;
if (color == "blue") return Colors::Blue;
if (color == "magenta") return Colors::Magenta;
if (color == "cyan") return Colors::Cyan;
if (color == "white") return Colors::White;
static const Regex rgb_regex{"rgb:[0-9a-fA-F]{6}"}; static const Regex rgb_regex{"rgb:[0-9a-fA-F]{6}"};
if (regex_match(color.begin(), color.end(), rgb_regex)) if (regex_match(color.begin(), color.end(), rgb_regex))
@ -48,26 +47,18 @@ Color str_to_color(StringView color)
String color_to_str(Color color) String color_to_str(Color color)
{ {
switch (color.color) if (color.color == Colors::RGB)
{ {
case Colors::Default: return "default"; char buffer[11];
case Colors::Black: return "black"; sprintf(buffer, "rgb:%02x%02x%02x", color.r, color.g, color.b);
case Colors::Red: return "red"; return buffer;
case Colors::Green: return "green"; }
case Colors::Yellow: return "yellow"; else
case Colors::Blue: return "blue"; {
case Colors::Magenta: return "magenta"; size_t index = static_cast<size_t>(color.color);
case Colors::Cyan: return "cyan"; kak_assert(index < std::end(color_names) - std::begin(color_names));
case Colors::White: return "white"; return color_names[index];
case Colors::RGB:
{
char buffer[11];
sprintf(buffer, "rgb:%02x%02x%02x", color.r, color.g, color.b);
return buffer;
}
} }
kak_assert(false);
return "default";
} }
String option_to_string(Color color) String option_to_string(Color color)