146 lines
		
	
	
	
		
			5.3 KiB
			
		
	
	
	
		
			Diff
		
	
	
	
	
	
			
		
		
	
	
			146 lines
		
	
	
	
		
			5.3 KiB
			
		
	
	
	
		
			Diff
		
	
	
	
	
	
| From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
 | |
| From: Cheng Zhao <zcbenz@gmail.com>
 | |
| Date: Thu, 20 Sep 2018 17:48:49 -0700
 | |
| Subject: mas: disable private window-frame APIs
 | |
| 
 | |
| Disable private window frame APIs (NSNextStepFrame and NSThemeFrame) for MAS
 | |
| build.
 | |
| 
 | |
| diff --git a/components/remote_cocoa/app_shim/browser_native_widget_window_mac.mm b/components/remote_cocoa/app_shim/browser_native_widget_window_mac.mm
 | |
| index 4d8f9f89f03653221fc0b509aa0e15ff20e73574..7bd5094db9b1a8e9af4ecc118fed7b78178e1e58 100644
 | |
| --- a/components/remote_cocoa/app_shim/browser_native_widget_window_mac.mm
 | |
| +++ b/components/remote_cocoa/app_shim/browser_native_widget_window_mac.mm
 | |
| @@ -9,6 +9,7 @@
 | |
|  #include "components/remote_cocoa/app_shim/native_widget_ns_window_bridge.h"
 | |
|  #include "components/remote_cocoa/common/native_widget_ns_window_host.mojom.h"
 | |
|  
 | |
| +#ifndef MAS_BUILD
 | |
|  @interface NSWindow (PrivateBrowserNativeWidgetAPI)
 | |
|  + (Class)frameViewClassForStyleMask:(NSUInteger)windowStyle;
 | |
|  @end
 | |
