Skip to content

AppKit macOS xcode16.2 b2

Rolf Bjarne Kvinge edited this page Dec 2, 2024 · 2 revisions

#AppKit.framework https://github.com/xamarin/xamarin-macios/pull/21735

diff -ruN /Applications/Xcode_16.1.0.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk/System/Library/Frameworks/AppKit.framework/Headers/AppKit.apinotes /Applications/Xcode_16.2.0-beta2.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk/System/Library/Frameworks/AppKit.framework/Headers/AppKit.apinotes
--- /Applications/Xcode_16.1.0.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk/System/Library/Frameworks/AppKit.framework/Headers/AppKit.apinotes	2024-10-09 23:58:18
+++ /Applications/Xcode_16.2.0-beta2.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk/System/Library/Frameworks/AppKit.framework/Headers/AppKit.apinotes	2024-10-31 00:42:42
@@ -7550,6 +7550,16 @@
   SwiftName: NSWorkspace.FileOperationName
 - Name: NSWorkspaceLaunchConfigurationKey
   SwiftName: NSWorkspace.LaunchConfigurationKey
+- Name: NSWritingToolsCoordinatorContextRequestReason
+  SwiftName: NSWritingToolsCoordinator.ContextRequestReason
+- Name: NSWritingToolsCoordinatorState
+  SwiftName: NSWritingToolsCoordinator.State
+- Name: NSWritingToolsCoordinatorTextAnimation
+  SwiftName: NSWritingToolsCoordinator.TextAnimation
+- Name: NSWritingToolsCoordinatorTextReplacementReason
+  SwiftName: NSWritingToolsCoordinator.TextReplacementReason
+- Name: NSWritingToolsCoordinatorTextUpdateReason
+  SwiftName: NSWritingToolsCoordinator.TextUpdateReason
 - Name: _BCFlags
   Availability: nonswift
 - Name: _BCFlags2
@@ -10689,6 +10699,8 @@
   SwiftName: NSWorkspace.willUnmountNotification
 - Name: NSWritingDirectionAttributeName
   SwiftName: writingDirection
+- Name: NSWritingToolsExclusionAttributeName
+  SwiftName: writingToolsExclusion
 - Name: NSYearMonthDatePickerElementFlag
   Availability: nonswift
   AvailabilityMsg: "prefer 'yearMonth'"
diff -ruN /Applications/Xcode_16.1.0.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk/System/Library/Frameworks/AppKit.framework/Headers/AppKit.h /Applications/Xcode_16.2.0-beta2.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk/System/Library/Frameworks/AppKit.framework/Headers/AppKit.h
--- /Applications/Xcode_16.1.0.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk/System/Library/Frameworks/AppKit.framework/Headers/AppKit.h	2024-10-10 00:36:06
+++ /Applications/Xcode_16.2.0-beta2.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk/System/Library/Frameworks/AppKit.framework/Headers/AppKit.h	2024-10-31 01:04:52
@@ -279,3 +279,7 @@
 #import <AppKit/NSTextViewportLayoutController.h>
 #import <AppKit/NSTextAttachmentCell.h>
 #import <AppKit/NSAdaptiveImageGlyph.h>
+
+#import <AppKit/NSWritingToolsCoordinatorAnimationParameters.h>
+#import <AppKit/NSWritingToolsCoordinatorContext.h>
+#import <AppKit/NSWritingToolsCoordinator.h>
diff -ruN /Applications/Xcode_16.1.0.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk/System/Library/Frameworks/AppKit.framework/Headers/NSAdaptiveImageGlyph.h /Applications/Xcode_16.2.0-beta2.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk/System/Library/Frameworks/AppKit.framework/Headers/NSAdaptiveImageGlyph.h
--- /Applications/Xcode_16.1.0.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk/System/Library/Frameworks/AppKit.framework/Headers/NSAdaptiveImageGlyph.h	2024-10-10 00:36:14
+++ /Applications/Xcode_16.2.0-beta2.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk/System/Library/Frameworks/AppKit.framework/Headers/NSAdaptiveImageGlyph.h	2024-10-31 01:05:00
@@ -6,7 +6,7 @@
 //  NSAdaptiveImageGlyph.h
 //  Text Kit
 //
-//  Copyright (c) 2024-2024, Apple Inc. All rights reserved.
+//  Copyright (c) 2024, Apple Inc. All rights reserved.
 //
 
 #import <Foundation/NSAttributedString.h>
@@ -23,7 +23,7 @@
 API_AVAILABLE(macos(15.0), ios(18.0), tvos(18.0), watchos(11.0), visionos(2.0)) NS_SWIFT_SENDABLE
 @interface NSAdaptiveImageGlyph : NSObject <NSCopying, NSSecureCoding, CTAdaptiveImageProviding>
 
-- (instancetype)initWithImageContent:(NSData*)imageContent NS_DESIGNATED_INITIALIZER; // Initialization: imageContent must conform to the image data format identified by contentType
+- (instancetype)initWithImageContent:(NSData *)imageContent NS_DESIGNATED_INITIALIZER; // Initialization: imageContent must conform to the image data format identified by contentType
 - (instancetype)initWithCoder:(NSCoder *)coder NS_DESIGNATED_INITIALIZER;
 - (instancetype)init NS_UNAVAILABLE;
 
diff -ruN /Applications/Xcode_16.1.0.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk/System/Library/Frameworks/AppKit.framework/Headers/NSAttributedString.h /Applications/Xcode_16.2.0-beta2.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk/System/Library/Frameworks/AppKit.framework/Headers/NSAttributedString.h
--- /Applications/Xcode_16.1.0.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk/System/Library/Frameworks/AppKit.framework/Headers/NSAttributedString.h	2024-10-10 00:36:19
+++ /Applications/Xcode_16.2.0-beta2.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk/System/Library/Frameworks/AppKit.framework/Headers/NSAttributedString.h	2024-10-31 01:05:05
@@ -53,6 +53,9 @@
 
 APPKIT_EXTERN NSAttributedStringKey const NSAdaptiveImageGlyphAttributeName API_AVAILABLE(macos(15.0), ios(18.0), tvos(18.0), watchos(11.0), visionos(2.0)); // NSAdaptiveImageGlyph, default nil
 
+// NSNumber (Boolean) value. Default is false. The range of text with NSWritingToolsExclusionAttributeName=true is excluded from the WritingTools processing and preserved.
+APPKIT_EXTERN NSAttributedStringKey const NSWritingToolsExclusionAttributeName API_AVAILABLE(ios(18.2), macos(15.2)) API_UNAVAILABLE(visionos, tvos, watchos);
+
 /************************ Attribute values ************************/
 // This defines currently supported values for NSUnderlineStyleAttributeName and NSStrikethroughStyleAttributeName. These values are or'ed together to produce an underline style.
 // Underlines will be drawn with a solid pattern by default, so NSUnderlineStylePatternSolid does not need to be specified.
diff -ruN /Applications/Xcode_16.1.0.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk/System/Library/Frameworks/AppKit.framework/Headers/NSMenu.h /Applications/Xcode_16.2.0-beta2.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk/System/Library/Frameworks/AppKit.framework/Headers/NSMenu.h
--- /Applications/Xcode_16.1.0.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk/System/Library/Frameworks/AppKit.framework/Headers/NSMenu.h	2024-10-10 00:36:15
+++ /Applications/Xcode_16.2.0-beta2.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk/System/Library/Frameworks/AppKit.framework/Headers/NSMenu.h	2024-10-31 01:05:01
@@ -184,6 +184,9 @@
 */
 @property BOOL allowsContextMenuPlugIns API_AVAILABLE(macos(10.6));
 
+/* Determines whether Writing Tools menu items may be inserted into the menu, if used as a context menu. The default is YES. */
+@property BOOL automaticallyInsertsWritingToolsItems API_AVAILABLE(macos(15.2));
+
 /* Determines whether the menu contains a column for the state image.  The default is YES. */
 @property BOOL showsStateColumn API_AVAILABLE(macos(10.5));
 
diff -ruN /Applications/Xcode_16.1.0.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk/System/Library/Frameworks/AppKit.framework/Headers/NSMenuItem.h /Applications/Xcode_16.2.0-beta2.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk/System/Library/Frameworks/AppKit.framework/Headers/NSMenuItem.h
--- /Applications/Xcode_16.1.0.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk/System/Library/Frameworks/AppKit.framework/Headers/NSMenuItem.h	2024-10-10 00:36:16
+++ /Applications/Xcode_16.2.0-beta2.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk/System/Library/Frameworks/AppKit.framework/Headers/NSMenuItem.h	2024-10-31 01:05:02
@@ -31,6 +31,10 @@
 /// Items created using this method are non-interactive and do not perform an action.
 + (instancetype)sectionHeaderWithTitle:(NSString *)title API_AVAILABLE(macos(14.0)) NS_REFINED_FOR_SWIFT;
 
+/// An array of standard menu items related to Writing Tools.
+/// Each call to this method returns an array of newly allocated instances of NSMenuItem.
+@property (class, readonly, copy) NSArray<NSMenuItem *> *writingToolsItems API_AVAILABLE(macos(15.2));
+
 - (instancetype)initWithTitle:(NSString *)string action:(nullable SEL)selector keyEquivalent:(NSString *)charCode NS_DESIGNATED_INITIALIZER;
 - (instancetype)initWithCoder:(NSCoder *)coder NS_DESIGNATED_INITIALIZER;
 
diff -ruN /Applications/Xcode_16.1.0.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk/System/Library/Frameworks/AppKit.framework/Headers/NSResponder.h /Applications/Xcode_16.2.0-beta2.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk/System/Library/Frameworks/AppKit.framework/Headers/NSResponder.h
--- /Applications/Xcode_16.1.0.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk/System/Library/Frameworks/AppKit.framework/Headers/NSResponder.h	2024-10-10 00:36:13
+++ /Applications/Xcode_16.2.0-beta2.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk/System/Library/Frameworks/AppKit.framework/Headers/NSResponder.h	2024-10-31 01:04:59
@@ -377,6 +377,12 @@
 
 @end
 
+@interface NSResponder(NSWritingToolsSupport)
+
+- (IBAction)showWritingTools:(nullable id)sender API_AVAILABLE(macos(15.2));
+
+@end
+
 
 @interface NSResponder(NSDeprecated)
 
diff -ruN /Applications/Xcode_16.1.0.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk/System/Library/Frameworks/AppKit.framework/Headers/NSSavePanel.h /Applications/Xcode_16.2.0-beta2.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk/System/Library/Frameworks/AppKit.framework/Headers/NSSavePanel.h
--- /Applications/Xcode_16.1.0.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk/System/Library/Frameworks/AppKit.framework/Headers/NSSavePanel.h	2024-10-10 00:36:15
+++ /Applications/Xcode_16.2.0-beta2.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk/System/Library/Frameworks/AppKit.framework/Headers/NSSavePanel.h	2024-10-31 01:05:01
@@ -275,7 +275,7 @@
 - (void)setDirectory:(nullable NSString *)path API_DEPRECATED("Use -setDirectoryURL: instead", macos(10.0,10.6));
 - (nullable NSString *)requiredFileType API_DEPRECATED("Use -allowedContentTypes instead", macos(10.0,10.6));
 - (void)setRequiredFileType:(nullable NSString *)type API_DEPRECATED("Use -allowedContentTypes: instead", macos(10.0,10.6));
