From 341b7bdf4ab7dd1a10471f57bf6f558985ff4cc0 Mon Sep 17 00:00:00 2001 From: Shelley Vohr Date: Wed, 13 Apr 2022 10:46:05 +0200 Subject: [PATCH] fix: #ARGB to #RGBA conversion (#33707) * fix: argb to rgba conversion * chore: remove logging import * refactor: color_str -> converted_color_str --- shell/common/color_util.cc | 21 +++++++++------------ 1 file changed, 9 insertions(+), 12 deletions(-) diff --git a/shell/common/color_util.cc b/shell/common/color_util.cc index afa4c7f7a40b..73bbc162cca9 100644 --- a/shell/common/color_util.cc +++ b/shell/common/color_util.cc @@ -16,7 +16,7 @@ namespace { -bool IsHexFormat(const std::string& str) { +bool IsHexFormatWithAlpha(const std::string& str) { // Must be either #ARGB or #AARRGGBB. bool is_hex_length = str.length() == 5 || str.length() == 9; if (str[0] != '#' || !is_hex_length) @@ -35,20 +35,17 @@ namespace electron { SkColor ParseCSSColor(const std::string& color_string) { // ParseCssColorString expects RGBA and we historically use ARGB // so we need to convert before passing to ParseCssColorString. - std::string color_str = color_string; - if (IsHexFormat(color_str)) { - if (color_str.length() == 5) { - // #ARGB => #RGBA - std::swap(color_str[1], color_str[4]); - } else { - // #AARRGGBB => #RRGGBBAA - std::swap(color_str[1], color_str[7]); - std::swap(color_str[2], color_str[8]); - } + std::string converted_color_str; + if (IsHexFormatWithAlpha(color_string)) { + std::string temp = color_string; + int len = color_string.length() == 5 ? 1 : 2; + converted_color_str = temp.erase(1, len) + color_string.substr(1, len); + } else { + converted_color_str = color_string; } SkColor color; - if (!content::ParseCssColorString(color_str, &color)) + if (!content::ParseCssColorString(converted_color_str, &color)) color = SK_ColorWHITE; return color;