electron/shell/browser/ui/cocoa/NSString+ANSI.mm

183 lines
5.9 KiB
Plaintext
Raw Permalink Normal View History

// Created by Kent Karlsson on 3/11/16.
// Copyright (c) 2016 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.
2017-11-09 15:21:07 -07:00
#import <Cocoa/Cocoa.h>
#include "content/public/common/color_parser.h"
#include "shell/browser/ui/cocoa/NSString+ANSI.h"
#include "skia/ext/skia_utils_mac.h"
2017-11-09 15:21:07 -07:00
@implementation NSMutableDictionary (ANSI)
- (NSMutableDictionary*)modifyAttributesForANSICodes:(NSString*)codes {
BOOL bold = NO;
NSFont* font = self[NSFontAttributeName];
NSArray* codeArray = [codes componentsSeparatedByString:@";"];
for (NSString* codeString in codeArray) {
int code = codeString.intValue;
SkColor color;
2017-11-09 15:21:07 -07:00
switch (code) {
case 0:
[self removeAllObjects];
// remove italic and bold from font here
2018-04-20 12:47:04 -06:00
if (font)
self[NSFontAttributeName] = font;
2017-11-09 15:21:07 -07:00
break;
case 1:
case 22:
bold = (code == 1);
break;
2018-04-20 12:47:04 -06:00
// case 3: italic
// case 23: italic off
// case 4: underlined
// case 24: underlined off
2017-11-09 15:21:07 -07:00
case 30:
content::ParseHexColorString(bold ? "#7f7f7f" : "#000000", &color);
2018-04-20 12:47:04 -06:00
self[NSForegroundColorAttributeName] =
skia::SkColorToCalibratedNSColor(color);
2017-11-09 15:21:07 -07:00
break;
case 31:
content::ParseHexColorString(bold ? "#cd0000" : "#ff0000", &color);
2018-04-20 12:47:04 -06:00
self[NSForegroundColorAttributeName] =
skia::SkColorToCalibratedNSColor(color);
2017-11-09 15:21:07 -07:00
break;
case 32:
content::ParseHexColorString(bold ? "#00cd00" : "#00ff00", &color);
2018-04-20 12:47:04 -06:00
self[NSForegroundColorAttributeName] =
skia::SkColorToCalibratedNSColor(color);
2017-11-09 15:21:07 -07:00
break;
case 33:
content::ParseHexColorString(bold ? "#cdcd00" : "#ffff00", &color);
2018-04-20 12:47:04 -06:00
self[NSForegroundColorAttributeName] =
skia::SkColorToCalibratedNSColor(color);
2017-11-09 15:21:07 -07:00
break;
case 34:
content::ParseHexColorString(bold ? "#0000ee" : "#5c5cff", &color);
2018-04-20 12:47:04 -06:00
self[NSForegroundColorAttributeName] =
skia::SkColorToCalibratedNSColor(color);
2017-11-09 15:21:07 -07:00
break;
case 35:
content::ParseHexColorString(bold ? "#cd00cd" : "#ff00ff", &color);
2018-04-20 12:47:04 -06:00
self[NSForegroundColorAttributeName] =
skia::SkColorToCalibratedNSColor(color);
2017-11-09 15:21:07 -07:00
break;
case 36:
content::ParseHexColorString(bold ? "#00cdcd" : "#00ffff", &color);
2018-04-20 12:47:04 -06:00
self[NSForegroundColorAttributeName] =
skia::SkColorToCalibratedNSColor(color);
2017-11-09 15:21:07 -07:00
break;
case 37:
content::ParseHexColorString(bold ? "#e5e5e5" : "#ffffff", &color);
2018-04-20 12:47:04 -06:00
self[NSForegroundColorAttributeName] =
skia::SkColorToCalibratedNSColor(color);
2017-11-09 15:21:07 -07:00
break;
case 39:
[self removeObjectForKey:NSForegroundColorAttributeName];
break;
case 40:
content::ParseHexColorString("#7f7f7f", &color);
2018-04-20 12:47:04 -06:00
self[NSBackgroundColorAttributeName] =
skia::SkColorToCalibratedNSColor(color);
2017-11-09 15:21:07 -07:00
break;
case 41:
content::ParseHexColorString("#cd0000", &color);
2018-04-20 12:47:04 -06:00
self[NSBackgroundColorAttributeName] =
skia::SkColorToCalibratedNSColor(color);
2017-11-09 15:21:07 -07:00
break;
case 42:
content::ParseHexColorString("#00cd00", &color);
2018-04-20 12:47:04 -06:00
self[NSBackgroundColorAttributeName] =
skia::SkColorToCalibratedNSColor(color);
2017-11-09 15:21:07 -07:00
break;
case 43:
content::ParseHexColorString("#cdcd00", &color);
2018-04-20 12:47:04 -06:00
self[NSBackgroundColorAttributeName] =
skia::SkColorToCalibratedNSColor(color);
2017-11-09 15:21:07 -07:00
break;
case 44:
content::ParseHexColorString("#0000ee", &color);
2018-04-20 12:47:04 -06:00
self[NSBackgroundColorAttributeName] =
skia::SkColorToCalibratedNSColor(color);
2017-11-09 15:21:07 -07:00
break;
case 45:
content::ParseHexColorString("cd00cd", &color);
2018-04-20 12:47:04 -06:00
self[NSBackgroundColorAttributeName] =
skia::SkColorToCalibratedNSColor(color);
2017-11-09 15:21:07 -07:00
break;
case 46:
content::ParseHexColorString("#00cdcd", &color);
2018-04-20 12:47:04 -06:00
self[NSBackgroundColorAttributeName] =
skia::SkColorToCalibratedNSColor(color);
2017-11-09 15:21:07 -07:00
break;
case 47:
content::ParseHexColorString("#e5e5e5", &color);
2018-04-20 12:47:04 -06:00
self[NSBackgroundColorAttributeName] =
skia::SkColorToCalibratedNSColor(color);
2017-11-09 15:21:07 -07:00
break;
case 49:
[self removeObjectForKey:NSBackgroundColorAttributeName];
break;
default:
break;
}
}
return self;
}
@end
@implementation NSString (ANSI)
- (BOOL)containsANSICodes {
2017-11-28 00:28:58 -07:00
return [self rangeOfString:@"\033["].location != NSNotFound;
2017-11-09 15:21:07 -07:00
}
- (NSMutableAttributedString*)attributedStringParsingANSICodes {
NSMutableAttributedString* result = [[NSMutableAttributedString alloc] init];
chore: bump chromium to 117.0.5923.0 (main) (#39304) * chore: bump chromium in DEPS to 117.0.5921.0 * chore: update chromium patches * 4721409: Remove redundant ARC configuration in /components | https://chromium-review.googlesource.com/c/chromium/src/+/4721409 * 4643750: Add V8_LOW_PRIORITY_TQ for main thread | https://chromium-review.googlesource.com/c/chromium/src/+/4643750 * 4022621: Re-register status item when owner of status watcher is changed | https://chromium-review.googlesource.com/c/chromium/src/+/4022621 * chore: update V8/boringssl patches * fixup! 4643750: Add V8_LOW_PRIORITY_TQ for main thread | https://chromium-review.googlesource.com/c/chromium/src/+/4643750 * chore: bump chromium in DEPS to 117.0.5923.0 * build [debug]: remove assert 4722125: Update enterprise content analysis buildflags usage | https://chromium-review.googlesource.com/c/chromium/src/+/4722125 * chore: manually rollback to 117.0.5921.0 * build [arc]: ARC conversion in auto_updater * build [arc]: ARC conversion in browser/api * build [arc]: ARC conversion in notifications/mac * build [arc]: ARC conversion in in_app_purchase * build [arc]: ARC conversion in browser/ui * build [arc]: ARC conversion in ui/cocoa * build [arc]: ARC conversion in shell/common * build [arc]: ARC conversion in OSR * build [arc]: ARC conversion in login_helper * build [arc]: ARC conversion in app_mas * build [arc]: fix up ARC syntax (thanks @codebytere!) * 4726946: [Extensions] Work around dangling BrowserContext pointer. | https://chromium-review.googlesource.com/c/chromium/src/+/4726946 --------- Co-authored-by: electron-roller[bot] <84116207+electron-roller[bot]@users.noreply.github.com> Co-authored-by: Keeley Hammond <vertedinde@electronjs.org> Co-authored-by: VerteDinde <keeleymhammond@gmail.com>
2023-08-04 02:47:29 -06:00
NSMutableDictionary* attributes([[NSMutableDictionary alloc] init]);
2017-11-28 00:28:58 -07:00
NSArray* parts = [self componentsSeparatedByString:@"\033["];
chore: bump chromium to 117.0.5923.0 (main) (#39304) * chore: bump chromium in DEPS to 117.0.5921.0 * chore: update chromium patches * 4721409: Remove redundant ARC configuration in /components | https://chromium-review.googlesource.com/c/chromium/src/+/4721409 * 4643750: Add V8_LOW_PRIORITY_TQ for main thread | https://chromium-review.googlesource.com/c/chromium/src/+/4643750 * 4022621: Re-register status item when owner of status watcher is changed | https://chromium-review.googlesource.com/c/chromium/src/+/4022621 * chore: update V8/boringssl patches * fixup! 4643750: Add V8_LOW_PRIORITY_TQ for main thread | https://chromium-review.googlesource.com/c/chromium/src/+/4643750 * chore: bump chromium in DEPS to 117.0.5923.0 * build [debug]: remove assert 4722125: Update enterprise content analysis buildflags usage | https://chromium-review.googlesource.com/c/chromium/src/+/4722125 * chore: manually rollback to 117.0.5921.0 * build [arc]: ARC conversion in auto_updater * build [arc]: ARC conversion in browser/api * build [arc]: ARC conversion in notifications/mac * build [arc]: ARC conversion in in_app_purchase * build [arc]: ARC conversion in browser/ui * build [arc]: ARC conversion in ui/cocoa * build [arc]: ARC conversion in shell/common * build [arc]: ARC conversion in OSR * build [arc]: ARC conversion in login_helper * build [arc]: ARC conversion in app_mas * build [arc]: fix up ARC syntax (thanks @codebytere!) * 4726946: [Extensions] Work around dangling BrowserContext pointer. | https://chromium-review.googlesource.com/c/chromium/src/+/4726946 --------- Co-authored-by: electron-roller[bot] <84116207+electron-roller[bot]@users.noreply.github.com> Co-authored-by: Keeley Hammond <vertedinde@electronjs.org> Co-authored-by: VerteDinde <keeleymhammond@gmail.com>
2023-08-04 02:47:29 -06:00
[result appendAttributedString:[[NSAttributedString alloc]
2017-11-28 00:28:58 -07:00
initWithString:parts.firstObject
chore: bump chromium to 117.0.5923.0 (main) (#39304) * chore: bump chromium in DEPS to 117.0.5921.0 * chore: update chromium patches * 4721409: Remove redundant ARC configuration in /components | https://chromium-review.googlesource.com/c/chromium/src/+/4721409 * 4643750: Add V8_LOW_PRIORITY_TQ for main thread | https://chromium-review.googlesource.com/c/chromium/src/+/4643750 * 4022621: Re-register status item when owner of status watcher is changed | https://chromium-review.googlesource.com/c/chromium/src/+/4022621 * chore: update V8/boringssl patches * fixup! 4643750: Add V8_LOW_PRIORITY_TQ for main thread | https://chromium-review.googlesource.com/c/chromium/src/+/4643750 * chore: bump chromium in DEPS to 117.0.5923.0 * build [debug]: remove assert 4722125: Update enterprise content analysis buildflags usage | https://chromium-review.googlesource.com/c/chromium/src/+/4722125 * chore: manually rollback to 117.0.5921.0 * build [arc]: ARC conversion in auto_updater * build [arc]: ARC conversion in browser/api * build [arc]: ARC conversion in notifications/mac * build [arc]: ARC conversion in in_app_purchase * build [arc]: ARC conversion in browser/ui * build [arc]: ARC conversion in ui/cocoa * build [arc]: ARC conversion in shell/common * build [arc]: ARC conversion in OSR * build [arc]: ARC conversion in login_helper * build [arc]: ARC conversion in app_mas * build [arc]: fix up ARC syntax (thanks @codebytere!) * 4726946: [Extensions] Work around dangling BrowserContext pointer. | https://chromium-review.googlesource.com/c/chromium/src/+/4726946 --------- Co-authored-by: electron-roller[bot] <84116207+electron-roller[bot]@users.noreply.github.com> Co-authored-by: Keeley Hammond <vertedinde@electronjs.org> Co-authored-by: VerteDinde <keeleymhammond@gmail.com>
2023-08-04 02:47:29 -06:00
attributes:nil]];
2017-11-09 15:21:07 -07:00
2018-04-20 12:47:04 -06:00
for (NSString* part in
[parts subarrayWithRange:NSMakeRange(1, parts.count - 1)]) {
2017-11-09 15:21:07 -07:00
if (part.length == 0)
continue;
NSArray* sequence = [part componentsSeparatedByString:@"m"];
NSString* text = sequence.lastObject;
if (sequence.count < 2) {
chore: bump chromium to 117.0.5923.0 (main) (#39304) * chore: bump chromium in DEPS to 117.0.5921.0 * chore: update chromium patches * 4721409: Remove redundant ARC configuration in /components | https://chromium-review.googlesource.com/c/chromium/src/+/4721409 * 4643750: Add V8_LOW_PRIORITY_TQ for main thread | https://chromium-review.googlesource.com/c/chromium/src/+/4643750 * 4022621: Re-register status item when owner of status watcher is changed | https://chromium-review.googlesource.com/c/chromium/src/+/4022621 * chore: update V8/boringssl patches * fixup! 4643750: Add V8_LOW_PRIORITY_TQ for main thread | https://chromium-review.googlesource.com/c/chromium/src/+/4643750 * chore: bump chromium in DEPS to 117.0.5923.0 * build [debug]: remove assert 4722125: Update enterprise content analysis buildflags usage | https://chromium-review.googlesource.com/c/chromium/src/+/4722125 * chore: manually rollback to 117.0.5921.0 * build [arc]: ARC conversion in auto_updater * build [arc]: ARC conversion in browser/api * build [arc]: ARC conversion in notifications/mac * build [arc]: ARC conversion in in_app_purchase * build [arc]: ARC conversion in browser/ui * build [arc]: ARC conversion in ui/cocoa * build [arc]: ARC conversion in shell/common * build [arc]: ARC conversion in OSR * build [arc]: ARC conversion in login_helper * build [arc]: ARC conversion in app_mas * build [arc]: fix up ARC syntax (thanks @codebytere!) * 4726946: [Extensions] Work around dangling BrowserContext pointer. | https://chromium-review.googlesource.com/c/chromium/src/+/4726946 --------- Co-authored-by: electron-roller[bot] <84116207+electron-roller[bot]@users.noreply.github.com> Co-authored-by: Keeley Hammond <vertedinde@electronjs.org> Co-authored-by: VerteDinde <keeleymhammond@gmail.com>
2023-08-04 02:47:29 -06:00
[result appendAttributedString:[[NSAttributedString alloc]
initWithString:text
attributes:attributes]];
2017-11-09 15:21:07 -07:00
} else if (sequence.count >= 2) {
text = [[sequence subarrayWithRange:NSMakeRange(1, sequence.count - 1)]
2018-04-20 12:47:04 -06:00
componentsJoinedByString:@"m"];
2017-11-09 15:21:07 -07:00
[attributes modifyAttributesForANSICodes:sequence[0]];
chore: bump chromium to 117.0.5923.0 (main) (#39304) * chore: bump chromium in DEPS to 117.0.5921.0 * chore: update chromium patches * 4721409: Remove redundant ARC configuration in /components | https://chromium-review.googlesource.com/c/chromium/src/+/4721409 * 4643750: Add V8_LOW_PRIORITY_TQ for main thread | https://chromium-review.googlesource.com/c/chromium/src/+/4643750 * 4022621: Re-register status item when owner of status watcher is changed | https://chromium-review.googlesource.com/c/chromium/src/+/4022621 * chore: update V8/boringssl patches * fixup! 4643750: Add V8_LOW_PRIORITY_TQ for main thread | https://chromium-review.googlesource.com/c/chromium/src/+/4643750 * chore: bump chromium in DEPS to 117.0.5923.0 * build [debug]: remove assert 4722125: Update enterprise content analysis buildflags usage | https://chromium-review.googlesource.com/c/chromium/src/+/4722125 * chore: manually rollback to 117.0.5921.0 * build [arc]: ARC conversion in auto_updater * build [arc]: ARC conversion in browser/api * build [arc]: ARC conversion in notifications/mac * build [arc]: ARC conversion in in_app_purchase * build [arc]: ARC conversion in browser/ui * build [arc]: ARC conversion in ui/cocoa * build [arc]: ARC conversion in shell/common * build [arc]: ARC conversion in OSR * build [arc]: ARC conversion in login_helper * build [arc]: ARC conversion in app_mas * build [arc]: fix up ARC syntax (thanks @codebytere!) * 4726946: [Extensions] Work around dangling BrowserContext pointer. | https://chromium-review.googlesource.com/c/chromium/src/+/4726946 --------- Co-authored-by: electron-roller[bot] <84116207+electron-roller[bot]@users.noreply.github.com> Co-authored-by: Keeley Hammond <vertedinde@electronjs.org> Co-authored-by: VerteDinde <keeleymhammond@gmail.com>
2023-08-04 02:47:29 -06:00
[result appendAttributedString:[[NSAttributedString alloc]
initWithString:text
attributes:attributes]];
2017-11-09 15:21:07 -07:00
}
}
return result;
}
@end