refactor: leverage Skia helpers for NSColor ANSI logic (#37452)
This commit is contained in:
		
					parent
					
						
							
								6bd9ee6988
							
						
					
				
			
			
				commit
				
					
						17ccb3c6ec
					
				
			
		
					 5 changed files with 37 additions and 115 deletions
				
			
		|  | @ -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", | ||||
|  |  | |||
|  | @ -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" | ||||
|  |  | |||
|  | @ -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_
 | ||||
|  | @ -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 | ||||
|  | @ -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: | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Shelley Vohr
				Shelley Vohr