From 49ed94c87b0c8c723c5b22d22f3f2cbc7b418f20 Mon Sep 17 00:00:00 2001 From: Kevin Walzer Date: Wed, 30 Aug 2023 17:30:28 +0000 Subject: Fix for ef5d3e29a4 --- macosx/tkMacOSXWindowEvent.c | 25 ++----------------------- macosx/tkMacOSXWm.c | 20 ++++++++++++++++++++ 2 files changed, 22 insertions(+), 23 deletions(-) diff --git a/macosx/tkMacOSXWindowEvent.c b/macosx/tkMacOSXWindowEvent.c index c0f8afc..e261bee 100644 --- a/macosx/tkMacOSXWindowEvent.c +++ b/macosx/tkMacOSXWindowEvent.c @@ -239,8 +239,8 @@ extern NSString *NSWindowDidOrderOffScreenNotification; if (winPtr) { TKContentView *view = [window contentView]; -#if MAC_OS_X_VERSION_MAX_ALLOWED >= 101500 - if (@available(macOS 10.15, *)) { +#if MAC_OS_X_VERSION_MAX_ALLOWED >= 101400 + if (@available(macOS 10.14, *)) { [view viewDidChangeEffectiveAppearance]; } #endif @@ -1237,29 +1237,8 @@ static const char *const accentNames[] = { } else if (effectiveAppearanceName == NSAppearanceNameDarkAqua) { Tk_SendVirtualEvent(tkwin, "DarkAqua", NULL); } - if ([NSApp macOSVersion] < 101500) { - - /* - * Mojave cannot handle the KVO shenanigans that we need for the - * highlight and accent color notifications. - */ - - return; - } if (!defaultColor) { defaultColor = [NSApp macOSVersion] < 110000 ? "Blue" : "Multicolor"; - preferences = [[NSUserDefaults standardUserDefaults] retain]; - - /* - * AppKit calls this method when the user changes the Accent Color - * but not when the user changes the Highlight Color. So we register - * to receive KVO notifications for Highlight Color as well. - */ - - [preferences addObserver:self - forKeyPath:@"AppleHighlightColor" - options:NSKeyValueObservingOptionNew - context:NULL]; } NSString *accent = [preferences stringForKey:@"AppleAccentColor"]; NSArray *words = [[preferences stringForKey:@"AppleHighlightColor"] diff --git a/macosx/tkMacOSXWm.c b/macosx/tkMacOSXWm.c index 8b72faf..75ebdbc 100644 --- a/macosx/tkMacOSXWm.c +++ b/macosx/tkMacOSXWm.c @@ -1289,6 +1289,11 @@ TkWmDeadWindow( [NSApp _setMainWindow:nil]; } [deadNSWindow close]; +#if MAC_OS_X_VERSION_MAX_ALLOWED >= 101400 + NSUserDefaults *preferences = [NSUserDefaults standardUserDefaults]; + [preferences removeObserver:deadNSWindow.contentView + forKeyPath:@"AppleHighlightColor"]; +#endif [deadNSWindow release]; #if DEBUG_ZOMBIES > 1 @@ -6763,6 +6768,21 @@ TkMacOSXMakeRealWindowExist( } TKContentView *contentView = [[TKContentView alloc] initWithFrame:NSZeroRect]; +#if MAC_OS_X_VERSION_MAX_ALLOWED >= 101400 + NSUserDefaults *preferences = [NSUserDefaults standardUserDefaults]; + + /* + * AppKit calls the viewDidChangeEffectiveAppearance method when the + * user changes the Accent Color but not when the user changes the + * Highlight Color. So we register to receive KVO notifications for + * Highlight Color as well. + */ + + [preferences addObserver:contentView + forKeyPath:@"AppleHighlightColor" + options:NSKeyValueObservingOptionNew + context:NULL]; +#endif [window setContentView:contentView]; [contentView release]; [window setDelegate:NSApp]; -- cgit v0.12