| @@ -55,10 +56,13 @@ - (BOOL)_shouldCenterTrafficLights {
 | |
|  
 | |
|  @end
 | |
|  
 | |
| +#endif  // MAS_BUILD
 | |
| +
 | |
|  @implementation BrowserNativeWidgetWindow
 | |
|  
 | |
|  // NSWindow (PrivateAPI) overrides.
 | |
|  
 | |
| +#ifndef MAS_BUILD
 | |
|  + (Class)frameViewClassForStyleMask:(NSUInteger)windowStyle {
 | |
|    // - NSThemeFrame and its subclasses will be nil if it's missing at runtime.
 | |
|    if ([BrowserWindowFrame class])
 | |
| @@ -73,6 +77,8 @@ - (BOOL)_usesCustomDrawing {
 | |
|    return NO;
 | |
|  }
 | |
|  
 | |
| +#endif  // MAS_BUILD
 | |
| +
 | |
|  // Handle "Move focus to the window toolbar" configured in System Preferences ->
 | |
|  // Keyboard -> Shortcuts -> Keyboard. Usually Ctrl+F5. The argument (|unknown|)
 | |
|  // tends to just be nil.
 | |
| diff --git a/components/remote_cocoa/app_shim/native_widget_mac_frameless_nswindow.mm b/components/remote_cocoa/app_shim/native_widget_mac_frameless_nswindow.mm
 | |
| index 8416c7c6e052dafb2aad61c0bd3224c36e945d23..cd356beda023ab2409b16d58ca38c70ba3674913 100644
 | |
| --- a/components/remote_cocoa/app_shim/native_widget_mac_frameless_nswindow.mm
 | |
| +++ b/components/remote_cocoa/app_shim/native_widget_mac_frameless_nswindow.mm
 | |
| @@ -4,6 +4,8 @@
 | |
|  
 | |
|  #import "components/remote_cocoa/app_shim/native_widget_mac_frameless_nswindow.h"
 | |
|  
 | |
| +#ifndef MAS_BUILD
 | |
| +
 | |
|  @interface NSWindow (PrivateAPI)
 | |
|  + (Class)frameViewClassForStyleMask:(NSUInteger)windowStyle;
 | |
|  @end
 | |
| @@ -18,8 +20,12 @@ - (CGFloat)_titlebarHeight {
 | |
|  }
 | |
|  @end
 | |
|  
 | |
| +#endif  // MAS_BUILD
 | |
| +
 | |
|  @implementation NativeWidgetMacFramelessNSWindow
 | |
|  
 | |
| +#ifndef MAS_BUILD
 | |
| +
 | |
|  + (Class)frameViewClassForStyleMask:(NSUInteger)windowStyle {
 | |
|    if ([NativeWidgetMacFramelessNSWindowFrame class]) {
 | |
|      return [NativeWidgetMacFramelessNSWindowFrame class];
 | |
| @@ -27,4 +33,6 @@ + (Class)frameViewClassForStyleMask:(NSUInteger)windowStyle {
 | |
|    return [super frameViewClassForStyleMask:windowStyle];
 | |
|  }
 | |
|  
 | |
| +#endif  // MAS_BUILD
 | |
| +
 | |
|  @end
 | |
| diff --git a/components/remote_cocoa/app_shim/native_widget_mac_nswindow.h b/components/remote_cocoa/app_shim/native_widget_mac_nswindow.h
 | |
| index 77662e89cf2c6135b99b3905c20456f4da0a6e09..fea78cc7fa195f44d88ec08a027b8e90209ee47c 100644
 | |
| --- a/components/remote_cocoa/app_shim/native_widget_mac_nswindow.h
 | |
| +++ b/components/remote_cocoa/app_shim/native_widget_mac_nswindow.h
 | |
| @@ -17,6 +17,7 @@ class NativeWidgetNSWindowBridge;
 | |
|  
 | |
|  @protocol WindowTouchBarDelegate;
 | |
|  
 | |
| +#ifndef MAS_BUILD
 | |
|  // Weak lets Chrome launch even if a future macOS doesn't have the below classes
 | |
|  WEAK_IMPORT_ATTRIBUTE
 | |
|  @interface NSNextStepFrame : NSView
 | |
| @@ -33,6 +34,7 @@ REMOTE_COCOA_APP_SHIM_EXPORT
 | |
|  REMOTE_COCOA_APP_SHIM_EXPORT
 | |
|  @interface NativeWidgetMacNSWindowTitledFrame : NSThemeFrame
 | |
|  @end
 | |
| +#endif
 | |
|  
 | |
|  // The NSWindow used by BridgedNativeWidget. Provides hooks into AppKit that
 | |
|  // can only be accomplished by overriding methods.
 | |
| diff --git a/components/remote_cocoa/app_shim/native_widget_mac_nswindow.mm b/components/remote_cocoa/app_shim/native_widget_mac_nswindow.mm
 | |
| index 18c63a44773700852365c508ee222232d0e5c8ec..8c644c4e16ce2305719caaa7d67dc583513ea8ec 100644
 | |
| --- a/components/remote_cocoa/app_shim/native_widget_mac_nswindow.mm
 | |
| +++ b/components/remote_cocoa/app_shim/native_widget_mac_nswindow.mm
 | |
| @@ -77,7 +77,9 @@ void OrderChildWindow(NSWindow* child_window,
 | |
|  }  // namespace
 | |
|  
 | |
|  @interface NSWindow (Private)
 | |
| +#ifndef MAS_BUILD
 | |
|  + (Class)frameViewClassForStyleMask:(NSWindowStyleMask)windowStyle;
 | |
| +#endif
 | |
|  - (BOOL)hasKeyAppearance;
 | |
|  - (long long)_resizeDirectionForMouseLocation:(CGPoint)location;
 | |
|  - (BOOL)_isConsideredOpenForPersistentState;
 | |
| @@ -109,6 +111,8 @@ - (void)cr_mouseDownOnFrameView:(NSEvent*)event {
 | |
|  }
 | |
|  @end
 | |
|  
 | |
| +#ifndef MAS_BUILD
 | |
| +
 | |
|  @implementation NativeWidgetMacNSWindowTitledFrame
 | |
|  - (void)mouseDown:(NSEvent*)event {
 | |
|    if (self.window.isMovable)
 | |
| @@ -135,6 +139,8 @@ - (BOOL)usesCustomDrawing {
 | |
|  }
 | |
|  @end
 | |
|  
 | |
| +#endif  // MAS_BUILD
 | |
| +
 | |
|  @implementation NativeWidgetMacNSWindow {
 | |
|   @private
 | |
|    base::scoped_nsobject<CommandDispatcher> _commandDispatcher;
 | |
| @@ -287,6 +293,8 @@ - (NSAccessibilityRole)accessibilityRole {
 | |
|  
 | |
|  // NSWindow overrides.
 | |
|  
 | |
| +#ifndef MAS_BUILD
 | |
| +
 | |
|  + (Class)frameViewClassForStyleMask:(NSWindowStyleMask)windowStyle {
 | |
|    if (windowStyle & NSWindowStyleMaskTitled) {
 | |
|      if (Class customFrame = [NativeWidgetMacNSWindowTitledFrame class])
 | |
| @@ -298,6 +306,8 @@ + (Class)frameViewClassForStyleMask:(NSWindowStyleMask)windowStyle {
 | |
|    return [super frameViewClassForStyleMask:windowStyle];
 | |
|  }
 | |
|  
 | |
| +#endif
 | |
| +
 | |
|  - (BOOL)_isTitleHidden {
 | |
|    bool shouldShowWindowTitle = YES;
 | |
|    if (_bridge)
 | 
![electron-roller[bot]](/assets/img/avatar_default.png)