-- (void)beginSheetForDirectory:(NSString *)path file:(nullable NSString *)name modalForWindow:(nullable NSWindow *)docWindow modalDelegate:(nullable id)delegate didEndSelector:(nullable SEL)didEndSelector contextInfo:(nullable void *)contextInfo API_DEPRECATED("Use beginSheetModalForWindow:completionHandler: instead. The following parameters are replaced by properties: 'path' is replaced by 'directoryURL' and 'name' by 'nameFieldStringValue'.", macos(10.0,10.6));
+- (void)beginSheetForDirectory:(nullable NSString *)path file:(nullable NSString *)name modalForWindow:(nullable NSWindow *)docWindow modalDelegate:(nullable id)delegate didEndSelector:(nullable SEL)didEndSelector contextInfo:(nullable void *)contextInfo API_DEPRECATED("Use beginSheetModalForWindow:completionHandler: instead. The following parameters are replaced by properties: 'path' is replaced by 'directoryURL' and 'name' by 'nameFieldStringValue'.", macos(10.0,10.6));
 - (NSInteger)runModalForDirectory:(nullable NSString *)path file:(nullable NSString *)name API_DEPRECATED("Use -runModal instead. The following parameters are replaced by properties: 'path' is replaced by 'directoryURL' and 'name' by 'nameFieldStringValue'.", macos(10.0,10.6));
 - (IBAction)selectText:(nullable id)sender API_DEPRECATED("Default implementation does nothing.", macos(10.0,10.3));
 
diff -ruN /Applications/Xcode_16.1.0.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk/System/Library/Frameworks/AppKit.framework/Headers/NSTextField.h /Applications/Xcode_16.2.0-beta2.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk/System/Library/Frameworks/AppKit.framework/Headers/NSTextField.h
--- /Applications/Xcode_16.1.0.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk/System/Library/Frameworks/AppKit.framework/Headers/NSTextField.h	2024-10-10 00:36:14
+++ /Applications/Xcode_16.2.0-beta2.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk/System/Library/Frameworks/AppKit.framework/Headers/NSTextField.h	2024-10-31 01:05:00
@@ -57,6 +57,7 @@
 @property NSLineBreakStrategy lineBreakStrategy API_AVAILABLE(macos(10.15));
 #endif
 
+@property BOOL allowsWritingTools API_AVAILABLE(macos(15.2)); // Default is YES. Configures its field editor to work with Writing Tools.
 @end
 
 #pragma mark NSTextField NSTouchBar Properties
diff -ruN /Applications/Xcode_16.1.0.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk/System/Library/Frameworks/AppKit.framework/Headers/NSToolbarItem.h /Applications/Xcode_16.2.0-beta2.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk/System/Library/Frameworks/AppKit.framework/Headers/NSToolbarItem.h
--- /Applications/Xcode_16.1.0.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk/System/Library/Frameworks/AppKit.framework/Headers/NSToolbarItem.h	2024-10-10 00:36:15
+++ /Applications/Xcode_16.2.0-beta2.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk/System/Library/Frameworks/AppKit.framework/Headers/NSToolbarItem.h	2024-10-31 01:05:01
@@ -265,6 +265,9 @@
 /** A standard item for cloud sharing via NSSharingServiceNameCloudSharing. It validates itself and modifies its appearance by using the NSCloudSharingValidation protocol. It sends -performCloudSharing: to the firstResponder. */
 APPKIT_EXTERN NSToolbarItemIdentifier NSToolbarCloudSharingItemIdentifier API_AVAILABLE(macos(10.12));
 
+/** A standard item that is configured to send -showWritingTools: to the firstResponder when invoked. */
+APPKIT_EXTERN NSToolbarItemIdentifier NSToolbarWritingToolsItemIdentifier API_AVAILABLE(macos(15.2));
+
 /**
  Creates a new NSTrackingSeparatorToolbarItem and automatically configures it to track the divider of the sidebar if one is discovered.
  Only applies to windows with `NSWindowStyleMaskFullSizeContentView` applied.
diff -ruN /Applications/Xcode_16.1.0.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk/System/Library/Frameworks/AppKit.framework/Headers/NSUserActivity.h /Applications/Xcode_16.2.0-beta2.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk/System/Library/Frameworks/AppKit.framework/Headers/NSUserActivity.h
--- /Applications/Xcode_16.1.0.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk/System/Library/Frameworks/AppKit.framework/Headers/NSUserActivity.h	2024-10-10 00:36:19
+++ /Applications/Xcode_16.2.0-beta2.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk/System/Library/Frameworks/AppKit.framework/Headers/NSUserActivity.h	2024-10-31 01:05:05
@@ -20,16 +20,16 @@
 APPKIT_API_UNAVAILABLE_BEGIN_MACCATALYST
 
 @protocol NSUserActivityRestoring <NSObject>
-/* This method exists to be overridden and will be called from the main thread. It will be called on any objects passed to the restorationHandler given to application:continueUserActivity:restorationHandler: below. You should use the state in the userInfo to restore the object. On OS X, activities managed by NSDocument can be restored automatically, if NO is returned from application:continueActivity:restorationHandler: (or it is unimplemented). In this situation, the document will be opened via -[NSDocumentController openDocumentWithContentsOfURL:display:completionHandler:], and will have restoreUserActivityState: called on it. */
+/* This method exists to be overridden and will be called from the main thread. It will be called on any objects passed to the restorationHandler given to application:continueUserActivity:restorationHandler: below. You should use the state in the userInfo to restore the object. On macOS, activities managed by NSDocument can be restored automatically, if NO is returned from application:continueActivity:restorationHandler: (or it is unimplemented). In this situation, the document will be opened via -[NSDocumentController openDocumentWithContentsOfURL:display:completionHandler:], and will have restoreUserActivityState: called on it. */
 - (void)restoreUserActivityState:(NSUserActivity *)userActivity NS_SWIFT_UI_ACTOR API_AVAILABLE(macos(10.10));
 @end
 
 @interface NSResponder (NSUserActivity) <NSUserActivityRestoring>
 
 /*
- Setting an NSUserActivity will cause it to become managed by AppKit/UIKIt. NSUserActivities managed by AppKit/UIKIt will be saved automatically at an appropriate time. You will have an opportunity to add state representing the user’s activity via the below updateUserActivityState: override. It is recommended that you override the updateUserActivityState: method to lazily write any state to the userInfo.
+ Setting an NSUserActivity will cause it to become managed by AppKit/UIKit. NSUserActivities managed by AppKit/UIKit will be saved automatically at an appropriate time. You will have an opportunity to add state representing the user’s activity via the below updateUserActivityState: override. It is recommended that you override the updateUserActivityState: method to lazily write any state to the userInfo.
 
- On OS X, NSUserActivities managed by NSResponder will automatically becomeCurrent based on the main window and the responder chain.
+ On macOS, NSUserActivities managed by NSResponder will automatically becomeCurrent based on the main window and the responder chain.
 
  To unassociate an object from the user activity, you can set this to nil. If no objects are associated with an NSUserActivity managed by AppKit/UIKit, it will be removed.
 
@@ -49,13 +49,13 @@
 /*
  This works just like the above responder methods for the most part.
 
- On OS X, NSUserActivities managed by NSDocument will automatically become current when any of the document window controller's window's become main. You will need to invoke [[document userActivity] becomeCurrent] at an appropriate time if there aren't any.
+ On macOS, NSUserActivities managed by NSDocument will automatically become current when any of the document window controller's window's become main. You will need to invoke [[document userActivity] becomeCurrent] at an appropriate time if there aren't any.
 
- If there is a CFBundleDocumentTypes entry for the document's type with a NSUbiquitousDocumentUserActivityType key, AppKit/UIKIt will automatically create an NSUserActivity with the given activityType when the document is ubiquitous. When it is non-ubiquitous, the userActivity will be nil. Note that userActivity is KVO observable, in case the userActivity is being shared with other objects that need to be kept in sync as the document moves into and out of iCloud.
+ If there is a CFBundleDocumentTypes entry for the document's type with a NSUbiquitousDocumentUserActivityType key, AppKit/UIKit will automatically create an NSUserActivity with the given activityType when the document is ubiquitous. When it is non-ubiquitous, the userActivity will be nil. Note that userActivity is KVO observable, in case the userActivity is being shared with other objects that need to be kept in sync as the document moves into and out of iCloud.
  */
 @property (nullable, strong) NSUserActivity *userActivity API_AVAILABLE(macos(10.10));
 
-/* On OS X, The default implementation of this will put the fileURL into the userInfo with the NSUserActivityDocumentURLKey. NSDocument will automatically call needsSave on the userActivity when the fileURL changes. */
+/* On macOS, the default implementation of this will put the fileURL into the userInfo with the NSUserActivityDocumentURLKey. NSDocument will automatically call needsSave on the userActivity when the fileURL changes. */
 - (void)updateUserActivityState:(NSUserActivity *)activity API_AVAILABLE(macos(10.10));
 
 @end
diff -ruN /Applications/Xcode_16.1.0.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk/System/Library/Frameworks/AppKit.framework/Headers/NSView.h /Applications/Xcode_16.2.0-beta2.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk/System/Library/Frameworks/AppKit.framework/Headers/NSView.h
--- /Applications/Xcode_16.1.0.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk/System/Library/Frameworks/AppKit.framework/Headers/NSView.h	2024-10-10 00:36:18
+++ /Applications/Xcode_16.2.0-beta2.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk/System/Library/Frameworks/AppKit.framework/Headers/NSView.h	2024-10-31 01:05:04
@@ -22,6 +22,7 @@
 #import <AppKit/NSUserInterfaceLayout.h>
 
 @protocol NSDraggingSource;
+@class NSWritingToolsCoordinator;
 
 NS_HEADER_AUDIT_BEGIN(nullability, sendability)
 APPKIT_API_UNAVAILABLE_BEGIN_MACCATALYST
@@ -633,6 +634,10 @@
                                       
 @end
 
+API_AVAILABLE(macos(15.2))
+@interface NSView (NSWritingToolsCoordinator)
+@property (nullable) NSWritingToolsCoordinator *writingToolsCoordinator;
+@end
 
 /* Notifications */
 
