refactor: leverage Skia helpers for NSColor ANSI logic (#37452)

This commit is contained in:
Shelley Vohr 2023-03-03 09:42:50 +01:00 committed by GitHub
parent 6bd9ee6988
commit 17ccb3c6ec
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
5 changed files with 37 additions and 115 deletions

View file

@ -175,8 +175,6 @@ filenames = {
"shell/browser/ui/cocoa/electron_touch_bar.mm",
"shell/browser/ui/cocoa/event_dispatching_window.h",
"shell/browser/ui/cocoa/event_dispatching_window.mm",
"shell/browser/ui/cocoa/NSColor+Hex.h",
"shell/browser/ui/cocoa/NSColor+Hex.mm",
"shell/browser/ui/cocoa/NSString+ANSI.h",
"shell/browser/ui/cocoa/NSString+ANSI.mm",
"shell/browser/ui/cocoa/root_view_mac.h",

View file

@ -23,7 +23,6 @@
#include "net/base/mac/url_conversions.h"
#include "shell/browser/mac/dict_util.h"
#include "shell/browser/mac/electron_application.h"
#include "shell/browser/ui/cocoa/NSColor+Hex.h"
#include "shell/common/color_util.h"
#include "shell/common/gin_converters/gurl_converter.h"
#include "shell/common/gin_converters/value_converter.h"

View file

@ -1,18 +0,0 @@
// Created by Mathias Leppich on 03/02/14.
// Copyright (c) 2014 Bit Bar. All rights reserved.
// Copyright (c) 2017 GitHub, Inc.
// Use of this source code is governed by the MIT license that can be
// found in the LICENSE file.
#ifndef ELECTRON_SHELL_BROWSER_UI_COCOA_NSCOLOR_HEX_H_
#define ELECTRON_SHELL_BROWSER_UI_COCOA_NSCOLOR_HEX_H_
#import <Cocoa/Cocoa.h>
@interface NSColor (Hex)
- (NSString*)hexadecimalValue;
- (NSString*)RGBAValue;
+ (NSColor*)colorWithHexColorString:(NSString*)hex;
@end
#endif // ELECTRON_SHELL_BROWSER_UI_COCOA_NSCOLOR_HEX_H_

View file

@ -1,77 +0,0 @@
// Created by Mathias Leppich on 03/02/14.
// Copyright (c) 2014 Bit Bar. All rights reserved.
// Copyright (c) 2017 GitHub, Inc.
// Use of this source code is governed by the MIT license that can be
// found in the LICENSE file.
#include "shell/browser/ui/cocoa/NSColor+Hex.h"
@implementation NSColor (Hex)
- (NSString*)RGBAValue {
double redFloatValue, greenFloatValue, blueFloatValue, alphaFloatValue;
NSColor* convertedColor =
[self colorUsingColorSpaceName:NSCalibratedRGBColorSpace];
if (convertedColor) {
[convertedColor getRed:&redFloatValue
green:&greenFloatValue
blue:&blueFloatValue
alpha:&alphaFloatValue];
int redIntValue = redFloatValue * 255.99999f;
int greenIntValue = greenFloatValue * 255.99999f;
int blueIntValue = blueFloatValue * 255.99999f;
int alphaIntValue = alphaFloatValue * 255.99999f;
return
[NSString stringWithFormat:@"%02x%02x%02x%02x", redIntValue,
greenIntValue, blueIntValue, alphaIntValue];
}
return nil;
}
- (NSString*)hexadecimalValue {
double redFloatValue, greenFloatValue, blueFloatValue;
NSColor* convertedColor =
[self colorUsingColorSpaceName:NSCalibratedRGBColorSpace];
if (convertedColor) {
[convertedColor getRed:&redFloatValue
green:&greenFloatValue
blue:&blueFloatValue
alpha:NULL];
int redIntValue = redFloatValue * 255.99999f;
int greenIntValue = greenFloatValue * 255.99999f;
int blueIntValue = blueFloatValue * 255.99999f;
return [NSString stringWithFormat:@"#%02x%02x%02x", redIntValue,
greenIntValue, blueIntValue];
}
return nil;
}
+ (NSColor*)colorWithHexColorString:(NSString*)inColorString {
unsigned colorCode = 0;
if (inColorString) {
NSScanner* scanner = [NSScanner scannerWithString:inColorString];
(void)[scanner scanHexInt:&colorCode]; // ignore error
}
unsigned char redByte = (unsigned char)(colorCode >> 16);
unsigned char greenByte = (unsigned char)(colorCode >> 8);
unsigned char blueByte = (unsigned char)(colorCode); // masks off high bits
return [NSColor colorWithCalibratedRed:(CGFloat)redByte / 0xff
green:(CGFloat)greenByte / 0xff
blue:(CGFloat)blueByte / 0xff
alpha:1.0];
}
@end

View file

@ -4,9 +4,12 @@
// Use of this source code is governed by the MIT license that can be
// found in the LICENSE file.
#import <Cocoa/Cocoa.h>
#include "base/mac/scoped_nsobject.h"
#include "shell/browser/ui/cocoa/NSColor+Hex.h"
#include "content/public/common/color_parser.h"
#include "shell/browser/ui/cocoa/NSString+ANSI.h"
#include "skia/ext/skia_utils_mac.h"
@implementation NSMutableDictionary (ANSI)
@ -18,6 +21,7 @@
for (NSString* codeString in codeArray) {
int code = codeString.intValue;
SkColor color;
switch (code) {
case 0:
[self removeAllObjects];
@ -37,36 +41,44 @@
// case 24: underlined off
case 30:
content::ParseHexColorString(bold ? "#7f7f7f" : "#000000", &color);
self[NSForegroundColorAttributeName] =
[NSColor colorWithHexColorString:bold ? @"7f7f7f" : @"000000"];
skia::SkColorToCalibratedNSColor(color);
break;
case 31:
content::ParseHexColorString(bold ? "#cd0000" : "#ff0000", &color);
self[NSForegroundColorAttributeName] =
[NSColor colorWithHexColorString:bold ? @"cd0000" : @"ff0000"];
skia::SkColorToCalibratedNSColor(color);
break;
case 32:
content::ParseHexColorString(bold ? "#00cd00" : "#00ff00", &color);
self[NSForegroundColorAttributeName] =
[NSColor colorWithHexColorString:bold ? @"00cd00" : @"00ff00"];
skia::SkColorToCalibratedNSColor(color);
break;
case 33:
content::ParseHexColorString(bold ? "#cdcd00" : "#ffff00", &color);
self[NSForegroundColorAttributeName] =
[NSColor colorWithHexColorString:bold ? @"cdcd00" : @"ffff00"];
skia::SkColorToCalibratedNSColor(color);
break;
case 34:
content::ParseHexColorString(bold ? "#0000ee" : "#5c5cff", &color);
self[NSForegroundColorAttributeName] =
[NSColor colorWithHexColorString:bold ? @"0000ee" : @"5c5cff"];
skia::SkColorToCalibratedNSColor(color);
break;
case 35:
content::ParseHexColorString(bold ? "#cd00cd" : "#ff00ff", &color);
self[NSForegroundColorAttributeName] =
[NSColor colorWithHexColorString:bold ? @"cd00cd" : @"ff00ff"];
skia::SkColorToCalibratedNSColor(color);
break;
case 36:
content::ParseHexColorString(bold ? "#00cdcd" : "#00ffff", &color);
self[NSForegroundColorAttributeName] =
[NSColor colorWithHexColorString:bold ? @"00cdcd" : @"00ffff"];
skia::SkColorToCalibratedNSColor(color);
break;
case 37:
content::ParseHexColorString(bold ? "#e5e5e5" : "#ffffff", &color);
self[NSForegroundColorAttributeName] =
[NSColor colorWithHexColorString:bold ? @"e5e5e5" : @"ffffff"];
skia::SkColorToCalibratedNSColor(color);
break;
case 39:
@ -74,36 +86,44 @@
break;
case 40:
content::ParseHexColorString("#7f7f7f", &color);
self[NSBackgroundColorAttributeName] =
[NSColor colorWithHexColorString:@"7f7f7f"];
skia::SkColorToCalibratedNSColor(color);
break;
case 41:
content::ParseHexColorString("#cd0000", &color);
self[NSBackgroundColorAttributeName] =
[NSColor colorWithHexColorString:@"cd0000"];
skia::SkColorToCalibratedNSColor(color);
break;
case 42:
content::ParseHexColorString("#00cd00", &color);
self[NSBackgroundColorAttributeName] =
[NSColor colorWithHexColorString:@"00cd00"];
skia::SkColorToCalibratedNSColor(color);
break;
case 43:
content::ParseHexColorString("#cdcd00", &color);
self[NSBackgroundColorAttributeName] =
[NSColor colorWithHexColorString:@"cdcd00"];
skia::SkColorToCalibratedNSColor(color);
break;
case 44:
content::ParseHexColorString("#0000ee", &color);
self[NSBackgroundColorAttributeName] =
[NSColor colorWithHexColorString:@"0000ee"];
skia::SkColorToCalibratedNSColor(color);
break;
case 45:
content::ParseHexColorString("cd00cd", &color);
self[NSBackgroundColorAttributeName] =
[NSColor colorWithHexColorString:@"cd00cd"];
skia::SkColorToCalibratedNSColor(color);
break;
case 46:
content::ParseHexColorString("#00cdcd", &color);
self[NSBackgroundColorAttributeName] =
[NSColor colorWithHexColorString:@"00cdcd"];
skia::SkColorToCalibratedNSColor(color);
break;
case 47:
content::ParseHexColorString("#e5e5e5", &color);
self[NSBackgroundColorAttributeName] =
[NSColor colorWithHexColorString:@"e5e5e5"];
skia::SkColorToCalibratedNSColor(color);
break;
case 49: