Branch: refs/heads/main
  Home:   https://github.com/WebKit/WebKit
  Commit: 48c566a109a63be806e989c0a0c54c16b2c09263
      
https://github.com/WebKit/WebKit/commit/48c566a109a63be806e989c0a0c54c16b2c09263
  Author: Timothy Hatcher <[email protected]>
  Date:   2024-10-04 (Fri, 04 Oct 2024)

  Changed paths:
    M Source/WebKit/UIProcess/API/Cocoa/WKWebExtensionAction.h
    M Source/WebKit/UIProcess/API/Cocoa/WKWebExtensionAction.mm
    M Source/WebKit/UIProcess/API/Cocoa/WKWebExtensionControllerDelegate.h
    M Source/WebKit/UIProcess/Extensions/Cocoa/WebExtensionActionCocoa.mm
    M Source/WebKit/UIProcess/Extensions/Cocoa/WebExtensionContextCocoa.mm
    M Source/WebKit/UIProcess/Extensions/WebExtensionAction.h
    M Tools/TestWebKitAPI/Tests/WebKitCocoa/WKWebExtensionAPIAction.mm
    M Tools/TestWebKitAPI/cocoa/TestWebExtensionsDelegate.h
    M Tools/TestWebKitAPI/cocoa/TestWebExtensionsDelegate.mm

  Log Message:
  -----------
  Consider delegate methods for _WKWebExtensionAction changes instead of a 
notification.
https://webkit.org/b/268017
rdar://problem/121536906

Reviewed by Brian Weinstein.

Add a new delegate method that get notified about any tab actions that have 
updated.
This will notify the app for all tab actions when a default or window action 
changes,
which we were missing before when it was a simple notification. Also update 
after a
small delay, so multiple changes in succession are only notifying the delegate 
once.

Some tests have been updated to use the new delegate method instead to exercise 
it.

* Source/WebKit/UIProcess/API/Cocoa/WKWebExtensionAction.h:
* Source/WebKit/UIProcess/API/Cocoa/WKWebExtensionAction.mm:
* Source/WebKit/UIProcess/API/Cocoa/WKWebExtensionControllerDelegate.h:
* Source/WebKit/UIProcess/Extensions/Cocoa/WebExtensionActionCocoa.mm:
(WebKit::WebExtensionAction::propertiesDidChange): Call the delegate on a 
timeout.
* Source/WebKit/UIProcess/Extensions/Cocoa/WebExtensionContextCocoa.mm:
(WebKit::WebExtensionContext::getOrCreateAction): Pass window to the 
constructor.
This was a bug, but in practice it wasn't hit.
* Source/WebKit/UIProcess/Extensions/WebExtensionAction.h:
(WebKit::WebExtensionAction::isTabAction const): Added.
(WebKit::WebExtensionAction::isWindowAction const): Added.
(WebKit::WebExtensionAction::isDefaultAction const): Added.
* Tools/TestWebKitAPI/Tests/WebKitCocoa/WKWebExtensionAPIAction.mm:
(TestWebKitAPI::TEST(WKWebExtensionAPIAction, SetIconSinglePath)): Use new 
delegate.
(TestWebKitAPI::TEST(WKWebExtensionAPIAction, SetIconSinglePathRelative)): 
Ditto.
(TestWebKitAPI::TEST(WKWebExtensionAPIAction, SetIconMultipleSizes)): Ditto.
(TestWebKitAPI::TEST(WKWebExtensionAPIAction, SetIconMultipleSizesRelative)): 
Ditto.
(TestWebKitAPI::TEST(WKWebExtensionAPIAction, SetIconWithImageData)): Ditto.
(TestWebKitAPI::TEST(WKWebExtensionAPIAction, 
SetIconWithMultipleImageDataSizes)): Ditto.
(TestWebKitAPI::TEST(WKWebExtensionAPIAction, SetIconWithDataURL)): Ditto.
(TestWebKitAPI::TEST(WKWebExtensionAPIAction, SetIconWithMultipleDataURLs)): 
Ditto.
(TestWebKitAPI::TEST(WKWebExtensionAPIAction, SetIconWithVariants)): Ditto.
(TestWebKitAPI::TEST(WKWebExtensionAPIAction, 
SetIconWithImageDataAndVariants)): Ditto.
(TestWebKitAPI::TEST(WKWebExtensionAPIAction, 
SetIconWithMixedValidAndInvalidVariants)): Ditto.
(TestWebKitAPI::TEST(WKWebExtensionAPIAction, 
SetIconWithAnySizeVariantAndSVGDataURL)): Ditto.
* Tools/TestWebKitAPI/cocoa/TestWebExtensionsDelegate.h:
* Tools/TestWebKitAPI/cocoa/TestWebExtensionsDelegate.mm:
(-[TestWebExtensionsDelegate 
webExtensionController:didUpdateAction:forExtensionContext:]): Added.

Canonical link: https://commits.webkit.org/284707@main



To unsubscribe from these emails, change your notification settings at 
https://github.com/WebKit/WebKit/settings/notifications
_______________________________________________
webkit-changes mailing list
[email protected]
https://lists.webkit.org/mailman/listinfo/webkit-changes

Reply via email to