fix: #ARGB to #RGBA conversion (#33707)

* fix: argb to rgba conversion

* chore: remove logging import

* refactor: color_str -> converted_color_str
This commit is contained in:
Shelley Vohr 2022-04-13 10:46:05 +02:00 committed by GitHub
parent 4c4e02318f
commit 341b7bdf4a
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23

View file

@ -16,7 +16,7 @@
namespace { namespace {
bool IsHexFormat(const std::string& str) { bool IsHexFormatWithAlpha(const std::string& str) {
// Must be either #ARGB or #AARRGGBB. // Must be either #ARGB or #AARRGGBB.
bool is_hex_length = str.length() == 5 || str.length() == 9; bool is_hex_length = str.length() == 5 || str.length() == 9;
if (str[0] != '#' || !is_hex_length) if (str[0] != '#' || !is_hex_length)
@ -35,20 +35,17 @@ namespace electron {
SkColor ParseCSSColor(const std::string& color_string) { SkColor ParseCSSColor(const std::string& color_string) {
// ParseCssColorString expects RGBA and we historically use ARGB // ParseCssColorString expects RGBA and we historically use ARGB
// so we need to convert before passing to ParseCssColorString. // so we need to convert before passing to ParseCssColorString.
std::string color_str = color_string; std::string converted_color_str;
if (IsHexFormat(color_str)) { if (IsHexFormatWithAlpha(color_string)) {
if (color_str.length() == 5) { std::string temp = color_string;
// #ARGB => #RGBA int len = color_string.length() == 5 ? 1 : 2;
std::swap(color_str[1], color_str[4]); converted_color_str = temp.erase(1, len) + color_string.substr(1, len);
} else { } else {
// #AARRGGBB => #RRGGBBAA converted_color_str = color_string;
std::swap(color_str[1], color_str[7]);
std::swap(color_str[2], color_str[8]);
}
} }
SkColor color; SkColor color;
if (!content::ParseCssColorString(color_str, &color)) if (!content::ParseCssColorString(converted_color_str, &color))
color = SK_ColorWHITE; color = SK_ColorWHITE;
return color; return color;