diff -ruN /Applications/Xcode_16.1.0.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk/System/Library/Frameworks/AppKit.framework/Headers/NSWritingToolsCoordinator.h /Applications/Xcode_16.2.0-beta2.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk/System/Library/Frameworks/AppKit.framework/Headers/NSWritingToolsCoordinator.h
--- /Applications/Xcode_16.1.0.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk/System/Library/Frameworks/AppKit.framework/Headers/NSWritingToolsCoordinator.h	1969-12-31 19:00:00
+++ /Applications/Xcode_16.2.0-beta2.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk/System/Library/Frameworks/AppKit.framework/Headers/NSWritingToolsCoordinator.h	2024-10-31 01:05:00
@@ -0,0 +1,1086 @@
+/*
+        NSWritingToolsCoordinator.h
+        Application Kit
+        Copyright (c) 2024, Apple Inc.
+        All rights reserved.
+*/
+
+#import <Foundation/NSArray.h>
+#import <Foundation/NSGeometry.h>
+#import <CoreGraphics/CGImage.h>
+#import <AppKit/NSTextCheckingClient.h>
+
+APPKIT_API_UNAVAILABLE_BEGIN_MACCATALYST
+NS_ASSUME_NONNULL_BEGIN
+
+@class NSWritingToolsCoordinator;
+@class NSWritingToolsCoordinatorContext;
+@class NSWritingToolsCoordinatorAnimationParameters;
+@class NSTextPreview;
+@class NSAttributedString;
+@class NSView;
+@class NSBezierPath;
+@class NSUUID;
+@protocol NSWritingToolsCoordinatorDelegate;
+
+#pragma mark NSWritingToolsCoordinator
+/// Constants that specify the reason you updated your view’s content
+/// outside of the Writing Tools workflow.
+///
+/// If you modify your view’s text storage while Writing Tools is active,
+/// report those changes to your ``NSWritingToolsCoordinator`` object
+/// so it can track them correctly. Call the
+/// ``NSWritingToolsCoordinator/updateRange(_:with:reason:forContextWithIdentifier:)``
+/// method to report changes that occur inside one of your context objects. Call the
+/// ``NSWritingToolsCoordinator/updateForReflowedTextInContextWithIdentifier(_:)``
+/// method for changes that affect the layout of your text, such as text insertions
+/// before a context object or changes to your view’s frame rectangle.
+typedef NS_ENUM(NSInteger, NSWritingToolsCoordinatorTextUpdateReason) {
+    
+    /// An operation that involved a person editing the text in your view.
+    ///
+    /// Specify this option when the changes come from the text input system.
+    NSWritingToolsCoordinatorTextUpdateReasonTyping,
+    
+    /// An operation that changed the view’s text as part of an undo or
+    /// redo command.
+    ///
+    /// Specify this option when an undo or redo command initiated the
+    /// change to your view.
+    NSWritingToolsCoordinatorTextUpdateReasonUndoRedo,
+} API_AVAILABLE(macos(15.2));
+
+/// The states that indicate the current activity, if any, Writing Tools
+/// is performing in your view.
+///
+/// Making changes to your view requires several different levels of
+/// interaction. Initially, Writing Tools displays its UI and collects
+/// information about what the person wants to do. When the person selects
+/// an operation, Writing Tools sends the relevant details to a large language
+/// model (LLM) and processes the results. It then works with the custom view to
+/// integrate any changes into the view’s text storage. During each
+/// of these activities, the coordinator reflects what’s happening in
+/// its ``NSWritingToolsCoordinator/state`` property. You can use
+/// the current state as a guide to making decisions in other parts of your view.
+typedef NS_ENUM(NSInteger, NSWritingToolsCoordinatorState) {
+    // Open question: Do we also want a `Disabled` state?
+    
+    /// A state that indicates Writing Tools isn’t currently performing
+    /// any work on your view’s content.
+    ///
+    /// The coordinator starts in the `inactive` state, and transitions
+    /// immediately to the ``noninteractive`` or ``interactiveResting``
+    /// state when someone chooses an option from the Writing Tools UI.
+    /// After the coordinator finishes incorporating any changes for the
+    /// current operation, it returns to the `inactive` state and waits
+    /// for the person to choose a different option or dismiss the Writing Tools UI.
+    NSWritingToolsCoordinatorStateInactive, // Writing Tools is not active
+    
+    /// A state that indicates Writing Tools is handling interactions in
+    /// the system UI, instead of in your view.
+    ///
+    /// Writing Tools transitions to this state when the coordinator uses
+    /// the ``NSWritingToolsBehavior/limited`` experience or when someone chooses an
+    /// option that displays its results in the Writing Tools UI. When
+    /// the person accepts the changes from the tool or dismisses the
+    /// Writing Tools UI, the coordinator returns to the ``inactive``
+    /// state. If the person discards the change and selects a tool with
+    /// an interactive experience instead, the coordinator transitions
+    /// to the ``interactiveResting`` state.
+    NSWritingToolsCoordinatorStateNoninteractive, // Writing Tools is presenting UI, and the WTC may call the -writingToolsCoordinator:replaceRange:inContext:withText:reason: delegate method (with NSWritingToolsCoordinatorTextReplacementReasonNoninteractive) if the textual view is editable
+    
+    /// A state that indicates Writing Tools is in the resting state
+    /// for an inline editing experience.
+    ///
+    /// When someone initially selects a tool with an interactive experience,
+    /// the coordinator transitions briefly to this state and starts the
+    /// operation. The coordinator transitions swiftly to the ``interactiveStreaming``
+    /// state when it submits the request and delivers the results to your
+    /// view. When it finishes delivering the results, it transitions back
+    /// to the `interactiveResting` state and awaits further commands. If
+    /// the person accepts the changes or dismisses the Writing Tools UI,
+    /// the coordinator transitions from this state to the ``inactive`` state.
+    NSWritingToolsCoordinatorStateInteractiveResting, // Writing Tools is providing the full inline-editing experience, and has delivered a complete set of results.
+    
+    /// A state that indicates Writing Tools is processing a request and
+    /// incorporating changes interactively into your view.
+    ///
+    /// The coordinator transitions swiftly from the ``interactiveResting``
+    /// state to this state at the start of an operation. In this state,
+    /// the coordinator submits the request for processing and delivers
+    /// the results back to your view. When the coordinator finishes delivering
+    /// the results, it transitions back to the ``interactiveResting`` state.
+    NSWritingToolsCoordinatorStateInteractiveStreaming, // Writing Tools is providing the full inline-editing experience, and is updating text, either because results are provided from AppleIntelligence, or because user interaction has requested changes, such as showing a different revision
+} API_AVAILABLE(macos(15.2));
+
+/// Options that indicate whether Writing Tools is animating changes to
+/// your view’s text.
+///
+/// During an operation, Writing Tools delivers replacement text to the
+/// delegate of the active ``NSWritingToolsCoordinator`` object. Depending
+/// on the configured experience for your view, it delivers these changes
+/// as either interactive or noninteractive replacements. For interactive
+/// replacements, Writing Tools animates the change automatically and provides
+/// you with the information you need to perform any related animations.
+typedef NS_ENUM(NSInteger, NSWritingToolsCoordinatorTextReplacementReason) {
+    
+    /// An option to animate the replacement of text in your view.
+    ///
+    /// When Writing Tools requests an interactive change in your delegate’s
+    /// ``NSWritingToolsCoordinator/writingToolsCoordinator(_:replaceRange:inContext:proposedText:reason:animationParameters:completion:)``
+    /// method, it passes a valid set of animation parameters to that method.
+    /// Update your view’s text storage and use the provided ``NSWritingToolsCoordinator/AnimationParameters``
+    /// type to create any view-specific animations you need to support the
+    /// animated replacement of the text.
+    NSWritingToolsCoordinatorTextReplacementReasonInteractive, // animating a chunk from a proofreading or rewrite inline delivery
+    
+    /// An option to replace the text in your view without animating the change.
+    ///
+    /// When Writing Tools requests a noninteractive change in your delegate’s
+    /// ``NSWritingToolsCoordinator/writingToolsCoordinator(_:replaceRange:inContext:proposedText:reason:animationParameters:completion:)``
+    /// method, update your view’s text storage without animating the change.
+    NSWritingToolsCoordinatorTextReplacementReasonNoninteractive, // an unanimated replacement prompted from writing tools, perhaps copied from the overlay-panel experience, perhaps a reverted rewrite or individual proofreading suggestion, and so forth
+} API_AVAILABLE(macos(15.2));
+
+/// Options that indicate how much of your content Writing Tools requested.
+///
+/// At the start of any Writing Tools interaction, you provide the text for
+/// the system to evaluate from your ``NS/UIWritingToolsCoordinator/Delegate``
+/// object. The request for your content comes with a scope constant that
+/// indicates how much of your view’s text to provide.
+typedef NS_ENUM(NSInteger, NSWritingToolsCoordinatorContextScope) {
+    
+    /// An option to provide only the view’s currently selected text.
+    ///
+    /// With this option, include the selected text in your context object,
+    /// along with some additional text before and after the selection. When
+    /// performing changes inline with your view’s content, Writing Tools
+    /// applies animations only to the selected text.
+    NSWritingToolsCoordinatorContextScopeUserSelection, // inline editing on a user selection; Writing Tools visual effects appear within the text view
+    
+    /// An option to provide all of your view’s text.
+    ///
+    /// With this option, include all of the text your view manages. If your
+    /// view has multiple text storage objects, create a separate context object
+    /// for each one.
+    NSWritingToolsCoordinatorContextScopeFullDocument, // full document is needed independent of user selection, for Writing Tools to, for example, create additional text; Writing Tools visual effects appear within the text view
+    
+    /// An option to provide only the text in the currently visible portion
+    /// of your view.
+    ///
+    /// With this option, include only the currently visible text, along with
+    /// some additional text before and after the visible text.
+    NSWritingToolsCoordinatorContextScopeVisibleArea, // inline editing on a user visible text; Writing Tools visual effects appear within the text view
+} API_AVAILABLE(macos(15.2));
+
+/// Use the `NSWritingToolsCoordinator.TextAnimation` constants to determine
+/// the type of animation that is occurring. During an interactive change to
+/// your view, Writing Tools creates animations to provide feedback about what’s
+/// happening. During the setup for each animation, Writing Tools reports the
+/// type of animation to the coordinator’s delegate, so that you can perform
+/// additional actions related to that animation. For example, during an insertion
+/// animation, you might animate changes to other views in your interface.
+typedef NS_ENUM(NSInteger, NSWritingToolsCoordinatorTextAnimation) {
+    
+    /// The animation that Writing Tools performs when waiting to receive
+    /// results from the large language model.
+    ///
+    /// This type of animation applies a visual effect to the text that
+    /// Writing Tools is evaluating. When preparing for this animation, hide
+    /// the text that Writing Tools is about to evaluate. In the same space
+    /// where that text appears, Writing Tools displays a preview image that
+    /// you provide and animates changes to that image.
+    NSWritingToolsCoordinatorTextAnimationAnticipate, // The animation effect for the text awaiting the results of the Writing Tools evaluation
+    
+    /// The animation that Writing Tools performs when removing text from your view.
+    ///
+    /// This type of animation shows the removal of text from your view. When
+    /// preparing for this animation, hide the text in the provided range if
+    /// you haven’t already. If you support animating the reflow of your view’s
+    /// text, you can also prepare any other animations you need. Writing Tools
+    /// uses a preview object you provide to animate the removal of the text.
+    NSWritingToolsCoordinatorTextAnimationRemove, // The animation effect for washing out text that will be replaced by a Writing Tools delivery
+    
+    /// The animation that Writing Tools performs when inserting text into your view.
+    ///
+    /// This type of animation shows the insertion of text to your view. When preparing
+    /// for this animation, hide the text in the provided range if you haven’t
+    /// already. If you support animating the reflow of your view’s text, you can
+    /// also prepare any other animations you need. Writing Tools uses a preview
+    /// object you provide to animate the insertion of the text.
+    NSWritingToolsCoordinatorTextAnimationInsert, // The animation effect for washing in replacement text from a Writing Tools delivery
+    
+    /// The animation effect that Writing Tools performs when the view is waiting
+    /// for results, but the system isn’t actively evaluating the text.
+    ///
+    /// When Writing Tools isn’t actively evaluating your text, it creates this animation.
+    /// When preparing for this animation, display the text in the specified range
+    /// with a foreground color of 50% grey.
+    NSWritingToolsCoordinatorTextAnimationAnticipateInactive = 8, // The animation effect for the text awaiting the results of the Writing Tools evaluation but not actively pondering
+    
+    /// The animation effect that Writing Tools performs on text situated after
+    /// the insertion point.
+    ///
+    /// When Writing Tools inserts text at a given location, it creates an animation
+    /// to make room for the new text. When preparing for this animation, hide the
+    /// text between the insertion point and the end of your text storage. When
+    /// finishing the animation, show the text again.
+    NSWritingToolsCoordinatorTextAnimationTranslate = 9, // The animation effect for translating the trailing or "remainder" text during a replace animation
+} API_AVAILABLE(macos(15.2));
+
+/// An object that manages interactions between Writing Tools and
+/// your custom text view.
+///
+/// Add a `NSWritingToolsCoordinator` object to a custom view when you
+/// want to add Writing Tools support to that view. The coordinator manages
+/// interactions between your view and the Writing Tools UI and back-end
+/// capabilities. When creating a coordinator, you supply a delegate object
+/// to respond to requests from the system and provide needed information.
+/// Your delegate delivers your view’s text to Writing Tools, incorporates
+/// suggested changes back into your text storage, and supports the animations
+/// that Writing Tools creates to show the state of an operation.
+///
+/// Create the `NSWritingToolsCoordinator` object when setting up your UI, and
+/// initialize it with a custom object that adopts the ``NSWritingToolsCoordinator/Delegate``
+/// protocol. Add the coordinator to the ``NSView/writingToolsCoordinator`` property
+/// of your view. When a coordinator is present on a view, the system adds UI elements
+/// to initiate Writing Tools operations.
+///
+/// When defining the delegate, choose an object from your app that has access
+/// to your view and its text storage. You can adopt the ``NSWritingToolsCoordinator/Delegate``
+/// protocol in the view itself, or in another type that your view uses to
+/// manage content. During the interactions with Writing Tools, the delegate
+/// gets and sets the contents of the view’s text storage and supports Writing Tools behaviors.
+///
+/// > Note: You don’t need to create an `NSWritingToolsCoordinator`  object
+/// if you display text using a <doc://com.apple.documentation/documentation/uikit/uitextview>,
+/// ``NSTextView``,
+/// <doc://com.apple.documentation/documentation/swiftui/text>,
+/// <doc://com.apple.documentation/documentation/swiftui/textfield>, or
+/// <doc://com.apple.documentation/documentation/swiftui/texteditor> view.
+/// Those views already include the required support to handle Writing Tools
+/// interactions.
+API_AVAILABLE(macos(15.2)) NS_SWIFT_UI_ACTOR
+@interface NSWritingToolsCoordinator : NSObject
+
+/// A Boolean value that indicates whether Writing Tools features are
+/// currently available.
+///
+/// The value of this property is `true` when Writing Tools features are
+/// available, and `false` when they aren’t. Writing Tools support might
+/// be unavailable because of device constraints or because the system isn’t
+/// ready to process Writing Tools requests.
+@property (class, readonly) BOOL isWritingToolsAvailable;
+
+// Convenience initializers
+
+/// Creates a writing tools coordinator and assigns the specified
+/// delegate object to it.
+///
+/// - Parameters:
+///    - delegate: An object capable of handling Writing Tools interactions
+///    for your view. The delegate must be able to modify your view’s text
+///    storage and refresh the view’s layout and appearance.
+///
+/// Create the coordinator object during your view’s initialization, and assign
+/// the object to your view. Assign the coordinator to the ``NSView/writingToolsCoordinator``
+/// property of your view.
+- (instancetype)initWithDelegate:(nullable id <NSWritingToolsCoordinatorDelegate>)delegate;
+
+/// The object that handles Writing Tools interactions for your view.
+///
+/// Specify this object at initialization time when creating your `NSWritingToolsCoordinator`
+/// object. The object must adopt the ``NSWritingToolsCoordinator/Delegate``
+/// protocol, and be capable of modifying your view’s text storage and
+/// refreshing the view’s layout and appearance.
+@property (weak, nullable, readonly) id <NSWritingToolsCoordinatorDelegate> delegate;
+
+/// The view that currently uses the writing tools coordinator.
+///
+/// Use this property to refer to the view that currently owns the coordinator
+/// object. The system updates this property automatically when you assign the
+/// coordinator to the ``NSView/writingToolsCoordinator`` property of your view.
+/// The value of this property is `nil` if there is no associated view.
+@property (nullable, weak, readonly) __kindof NSView *view;
+
+// Note: The effectContainerView and decorationContainerView may only be changed when state (below) is NSWritingToolsCoordinatorStateInactive, otherwise the setters will throw an exception
+
+/// The view that Writing Tools uses to display visual effects during
+/// the text-rewriting process.
+///
+/// Writing Tools uses the view in this property to host the visual effects
+/// it creates when making interactive changes to your view’s content.
+/// These visual effects let people know the state of the text and provide
+/// feedback about what’s happening to it. Set this property to a subview
+/// that sits visually above, and covers, all of the text in your custom
+/// text view. If you don’t assign a value to this property, the coordinator
+/// places its own effect view in front of the subviews in your custom view.
+/// The default value of this property is `nil`.
+///
+/// If you display your view’s text using multiple text containers, implement the
+/// ``NSWritingToolsCoordinator/Delegate/writingToolsCoordinator(_:singleContainerSubrangesOf:in:)``
+/// method to request multiple previews.
+@property (weak, nullable) NSView *effectContainerView; // When nil, uses the view property. The WTC will have a "real" effect container which will be kept in front of all the public container's subviews. Ignored if the delegate implements -requestsEffectContainerView
+
+/// The view that Writing Tools uses to display background decorations
+/// such as proofreading marks.
+///
+/// Writing Tools uses the view in this property to host proofreading marks
+/// and other visual elements that show any suggested changes. Set this
+/// property to a subview situated visibly below the text in your custom
+/// text view. It's also satisfactory to place this view visually in front
+/// of the text. Make sure the size of the view is big enough to
+/// cover all of the affected text. If you don’t assign a value to this
+/// property, the coordinator places its own decoration view behind the subviews
+/// in your custom view. The default value of this property is `nil`.
+///
+/// If you display your view’s text using multiple text containers, implement the
+/// ``NSWritingToolsCoordinator/Delegate/writingToolsCoordinator(_:singleContainerSubrangesOf:in:)``
+/// and ``NSWritingToolsCoordinator/Delegate/writingToolsCoordinator(_:decorationContainerViewFor:in:)``
+/// methods to provide separate decoration views for each container.
+@property (weak, nullable) NSView *decorationContainerView; // When nil, uses the view property. The WTC will have a "real" decorations container which will be kept behind all the public container's subviews. Ignored if the delegate implements -requestsDecorationContainerView
+
+/// The current level of Writing Tools activity in your view.
+///
+/// Use this property to determine when Writing Tools is actively making
+/// changes to your view. During the course of Writing Tools interactions,
+/// the system reports state changes to the delegate’s
+/// ``NSWritingToolsCoordinator/Delegate/writingToolsCoordinator(_:willChangeTo:completion:)``
+/// method and updates this property accordingly.
+@property (readonly) NSWritingToolsCoordinatorState state; // Values: Inactive, Noninteractive, InteractiveResting, InteractiveStreaming
+
+/// Stops the current Writing Tools operation and dismisses the system UI.
+///
+/// Call this method to abort the current Writing Tools operation. This
+/// method dismisses the system’s Writing Tools UI and stops any in-flight
+/// interactions with your view. This method does not undo any changes that
+/// Writing Tools already made to your view’s content.
+- (void)stopWritingTools;
+
+/// The level of Writing Tools support you want the system to provide
+/// for your view.
+///
+/// Use this property to request an inline or panel-based experience,
+/// or to disable Writing Tools for your view altogether. The default
+/// value of this property is ``NSWritingToolsBehavior/default``.
+@property NSWritingToolsBehavior preferredBehavior; // Defaults to "Default"
+
+/// The actual level of Writing Tools support the system provides for your view.
+///
+/// The system chooses this value based on the device capabilities, and takes
+/// the value in the ``preferredBehavior`` property into consideration when
+/// making the choice. The value in this property is never the default option,
+/// and is instead one of the specific options such as ``NSWritingToolsBehavior/none``,
+/// ``NSWritingToolsBehavior/limited``, or ``NSWritingToolsBehavior/complete``.
+@property (readonly) NSWritingToolsBehavior behavior; // Returns None, Limited, or Complete after considering system information along with the value of preferredBehavior
+
+/// The type of content you allow Writing Tools to generate for your custom
+/// text view.
+///
+/// Writing Tools can create plain text or rich text, and it can format text
+/// using lists or tables as needed. If your view doesn’t support specific
+/// types of content, specify the types you do support in this property.
+/// The default value of this property is ``NSWritingToolsResult/default``,
+/// which lets the system determine the type of content to generate.
+@property NSWritingToolsResultOptions preferredResultOptions; // Defaults to "Default"
+
+/// The type of content the system generates for your custom text view.
+///
+/// This property contains the set of options that Writing Tools outputs
+/// for your view. Writing Tools takes the value in the
+/// ``NSWritingToolsCoordinator/preferredResultOptions`` property into
+/// consideration when determining this value.
+@property (readonly) NSWritingToolsResultOptions resultOptions; // Returns a nonzero value after considering system information along with the value of preferredResultOptions
+
+/// Informs the coordinator about changes your app made to the text
+/// in the specified context object.
+///
+/// - Parameters:
+///    - range: The range of text to replace. This range is relative to
+///    the starting location of the specified context object’s text in
+///    your view’s text storage. If you initialized the context object
+///    with the entire contents of your view’s text storage, specify the
+///    range of text you’re replacing in your text storage. However, if
+///    you initialized the context object with only a portion of your
+///    view’s text, specify a range that is relative to the starting
+///    location of the context object’s text.
+///    - replacementText: The text that replaces the previous content in
+///    `range`. Specify an empty string to delete the text in the specified range.
+///    - reason: The reason you updated the text.
+///    - contextID: The unique identifier of the context object that
+///    contains the text you modified.
+///
+/// If you make any changes to the text Writing Tools is evaluating, call
+/// this method to report those changes to your view’s coordinator object.
+/// You might make changes in response to an undo command or when someone
+/// types into the same part of your view’s text. Calling this method
+/// keeps the coordinator object informed of any changes, and ensures
+/// it delivers accurate information to its delegate. In response, the
+/// coordinator refreshes previews and other information related to your
+/// view. If the scope of the update is significantly large, the coordinator
+/// can optionally cancel the Writing Tools session altogether.
+///
+/// Use this method to report changes that precisely intersect your context
+/// object’s text. The first time you call this method for a context object,
+/// report changes only to the original attributed string in that object.
+/// If you call this method more than once, report changes to the newly
+/// modified version of that string. Don’t use this method to report changes
+/// to text that comes before or after the context object. If you make
+/// changes before your context object, report those changes separately using the
+/// ``updateForReflowedTextInContextWithIdentifier(_:)`` method.
+///
+/// > Warning: Failure to call this method for a change can cause Writing Tools
+/// to deliver inaccurate information to your delegate and lead to data loss.
+- (void)updateRange:(NSRange)range withText:(NSAttributedString *)replacementText reason:(NSWritingToolsCoordinatorTextUpdateReason)reason forContextWithIdentifier:(NSUUID *)contextID NS_SWIFT_NAME(updateRange(_:with:reason:forContextWithIdentifier:));
+
+/// Informs the coordinator that a change occurred to the view or its text
+/// that requires a layout update.
+///
+/// - Parameters:
+///    - contextID: The unique identifier of the context object affected
+///    by the change. Pass the identifier for the context object that comes
+///    after the changes.
+///
+/// Use this method to inform Writing Tools when the geometry of your view
+/// changes, or when the text that precedes one of your context objects changes.
+/// Changes to the view’s geometry or text can affect the flow of any remaining
+/// text, and require a layout update. Writing Tools uses this method to
+/// refresh any layout-dependent information it’s currently tracking. For
+/// example, it uses it to refresh the location of proofreading marks it’s
+/// displaying in your view.
+///
+/// If a text change affects the text inside a context object, call the
+/// ``updateRange(_:with:reason:forContextWithIdentifier:)`` method to report
+/// that change instead.
+- (void)updateForReflowedTextInContextWithIdentifier:(NSUUID *)contextID NS_SWIFT_NAME(updateForReflowedTextInContextWithIdentifier(_:));
+@end
+
+#pragma mark NSWritingToolsCoordinatorDelegate
+/// An interface that you use to manage interactions between Writing Tools
+/// and your custom text view.
+///
+/// Adopt the `NSWritingToolsCoordinator.Delegate` protocol in the type you
+/// use to manage your custom text view. When you add a ``NSWritingToolsCoordinator``
+/// object to your view, the coordinator uses this protocol to communicate
+/// with that view. The protocol lets Writing Tools fetch your view’s text,
+/// report suggested changes back to your view, and deliver visual feedback
+/// when Writing Tools features are active. Make sure the type that adopts
+/// this protocol has access to your view’s text storage and can perform
+/// relevant tasks on behalf of the view.
+///
+/// Writing Tools expects you to call the provided handler blocks at the end
+/// of your delegate methods. It’s crucial that you execute these blocks in a
+/// timely manner to allow Writing Tools to perform subsequent tasks. For example,
+/// Writing Tools waits for you to execute the handlers for animation-related methods
+/// before moving on to the next stage of the animations.
+API_AVAILABLE(macos(15.2)) NS_SWIFT_NAME(NSWritingToolsCoordinator.Delegate)
+@protocol NSWritingToolsCoordinatorDelegate <NSObject>
+
+/// Asks your delegate to provide the text to evaluate during the Writing Tools
+/// operation.
+///
+/// - Parameters:
+///    - writingToolsCoordinator: The coordinator object requesting information
+///    from your custom view.
+///    - scope: The amount of text the coordinator requested. Use this property
+///    to determine if Writing Tools is evaluating all of your text or only a subset.
+///    - completion: A completion block to execute with the required information.
+///    You must execute this block once at end of your method's implementation.
+///    The block has no return value and takes an array of
+///    ``NSWritingToolsCoordinator/Context`` objects that contain the requested information.
+///
+/// At the start of every operation, the ``NSWritingToolsCoordinator`` object calls
+/// this method to request the text to evaluate. Use this method to create one or
+/// more ``NSWritingToolsCoordinator/Context`` objects with your view’s text.
+/// Create only one ``NSWritingToolsCoordinator/Context`` object if your view has
+/// only one text storage object. If your view contains multiple text storage objects,
+/// create separate ``NSWritingToolsCoordinator/Context`` objects for each
+/// text storage object. Writing Tools returns updates for each context object
+/// separately, making it easier for you to incorporate changes into the correct
+/// text storage object. Don’t create multiple context objects if your view has
+/// only one text storage object.
+///
+/// The `scope` parameter tells you what content Writing Tools expects you to provide
+/// in your context object. For example, Writing Tools expects you to provide the
+/// selected text when the parameter contains the ``NSWritingToolsCoordinator/ContextScope/userSelection``
+/// option. When Writing Tools requests a subset of your overall text, include
+/// some of the surrounding text in your context object too. Writing Tools can
+/// use the extra text you provide to improve the results of its evaluation. For
+/// example, it might use an entire paragraph, instead of only the selected sentence,
+/// to evaluate ways to rewrite that sentence. It’s best to include the text up
+/// to the nearest paragraph boundary before and after the selection. If you
+/// include extra text in your context object, set the ``NSWritingToolsCoordinator/Context/range``
+/// property to the range of the selected text.
+///
+/// > Note: When a context object stores only a subset of your view’s text, record
+/// additional information to map the location of that text to the correct location
+/// in your view’s text storage. Keep that information up-to-date throughout the
+///  Writing Tools session.
+///
+/// Pass the context objects you create to the provided completion handler before
+/// your method returns. Writing Tools waits for you to call the completion
+/// handler before proceeding with the operation.
+- (void)writingToolsCoordinator:(NSWritingToolsCoordinator *)writingToolsCoordinator requestsContextsForScope:(NSWritingToolsCoordinatorContextScope)scope completion:(void(^)(NSArray<NSWritingToolsCoordinatorContext *> *))completion NS_SWIFT_ASYNC_NAME(writingToolsCoordinator(_:contextsFor:));
+
+/// Tells the delegate that there are text changes to incorporate into the view.
+///
+/// - Parameters:
+///    - writingToolsCoordinator: The coordinator object providing the changes
+///    to your custom view.
+///    - range: A range of text to update. This range is relative to the text
+///    in your context object, and it’s your responsibility to match that location
+///    to the correct location in your text storage. If you initialized the
+///    context object with the entire contents of your view’s text storage,
+///    you can use `range` as-is to access that text storage. However, if you
+///    initialized the context object with only a portion of your view’s text,
+///    add the starting location of your context object’s text to this value
+///    to get the correct range for that text storage.
+///    - context: The context object that contains the original text to modify.
+///    Use this object to locate the correct text storage object for your view.
+///    - replacementText: The text to insert in place of the current text at `range`.
+///    You can insert this text as-is, insert a modified version of this string,
+///    or reject the replacement text altogether.
+///    - reason: The type of replacement Writing Tools performs. This parameter
+///    indicates whether Writing Tools is replacing the text with or without animations.
+///    - animationParameters: The animation parameters for any interactive changes,
+///    or `nil` if the changes aren’t interactive. Use this object to create any
+///    additional animations for the system to run alongside the changes Writing Tools
+///    makes. For example, use it to update other views that contain related information.
+///    - completion: A completion handler to execute with the results of the operation.
+///    The handler has no return value and takes an optional attributed string as
+///    a parameter. If you incorporate the replacement text, either as-is or with
+///    modifications, pass the actual string you incorporated to the completion
+///    block. If you reject the suggested change and leave the original text
+///    unchanged, specify `nil` for this parameter.
+///
+/// Use this method to update your view’s text storage with the proposed changes.
+/// Writing Tools can call this method multiple times during the course of a
+/// session to notify you of changes to different ranges of text. Incorporate
+/// the changes into your view’s text storage and notify your layout manager
+/// so it can refresh the view.
+///
+/// > Important: When integrating changes, remember to update `range.location` as needed
+/// to get the correct location in your view’s text storage.
+///
+/// Remove the text in the appropriate range of your text storage, and replace
+/// it with the contents of `replacementText`. When you finish, call the completion
+/// handler and pass in the replacement text you inserted. If you change the
+/// string in `replacementText` before incorporating it into your text storage,
+/// return your modified string instead. Returning the string lets Writing Tools
+/// track any alterations you made to it. You can also pass `nil` to the
+/// completion handler if you don’t incorporate the replacement text.
+///
+/// For interactive changes, Writing Tools works with your delegate to animate
+/// the removal of the old text and the insertion of any replacement text. If
+/// you need to modify other parts of your interface to reflect the changes,
+/// use the provided ``NSWritingToolsCoordinator/AnimationParameters`` object
+/// to create additional animations to run at the same time as the system-provided animations.
+- (void)writingToolsCoordinator:(NSWritingToolsCoordinator *)writingToolsCoordinator replaceRange:(NSRange)range inContext:(NSWritingToolsCoordinatorContext *)context proposedText:(NSAttributedString *)replacementText reason:(NSWritingToolsCoordinatorTextReplacementReason)reason  animationParameters:(NSWritingToolsCoordinatorAnimationParameters *__nullable)animationParameters completion:(void(^)(NSAttributedString *__nullable attributedString))completion;
+
+/// Asks the delegate to update your view’s current text selection.
+///
+/// - Parameters:
+///    - writingToolsCoordinator: The coordinator object making the change
+///    to your view.
+///    - ranges: One or more ranges of text to select. Each range is relative
+///    to the text in your context object, and it’s your responsibility to
+///    match each location to the correct location in your text storage. If
+///    you initialized the context object with the entire contents of your
+///    view’s text storage, you can use the ranges as-is to access that text
+///    storage. However, if you initialized the context object with only a
+///    portion of your view’s text, add the starting location of your context
+///    object’s text to each value to get the correct range for that text storage.
+///    - context: The context object you use to identify the associated text storage.
+///    - completion: The completion handler to execute when your delegate finishes updating
+///    the selection. The handler has no parameters or return value. You must
+///    call this handler at some point during the implementation of your method.
+///
+/// As Writing Tools suggests changes to your view’s text, it calls this method
+/// to update the text selection accordingly. Use this method to update the
+/// current selection in your view’s text storage. When you finish making the
+/// changes, call the provided completion block to let Writing Tools know you’re finished.
+- (void)writingToolsCoordinator:(NSWritingToolsCoordinator *)writingToolsCoordinator selectRanges:(NSArray<NSValue * /* NSRange */> *)ranges inContext:(NSWritingToolsCoordinatorContext *)context completion:(void(^)(void))completion NS_SWIFT_NAME(writingToolsCoordinator(_:select:in:completion:));
+
+/// Asks the delegate to provide the location of the character at the
+/// specified point in your view’s coordinate system.
+///
+/// - Parameters:
+///     - writingToolsCoordinator: The coordinator object requesting
+///     information from your custom view.
+///     - point: A point in your view’s coordinate space. Find the
+///     location of the text under this point, if any.
+///     - completion: A handler to execute with the required information.
+///     This handler has no return value and takes an <doc://com.apple.documentation/documentation/foundation/nsrange>
+///     and <doc://com.apple.documentation/documentation/foundation/uuid>
+///     as parameters. Set the range to the character’s location in one of your
+///     ``NSWritingToolsCoordinator/Context`` objects, which you specify using
+///     the <doc://com.apple.documentation/documentation/foundation/uuid> parameter.
+///     You must call this handler at some point during your method’s implementation.
+///
+/// When someone interacts with your view during a proofreading operation, Writing Tools
+/// calls this method to get the location of the interaction. If the interaction
+/// occurs in the text of one of your ``NSWritingToolsCoordinator/Context`` objects,
+/// configure an <doc://com.apple.documentation/documentation/foundation/nsrange>
+/// with the character’s location in that context object and a length of `1`. If
+/// the interaction occurs outside of the text of your context objects, configure
+/// the range with a location of `NSNotFound`.
+///
+/// When specifying the location of a character in your context object, provide a
+/// location relative to the start of your context object’s text. The first character
+/// in a context object’s text is always at location `0`, and it’s your responsibility
+/// to track the location of the context object’s text in your text storage object.
+/// When the context object’s text begins in the middle of your text storage,
+/// subtract the starting location of the context object’s text from the location
+/// you specify in your range value. For example, if the context object’s text
+/// starts at character `100` in your text storage, and an interaction occurs
+/// with the character at location `102`, specify a range with a location of
+/// `2` and a length of `1`.
+- (void)writingToolsCoordinator:(NSWritingToolsCoordinator *)writingToolsCoordinator requestsRangeInContextWithIdentifierForPoint:(CGPoint)point completion:(void(^)(NSRange range, NSUUID *contextID))completion NS_SWIFT_ASYNC_NAME(writingToolsCoordinator(_:rangeInContextWithIdentifierFor:));
+
+/// Asks the delegate to provide the bounding paths for the specified
+/// text in your view.
+///
+/// - Parameters:
+///     - writingToolsCoordinator: The coordinator object requesting information
+///     from your custom view.
+///     - range: The range of text to evaluate. This range is relative to the
+///     text in your context object, and it’s your responsibility to match that
+///     location to the correct location in your text storage. If you initialized
+///     the context object with the entire contents of your view’s text storage,
+///     you can use `range` as-is to access that text storage. However, if you
+///     initialized the context object with only a portion of your view’s text,
+///     add the starting location of your context object’s text to this value to
+///     get the correct range for that text storage.
+///     - context: The context object with the target text. Use this object to
+///     find the text in your view’s text storage.
+///     - completion: A handler to execute with the required information. The
+///     handler has no return value and takes an array of Bezier paths as a
+///     parameter. You must call this handler at some point during your method’s implementation.
+///
+/// After applying proofreading marks to your view’s text, Writing Tools lets
+/// the person accept or reject individual suggestions. To facilitate interactions,
+/// the coordinator asks your delegate to provide one or more Bezier paths that
+/// surround those proofreading suggestions. For each distinct range of text
+/// with a suggestion, it calls this method to get the Bezier paths that surround
+/// the corresponding text.
+///
+/// After you determine the location of the specified range of text in your view’s
+/// text storage, find the rectangle around that text. If you're using TextKit, call the <doc://com.apple.documentation/documentation/uikit/nstextlayoutmanager/3809995-enumeratetextsegments>
+/// method of your view’s <doc://com.apple.documentation/documentation/uikit/nstextlayoutmanager>
+/// to compute the selection rectangles for that text. That method finds the text
+/// segments that contain the text and returns the frame rectangle for each one.
+/// Create a Bezier path for each rectangle, and convert the coordinates of each path
+/// to the coordinate space of the view in your coordinator's ``NSWritingToolsCoordinator/decorationContainerView``
+/// property. Pass the resulting paths to the completion handler.
+- (void)writingToolsCoordinator:(NSWritingToolsCoordinator *)writingToolsCoordinator requestsBoundingBezierPathsForRange:(NSRange)range inContext:(NSWritingToolsCoordinatorContext *)context completion:(void(^)(NSArray<NSBezierPath *> *bezierPaths))completion NS_SWIFT_ASYNC_NAME(writingToolsCoordinator(_:boundingBezierPathsFor:context:));
+
+/// Asks the delegate to provide an underline shape for the specified text
+/// during a proofreading session.
+///
+/// - Parameters:
+///     - writingToolsCoordinator: The coordinator object requesting information
+///     from your custom view.
+///     - range: The range of text to evaluate. This range is relative to the
+///     text in your context object, and it’s your responsibility to match that
+///     location to the correct location in your text storage. If you initialized
+///     the context object with the entire contents of your view’s text storage,
+///     you can use `range` as-is to access that text storage. However, if you
+///     initialized the context object with only a portion of your view’s text,
+///     add the starting location of your context object’s text to this value
+///     to get the correct range for that text storage.
+///     - context: The context object with the target text. Use this object to
+///     find the text in your view’s text storage.
+///     - completion: A handler to execute with the required information. The
+///     handler has no return value and takes an array of Bezier paths as a
+///     parameter. You must call this handler at some point during your method’s implementation.
+///
+/// When applying proofreading marks to your view’s content, the coordinator
+/// calls this method to retrieve a shape to draw under the specified text.
+/// You provide the shape using one or more Bezier paths, and the coordinator
+/// draws and animates that shape during the proofreading session.
+///
+/// After you determine the location of the specified range of text in your
+/// view’s text storage, find the rectangle around that text. If you're using
+/// TextKit, you can call the <doc://com.apple.documentation/documentation/uikit/nstextlayoutmanager/3809995-enumeratetextsegments>
+/// method of your view’s <doc://com.apple.documentation/documentation/uikit/nstextlayoutmanager>
+/// to get the rectangles for a range of text. Convert the coordinates of each rectangle
+/// to the coordinate space of the view in your coordinator's ``NSWritingToolsCoordinator/decorationContainerView``
+/// property. Use those rectangles to create the Bezier paths for your text.
+/// For example, you might create a path with a straight or wavy line at the
+/// bottom of the rectangle.
+- (void)writingToolsCoordinator:(NSWritingToolsCoordinator *)writingToolsCoordinator requestsUnderlinePathsForRange:(NSRange)range inContext:(NSWritingToolsCoordinatorContext *)context completion:(void(^)(NSArray<NSBezierPath *> *bezierPaths))completion NS_SWIFT_ASYNC_NAME(writingToolsCoordinator(_:underlinePathsFor:context:));
+
+//
+// Animation support
+//
+// range.location is an offset from the beginning of the resolvedRange throughout. Expected to match textual view's text storage, presuming client has been updating as expected through the text delegate replaceRange
+
+/// Prepare for animations for the content that Writing Tools is evaluating.
+///
+/// - Parameters:
+///    - writingToolsCoordinator: The coordinator object notifying you that
+///    animations are about to begin.
+///    - textAnimation: The type of animation Writing Tools is preparing.
+///    - range: The range of text affected by the animation. This range is
+///    relative to the text in your context object, and it’s your responsibility
+///    to match that location to the correct location in your text storage.
+///    If you initialized the context object with the entire contents of your
+///    view’s text storage, you can use `range` as-is to access that text
+///    storage. However, if you initialized the context object with only a portion
+///    of your view’s text, add the starting location of your context object’s
+///    text to this value to get the correct range for that text storage.
+///    - context: The context object that contains the original text. Use this
+///    object to fetch the current text, and to match that text to your underlying
+///    text storage.
+///    - completion: A completion handler to execute when you are done. The handler
+///    has no return value and takes no parameters. You must call this handler
+///    at some point during your implementation.
+///
+/// During an interactive evaluation of your view’s text, Writing Tools creates
+/// different animations to provide feedback on what’s happening. For example, it
+/// creates an ``NSWritingToolsCoordinator/TextAnimation/anticipate`` animation to
+/// let people know the system is evaluating the text. The `textAnimation` parameter
+/// tells you what type of animation to prepare for.
+///
+/// Use this method to prepare for the system-provided animations of your view’s
+/// content. For interactive animations, hide the text in the specified range temporarily
+/// while the system animations run. For non-interactive animations, dim the text
+/// for the duration of the animation to indicate it’s not editable. For animations
+/// to remove or insert text, you can also use this method to set up animations
+/// to reflow your view’s content to match the changes. At the end of a given animation,
+/// use your delegate’s ``writingToolsCoordinator(_:finish:for:in:completion:)``
+/// method to undo any changes you make to your content.
+///
+/// For a single animation type, the system calls this method, followed sequentially
+/// by the ``writingToolsCoordinator(_:previewFor:range:context:completion:)``
+/// and ``writingToolsCoordinator(_:finish:for:in:completion:)``
+/// methods. Each method executes asynchronously, but the system calls the next
+/// method in the sequence only after you call the completion handler of the previous
+/// method. However, multiple animations can run simultaneously, so check the
+/// `textAnimation` and `range` parameters to differentiate sequences.
+- (void)writingToolsCoordinator:(NSWritingToolsCoordinator *)writingToolsCoordinator prepareForTextAnimation:(NSWritingToolsCoordinatorTextAnimation)textAnimation forRange:(NSRange)range inContext:(NSWritingToolsCoordinatorContext *)context completion:(void(^)(void))completion;
+
+/// Asks the delegate for a preview image and layout information for the
+/// specified text.
+///
+/// - Parameters:
+///    - writingToolsCoordinator: The coordinator object notifying you that
+///    animations are about to begin.
+///    - textAnimation: The type of animation Writing Tools is preparing.
+///    - range: The range of text that requires a preview image. This range
+///    is relative to the text in your context object, and it’s your responsibility
+///    to match that location to the correct location in your text storage.
+///    If you initialized the context object with the entire contents of
+///    your view’s text storage, you can use `range` as-is to access that
+///    text storage. However, if you initialized the context object with only
+///    a portion of your view’s text, add the starting location of your
+///    context object’s text to this value to get the correct range for that
+///    text storage.
+///    - context: The context object that contains the original text. Use this
+///    object to fetch the current text, and to match that text to your
+///    underlying text storage.
+///    - completion: A completion handler to execute when you are done. The
+///    handler has no return value and takes an ``NSTextPreview`` object
+///    as a parameter. You must call this handler at some point during your implementation.
+///
+/// During an interactive evaluation of your view’s text, Writing Tools creates
+/// different animations to provide feedback on what’s happening. As part of
+/// the preparation for those animations, Writing Tools asks you to provide
+/// a preview of the affected content in your view. Writing Tools uses this
+/// preview to build and execute the animations in the view stored in the
+/// ``NSWritingToolsCoordinator/effectContainerView`` property of the coordinator object.
+///
+/// To build a preview of your content in macOS, render the specified range of text
+/// into an image with a transparent background and use that image to create your
+/// ``NSTextPreview`` object directly. Set the ``NSTextPreview/presentationFrame``
+/// property to the rectangle in your view’s coordinate space that contains the
+/// text you captured. Set the ``NSTextPreview/candidateRects`` property to the
+/// selection rectangles for the text, which you get from your view’s layout manager.
+/// Writing Tools uses this information to place your image directly above the text in your view.
+///
+/// For a single animation type, the system calls the
+/// ``writingToolsCoordinator(_:prepareFor:range:context:completion:)``
+/// method, followed sequentially by this method and then the
+/// ``writingToolsCoordinator(_:finish:for:in:completion:)``
+/// method. Each method executes asynchronously, but the system calls the next
+/// method in the sequence only after you call the completion handler of the
+/// previous method. However, multiple animations can run simultaneously, so
+/// check the `textAnimation` parameter to differentiate sequences.
+- (void)writingToolsCoordinator:(NSWritingToolsCoordinator *)writingToolsCoordinator requestsPreviewForTextAnimation:(NSWritingToolsCoordinatorTextAnimation)textAnimation ofRange:(NSRange)range inContext:(NSWritingToolsCoordinatorContext *)context completion:(void(^)(NSArray<NSTextPreview *> * _Nullable textPreviews))completion NS_SWIFT_ASYNC_NAME(writingToolsCoordinator(_:previewFor:range:context:));
+
+/// Asks the delegate for a preview image and layout information for the
+/// specified text.
+///
+/// - Parameters:
+///    - writingToolsCoordinator: The coordinator object notifying you that
+///    animations are about to begin.
+///    - rect: The portion of your view that contains the requested text. This rectangle is in the view’s coordinate system.
+///    - context: The context object that contains the original text. Use this
+///    object to fetch the current text, and to match that text to your
+///    underlying text storage.
+///    - completion: A completion handler to execute when you are done. The
+///    handler has no return value and takes an ``NSTextPreview`` object
+///    as a parameter. You must call this handler at some point during your implementation.
+///
+/// During an interactive evaluation of your view’s text, Writing Tools creates
+/// different animations to provide feedback on what’s happening. As part of
+/// the preparation for those animations, Writing Tools asks you to provide
+/// a preview of the affected content in your view. Writing Tools uses this
+/// preview to build and execute the animations in the view stored in the
+/// ``NSWritingToolsCoordinator/effectContainerView`` property of the coordinator object.
+///
+/// To build a preview of your content in macOS, render the requested portion
+/// of your view into an image with a transparent background and use that image
+/// to create your ``NSTextPreview`` object directly. Set the ``NSTextPreview/presentationFrame``
+/// property to the specified rectangle. Set the ``NSTextPreview/candidateRects``
+/// property to the selection rectangles for the associated text, which you get
+/// from your view’s layout manager. Writing Tools uses this information to
+/// place your image directly above the text in your view.
+///
+/// For a single animation type, the system calls the
+/// ``writingToolsCoordinator(_:prepareFor:range:context:completion:)``
+/// method, followed sequentially by this method and then the
+/// ``writingToolsCoordinator(_:finish:for:in:completion:)``
+/// method. Each method executes asynchronously, but the system calls the next
+/// method in the sequence only after you call the completion handler of the
+/// previous method. However, multiple animations can run simultaneously, so
+/// check the `textAnimation` parameter to differentiate sequences.
+- (void)writingToolsCoordinator:(NSWritingToolsCoordinator *)writingToolsCoordinator requestsPreviewForRect:(NSRect)rect inContext:(NSWritingToolsCoordinatorContext *)context completion:(void(^)(NSTextPreview * _Nullable textPreview))completion NS_SWIFT_ASYNC_NAME(writingToolsCoordinator(_:previewFor:context:));
+
+/// Asks the delegate to clean up any state related to the specified
+/// Writing Tools animation.
+///
+/// - Parameters:
+///    - writingToolsCoordinator: The coordinator object notifying you
+///    that animations are about to begin.
+///    - textAnimation: The type of animation Writing Tools finished.
+///    - range: The range of text that finished animating. This range is
+///    relative to the text in your context object, and it’s your responsibility
+///    to match that location to the correct location in your text storage.
+///    If you initialized the context object with the entire contents of
+///    your view’s text storage, you can use `range` as-is to access that
+///    text storage. However, if you initialized the context object with
+///    only a portion of your view’s text, add the starting location of
+///    your context object’s text to this value to get the correct range
+///    for that text storage.
+///    - context: The context object that contains the original text.
+///    - completion: A completion handler to execute when you are done.
+///    The handler has no return value and takes no parameters. You must
+///    call this handler at some point during your implementation.
+///
+/// Use this method to clean up any data structures you created to support
+/// the specified type of Writing Tools animation. You can also use this
+/// method to restore the visibility of any text you hid previously. When
+/// you finish your cleanup work, call the completion handler to notify Writing Tools.
+///
+/// Writing Tools calls this method only after previous calls to the
+/// ``writingToolsCoordinator(_:prepareFor:range:context:completion:)``
+/// and ``writingToolsCoordinator(_:previewFor:range:context:completion:)``
+/// methods for the same animation type. However, Writing Tools can interleave
+/// calls to this method with calls to prepare an animation of a different
+/// type. In your implementation of this method, make sure the actions you
+/// take don’t interfere with other in-flight animations.
+- (void)writingToolsCoordinator:(NSWritingToolsCoordinator *)writingToolsCoordinator finishTextAnimation:(NSWritingToolsCoordinatorTextAnimation)textAnimation forRange:(NSRange)range inContext:(NSWritingToolsCoordinatorContext *)context completion:(void(^)(void))completion;
+
+@optional
+
+// Multiple container support
+
+// The NSTextPreview's container will be used for a coordinate conversion into the effectContainerView
+
+/// Asks the delegate to divide the specified range of text into the separate
+/// containers that render that text.
+///
+/// - Parameters:
+///     - writingToolsCoordinator: The coordinator object requesting information
+///     from your custom view.
+///     - range: The range of text to consider in the specified `context` object.
+///     The location value of this range is relative to the beginning of the text
+///     in your context object, and it’s your responsibility to match that location
+///     to the correct location in your text storage. If you initialized the
+///     context object with the entire contents of your view’s text storage,
+///     you can use `range` as-is to access that text storage. However, if you
+///     initialized the context object with only a portion of your view’s text,
+///     add the starting location of your context object’s text to this value
+///     to get the correct range for that text storage.
+///     - context: The context object that contains the text to consider. Use this
+///     object to locate the appropriate text storage object for your view.
+///     - completion: A completion handler to execute when you are done. The handler
+///     has no return value and takes an array of <doc://com.apple.documentation/documentation/foundation/nsvalue>
+///     types, each of which contains an <doc://com.apple.documentation/documentation/foundation/nsrange>.
+///     The union of the ranges you pass to this handler must equal all of the
+///     text in `range`. The order of the ranges in the array must be sequential,
+///     with each new range's starting location coming after the previous one.
+///     There must also not be any gaps or overlap between ranges.
+///     You must call this handler at some point during your implementation.
+///
+/// If your view uses multiple ``NSTextContainer`` objects to draw text in different
+/// regions, use this method to tell Writing Tools about the containers that display
+/// the specified text. In your implementation, subdivide `range` to create one new
+/// range for each portion of text that resides in a different container object.
+/// For example, if the text in `range` is split between two containers, provide
+/// two new <doc://com.apple.documentation/documentation/foundation/nsrange> types
+/// that reflect the portion of the total text in each container. If `range` resides completely
+/// within one container, call the completion handler with `range` as the only value
+/// in the array.
+///
+/// When configuring animations for your view, Writing Tools asks your delegate to
+/// provide separate previews for each of your view’s container object. Specifically,
+/// it calls your delegate’s ``writingToolsCoordinator(_:previewFor:range:context:completion:)``
+/// method separately for each range of text you return in the completion handler.
+/// Your implementation of that method must create a preview suitable for animating
+/// the content from the underlying text container.
+- (void)writingToolsCoordinator:(NSWritingToolsCoordinator *)writingToolsCoordinator requestsSingleContainerSubrangesOfRange:(NSRange)range inContext:(NSWritingToolsCoordinatorContext *)context completion:(void(^)(NSArray<NSValue */*NSRange*/> *))completion NS_SWIFT_ASYNC_NAME(writingToolsCoordinator(_:singleContainerSubrangesOf:in:));
+
+/// Asks the delegate to provide a decoration view for the specified range of text.
+///
+/// - Parameters:
+///     - writingToolsCoordinator: The coordinator object requesting information
+///     from your custom view.
+///     - range: The range of text to consider in the specified `context` object.
+///     The location value of this range is relative to the beginning of the text
+///     in your context object, and it’s your responsibility to match that location
+///     to the correct location in your text storage. If you initialized the
+///     context object with the entire contents of your view’s text storage, you
+///     can use `range` as-is to access that text storage. However, if you initialized
+///     the context object with only a portion of your view’s text, add the starting
+///     location of your context object’s text to this value to get the correct
+///     range for that text storage.
+///     - context: The context object that contains the text to consider. Use this
+///     object to locate the appropriate text storage object for your view.
+///     - completion: A completion handler to execute when you are done. The handler
+///     has no return value and takes an ``NSView`` object as a parameter. You must call
+///     this handler at some point during your implementation.
+///
+/// If your view uses multiple ``NSTextContainer`` objects to draw text in different
+/// regions, use this method to provide Writing Tools with the view to use for the
+/// specified range of text. After calling your delegate’s ``writingToolsCoordinator(_:singleContainerSubrangesOf:in:)``
+/// method, Writing Tools calls this method for each subrange of text you provided.
+/// Find or provide a view situated visibly below the specified text in your text
+/// view. It's also satisfactory to provide a view that’s visually in front of the
+/// text. Writing Tools uses the provided view to host any proofreading marks for
+/// the specified range of text.
+///
+/// If your view has only one text container, use the coordinator’s ``NSWritingToolsCoordinator/decorationContainerView``
+/// property to specify the view to use for proofreading marks.
+- (void)writingToolsCoordinator:(NSWritingToolsCoordinator *)writingToolsCoordinator requestsDecorationContainerViewForRange:(NSRange)range inContext:(NSWritingToolsCoordinatorContext *)context completion:(void(^)(NSView *))completion NS_SWIFT_ASYNC_NAME(writingToolsCoordinator(_:decorationContainerViewFor:in:));
+
+// Lifecycle
+
+// Possible state changes
+//  Inactive -> Noninteractive
+//  Noninteractive -> Inactive
+//  Inactive -> InteractiveResting
+//  InteractiveResting -> InteractiveStreaming
+//  InteractiveResting -> Inactive
+//  InteractiveStreaming -> InteractiveResting
+//  InteractiveStreaming -> Inactive
+
+/// Notifies your delegate of relevant state changes when Writing Tools
+/// is running in your view.
+///
+/// - Parameters:
+///     - writingToolsCoordinator: The coordinator object providing
+///     information to your custom view.
+///     - state: The new state for the Writing Tools session. For information
+///     about the possible states, see ``NSWritingToolsCoordinator/State``.
+///     - text: The current text for your context object.
+///     - reason: The reason for the state change.
+///     - context: The context object that contains the original text for
+///     Writing Tools to evaluate.
+///     - completion: A handler to execute when your delegate finishes processing
+///     the change of state. The handler has no parameters or return value. You
+///     must call this handler at some point during the implementation of your method.
+///
+/// Use state transitions to perform actions related to your view or text storage.
+/// When Writing Tools is active, it updates its state to indicate what task
+/// it’s currently performing. Writing Tools starts in the ``NSWritingToolsCoordinator/State/inactive``
+/// state and moves to other states as it presents UI and starts interacting with
+/// your view’s content. For example, it moves to the ``NSWritingToolsCoordinator/State/interactiveUpdating``
+/// state when it’s making changes to your view’s text storage.
+- (void)writingToolsCoordinator:(NSWritingToolsCoordinator *)writingToolsCoordinator willChangeToState:(NSWritingToolsCoordinatorState)newState completion:(void(^)(void))completion;
+@end
+
+#pragma mark NSTextPreview
+/// A snapshot of the text in your view, which the system uses to create
+/// user-visible effects.
+///
+/// An `NSTextPreview` object provides a static image of your view’s text
+/// content that the system can use to create animations. You provide preview
+/// objects in response to system requests, such as ones from Writing Tools.
+/// In addition to creating an image of your view’s text, you also specify
+/// the location of that text in your view’s frame rectangle. When creating
+/// animations, the system places the image on top of your view’s content
+/// and animates changes to the image instead of to your view.
+///
+/// Create an `NSTextPreview` object in response to specific system requests.
+/// Create an image with a transparent background and render your view’s text
+/// into the image using the current text attributes. Construct your `NSTextPreview`
+/// object with both the image and the frame rectangle that represents the
+/// location of the rendered text in your view’s coordinate system. To highlight
+/// specific portions of text, instead of all the text in the image, provide
+/// a set of candidate rectangles with the locations of the text you want to highlight.
+API_AVAILABLE(macos(15.2)) NS_SWIFT_UI_ACTOR
+@interface NSTextPreview : NSObject
+
+/// Creates a text preview using the specified image and rectangles that indicate
+/// the portions of text to highlight.
+///
+/// - Parameters:
+///     - snapshotImage: An image that contains the requested text from your view.
+///     Create the image using a transparent background and the current rendering
+///     attributes for your text.
+///     - presentationFrame: A rectangle in the coordinate space of your text view.
+///     The system uses this rectangle to place your image precisely over your
+///     view’s actual text. Set its size to the size of your snapshot image, and
+///     set its origin to the point that allows the system to place your image
+///     directly over the text.
+///     - candidateRects: An array of <doc://com.apple.documentation/documentation/foundation/nsvalue>
+///     objects, each of which contains an <doc://com.apple.documentation/documentation/foundation/nsrect>
+///     in the coordinate space of your text view. Each rectangle contains a
+///     bounding rectangle for text that is part of the preview. When applying
+///     visual effects, the system adds highlights only to the text in the specified rectangles.
+- (instancetype)initWithSnapshotImage:(CGImageRef)snapshotImage presentationFrame:(NSRect)presentationFrame candidateRects:(NSArray <NSValue /*NSRect*/ *> *)candidateRects NS_DESIGNATED_INITIALIZER;
+
+/// Creates a text preview using the specified image.
+///
+/// - Parameters:
+///     - snapshotImage: An image that contains the requested text from your view.
+///     Create the image using a transparent background and the current rendering
+///     attributes for your text.
+///     - presentationFrame: A rectangle in your frame’s coordinate space. The
+///     system uses this rectangle to place your image precisely over your view’s
+///     actual text. Set its size to the size of your snapshot image, and set its
+///     origin to the point that allows the system to place your image directly over the text.
+- (instancetype)initWithSnapshotImage:(CGImageRef)snapshotImage presentationFrame:(NSRect)presentationFrame;
+- (instancetype)init NS_UNAVAILABLE;
+
+/// The image that contains the requested text from your view.
+///
+/// You specify this image at initialization time. The system uses it to
+/// implement any visual effects involving your view’s text. Create the image
+/// with your text on a transparent background.
+@property (readonly) CGImageRef previewImage;
+
+/// The frame rectangle that places the preview image directly over the
+/// matching text.
+///
+/// You specify this value at initialization time. The system uses it to
+/// position the preview image over the text in your view. Make sure the
+/// frame rectangle is in your view's coordinate space.
+@property (readonly) NSRect presentationFrame;
+
+/// Rectangles that define the specific portions of text to highlight.
+///
+/// At initialization time, you set this property to an array of
+/// <doc://com.apple.documentation/documentation/foundation/nsvalue> objects,
+/// each of which contains an <doc://com.apple.documentation/documentation/foundation/nsrect>
+/// in the coordinate space of the target view. Each rectangle contains a bounding
+/// rectangle for text that is part of the preview. When applying visual effects,
+/// the system adds highlights only to the text in the specified rectangles.
+@property (readonly) NSArray <NSValue /*CGRect*/ *> *candidateRects;
+
+@end
+
+NS_ASSUME_NONNULL_END
+API_UNAVAILABLE_END
diff -ruN /Applications/Xcode_16.1.0.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk/System/Library/Frameworks/AppKit.framework/Headers/NSWritingToolsCoordinatorAnimationParameters.h /Applications/Xcode_16.2.0-beta2.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk/System/Library/Frameworks/AppKit.framework/Headers/NSWritingToolsCoordinatorAnimationParameters.h
--- /Applications/Xcode_16.1.0.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk/System/Library/Frameworks/AppKit.framework/Headers/NSWritingToolsCoordinatorAnimationParameters.h	1969-12-31 19:00:00
+++ /Applications/Xcode_16.2.0-beta2.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk/System/Library/Frameworks/AppKit.framework/Headers/NSWritingToolsCoordinatorAnimationParameters.h	2024-10-31 01:05:01
@@ -0,0 +1,67 @@
+/*
+     NSWritingToolsCoordinatorAnimationParameters.h
+     Application Kit
+     Copyright (c) 2024, Apple Inc.
+     All rights reserved.
+ */
+
+#import <Foundation/NSObject.h>
+#import <Foundation/NSRange.h>
+#import <Foundation/NSGeometry.h>
+#import <AppKit/AppKitDefines.h>
+
+@class NSAttributedString;
+@class NSUUID;
+
+NS_HEADER_AUDIT_BEGIN(nullability, sendability)
+
+/// An object you use to configure additional tasks or animations to
+/// run alongside the Writing Tools animations.
+///
+/// When Writing Tools replaces text in one of your context objects,
+/// it provides an `NSWritingToolsCoordinator.AnimationParameters` object for
+/// you to use to configure any additional animations. During a Writing
+/// Tools session, you hide the text under evaluation and provide a
+/// targeted preview of your content. Writing Tools animations changes
+/// to that preview, but you might need to provide additional animations
+/// for other parts of your view’s content. For example, you might
+/// need to animate any layout changes caused by the insertion or
+/// removal of text in other parts of your view. Use this object to
+/// configure those animations.
+///
+/// You don’t create an `NSWritingToolsCoordinator.AnimationParameters`
+/// object directly. Instead, the system creates one and passes it to the
+///``NSWritingToolsCoordinator/writingToolsCoordinator(_:replaceRange:inContext:proposedText:reason:animationParameters:completion:)``
+///method of your ``NSWritingToolsCoordinator/Delegate`` object. Use that
+///object to specify the blocks to run during and after the system animations.
+API_AVAILABLE(ios(18.2), macos(15.2)) NS_SWIFT_SENDABLE NS_SWIFT_NAME(NSWritingToolsCoordinator.AnimationParameters)
+@interface NSWritingToolsCoordinatorAnimationParameters : NSObject
+- (instancetype)init NS_UNAVAILABLE;
+
+/// The number of seconds it takes the system animations to run.
+@property (readonly) CGFloat duration;
+
+/// The number of seconds the system waits before starting its animations.
+@property (readonly) CGFloat delay;
+
+/// A custom block that runs at the same time as the system animations.
+///
+/// If you have animations you want to run at the same time as the system
+/// animations, assign a block to this property and use it to run your
+/// animations. The block you provide must have no return value and take
+/// a floating-point value as a parameter. The parameter indicates the
+/// current progress of the animations as a percentage value between
+/// `0.0` to `1.0`. The system executes your block multiple times during
+/// the course of the animations, providing an updated completion value each time.
+@property (nullable, strong) void(^progressHandler)(float progress);
+
+/// A custom block to run when the system animations finish.
+///
+/// Set this property to a block that you want the system to run when any
+/// animations finish. The block you provide must have no return value
+/// and no parameters. The system executes this block once when the current
+/// animation finish.
+@property (nullable, strong) void(^completionHandler)(void);
+@end
+
+NS_HEADER_AUDIT_END(nullability, sendability)
diff -ruN /Applications/Xcode_16.1.0.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk/System/Library/Frameworks/AppKit.framework/Headers/NSWritingToolsCoordinatorContext.h /Applications/Xcode_16.2.0-beta2.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk/System/Library/Frameworks/AppKit.framework/Headers/NSWritingToolsCoordinatorContext.h
--- /Applications/Xcode_16.1.0.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk/System/Library/Frameworks/AppKit.framework/Headers/NSWritingToolsCoordinatorContext.h	1969-12-31 19:00:00
+++ /Applications/Xcode_16.2.0-beta2.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk/System/Library/Frameworks/AppKit.framework/Headers/NSWritingToolsCoordinatorContext.h	2024-10-31 01:04:59
@@ -0,0 +1,142 @@
+/*
+     NSWritingToolsCoordinatorContext.h
+     Application Kit
+     Copyright (c) 2024, Apple Inc.
+     All rights reserved.
+ */
+
+#import <Foundation/NSObject.h>
+#import <Foundation/NSRange.h>
+#import <AppKit/AppKitDefines.h>
+
+@class NSAttributedString;
+@class NSUUID;
+
+NS_HEADER_AUDIT_BEGIN(nullability, sendability)
+
+/// A data object that you use to share your custom view’s text with Writing Tools.
+///
+/// At the start of every Writing Tools operation, you create one or more
+/// `NSWritingToolsCoordinator.Context` objects with a copy of the text you want Writing Tools
+/// to evaluate. Each Writing Tools operation starts with a call to the
+/// ``NSWritingToolsCoordinator/Delegate/writingToolsCoordinator(_:requestsContextsFor:completion:)``
+/// method of your ``NSWritingToolsCoordinator/Delegate`` object. Use the parameters
+/// of that method to determine how much of your view’s text to provide. For
+/// some operations, Writing Tools asks for all of your view’s text, but in
+/// others it asks for only a portion of the text. When Writing Tools finishes
+/// its evaluation, it reports changes back to your delegate relative to the
+/// context objects you provided.
+///
+/// When Writing Tools asks for your view’s text, create one or more
+/// `NSWritingToolsCoordinator.Context` objects with the requested content. If your view
+/// contains only one text storage object, create only one context object for
+/// the request. However, if you use multiple text storage objects to manage
+/// different parts of your view’s content, you might need to create multiple
+/// context objects. The actual number depends on how much of your text Writing
+/// Tools asks for. For example, when Writing Tools asks for all of your view’s
+/// content, you return one context object for each text storage object in your
+/// view. However, if Writing Tools asks for the current selection, and one
+/// text storage object contains all of the selected text, you create only
+/// one context object for the content.
+///
+/// Writing Tools uses your context objects as the starting point for its
+/// evaluations, and as a reference point for any changes. Because Writing
+/// Tools doesn’t know anything about your view or its content, it makes
+/// suggestions only relative to your context objects. It’s your responsibility
+/// to take those suggestions and incorporate them back into your view’s
+/// text storage. In some cases, you might need to store additional information
+/// to update your storage correctly. For example, you might need to store,
+/// and update as needed, the offset from the start of your document to the
+/// start of the text in your context object.
+///
+/// When Writing Tools asks for the currently selected text in your view,
+/// include some of the surrounding text in your context object as well.
+/// Supply a string that includes the selection and any text up to the nearest
+/// paragraph boundary. When creating your context object, specify a range
+/// value that represents the portion of that string that corresponds to the
+/// text selection. Providing some additional text in your context object can
+/// help Writing Tools improve its evaluation of your content. Writing Tools
+/// uses the ``resolvedRange`` property of your context object to indicate
+/// what text it considered.
+///
+/// If your context object includes text that you don’t want Writing Tools to
+/// evaluate, add the `excludeFromWritingTools` attribute to the corresponding
+/// characters of your <doc://com.apple.documentation/documentation/foundation/nsattributedstring>
+/// object. You might add this attribute if the text string includes a code
+/// listing or readonly content that you don’t want Writing Tools to change.
+API_AVAILABLE(macos(15.2)) NS_SWIFT_SENDABLE NS_SWIFT_NAME(NSWritingToolsCoordinator.Context)
+@interface NSWritingToolsCoordinatorContext : NSObject
+
+/// Creates a context object with the specified attributed string and range
+/// information.
+///
+/// - Parameters:
+///    - attributedString: A string that contains some or all of the content
+///    from your view’s text storage. This initializer makes a copy of the
+///    string you provide, so you can discard the original when you’re done.
+///    - range: The portion of `attributedString` you want Writing Tools to
+///    evaluate. If you want Writing Tools to evaluate the entire string you
+///    provided, specify a range with a location of `0` and a length equal to
+///    your string’s length. If you want Writing Tools to evaluate only part
+///    of the string, provide the appropriate range in this parameter. Writing
+///    Tools suggests changes only to the range of text you specify, but it
+///    can consider text outside that range during the evaluation process.
+///
+/// When Writing Tools asks for your view’s current selection, it’s best to
+/// create a string that includes text before and after that selection. During
+/// the evaluation process, Writing Tools can use the additional text you
+/// provided to improve the results it delivers. If you do provide additional
+/// text, set the `range` parameter to the portion of `attributedString` with
+/// the current selection. Don’t use the `range` parameter to specify the
+/// location of the text in your view’s text storage.
+- (instancetype)initWithAttributedString:(NSAttributedString *)attributedString range:(NSRange)range NS_DESIGNATED_INITIALIZER;
+- (instancetype)init NS_UNAVAILABLE;
+
+/// The portion of your view’s text to evaluate.
+///
+/// The ``NSWritingToolsCoordinator/Context`` object initializes the value of this
+/// property at creation time and doesn’t change it during the course of an operation.
+/// Instead, it suggests changes to the text in the indicated range and reports
+/// those changes to your ``NSWritingToolsCoordinator/Delegate`` object. Use the methods
+/// of your delegate object to integrate those changes back into your view’s text storage.
+///
+/// It’s your responsibility to track the location of this text in your
+/// view’s text storage object. When Writing Tools reports changes,
+/// it provides range values relative to this string. If you initialize
+/// this property with a subset of your view’s content, you must adjust
+/// any ranges that Writing Tools provides to get the correct location
+/// in your text storage.
+@property (copy, readonly) NSAttributedString *attributedString;
+
+/// The unique identifier of the context object.
+///
+/// The ``NSWritingToolsCoordinator/Context`` object initializes the value of this property
+/// at creation time. Use this value to identify the context object within your app.
+@property (readonly) NSRange range; // The range it was initialized with
+
+/// The unique identifier of the context object.
+///
+/// The ``NSWritingToolsCoordinator/Context`` object initializes the value of
+/// this property at creation time. Use this value to identify the
+/// context object within your app.
+@property (strong, readonly) NSUUID *identifier;
+
+/// The actual range of text that Writing Tools might change, which can
+/// be different than the range of text you supplied.
+///
+/// After analyzing the text in your context object, Writing Tools sets
+/// this property to the portion of ``attributedString`` it might modify.
+/// Initially, this property has a location of
+/// <doc://com.apple.documentation/documentation/foundation/nsnotfound> and a length
+/// of `0`, but Writing Tools updates those values before making any changes
+/// to the text.
+///
+/// While the Writing Tools operation is active, make sure Writing Tools has
+/// exclusive access to the text in this range. Your ``NSWritingToolsCoordinator/Delegate``
+/// object can make changes to the text as part of incorporating Writing Tools
+/// results, but don’t allow changes to come from other sources. For example,
+/// don’t let someone edit the text in this range directly until Writing Tools finishes.
+@property (readonly) NSRange resolvedRange; // The range that Writing Tools ends up using (sometimes larger than range)
+@end
+
+NS_HEADER_AUDIT_END(nullability, sendability)
Clone this wiki locally