Skip to content

CoreMIDI watchOS xcode13.0 beta3

Rachel Kang edited this page Jul 30, 2021 · 3 revisions

#CoreMIDI.framework

diff -ruN /Applications/Xcode_13.0.0-beta2.app/Contents/Developer/Platforms/WatchOS.platform/Developer/SDKs/WatchOS.sdk/System/Library/Frameworks/CoreMIDI.framework/Headers/CoreMIDI.h /Applications/Xcode_13.0.0-beta3.app/Contents/Developer/Platforms/WatchOS.platform/Developer/SDKs/WatchOS.sdk/System/Library/Frameworks/CoreMIDI.framework/Headers/CoreMIDI.h
--- /Applications/Xcode_13.0.0-beta2.app/Contents/Developer/Platforms/WatchOS.platform/Developer/SDKs/WatchOS.sdk/System/Library/Frameworks/CoreMIDI.framework/Headers/CoreMIDI.h	1969-12-31 19:00:00.000000000 -0500
+++ /Applications/Xcode_13.0.0-beta3.app/Contents/Developer/Platforms/WatchOS.platform/Developer/SDKs/WatchOS.sdk/System/Library/Frameworks/CoreMIDI.framework/Headers/CoreMIDI.h	2021-07-05 06:37:38.000000000 -0400
@@ -0,0 +1,32 @@
+/*
+ 	File:   	CoreMIDI/CoreMIDI.h
+ 
+ 	Contains:   Umbrella header for the CoreMIDI framework.
+ 
+ 	Copyright:  (c) 2000-2020 by Apple Inc., all rights reserved.
+ 
+ 	Bugs?:  	For bug reports, consult the following page on
+ 				the World Wide Web:
+ 
+ 					http://feedbackassistant.apple.com/
+ 
+*/
+
+#ifndef __CoreMIDI_h__
+#define __CoreMIDI_h__
+
+#include <CoreMIDI/MIDIServices.h>
+#include <CoreMIDI/MIDISetup.h>
+#include <CoreMIDI/MIDIThruConnection.h>
+#include <CoreMIDI/MIDIDriver.h>
+#include <CoreMIDI/MIDIMessages.h>
+
+#if __OBJC__
+#import <CoreMIDI/MIDINetworkSession.h>
+#endif
+
+#if __OBJC2__
+#import <CoreMIDI/MIDICapabilityInquiry.h>
+#endif
+
+#endif
diff -ruN /Applications/Xcode_13.0.0-beta2.app/Contents/Developer/Platforms/WatchOS.platform/Developer/SDKs/WatchOS.sdk/System/Library/Frameworks/CoreMIDI.framework/Headers/MIDICapabilityInquiry.h /Applications/Xcode_13.0.0-beta3.app/Contents/Developer/Platforms/WatchOS.platform/Developer/SDKs/WatchOS.sdk/System/Library/Frameworks/CoreMIDI.framework/Headers/MIDICapabilityInquiry.h
--- /Applications/Xcode_13.0.0-beta2.app/Contents/Developer/Platforms/WatchOS.platform/Developer/SDKs/WatchOS.sdk/System/Library/Frameworks/CoreMIDI.framework/Headers/MIDICapabilityInquiry.h	1969-12-31 19:00:00.000000000 -0500
+++ /Applications/Xcode_13.0.0-beta3.app/Contents/Developer/Platforms/WatchOS.platform/Developer/SDKs/WatchOS.sdk/System/Library/Frameworks/CoreMIDI.framework/Headers/MIDICapabilityInquiry.h	2021-07-13 00:34:09.000000000 -0400
@@ -0,0 +1,398 @@
+/*
+ File:       CoreMIDI/MIDICapabilityInquiry.h
+ 
+ Contains:   API for MIDI Capability Inquiry (MIDI-CI)
+ 
+ Copyright:  (c) 2018-2020 by Apple Inc., all rights reserved.
+ 
+ Bugs?:      For bug reports, consult the following page on
+ the World Wide Web:
+ 
+ http://feedbackassistant.apple.com/
+ */
+
+// This API requires the modern Objective-C runtime.
+#if !defined(MIDICapabilityInquiry_h)
+#define MIDICapabilityInquiry_h
+
+/*!
+    @header MIDICapabilityInquiry.h
+
+    This is the header file for MIDI Capability Inquiry (MIDI-CI) system services.
+
+	API Overview
+	------------
+	
+    MIDI-CI is the portion of MIDI 2.0 that allows for the selection of data protocol and the
+    advertisement and manipulation of profiles and properties. These three capabilities are
+    sometimes referred to as the three P's. MIDI 2.0 (and specifically MIDI-CI) are bidirectional
+    protocols, unlike MIDI 1.0 which could be unidirectional or bidirectional.
+
+    The two sides of MIDI-CI communication are the Initiator and Responder. Most MIDI-CI messages
+    can only be sent from the Initiator or from the Responder, but a small number of messages could
+    originate from the Initiator or the Responder.
+
+    MIDI client processes playing the Initiator roles of a MIDI-CI connection use the MIDICISession
+    API, which allows for profile and property manipulation on the associated responder. MIDI client
+    processes that wish to advertise their own profile and property capabilities use the MIDICIResponder
+    API, which is capable of sending Responder-originated MIDI-CI messages to Initiators.
+
+	Implementation overview
+	-----------------------
+	
+    With MIDI-CI beta enabled, Universal MIDI System Exclusive (SysEx) messages are filtered from the
+    I/O stream and sent to the MIDI-CI subsystem for routing and handling. Other SysEx messages are
+    untouched. In the release API, filtering will be on by default, and Universal MIDI SysEx messages
+    with associated CoreMIDI API will only be received and routed by the MIDI-CI subsystem.
+ 
+    Discovering MIDI-CI capable nodes managed by CoreMIDI is accomplished with MIDICIDiscoveryManager,
+    which sends a MIDI-CI discovery message to all MIDI destinations in the system and aggregates the
+    respondents as MIDICIDiscoveredNode objects.
+        
+    After MIDI-CI discovery has been performed, a MIDI client process may act as Initiator by creating
+    a MIDICISession using a MIDICIDiscoveredNode. The MIDICISession is synchronously returned prior to
+    capability inquiry, and the supplied handler is invoked once the results are received or after
+    timeout. Any available profiles may then be examined/toggled for each channel and the whole port
+    (represented  by MIDI channel 0x7F).
+    
+    No API for protocol negotiation is currently supplied. CoreMIDI is MIDI 2.0-capable system-wide
+    and will not only select the appropriate protocol for connected hardware but will also automatically
+    convert between MIDI 1.0 and MIDI 2.0 protocol as needed. See MIDIServices.h for API guidelines and
+    usage for MIDI 2.0 protocol and Universal MIDI Packets (UMP).
+    
+    Additionally, no explicit property exchange API is provided. However, property exchange can be
+    accomplished by performing first performing MIDI-CI discovery and then sending the appropriate
+    Universal MIDI SysEx messages to the supplied destination and monitoring the MIDICISession's
+    supplied source. Responses to Has Property, Get Property, Set Property, and Subscribe to
+    Property messages are not filtered by the MIDI-CI subsystem and can be received by any MIDI client.
+    However, Property Exchange capabilities must still be discovered using API first since the
+    Inquiry: Property Exchange Capabilities (msg ID 0x30) and Reply to Property Exchange Capabilities
+    (msg ID 0x31) are reserved by CoreMIDI.
+     
+    A MIDI client process may also/instead play the role of responder by creating a MIDICIResponderDelegate
+    and then a MIDICIResponder. Similarly to MIDICISession, a MIDICIResponder may advertise property
+    capabilities, but the details of property exchange rely on the implementation.
+ 
+    Please visit http://www.midi.org/specifications for more information on MIDI Capability Inquiry
+    and a list of currently defined capabilities.
+*/
+
+
+#import <CoreMIDI/MIDIServices.h>
+
+/// MIDI Channel, 0~15 (channels 1 through 16, respectively), or MIDIChannelsWholePort.
+/// Per the MIDI-CI specification, this is always a single byte.
+typedef uint8_t MIDIChannelNumber;
+
+/// All MIDI-CI methods involving a channel number use 0x7f to mean "the whole port", i.e. all
+/// channels.
+static const MIDIChannelNumber MIDIChannelsWholePort = 0x7f;
+
+/*!
+ @struct MIDICIDeviceIdentification
+ @brief  struct describing a MIDI-CI device.
+ */
+struct MIDICIDeviceIdentification {
+    uint8_t manufacturer[3];
+    uint8_t family[2];
+    uint8_t modelNumber[2];
+    uint8_t revisionLevel[4];
+    uint8_t reserved[5];		// always zero
+};
+typedef struct MIDICIDeviceIdentification MIDICIDeviceIdentification;
+
+#if defined(__OBJC2__)
+#import <Foundation/Foundation.h>
+#import <stdint.h>
+
+#define MIDICI1_0_AVAILABILITY API_AVAILABLE(macos(10.14), ios(12.0)) API_UNAVAILABLE(watchos, tvos)
+#define MIDICI1_1_AVAILABILITY API_AVAILABLE(macos(11.0), ios(14.0)) API_UNAVAILABLE(watchos, tvos)
+
+NS_ASSUME_NONNULL_BEGIN
+
+// Forward declarations.
+@class MIDICISession;
+@class MIDICIProfile;
+@class MIDICIProfileState;
+@class MIDICIResponder;
+@class MIDICIDiscoveredNode;
+
+//! The unique MIDI-CI negotiation identifier (MUID) used for a MIDICIResponder connection.
+//! Per the MIDI-CI specification, this is a randomly assigned 28-bit integer.
+typedef NSNumber * MIDICIInitiatiorMUID;
+
+//! An array of MIDICIProfileState objects that describes the profile
+//! configuration for all channels for a reachable MIDI-CI node.
+typedef NSArray<MIDICIProfileState *> MIDICIProfileStateList;
+
+// =================================================================================================
+
+/*!
+ 	@class		MIDICIDeviceInfo
+ 	@brief  	An NSObject containing basic information about a MIDI-CI-capable node.
+*/
+MIDICI1_1_AVAILABILITY
+@interface MIDICIDeviceInfo : NSObject <NSSecureCoding>
+
+/// The MIDI System Exclusive ID of the device manufacturer, 3 bytes long. One-byte SysEx IDs are
+/// padded with trailing zeroes (e.g., Apple's System Exclusive ID, 0x11, would be expressed as 0x110000).
+@property (nonatomic, readonly) NSData *manufacturerID;		// 3 bytes
+
+/// The group of models to which the device belongs, 2 bytes.
+@property (nonatomic, readonly) NSData *family;				// 2 bytes
+
+/// The specific model from the device manufacturer, 2 bytes.
+@property (nonatomic, readonly) NSData *modelNumber;		// 2 bytes
+
+/// The version number of a device model number, 2 bytes.
+@property (nonatomic, readonly) NSData *revisionLevel;		// 4 bytes
+
+/// The MIDI destination used by device's MIDI entity for capability inquiries.
+@property (nonatomic, readonly) MIDIEndpointRef midiDestination;
+
+- (instancetype)init NS_UNAVAILABLE;
+- (instancetype)initWithDestination:(MIDIEntityRef)midiDestination manufacturer:(NSData *)manufacturer family:(NSData *)family model:(NSData *)modelNumber revision:(NSData *)revisionLevel;
+@end
+
+// =================================================================================================
+
+/*!
+ 	@class		MIDICIProfile
+ 	@abstract  	An NSObject representing Capability Inquiry profile. MIDI-CI profiles describe a mapping
+				of MIDI messages to specific sounds and synthesis behaviors, e.g. General MIDI, a drawbar organ,
+				etc. A MIDI-CI profile may be a standard registered profile or vendor-specific.
+ 
+								Standard Profile				Vendor-Specific Profile
+				Profile ID Byte 1:	0x7E Standard Profile			Manufacturer SysEx ID 1 Profile
+				Profile ID Byte 2:	Profile Bank				Manufacturer SysEx ID 2 Profile
+				Profile ID Byte 3:	Profile Number				Manufacturer SysEx ID 3 Profile
+				Profile ID Byte 4:	Profile Version				Manufacturer-specific Info
+				Profile ID Byte 5:	Profile Level				Manufacturer-specific Info
+*/
+MIDICI1_0_AVAILABILITY
+@interface MIDICIProfile : NSObject <NSSecureCoding>
+
+/// An NSString describing the profile.
+@property (nonatomic, readonly) NSString *name;
+
+/// The unique 5-byte profile identifier representing the profile.
+@property (nonatomic, readonly) NSData *profileID;	// always 5 bytes
+
+- (instancetype)init NS_UNAVAILABLE;
+- (instancetype)initWithData:(NSData *)data MIDICI1_1_AVAILABILITY;
+- (instancetype)initWithData:(NSData *)data name:(NSString *)inName;
+@end
+
+// =================================================================================================
+
+/*!
+ 	@class	MIDICIProfileState
+ 	@brief  Lists the enabled and disabled profiles for a MIDI channel or port on a device.
+*/
+MIDICI1_0_AVAILABILITY
+@interface MIDICIProfileState : NSObject <NSSecureCoding>
+@property (nonatomic, readonly) MIDIChannelNumber midiChannel;
+@property (nonatomic, readonly) NSArray<MIDICIProfile *> *enabledProfiles;
+@property (nonatomic, readonly) NSArray<MIDICIProfile *> *disabledProfiles;
+
+- (instancetype)init NS_UNAVAILABLE;
+- (instancetype)initWithChannel:(MIDIChannelNumber)midiChannelNum enabledProfiles:(NSArray<MIDICIProfile *> *)enabled disabledProfiles:(NSArray<MIDICIProfile *> *)disabled MIDICI1_1_AVAILABILITY;
+- (instancetype)initWithEnabledProfiles:(NSArray<MIDICIProfile *> *)enabled disabledProfiles:(NSArray<MIDICIProfile *> *)disabled API_DEPRECATED_WITH_REPLACEMENT("initWithChannel:enabledProfiles:disabledProfiles", macos(10.14, API_TO_BE_DEPRECATED), ios(12.0, API_TO_BE_DEPRECATED));
+@end
+
+// =================================================================================================
+
+/*!
+     @class    MIDICIDiscoveredNode
+     @brief     An object created during MIDI-CI discovery representing a MIDI destination with an
+                 associated MIDI source that responds to capability inquiries.
+*/
+MIDICI1_1_AVAILABILITY
+@interface MIDICIDiscoveredNode : NSObject <NSSecureCoding>
+@property (nonatomic, readonly) MIDIEntityRef 		destination;
+@property (nonatomic, readonly) MIDICIDeviceInfo *	deviceInfo;
+@property (nonatomic, readonly) BOOL 				supportsProfiles;
+@property (nonatomic, readonly) BOOL 				supportsProperties;
+@property (nonatomic, readonly) NSNumber *          maximumSysExSize;
+
+-(instancetype)init NS_UNAVAILABLE;
+@end
+
+// =================================================================================================
+
+/*!
+ 	@fn     MIDICIProfileChangedBlock
+ 	@brief  A block called when a device notifies that a profile has been enabled or disabled.
+*/
+typedef void (^MIDICIProfileChangedBlock)(
+				MIDICISession *session, MIDIChannelNumber channel, MIDICIProfile *profile, BOOL enabled) MIDICI1_1_AVAILABILITY;
+
+/*!
+     @fn     MIDICISessionDisconnectBlock
+     @brief  A block called when a MIDICISession has been disconnected. If called, the MIDICISession should be destroyed.
+*/
+typedef void (^MIDICISessionDisconnectBlock)(
+                MIDICISession *session, NSError *error) MIDICI1_1_AVAILABILITY;
+
+/*!
+     @fn     MIDICIProfileSpecificDataBlock
+     @brief  A block called when a MIDICISession or MIDICIResponder receives profile-specific data.
+*/
+typedef void (^MIDICIProfileSpecificDataBlock)(
+                MIDICISession *session, MIDIChannelNumber channel, MIDICIProfile *profile, NSData *profileSpecificData) MIDICI1_1_AVAILABILITY;
+
+/*!
+     @fn     MIDICIDiscoveryResponseBlock
+     @brief  A block called when a MIDI-CI node discovery is complete.
+*/
+typedef void (^MIDICIDiscoveryResponseBlock)(
+                NSArray<MIDICIDiscoveredNode *> *discoveredNodes) MIDICI1_1_AVAILABILITY;
+
+// =================================================================================================
+
+/*!
+     @class  MIDICISession
+     @brief  Object representating a MIDI Capability Inquiry session.
+ 
+     A MIDI Capability Inquiry session is a bidirectional communication path between a MIDI process
+     and a MIDI-CI node (i.e., paired MIDI source and destination) identified using MIDI-CI discovery.
+     A MIDICISession can be used to manipulate MIDI-CI profiles and to discover the MIDI-CI property
+     capability.
+*/
+MIDICI1_0_AVAILABILITY
+@interface MIDICISession : NSObject
+
+/*!
+	@brief  Begin a MIDI-CI session with the provided discovered node.
+ 
+	dataReadyHandler will be called when properties of the session have become available.
+	Other methods of this class will not return valid/useful information before the dataReadyHandler
+	is called.
+ 
+	disconnectHandler will be called if the active MIDICISession is disconnected by the Responder
+    or if initial MIDI-CI discovery was unsuccessful.
+*/
+- (instancetype)init NS_UNAVAILABLE;
+
+- (instancetype)initWithDiscoveredNode:(MIDICIDiscoveredNode *)discoveredNode dataReadyHandler:(void (^)(void))handler disconnectHandler:(MIDICISessionDisconnectBlock)disconnectHandler;
+
+/// The MIDI destination with which the session is communicating.
+@property (nonatomic, readonly) MIDIEntityRef midiDestination;
+
+// After CI session data is ready, indicates whether the entity supports the MIDI-CI profile capability.
+@property (nonatomic, readonly) BOOL supportsProfileCapability;
+
+// After CI session data is ready, indicates whether the entity supports the MIDI-CI property exchange capability.
+@property (nonatomic, readonly) BOOL supportsPropertyCapability;
+
+/// Obtain the device's basic identification. Nil before data is ready or if the device does not
+/// support MIDI-CI.
+@property (nonatomic, readonly) MIDICIDeviceInfo *deviceInfo;
+
+// The maximum MIDI system exclusive size reported by the device during discovery
+@property (nonatomic, readonly) NSNumber *maxSysExSize; // unsigned long
+
+// The maximum number of simultaneous property exchange requests, if supported
+@property (nonatomic, readonly) NSNumber *maxPropertyRequests; // int
+
+/// Given a MIDI channel number, return the supported profiles. Note that the
+/// arrays will be empty if this property is queried before data is ready.
+- (MIDICIProfileState *)profileStateForChannel:(MIDIChannelNumber)channel;
+
+/// Given a MIDI channel number, asynchronously request that the supplied profile be enabled.
+/// The result of this operation is sent to the MIDICIProfileChangedBlock.
+/// Returns YES if the request is valid.
+- (BOOL)enableProfile:(MIDICIProfile *)profile
+			onChannel:(MIDIChannelNumber)channel
+				error:(NSError **)outError;
+
+/// Given a MIDI channel number, asynchronously request that the supplied profile be disabled.
+/// The result of this operation is sent to the MIDICIProfileChangedBlock.
+/// Returnes YES if the request is valid.
+- (BOOL)disableProfile:(MIDICIProfile *)profile
+			 onChannel:(MIDIChannelNumber)channel
+				 error:(NSError **)outError;
+
+/// Given a MIDI channel number, send profile specific data to the MIDICISession.
+/// Returns YES if the data was successfully sent.
+- (BOOL)sendProfile:(MIDICIProfile *)profile onChannel:(MIDIChannelNumber)channel profileData:(NSData *)profileSpecificData MIDICI1_1_AVAILABILITY;
+
+/// An optional block called when a device signals that a profile has been enabled or disabled.
+@property (nonatomic, copy, nullable) MIDICIProfileChangedBlock profileChangedCallback;
+
+/// An optional block called when a device sends profile-specific data to the session.
+@property (nonatomic, copy, nullable) MIDICIProfileSpecificDataBlock profileSpecificDataHandler;
+
+@end // MIDICISession
+
+// =================================================================================================
+
+/*!
+     @class  MIDICIDiscoveryManager
+     @brief  Singleton object that performs system-wide MIDI Capability Inquiry discovery
+ 
+     MIDICIDiscoveryManager is used to retrieve information about nodes in the MIDI subsystem
+     that are MIDI-CI capable. Only MIDI destinations discovered via this API can be used to
+     create MIDICISessions.
+*/
+MIDICI1_1_AVAILABILITY
+@interface MIDICIDiscoveryManager : NSObject
++ (MIDICIDiscoveryManager *)sharedInstance;
+- (void)discoverWithHandler:(MIDICIDiscoveryResponseBlock)completedHandler;
+@end
+
+// =================================================================================================
+
+/*!
+     @protocol  MIDICIProfileResponderDelegate
+     @brief     Protocol for an NSObject that constructs and issues responses for a MIDICIResponder.
+                A MIDICIProfileResponderDelegate is required to construct a MIDICIResponder.
+*/
+MIDICI1_1_AVAILABILITY
+@protocol MIDICIProfileResponderDelegate <NSObject>
+
+@required
+// Allow a new MIDI-CI Initiator to create a session or reject the connection attempt
+- (BOOL)connectInitiator:(MIDICIInitiatiorMUID)initiatorMUID withDeviceInfo:(MIDICIDeviceInfo *)deviceInfo;
+// Called when an initiator terminates its MIDI-CI connection
+- (void)initiatorDisconnected:(MIDICIInitiatiorMUID)initiatorMUID;
+
+@optional
+// These methods must be implemented if the associated responder implements MIDI-CI profiles.
+- (BOOL)willSetProfile:(MIDICIProfile *)aProfile onChannel:(MIDIChannelNumber)channel enabled:(BOOL)shouldEnable;
+- (void)handleDataForProfile:(MIDICIProfile *)aProfile onChannel:(MIDIChannelNumber)channel data:(NSData *)inData;
+@end // MIDICIProfileResponderDelegate
+
+// =================================================================================================
+
+/*!
+     @class     MIDICIResponder
+     @brief     Responds to MIDI-CI inquiries from an initiator on behalf of a MIDIClient and handles profile and property change
+                operations for the Responder role.
+*/
+MIDICI1_1_AVAILABILITY
+@interface MIDICIResponder : NSObject
+@property (nonatomic, readonly) NSArray<MIDICIInitiatiorMUID> *initiators;
+@property (nonatomic, readonly, retain) id<MIDICIProfileResponderDelegate>profileDelegate;
+@property (nonatomic, readonly) MIDICIDeviceInfo *deviceInfo;
+
+- (instancetype)init NS_UNAVAILABLE;
+- (instancetype)initWithDeviceInfo:(MIDICIDeviceInfo *)deviceInfo profileDelegate:(id<MIDICIProfileResponderDelegate>)delegate profileStates:(MIDICIProfileStateList *)profileList supportProperties:(BOOL)propertiesSupported;
+
+// Spontaneously enable or disable a profile and notify all connected Initiators
+- (BOOL)notifyProfile:(MIDICIProfile *)aProfile onChannel:(MIDIChannelNumber)channel isEnabled:(BOOL)enabledState;
+
+// Send profile-specific data for a profile to all connected Initiators
+- (BOOL)sendProfile:(MIDICIProfile *)aProfile onChannel:(MIDIChannelNumber)channel profileData:(NSData *)profileSpecificData;
+
+// Begin receiving Initiator requests
+- (BOOL)start;
+// Stop receiving Initiator requests and disconnect all connected Initiators
+- (void)stop;
+
+@end // MIDICIResponder
+
+NS_ASSUME_NONNULL_END
+
+#endif /* if defined(__OBJC2__) */
+#endif /* MIDICapabilityInquiry_h */
diff -ruN /Applications/Xcode_13.0.0-beta2.app/Contents/Developer/Platforms/WatchOS.platform/Developer/SDKs/WatchOS.sdk/System/Library/Frameworks/CoreMIDI.framework/Headers/MIDIDriver.h /Applications/Xcode_13.0.0-beta3.app/Contents/Developer/Platforms/WatchOS.platform/Developer/SDKs/WatchOS.sdk/System/Library/Frameworks/CoreMIDI.framework/Headers/MIDIDriver.h
--- /Applications/Xcode_13.0.0-beta2.app/Contents/Developer/Platforms/WatchOS.platform/Developer/SDKs/WatchOS.sdk/System/Library/Frameworks/CoreMIDI.framework/Headers/MIDIDriver.h	1969-12-31 19:00:00.000000000 -0500
+++ /Applications/Xcode_13.0.0-beta3.app/Contents/Developer/Platforms/WatchOS.platform/Developer/SDKs/WatchOS.sdk/System/Library/Frameworks/CoreMIDI.framework/Headers/MIDIDriver.h	2021-07-13 00:40:02.000000000 -0400
@@ -0,0 +1,563 @@
+/*
+     File:       CoreMIDI/MIDIDriver.h
+ 
+     Contains:   MIDI Services driver interfaces
+ 
+ 	Copyright:  (c) 2000-2015 by Apple Inc., all rights reserved.
+ 
+     Bugs?:      For bug reports, consult the following page on
+                 the World Wide Web:
+ 
+                     http://feedbackassistant.apple.com/
+*/
+
+#ifndef __MIDIDriver_h__
+#define __MIDIDriver_h__
+
+#include <CoreMIDI/MIDIServices.h>
+#if COREFOUNDATION_CFPLUGINCOM_SEPARATE
+#include <CoreFoundation/CFPlugInCOM.h>
+#endif
+
+CF_ASSUME_NONNULL_BEGIN
+
+/*!
+	@header MIDIDriver.h
+	
+	This is the header file for Mac OS X's MIDI driver interface.
+	
+
+	MIDI drivers are CFPlugIns, installed into the following places:
+
+	```
+    /System/Library/Extensions      -- not recommended for non-Apple drivers, but
+                                    necessary for compatibility with CoreMIDI 1.0
+    
+    /Library/Audio/MIDI Drivers     -- starting with CoreMIDI 1.1
+    
+    ~/Library/Audio/MIDI Drivers    -- starting with CoreMIDI 1.1
+	```
+
+	Refer to the CFPlugIn documentation for more information about plug-ins.
+	
+
+	A driver's bundle settings should include settings resembling the following:
+
+	```
+    Bundle settings:
+        CFBundleIdentifier              String          com.mycompany.midi.driver.mydevice
+            (note that this will be the driver's persistent ID in MIDISetup's)
+        CFPlugInDynamicRegistration     String          NO
+        CFPlugInFactories               Dictionary      1 key/value pair
+            [your new factory UUID]     String          [your factory function name]
+        CFPlugInTypes                   Dictionary      1 key/value pair
+            ECDE9574-0FE4-11D4-BB1A-0050E4CEA526        Array       1 object
+                (this is kMIDIDriverTypeID)
+                0                       String          [your new factory UUID]
+    Build settings:
+        WRAPPER_EXTENSION               plugin
+	```
+	
+
+	Drivers have access to most of the CoreMIDI API.  Starting in Mac OS X 10.6, drivers should link
+	with CoreMIDI.framework. In previous versions of Mac OS X, drivers should link with
+	CoreMIDIServer.framework, not CoreMIDI.framework.
+	
+	On Mac OS X versions prior to 10.6, MIDI driver plugins linked against the CoreMIDIServer
+	framework in order to access the CoreMIDI API. Drivers which are to run on earlier OS versions
+	should be built 32-bit fat (ppc and i386) and link against CoreMIDIServer. Drivers which are to
+	run on Mac OS X 10.6 and later should be built for x86_64 and link against the CoreMIDI
+	framework. Drivers which are to run on all versions of Mac OS X should be build 3-way fat (ppc,
+	i386, and x86_64), with the ppc and i386 slices linking against CoreMIDIServer, and the x86_64
+	slice linking against CoreMIDI.
+
+	Unlike applications, drivers communicate with the server directly, not through Mach messaging.
+	This necessitates some limitations on the contexts from which a driver may call the server.
+	
+	The MIDI I/O functions MIDISend and MIDIReceived may be called from any thread.
+	
+	All other CoreMIDI functions must only be called from the server's main thread, which is the
+	thread on which the driver is created and from which all calls to the driver other than Send()
+	are made.
+*/
+
+typedef struct MIDIDriverInterface		MIDIDriverInterface;
+
+/*!
+	@typedef		MIDIDriverRef
+	
+	@discussion		Points to a pointer to a MIDIDriverInterface, a CFPlugIn structure (defined in
+					MIDIDriver.h) containing function pointers for the driver's methods.  Only the
+					MIDIServer may call a driver's methods.
+*/
+typedef MIDIDriverInterface * __nonnull * MIDIDriverRef;
+
+/*!
+	@typedef		MIDIDeviceListRef
+	
+	@discussion		A MIDIDeviceListRef is a list of MIDIDeviceRef's.  The devices are not owned by
+					the list (i.e., disposing the list does not dispose the devices it references).
+*/
+typedef MIDIObjectRef MIDIDeviceListRef;
+
+/*!
+	@struct		MIDIDriverInterface
+	
+	@abstract		The COM-style interface to a MIDI driver.
+	
+	@discussion
+		This is the function table interface to a MIDI driver.  Version 1 and 2 drivers use
+		this same table of function pointers (except as noted).
+
+		Drivers which support multiple version interfaces can tell which version
+		of the server is running by checking to see whether kMIDIDriverInterface2ID
+        or kMIDIDriverInterfaceID is passed to the factory function. If the version 1 interface is
+        requested, the driver should behave as if it is a version 1 driver.
+*/
+struct MIDIDriverInterface
+{
+	IUNKNOWN_C_GUTS;
+
+	/*!
+		@fn FindDevices
+		@discussion
+			This is only called for version 1 drivers.  The server is requesting that the driver
+			detect the devices which are present.  For each device present, the driver should
+			create a MIDIDeviceRef with entities, using MIDIDeviceCreate and
+			MIDIDeviceAddEntity, and add the device to the supplied MIDIDeviceListRef, using
+			MIDIDeviceListAddDevice.
+
+			The driver should not retain any references to the created devices and entities.
+	*/
+	OSStatus	(*FindDevices)(MIDIDriverRef __nonnull self, MIDIDeviceListRef devList);
+
+	/*!
+		@fn Start
+		@discussion
+			The server is telling the driver to begin MIDI I/O.
+
+			The provided device list contains the devices which were previously located by
+			FindDevices (in the case of a version 1 driver), or the devices which are owned by
+			this driver and are currently in the current MIDISetup (for version 2 drivers).
+
+			The provided devices may or may not still be present.  A version 1 driver should
+			attempt to use as many of the devices as are actually present.
+
+			A version 2 driver may make calls such as MIDISetupAddDevice, MIDIDeviceAddEntity,
+			MIDIDeviceRemoveEntity to dynamically modify the system's current state. For devices
+			in the provided device list which are not present, the driver should set their
+			kMIDIPropertyOffline property to 1.  A version 2 driver may also set up
+			notifications when the IORegistry changes, to detect connection and disconnection of
+			devices it wishes to control.  At these times also, the driver may change the
+			devices' kMIDIPropertyOffline, and dynamically modify the system's current state to
+			reflect the devices which are present.  When passing a CFRunLoopRef to IOKit for
+			notification purposes, the driver must use the server's main runloop, which is
+			obtained with CFRunLoopGetCurrent().
+
+			The driver will probably want to iterate through the destination endpoints and
+			assign their driver refCons, so as to identify multiple destinations when Send() is
+			called.
+
+			The provided device list remains owned by the system and can be assumed to contain
+			only devices owned by this driver.  The driver may retain references to the devices
+			in this list and any it creates while running.
+	*/
+	OSStatus	(*Start)(MIDIDriverRef __nonnull self, MIDIDeviceListRef devList);
+
+	/*!
+		@fn Stop
+		@discussion
+			The server is telling the driver to terminate MIDI I/O.  All I/O operations that
+			were begun in Start, or as a result of a subsequent IOKit notification, should be
+			terminated.
+	*/
+	OSStatus	(*Stop)(MIDIDriverRef __nonnull self);
+	
+	/*!
+		@fn Configure
+		@discussion
+			not currently used
+	*/
+	OSStatus	(*Configure)(MIDIDriverRef __nonnull self, MIDIDeviceRef device);
+
+	/*!
+		@fn Send
+		@discussion
+			Send a MIDIPacketList to the destination endpoint whose refCons are being passed as
+			arguments.
+	*/
+	OSStatus	(*Send)(MIDIDriverRef __nonnull self, const MIDIPacketList *pktlist, void *destRefCon1, void *destRefCon2);
+	
+	/*!
+		@fn EnableSource
+		@discussion
+			A client has opened or closed a connection, and now the server is telling the driver
+			that input from a particular source either does or does not have any listeners in
+			the system.  The driver may use this information to decide whether to pass messages
+			from the source to the server, and it may even be able to tell the source hardware
+			not to generate incoming MIDI I/O for that source.
+	*/
+	OSStatus	(*EnableSource)(MIDIDriverRef __nonnull self, MIDIEndpointRef src, Boolean enabled);
+	
+	/*!
+		@fn Flush
+		@discussion
+			Only for version 2 drivers (new for CoreMIDI 1.1).
+
+			Drivers which support schedule-ahead, when receiving this message, should unschedule
+			all pending output to the specified destination.  If the destination is null/0, the
+			driver should unschedule all pending output to all destinations.
+	*/
+	OSStatus	(*Flush)(MIDIDriverRef __nonnull self, MIDIEndpointRef dest, void * __nullable destRefCon1, void * __nullable destRefCon2);
+
+	/*!
+		@fn Monitor
+		@discussion
+			Only for version 2 drivers (new for CoreMIDI 1.1).
+
+			Some specialized drivers (e.g. a MIDI monitor display) may wish to intercept and
+			look at all outgoing MIDI messages.  After a driver calls
+			MIDIDriverEnableMonitoring(true) on itself, this function is called with the
+			outgoing MIDI packets for all destinations in the system.  The Monitor function
+			cannot rely on the MIDI events arriving in order, due to MIDIServer's schedule-ahead
+			facilities.
+	*/
+	OSStatus	(*Monitor)(MIDIDriverRef __nonnull self, MIDIEndpointRef dest, const MIDIPacketList *pktlist);
+    
+	/*!
+		@fn SendPackets
+		@discussion
+	 		Only for provisional drivers.
+	 
+			Send a MIDIEventList to the destination endpoint whose refCons are being passed as
+			arguments.
+	*/
+	OSStatus	(*SendPackets)(MIDIDriverRef __nonnull self, const MIDIEventList *pktlist, void *destRefCon1, void *destRefCon2);
+    
+    /*!
+		@fn MonitorEvents
+		@discussion
+			Only for provisional drivers.
+
+			Same as Monitor but uses MIDEventList, whose protocol may vary from MIDI 1.0.
+	*/
+	OSStatus	(*MonitorEvents)(MIDIDriverRef __nonnull self, MIDIEndpointRef dest, const MIDIEventList *pktlist);
+
+};
+
+
+//  -----------------------------------------------------------------------------
+/*!
+	@define			kMIDIDriverTypeID
+	
+	@abstract		The UUID for MIDI driver plugins.
+	
+	@discussion		kMIDIDriverTypeID should be entered into your driver's bundle settings
+					as follows:
+					
+<pre>
+CFPlugInTypes                   Dictionary      1 key/value pair
+	ECDE9574-0FE4-11D4-BB1A-0050E4CEA526        Array       1 object
+		(this is kMIDIDriverTypeID)
+		0                       String          [your new factory UUID]
+</pre>
+*/
+#define kMIDIDriverTypeID \
+	CFUUIDGetConstantUUIDWithBytes(NULL, 0xEC, 0xDE, 0x95, 0x74, 0x0F, 0xE4, 0x11, 0xD4, 0xBB, 0x1A, 0x00, 0x50, 0xE4, 0xCE, 0xA5, 0x26)
+/* ECDE9574-0FE4-11D4-BB1A-0050E4CEA526 */
+
+
+/*!
+	@define			kMIDIDriverInterfaceID
+	
+	@abstract		The UUID for version 1 of the MIDI driver interface.
+	
+	@discussion		See the description of the MIDIDriverInterface structure for
+					information about different versions of the MIDI driver interface.
+*/
+#define kMIDIDriverInterfaceID \
+	CFUUIDGetConstantUUIDWithBytes(NULL, 0x49, 0xDF, 0xCA, 0x9E, 0x0F, 0xE5, 0x11, 0xD4, 0x95, 0x0D, 0x00, 0x50, 0xE4, 0xCE, 0xA5, 0x26)
+/* 49DFCA9E-0FE5-11D4-950D-0050E4CEA526 */
+
+/*!
+	@define			kMIDIDriverInterface2ID
+	
+	@abstract		The UUID for version 2 of the MIDI driver interface.
+	
+	@discussion		See the description of the MIDIDriverInterface structure for
+					information about different versions of the MIDI driver interface.
+					
+					The version 2 driver interface is available beginning with CoreMIDI 1.1.
+*/
+#define kMIDIDriverInterface2ID \
+	CFUUIDGetConstantUUIDWithBytes(NULL, 0x43, 0xC9, 0x8C, 0x3C, 0x30, 0x6C, 0x11, 0xD5, 0xAF, 0x73, 0x00, 0x30, 0x65, 0xA8, 0x30, 0x1E)
+/* 43C98C3C-306C-11D5-AF73-003065A8301E */
+
+/*!
+	@define			kMIDIDriverInterface3ID
+ 
+	@abstract		The UUID for version 3 of the MIDI driver interface.
+ 
+	@discussion		This UUID uses UniversalMIDIPacket I/O functions.
+					See the description of the MIDIDriverInterface structure for
+					information about different versions of the MIDI driver interface.
+ 
+					This provisional driver interface is provided for the purpose of
+                    prototyping MIDI 2.0 driver support. This driver interface will be replaced
+                    in the future when transport specifications are defined.
+*/
+#define kMIDIDriverInterface3ID \
+	CFUUIDGetConstantUUIDWithBytes(NULL, 0x2F, 0xD9, 0x4D, 0x0F, 0x8C, 0x2A, 0x48, 0x2A, 0x8A, 0xD8, 0x7D, 0x9E, 0xA3, 0x81, 0xC9, 0xC1)
+/* 2FD94D0F-8C2A-482A-8AD8-7D9EA381C9C1 */
+
+/*!
+	@constant		kMIDIDriverPropertyUsesSerial
+	
+	@discussion		This constant, "MIDIDriverUsesSerial", when defined to "YES" in a driver's
+					bundle, tells MIDIServer that the driver uses serial ports and is eligible to
+					have serial ports assigned to it.
+					
+					When a serial driver's Start() method is called, it should use
+					MIDIGetSerialPortOwner to discover which serial ports it has
+					been assigned to use, and only use those ports.
+					
+					New for CoreMIDI 1.1.
+*/
+extern const CFStringRef kMIDIDriverPropertyUsesSerial		API_AVAILABLE(macos(10.1)) API_UNAVAILABLE(ios, tvos, watchos);
+
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+// ___________________________________________________________________________________________
+//	MIDIDevice
+// ___________________________________________________________________________________________
+
+//  -----------------------------------------------------------------------------
+/*!
+	@function		MIDIDeviceCreate
+
+	@discussion		Drivers call this function to create new MIDIDevice objects
+					corresponding to the hardware that is present.
+					
+					Non-drivers may call this function as of CoreMIDI 1.1, to
+					create external devices.
+	
+	@param			owner
+						The driver creating the device.  NULL if a non-driver.
+	@param			name
+						The name of the new device.
+	@param			manufacturer
+						The name of the device's manufacturer.
+	@param			model
+						The device's model name.
+	@param			outDevice
+						On successful return, points to the newly-created device.
+	@result			An OSStatus result code.
+*/
+extern OSStatus		MIDIDeviceCreate(MIDIDriverRef __nullable owner,
+							CFStringRef name, CFStringRef manufacturer,
+							CFStringRef model, MIDIDeviceRef *outDevice)
+																API_AVAILABLE(macos(10.0), ios(4.2))  API_UNAVAILABLE(tvos, watchos);
+
+
+/*!
+	@function		MIDIDeviceDispose
+
+	@discussion		Drivers may call this function to dispose MIDIDevice objects
+					which have not yet been added to the system via MIDISetupAddDevice.
+					Once a device has been added to the system with MIDISetupAddDevice,
+					the driver must not use this call to destroy it; it must
+					use MIDISetupRemoveDevice to do so.
+					
+					Non-drivers do not have access to this function; they must call
+					MIDISetupAddDevice and MIDISetupRemoveDevice.
+	
+	@param			device
+						The device to be disposed.
+	@result			An OSStatus result code.
+*/
+extern OSStatus		MIDIDeviceDispose(MIDIDeviceRef device)		API_AVAILABLE(macos(10.3), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
+
+// ___________________________________________________________________________________________
+//	MIDIDeviceList
+// ___________________________________________________________________________________________
+
+//  -----------------------------------------------------------------------------
+/*!
+	@function		MIDIDeviceListGetNumberOfDevices
+
+	@discussion		Returns the number of devices in a device list.
+	
+	@param			devList
+						The device list.
+	@result			The number of devices in the list, or 0 if an error occurred.
+*/
+extern ItemCount		MIDIDeviceListGetNumberOfDevices(MIDIDeviceListRef devList)
+																API_AVAILABLE(macos(10.0), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
+
+//  -----------------------------------------------------------------------------
+/*!
+	@function		MIDIDeviceListGetDevice
+
+	@discussion		Return one of the devices in a device list.
+	
+	@param			devList
+						The device list.
+	@param			index0
+						The index (0...MIDIDeviceListGetNumberOfDevices()-1) of the device
+						to return.
+	@result			A reference to a device, or NULL if an error occurred.
+*/
+extern MIDIDeviceRef	MIDIDeviceListGetDevice(MIDIDeviceListRef devList, ItemCount index0)
+																API_AVAILABLE(macos(10.0), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
+
+//  -----------------------------------------------------------------------------
+/*!
+	@function		MIDIDeviceListAddDevice
+
+	@discussion		Add a device to a device list.
+	
+	@param			devList
+						The device list.
+	@param			dev
+						The device to add to the list.
+	@result			An OSStatus result code.
+*/
+extern OSStatus		MIDIDeviceListAddDevice(MIDIDeviceListRef devList, MIDIDeviceRef dev)
+																API_AVAILABLE(macos(10.0), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
+
+//  -----------------------------------------------------------------------------
+/*!
+	@function		MIDIDeviceListDispose
+
+	@discussion		Dispose a device list, but not the contained devices.
+	
+	@param			devList
+						The device list to be disposed.
+	@result			An OSStatus result code.
+*/
+extern OSStatus		MIDIDeviceListDispose(MIDIDeviceListRef devList)
+																API_AVAILABLE(macos(10.1), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
+
+
+// ___________________________________________________________________________________________
+//	MIDIEndpoint
+// ___________________________________________________________________________________________
+
+//  -----------------------------------------------------------------------------
+/*!
+	@function		MIDIEndpointSetRefCons
+
+	@discussion		Drivers need an efficient way to translate from a MIDIEndpoint (source or
+					destination) to their own internal data structures corresponding to
+					that endpoint.  This function provides a way for the driver to
+					assign its own refCons to endpoints.
+					
+					These refCons are passed back to the driver in its Send() and Flush()
+					methods.
+					
+					RefCons are not persistent (i.e. they are not saved as part of a
+					MIDISetup).  They need to be re-initialized in each call to Start().
+					
+					A typical use is to use one refCon to refer to a device, and a second
+					to refer to a port on the device.
+	
+	@param			endpt
+						The endpoint whose refCons are to be set
+	@param			ref1
+						The first refCon.
+	@param			ref2
+						The second refCon.
+	@result			An OSStatus result code.
+*/
+extern OSStatus		MIDIEndpointSetRefCons(MIDIEndpointRef endpt,
+					void * __nullable ref1, void * __nullable ref2)					API_AVAILABLE(macos(10.0), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
+
+//  -----------------------------------------------------------------------------
+/*!
+	@function		MIDIEndpointGetRefCons
+
+	@discussion		Obtain the refCons assigned to the endpoints
+	
+	@param			endpt
+						The endpoint whose refCons are to be return
+	@param			ref1
+						On exit, the first refCon.
+	@param			ref2
+						On exit, the second refCon.
+	@result			An OSStatus result code.
+*/
+extern OSStatus		MIDIEndpointGetRefCons(MIDIEndpointRef endpt,
+					void * __nonnull * __nullable ref1, void * __nonnull * __nullable ref2)
+																					API_AVAILABLE(macos(10.0), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
+
+// ___________________________________________________________________________________________
+
+//  -----------------------------------------------------------------------------
+/*!
+	@function		MIDIGetDriverIORunLoop
+
+	@discussion		Drivers typically need to receive asynchronous I/O completion callbacks
+					on a high-priority thread.  To save drivers from the trouble of
+					creating their own threads for this purpose, and to make efficient
+					use of system resources, the MIDIServer provides a thread which
+					drivers may use.
+					
+					Drivers should do as little work as possible in this thread; typically,
+					just dequeueing and encoding output packets, and decoding input packets
+					into MIDIPacketLists to be passed to MIDIReceived.
+	
+					This is a realtime-priority thread and shouldn't be used for anything other
+					than I/O.  For lower-priority tasks, drivers can use the runloop which
+					was current when they were constructed.
+
+	@result			The CFRunLoopRef of the server's driver I/O thread.
+*/
+extern CFRunLoopRef	MIDIGetDriverIORunLoop(void)			API_AVAILABLE(macos(10.0), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
+
+//  -----------------------------------------------------------------------------
+/*!
+	@function		MIDIGetDriverDeviceList
+
+	@discussion		Returns the list of devices which are in the current MIDISetup
+					and which were created/owned by the specified driver.
+	
+					The returned device list should be disposed (using MIDIDeviceListDispose)
+					by the caller.
+					
+	@param			driver
+						The driver whose devices are to be returned.
+
+	@result			The requested device list.
+*/
+extern MIDIDeviceListRef	MIDIGetDriverDeviceList(MIDIDriverRef __nonnull driver)
+															API_AVAILABLE(macos(10.1), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
+
+//  -----------------------------------------------------------------------------
+/*!
+	@function		MIDIDriverEnableMonitoring
+
+	@discussion		A driver may make this call to have MIDIServer pass it every outgoing MIDI
+					packet, to all destinations in the system (not just those controlled by
+					itself).
+					
+	@param			driver
+						The driver whose Monitor function is to be enabled.
+	@param			enabled
+						true to enable monitoring, false to disable it.
+
+	@result			An OSStatus result code.
+*/
+extern OSStatus			MIDIDriverEnableMonitoring(MIDIDriverRef __nonnull driver, Boolean enabled)
+															API_AVAILABLE(macos(10.1)) API_UNAVAILABLE(ios, tvos, watchos);
+
+
+#ifdef __cplusplus
+}
+#endif
+
+CF_ASSUME_NONNULL_END
+
+#endif // __MIDIDriver_h__
diff -ruN /Applications/Xcode_13.0.0-beta2.app/Contents/Developer/Platforms/WatchOS.platform/Developer/SDKs/WatchOS.sdk/System/Library/Frameworks/CoreMIDI.framework/Headers/MIDIMessages.h /Applications/Xcode_13.0.0-beta3.app/Contents/Developer/Platforms/WatchOS.platform/Developer/SDKs/WatchOS.sdk/System/Library/Frameworks/CoreMIDI.framework/Headers/MIDIMessages.h
--- /Applications/Xcode_13.0.0-beta2.app/Contents/Developer/Platforms/WatchOS.platform/Developer/SDKs/WatchOS.sdk/System/Library/Frameworks/CoreMIDI.framework/Headers/MIDIMessages.h	1969-12-31 19:00:00.000000000 -0500
+++ /Applications/Xcode_13.0.0-beta3.app/Contents/Developer/Platforms/WatchOS.platform/Developer/SDKs/WatchOS.sdk/System/Library/Frameworks/CoreMIDI.framework/Headers/MIDIMessages.h	2021-07-13 00:36:41.000000000 -0400
@@ -0,0 +1,536 @@
+/*
+ 	File:   	CoreMIDI/MIDIMessages.h
+ 
+ 	Contains:   Constants, structures, and helper functions for Universal MIDI Packet and MIDI 2.0 messages.
+ 
+ 	Copyright:  (c) 2018-2020 by Apple Inc., all rights reserved.
+ 
+ 	Bugs?:  	For bug reports, consult the following page on
+ 				the World Wide Web:
+ 
+ 					http://feedbackassistant.apple.com/
+ 
+*/
+
+#ifndef CoreMIDI_MIDIMessage_h
+#define CoreMIDI_MIDIMessage_h
+
+#include <CoreFoundation/CFBase.h>
+#include <CoreMIDI/MIDIServices.h>
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+
+//==================================================================================================
+#pragma mark -
+#pragma mark MIDI message constants
+
+// MIDI Universal Packet message type nibbles.
+typedef CF_ENUM(unsigned int, MIDIMessageType) {
+	kMIDIMessageTypeUtility	        =   0x0,	// 1 word
+	kMIDIMessageTypeSystem          =   0x1,	// 1 word
+	kMIDIMessageTypeChannelVoice1   =   0x2,	// 1 word - MIDI 1.0
+	kMIDIMessageTypeSysEx           =   0x3,	// 2 words (Data, but primarily SysEx)
+	kMIDIMessageTypeChannelVoice2   =   0x4,	// 2 words - MIDI 2.0
+	kMIDIMessageTypeData128         =   0x5,	// 4 words
+	kMIDIMessageTypeUnknownF		=	0xF
+	
+	// Sizes of undefined message types:
+	// 6: 1 word
+	// 7: 1 word
+	// 8: 2 words
+	// 9: 2 words
+	// A: 2 words
+	// B: 3 words
+	// C: 3 words
+	// D: 4 words
+	// E: 4 words
+	// F: 4 words
+};
+
+// kMIDIMessageTypeChannelVoice1 / kMIDIMessageTypeChannelVoice2 status nibbles.
+typedef CF_ENUM(unsigned int, MIDICVStatus) {
+	// MIDI 1.0
+	kMIDICVStatusNoteOff			=	0x8,
+	kMIDICVStatusNoteOn				=	0x9,
+	kMIDICVStatusPolyPressure		=	0xA,
+	kMIDICVStatusControlChange		=	0xB,
+	kMIDICVStatusProgramChange		=	0xC,
+	kMIDICVStatusChannelPressure	=	0xD,
+	kMIDICVStatusPitchBend			=	0xE,
+
+	// MIDI 2.0
+	kMIDICVStatusRegisteredPNC			= 	0x0, // Per-Note Controller
+	kMIDICVStatusAssignablePNC			=	0x1,
+	kMIDICVStatusRegisteredControl		=	0x2, // Registered Parameter Number (RPN)
+	kMIDICVStatusAssignableControl		=	0x3, // Non-Registered Parameter Number (NRPN)
+	kMIDICVStatusRelRegisteredControl	= 	0x4, // Relative
+	kMIDICVStatusRelAssignableControl	=	0x5, // Relative
+	kMIDICVStatusPerNotePitchBend		=	0x6,
+	kMIDICVStatusPerNoteMgmt			=	0xF
+};
+
+// kMIDIMessageTypeSystem status bytes.
+typedef CF_ENUM(unsigned int, MIDISystemStatus) {
+	// MIDI 1.0 only
+	kMIDIStatusStartOfExclusive		= 0xF0,
+	kMIDIStatusEndOfExclusive		= 0xF7,
+	
+	// MIDI 1.0 and 2.0
+	kMIDIStatusMTC					= 0xF1,
+	kMIDIStatusSongPosPointer		= 0xF2,
+	kMIDIStatusSongSelect			= 0xF3,
+	kMIDIStatusTuneRequest			= 0xF6,
+	
+	kMIDIStatusTimingClock			= 0xF8,
+	kMIDIStatusStart				= 0xFA,
+	kMIDIStatusContinue				= 0xFB,
+	kMIDIStatusStop					= 0xFC,
+	kMIDIStatusActiveSending		= 0xFE,
+	kMIDIStatusActiveSensing		= kMIDIStatusActiveSending,
+	kMIDIStatusSystemReset			= 0xFF
+};
+
+// kMIDIMessageTypeSysEx / kMIDIMessageTypeData128 status nibbles.
+typedef CF_ENUM(unsigned int, MIDISysExStatus) {
+	kMIDISysExStatusComplete        = 0x0,
+	kMIDISysExStatusStart           = 0x1,
+	kMIDISysExStatusContinue        = 0x2,
+	kMIDISysExStatusEnd             = 0x3,
+
+	// MIDI 2.0
+	kMIDISysExMixedDataSetHeader	= 0x8,
+	kMIDISysExMixedDataSetPayload	= 0x9
+};
+
+// kMIDIMessageTypeUtility status nibbles.
+typedef CF_ENUM(unsigned int, MIDIUtilityStatus) {
+	kMIDIUtilityStatusNOOP						= 0x0,
+	kMIDIUtilityStatusJitterReductionClock		= 0x1,
+	kMIDIUtilityStatusJitterReductionTimestamp	= 0x2
+};
+
+// MIDI 2.0 Note On/Off Message Attribute Types
+typedef CF_ENUM(UInt8, MIDINoteAttributeType) {
+	kMIDINoteAttributeNone					= 0x0,	// no attribute data
+	kMIDINoteAttributeManufacturerSpecific	= 0x1,	// Manufacturer-specific = unknown
+	kMIDINoteAttributeProfileSpecific		= 0x2,	// MIDI-CI profile-specific data
+	kMIDINoteAttributePitch					= 0x3	// Pitch 7.9
+};
+
+// MIDI 2.0 Program Change Options
+typedef CF_OPTIONS(UInt8, MIDIProgramChangeOptions) {
+    kMIDIProgramChangeBankValid = 0x1
+};
+
+// MIDI 2.0 Per Note Management Options
+typedef CF_OPTIONS(UInt8, MIDIPerNoteManagementOptions) {
+    kMIDIPerNoteManagementReset = 0x1,
+    kMIDIPerNoteManagementDetach = 0x2
+};
+
+
+
+//==================================================================================================
+#pragma mark -
+#pragma mark Universal MIDI Packet structs
+
+#pragma pack(push, 4)
+
+typedef UInt32 MIDIMessage_32;
+
+typedef struct MIDIMessage_64 {
+	UInt32 word0;
+	UInt32 word1;
+} MIDIMessage_64;
+
+typedef struct MIDIMessage_96 {
+	UInt32 word0;
+	UInt32 word1;
+	UInt32 word2;
+} MIDIMessage_96;
+
+typedef struct MIDIMessage_128 {
+	UInt32 word0;
+	UInt32 word1;
+	UInt32 word2;
+	UInt32 word3;
+} MIDIMessage_128;
+
+#pragma pack(pop)
+
+//==================================================================================================
+#pragma mark -
+#pragma mark Univerval MIDI Packet message helper functions
+
+CF_INLINE MIDIMessageType MIDIMessageTypeForUPWord(const UInt32 word) { return (MIDIMessageType)(word >> 28 & 0x7F); }
+
+/*
+	MIDI 1.0 Universal MIDI Packet (MIDI-1UP) Channel Voice Message generalized structure
+	
+	Word0: [aaaa][bbbb][cccc][dddd][0eeeeeee][0fffffff]
+	
+	a: Universal MIDI Packet Message Type (0x2 for all voice messages)
+	b: Channel group number
+	c: MIDI status
+	d: MIDI channel
+	e: MIDI note number
+	f: Velocity
+	
+	The following set of functions will correctly construct voice channel messages as MIDI-1UP.
+*/
+
+CF_INLINE MIDIMessage_32 MIDI1UPChannelVoiceMessage(UInt8 group, UInt8 status, UInt8 channel, UInt8 data1, UInt8 data2) {
+    return (MIDIMessage_32)( (UInt32)((kMIDIMessageTypeChannelVoice1 << 4) | (group & 0xF)) << 24 | (UInt32)(status << 4 | (channel & 0xF)) << 16 | (UInt32)(data1 & 0x7F) << 8 | (UInt32)(data2 & 0x7F));
+}
+
+CF_INLINE MIDIMessage_32 MIDI1UPNoteOff(UInt8 group, UInt8 channel, UInt8 noteNumber, UInt8 velocity) {
+    return MIDI1UPChannelVoiceMessage(group, kMIDICVStatusNoteOff, channel, noteNumber, velocity);
+}
+
+CF_INLINE MIDIMessage_32 MIDI1UPNoteOn(UInt8 group, UInt8 channel, UInt8 noteNumber, UInt8 velocity) {
+    return MIDI1UPChannelVoiceMessage(group, kMIDICVStatusNoteOn, channel, noteNumber, velocity);
+}
+
+CF_INLINE MIDIMessage_32 MIDI1UPControlChange(UInt8 group, UInt8 channel, UInt8 index, UInt8 data) {
+    return MIDI1UPChannelVoiceMessage(group, kMIDICVStatusControlChange, channel, index, data);
+}
+
+CF_INLINE MIDIMessage_32 MIDI1UPPitchBend(UInt8 group, UInt8 channel, UInt8 lsb, UInt8 msb) {
+    return MIDI1UPChannelVoiceMessage(group, kMIDICVStatusPitchBend, channel, lsb, msb);
+}
+
+CF_INLINE MIDIMessage_32 MIDI1UPSystemCommon(UInt8 group, UInt8 status, UInt8 byte1, UInt8 byte2) {
+    return (MIDIMessage_32)((UInt32)((kMIDIMessageTypeSystem << 4) | (group & 0xF)) << 24 | (UInt32)(status) << 16 | (UInt32)(byte1 & 0x7F) << 8 | (UInt32)(byte2 & 0x7F));
+}
+
+CF_INLINE MIDIMessage_64 MIDI1UPSysEx(UInt8 group, UInt8 status, UInt8 bytesUsed, UInt8 byte1, UInt8 byte2, UInt8 byte3, UInt8 byte4, UInt8 byte5, UInt8 byte6) {
+    MIDIMessage_64 sysExOut = {};
+    sysExOut.word0 = (UInt32)((kMIDIMessageTypeSysEx << 4) | (group & 0xF)) << 24 | (UInt32)((status << 4) | (bytesUsed)) << 16 | (UInt32)(byte1 & 0x7F) << 8 | (UInt32)(byte2 & 0x7F);
+    sysExOut.word1 = (UInt32)(byte3 & 0x7F) << 24 | (UInt32)(byte4 & 0x7F) << 16 | (UInt32)(byte5 & 0x7F) << 8 | (UInt32)(byte6 & 0x7F);
+    return sysExOut;
+}
+
+CF_INLINE MIDIMessage_64 MIDI1UPSysExArray(UInt8 group, UInt8 status, const Byte *begin, const Byte *end)
+{
+    Byte arrayCopy[6] = {};
+    int numberOfBytes = end <= begin ? 0 : end - begin;
+    for (int i = 0; i < numberOfBytes; ++i)
+        arrayCopy[i] = *(begin + i);
+    return MIDI1UPSysEx(group, status, numberOfBytes, arrayCopy[0], arrayCopy[1], arrayCopy[2], arrayCopy[3], arrayCopy[4], arrayCopy[5]);
+}
+
+//==================================================================================================
+#pragma mark -
+#pragma mark MIDI 2.0 Message helper functions
+
+/*
+	MIDI 2.0 Channel Voice Message generalized structure
+	
+	Word0: [aaaa][bbbb][cccc][dddd][eeeeeeeeeeeeeeee]
+	Word1: [nnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnn]
+	
+	a: Message Type (type 1 for all voice messages)
+	b: Channel group number
+	c: MIDI status
+	d: MIDI channel
+	e: "Index" -- the contents of this field vary based on message type
+	n: Data payload
+	
+	The following set of functions will correctly construct voice channel messages as two 32-bit words.
+*/
+
+CF_INLINE MIDIMessage_64 MIDI2ChannelVoiceMessage(UInt8 group, UInt8 status, UInt8 channel, UInt16 index, UInt32 value) {
+	return (MIDIMessage_64){ (UInt32)((group & 0xF) | 0x40) << 24 | (UInt32)((channel & 0xF) | (UInt8)(status) << 4) << 16 | (UInt32)(index), value};
+}
+
+CF_INLINE MIDIMessage_64 MIDI2NoteOn(UInt8 group, UInt8 channel, UInt8 noteNumber, UInt8 attributeType, UInt16 attributeData, UInt16 velocity) {
+	return MIDI2ChannelVoiceMessage(group, kMIDICVStatusNoteOn, channel, (UInt16)(noteNumber) << 8 | (UInt16)(attributeType), (UInt32)(velocity) << 16 | (UInt32)(attributeData));
+}
+
+CF_INLINE MIDIMessage_64 MIDI2NoteOff(UInt8 group, UInt8 channel, UInt8 noteNumber, UInt8 attributeType, UInt16 attributeData, UInt16 velocity) {
+	return MIDI2ChannelVoiceMessage(group, kMIDICVStatusNoteOff, channel, (UInt16)(noteNumber) << 8 | (UInt16)(attributeType), (UInt32)(velocity) << 16 | (UInt32)(attributeData));
+}
+
+CF_INLINE MIDIMessage_64 MIDI2PolyPressure(UInt8 group, UInt8 channel, UInt8 noteNumber, UInt32 value) {
+	return MIDI2ChannelVoiceMessage(group, kMIDICVStatusPolyPressure, channel, (UInt16)(noteNumber) << 8, value);
+}
+
+CF_INLINE MIDIMessage_64 MIDI2RegisteredPNC(UInt8 group, UInt8 channel, UInt8 noteNumber, UInt8 index, UInt32 value) {
+	return MIDI2ChannelVoiceMessage(group, kMIDICVStatusRegisteredPNC, channel, (UInt16)(noteNumber) << 8 | (UInt16)(index), value);
+}
+
+CF_INLINE MIDIMessage_64 MIDI2AssignablePNC(UInt8 group, UInt8 channel, UInt8 noteNumber, UInt8 index, UInt32 value) {
+	return MIDI2ChannelVoiceMessage(group, kMIDICVStatusAssignablePNC, channel, (UInt16)(noteNumber) << 8 | (UInt16)(index), value);
+}
+
+CF_INLINE MIDIMessage_64 MIDI2PerNoteManagment(UInt8 group, UInt8 channel, UInt8 noteNumber, bool detachPNCs, bool resetPNCsToDefault) {
+	UInt16 option_flags = (UInt16)(detachPNCs ? 1 : 0) << 1 | (UInt16)(resetPNCsToDefault ? 1: 0);
+    return MIDI2ChannelVoiceMessage(group, kMIDICVStatusPerNoteMgmt, channel, (UInt16)(noteNumber) << 8 | option_flags, 0);
+}
+
+CF_INLINE MIDIMessage_64 MIDI2ControlChange(UInt8 group, UInt8 channel, UInt8 index, UInt32 value) {
+	return MIDI2ChannelVoiceMessage(group, kMIDICVStatusControlChange, channel, (UInt16)(index) << 8, value);
+}
+
+CF_INLINE MIDIMessage_64 MIDI2RegisteredControl(UInt8 group, UInt8 channel, UInt8 bank, UInt8 index, UInt32 value) {
+	return MIDI2ChannelVoiceMessage(group, kMIDICVStatusRegisteredControl, channel, (UInt16)(bank) << 8 | (UInt16)(index), value);
+}
+
+CF_INLINE MIDIMessage_64 MIDI2AssignableControl(UInt8 group, UInt8 channel, UInt8 bank, UInt8 index, UInt32 value) {
+	return MIDI2ChannelVoiceMessage(group, kMIDICVStatusAssignableControl, channel, (UInt16)(bank) << 8 | (UInt16)(index), value);
+}
+
+CF_INLINE MIDIMessage_64 MIDI2RelRegisteredControl(UInt8 group, UInt8 channel, UInt8 bank, UInt8 index, UInt32 value) {
+	return MIDI2ChannelVoiceMessage(group, kMIDICVStatusRelRegisteredControl, channel, (UInt16)(bank) << 8 | (UInt16)(index), value);
+}
+
+CF_INLINE MIDIMessage_64 MIDI2RelAssignableControl(UInt8 group, UInt8 channel, UInt8 bank, UInt8 index, UInt32 value) {
+	return MIDI2ChannelVoiceMessage(group, kMIDICVStatusRelAssignableControl, channel, (UInt16)(bank) << 8 | (UInt16)(index), value);
+}
+
+CF_INLINE MIDIMessage_64 MIDI2ProgramChange(UInt8 group, UInt8 channel, bool bankIsValid, UInt8 program, UInt8 bank_msb, UInt8 bank_lsb) {
+	UInt16 option_flags = (UInt16)(bankIsValid ? 1 : 0);
+	UInt32 value = ((UInt32)(program) << 24) | ((UInt32)(bank_msb) << 8) | ((UInt32)(bank_lsb));
+	return MIDI2ChannelVoiceMessage(group, kMIDICVStatusProgramChange, channel, option_flags, value);
+}
+
+CF_INLINE MIDIMessage_64 MIDI2ChannelPressure(UInt8 group, UInt8 channel, UInt32 value) {
+	return MIDI2ChannelVoiceMessage(group, kMIDICVStatusChannelPressure, channel, 0, value);
+}
+
+CF_INLINE MIDIMessage_64 MIDI2PitchBend(UInt8 group, UInt8 channel, UInt32 value) {
+	return MIDI2ChannelVoiceMessage(group, kMIDICVStatusPitchBend, channel, 0, value);
+}
+
+CF_INLINE MIDIMessage_64 MIDI2PerNotePitchBend(UInt8 group, UInt8 channel, UInt8 noteNumber, UInt32 value) {
+	return MIDI2ChannelVoiceMessage(group, kMIDICVStatusPerNotePitchBend, channel, (UInt16)(noteNumber) << 8, value);
+}
+
+//==================================================================================================
+#pragma mark -
+#pragma mark UMP message helper functions for reading
+
+/*!
+    @struct    MIDIUniversalMessage
+    @abstract  A representation of all possible messages stored in a Universal MIDI packet.
+*/
+typedef struct MIDIUniversalMessage {
+	MIDIMessageType  type;    //!< determines which variant in the union is active
+	UInt8            group;   //!< 4 bit MIDI group
+	UInt8            reserved[3];
+
+	union {
+		struct {
+			MIDIUtilityStatus status;  //!< determines which variant is active
+			union {
+				UInt16 jitterReductionClock;      //!< active when status is kMIDIUtilityStatusJitterReductionClock
+				UInt16 jitterReductionTimestamp;  //!< active when status is kMIDIUtilityStatusJitterReductionTimestamp
+			};
+		} utility;   //!< active when type is kMIDIMessageTypeUtility
+
+		struct {
+			MIDISystemStatus status;  //!< determines which variant is active
+			union {
+				UInt8  timeCode;             //!< active when status is kMIDIStatusMTC
+				UInt16 songPositionPointer;  //!< active when status is kMIDIStatusSongPosPointer
+				UInt8  songSelect;           //!< active when status is kMIDIStatusSongSelect
+			};
+		} system;   //!< active when type is kMIDIMessageTypeSystem
+
+		struct {
+			MIDICVStatus  status;   //!< determines which variant is active
+			UInt8         channel;  //!< MIDI channel 0-15
+			UInt8         reserved[3];
+			union {
+				struct {
+					UInt8 number;    //!< 7 bit note number
+					UInt8 velocity;  //!< 7 bit note velocity
+				} note;   //!< active when status is kMIDICVStatusNoteOff or kMIDICVStatusNoteOn
+
+				struct
+				{
+					UInt8 noteNumber;  //!< 7 bit note number
+					UInt8 pressure;    //!< 7 bit poly pressure data
+				} polyPressure;   //!< active when status is kMIDICVStatusPolyPressure
+
+				struct {
+					UInt8 index;  //!< 7 bit index of control parameter
+					UInt8 data;   //!< 7 bit value for control parameter
+				} controlChange;  //!< active when status is kMIDICVStatusControlChange
+
+				UInt8  program;          //!< 7 bit program nr, active when status is kMIDICVStatusProgramChange
+				UInt8  channelPressure;  //!< 7 bit channel pressure, active when status is kMIDICVStatusChannelPressure
+				UInt16 pitchBend;        //!< 7 bit pitch bend active when status is kMIDICVStatusPitchBend
+			};
+		} channelVoice1;   //!< active when type is kMIDIMessageTypeChannelVoice1
+
+		struct {
+			MIDISysExStatus status;
+			UInt8           channel;  //!< MIDI channel 0-15
+			UInt8           data[6];  //!< SysEx data, 7 bit values
+			UInt8           reserved;
+		} sysEx;   //!< active when type is kMIDIMessageTypeSysEx
+
+		struct {
+			MIDICVStatus  status;   //!< determines which variant is active
+			UInt8         channel;  //!< MIDI channel
+			UInt8         reserved[3];
+			union {
+				struct {
+					UInt8                 number;         //!< 7 bit note number
+					MIDINoteAttributeType attributeType;  //!< attribute type
+					UInt16                velocity;       //!< note velocity
+					UInt16                attribute;      //!< attribute data
+				} note;    //!< active when status is kMIDICVStatusNoteOff or kMIDICVStatusNoteOn
+
+				struct
+				{
+					UInt8  noteNumber;  //!< 7 bit note number
+					UInt8  reserved;
+					UInt32 pressure;    //!< pressure value
+				} polyPressure;         //!< active when status is kMIDICVStatusPolyPressure
+
+				struct {
+					UInt8  index;     //!< 7 bit controller number
+					UInt8  reserved;
+					UInt32 data;      //!< controller value
+				} controlChange;      //!< active when status is kMIDICVStatusControlChange
+
+				struct {
+					MIDIProgramChangeOptions options;
+					UInt8   program;     //!< 7 bit program number
+					UInt8   reserved[2];
+					UInt16  bank;        //!< 14 bit bank
+				} programChange;         //!< active when status is kMIDICVStatusProgramChange
+
+				struct {
+					UInt32 data;         //!< channel pressure data
+					UInt8  reserved[2];
+				} channelPressure;       //!< active when status is kMIDICVStatusChannelPressure
+
+				struct {
+					UInt32 data;         //!< pitch bend data
+					UInt8  reserved[2];
+				} pitchBend;             //!< active when status is kMIDICVStatusPitchBend
+
+				struct {
+					UInt8  noteNumber;   //!< 7 bit note number
+					UInt8  index;        //!< 7 bit controller number
+					UInt32 data;         //!< controller data
+				} perNoteController;     //!< active when status is kMIDICVStatusRegisteredPNC or kMIDICVStatusAssignablePNC
+
+				struct {
+					UInt8  bank;    //!< 7 bit bank
+					UInt8  index;   //!< 7 bit controller number
+					UInt32 data;    //!< controller data
+				} controller;       //!< active when status is any of kMIDICVStatusRegisteredControl, kMIDICVStatusAssignableControl, kMIDICVStatusRelRegisteredControl, or kMIDICVStatusRelAssignableControl
+
+				struct {
+					UInt8  noteNumber;   //!< 7 bit note number
+					UInt8  reserved;
+					UInt32 bend;         //!< per note pitch bend value
+				} perNotePitchBend;      //!< active when status is kMIDICVStatusPerNotePitchBend
+
+				struct {
+					UInt8 note;         //!< 7 bit note number
+					MIDIPerNoteManagementOptions options;
+					UInt8 reserved[4];
+				} perNoteManagement;    //!< active when status is kMIDICVStatusPerNoteMgmt
+			};
+		} channelVoice2;  //!< active when type is kMIDIMessageTypeChannelVoice2
+
+		struct {
+			MIDISysExStatus status;    //!< determines which variant is active
+			union {
+				struct {
+					UInt8 byteCount;   //!< byte count of data including stream ID (1-14 bytes)
+					UInt8 streamID;
+					UInt8 data[13];
+					UInt8 reserved;
+				} sysex8;   //!< active when status any of kMIDISysExStatusComplete, kMIDISysExStatusStart, kMIDISysExStatusContinue, or kMIDISysExStatusEnd
+
+				struct {
+					UInt8 mdsID;      //!< mixed data set ID
+					UInt8 data[14];
+					UInt8 reserved;
+				} mixedDataSet;   //!< active when status is kMIDISysExMixedDataSetHeader or kMIDISysExMixedDataSetPayload
+			};
+		} data128;   //!< active when type is kMIDIMessageTypeData128
+
+		struct {
+			UInt32 words[4];  //!< up to four 32 bit words
+		} unknown;            //!< active when type is kMIDIMessageTypeUnknownF
+	};
+} MIDIUniversalMessage;
+
+
+/*!
+	@typedef	MIDIEventVisitor
+
+	@abstract	A callback function which receives a single MIDIUniversalMessage.
+
+	@discussion
+		This callback function is called by MIDIEventListForEachEvent on every UMP
+		that has been parsed from a MIDIEventList. From the provided `MIDIUniversalMessage`
+		the MIDI information can be accessed, e.g.:
+		```
+		void myMIDIMessageVisitor(void* context, MIDITimeStamp timeStamp, MIDIUniversalMessage message) {
+			switch (message.type) {
+			case kMIDIMessageTypeSystem:
+				...
+			case kMIDIMessageTypeChannelVoice2:
+				switch (message.channelVoice2.status) {
+				case kMIDICVStatusNoteOff:
+					// access message.channelVoice2.note.number, etc.
+					...
+				case kMIDICVStatusNoteOn:
+					...
+				case kMIDICVStatusPerNotePitchBend:
+					...
+				}
+			}
+		}
+		```
+
+	@param		context
+		A context provided by the client via call to MIDIEventListForEachEvent.
+
+	@param		timeStamp
+		The timestamp of the current UMP.
+
+	@param		message
+		A filled MIDIUniversalMessage struct that has been parsed from a single UMP.
+*/
+typedef void (*MIDIEventVisitor)(void* context, MIDITimeStamp timeStamp, MIDIUniversalMessage message);
+
+/*!
+	@typedef		MIDIEventListForEachEvent
+	@abstract		Parses UMPs from a MIDIEventList.
+	@discussion
+		MIDIEventListForEachEvent iterates over all UMPs in the provided MIDIEventList.
+		It parses each UMP and fills a MIDIUniversalMessage struct. It calls the provided
+		visitor on each of these UMPs. In case of an unknown UMP the raw UMP words will be provided.
+
+	@param			evtlist
+						The MIDIEventList which is to be parsed.
+
+	@param			visitor
+						The visitor that is called on each UMP in evtlist.
+
+	@param			visitorContext
+						A context for the visitor that is passed to it when being called.
+
+*/
+extern void MIDIEventListForEachEvent(
+	const MIDIEventList* evtlist, MIDIEventVisitor visitor, void* visitorContext)
+									API_AVAILABLE(macos(12.0), ios(15.0), tvos(15.0), watchos(8.0));
+
+
+#ifdef __cplusplus
+}
+#endif
+
+#endif // CoreMIDI_MIDIMessage_h
diff -ruN /Applications/Xcode_13.0.0-beta2.app/Contents/Developer/Platforms/WatchOS.platform/Developer/SDKs/WatchOS.sdk/System/Library/Frameworks/CoreMIDI.framework/Headers/MIDINetworkSession.h /Applications/Xcode_13.0.0-beta3.app/Contents/Developer/Platforms/WatchOS.platform/Developer/SDKs/WatchOS.sdk/System/Library/Frameworks/CoreMIDI.framework/Headers/MIDINetworkSession.h
--- /Applications/Xcode_13.0.0-beta2.app/Contents/Developer/Platforms/WatchOS.platform/Developer/SDKs/WatchOS.sdk/System/Library/Frameworks/CoreMIDI.framework/Headers/MIDINetworkSession.h	1969-12-31 19:00:00.000000000 -0500
+++ /Applications/Xcode_13.0.0-beta3.app/Contents/Developer/Platforms/WatchOS.platform/Developer/SDKs/WatchOS.sdk/System/Library/Frameworks/CoreMIDI.framework/Headers/MIDINetworkSession.h	2021-07-10 09:47:45.000000000 -0400
@@ -0,0 +1,129 @@
+/*
+    File:       CoreMIDI/MIDINetworkSession.h
+ 
+    Contains:   Routines for MIDI networking
+ 
+ 	Copyright:  (c) 2010 by Apple Inc., all rights reserved.
+ 
+    Bugs?:      For bug reports, consult the following page on
+                the World Wide Web:
+ 
+                    http://feedbackassistant.apple.com/
+ 
+*/
+
+#ifndef __MIDINetworkSession_h__
+#define __MIDINetworkSession_h__
+
+#if defined(__OBJC__)
+#import <CoreMIDI/MIDIServices.h>
+#import <Foundation/Foundation.h>
+
+#define MIDINETWORKSESSION_AVAILABLE API_AVAILABLE(macos(10.15), ios(4.2)) API_UNAVAILABLE(watchos, tvos)
+
+NS_ASSUME_NONNULL_BEGIN
+
+/* This is the Bonjour service type. */
+OS_EXPORT NSString *const MIDINetworkBonjourServiceType MIDINETWORKSESSION_AVAILABLE;
+
+/*
+	These are NSNotifications posted by MIDINetworkSession objects. 
+
+	MIDINetworkNotificationContactsDidChange signifies that the list of contacts changed.
+	MIDINetworkNotificationSessionDidChange signifies that other aspects of the session changed,
+	such as the connection list, connection policy, etc.
+*/
+OS_EXPORT NSString *const MIDINetworkNotificationContactsDidChange MIDINETWORKSESSION_AVAILABLE;
+OS_EXPORT NSString *const MIDINetworkNotificationSessionDidChange MIDINETWORKSESSION_AVAILABLE;
+
+
+/* __________________________________________________________________________________________________
+	These are the values of connectionPolicy
+*/
+typedef NS_ENUM(NSUInteger, MIDINetworkConnectionPolicy) {
+	MIDINetworkConnectionPolicy_NoOne				= 0,
+	MIDINetworkConnectionPolicy_HostsInContactList	= 1,
+	MIDINetworkConnectionPolicy_Anyone				= 2
+};
+
+/* __________________________________________________________________________________________________
+	MIDINetworkHost
+	
+	Represents a network address.
+	name: the user's tag for this object.
+	Representations are either:
+	-	address (IP address or hostname) and UDP port
+	-	netServiceName and netServiceDomain
+*/
+OS_EXPORT MIDINETWORKSESSION_AVAILABLE
+@interface MIDINetworkHost : NSObject {
+@private
+    void *_imp;
+}
++ (instancetype)hostWithName: (NSString *)name address: (NSString *)address port: (NSUInteger)port;
++ (instancetype)hostWithName: (NSString *)name netService: (NSNetService *)netService;
++ (instancetype)hostWithName: (NSString *)name netServiceName: (NSString *)netServiceName netServiceDomain: (NSString *)netServiceDomain;
+- (BOOL)hasSameAddressAs: (MIDINetworkHost *)other;
+
+@property(nonatomic,readonly) NSString *name;				/* user's tag */
+@property(nonatomic,readonly) NSString *address;			/* IP address or hostname */
+@property(nonatomic,readonly) NSUInteger port;						/* UDP port */
+@property(nonatomic,readonly,nullable) NSString *netServiceName;	/* NSNetService name */
+@property(nonatomic,readonly,nullable) NSString *netServiceDomain;	/* NSNetService domain */
+@end
+
+/*__________________________________________________________________________________________________
+	MIDINetworkConnection
+
+	Add a connection to a session to connect to the remote host; remove it to disconnect.
+*/
+OS_EXPORT MIDINETWORKSESSION_AVAILABLE
+@interface MIDINetworkConnection : NSObject {
+@private
+    void *_imp;
+}
++ (instancetype)connectionWithHost: (MIDINetworkHost *)host;
+@property(nonatomic,readonly) MIDINetworkHost *host;
+@end
+
+/* __________________________________________________________________________________________________
+	MIDINetworkSession
+	
+	A network session represents one CoreMIDI entity (source/destination pair). One session can
+	have any number of connections. Output is broadcast to all connections; input from multiple
+	connections is merged.
+*/
+OS_EXPORT MIDINETWORKSESSION_AVAILABLE
+@interface MIDINetworkSession : NSObject {
+@private
+    void *_imp;
+}
+
++ (MIDINetworkSession *)defaultSession; /* returns the singleton. */
+
+/* Basic attributes of a session */
+@property(nonatomic,getter=isEnabled) BOOL enabled;			/* disabled sessions do not appear on the network and cannot initiate or receive connections. default is NO (disabled). */
+@property(nonatomic,readonly) NSUInteger networkPort;		/* UDP port */
+@property(nonatomic,readonly) NSString *networkName;		/* name by which this session is advertised via Bonjour */
+@property(nonatomic,readonly) NSString *localName;			/* name of this session's CoreMIDI entity (inherited by its endpoints) */
+@property(nonatomic) MIDINetworkConnectionPolicy connectionPolicy;	/* who can connect to this session? see constants above. */
+
+/*	The driver maintains a directory of MIDINetworkHosts, "contacts," for user convenience in initiating 
+	connections, and for controlling incoming connection requests. */
+- (NSSet<MIDINetworkHost *> *)contacts;
+- (BOOL)addContact: (MIDINetworkHost *)contact;
+- (BOOL)removeContact: (MIDINetworkHost *)contact;
+
+- (NSSet<MIDINetworkConnection *> *)connections;
+- (BOOL)addConnection: (MIDINetworkConnection *)connection;
+- (BOOL)removeConnection: (MIDINetworkConnection *)connection;
+
+- (MIDIEndpointRef)sourceEndpoint;
+- (MIDIEndpointRef)destinationEndpoint;
+@end
+
+NS_ASSUME_NONNULL_END
+
+#endif // defined(__OBJC__)
+
+#endif /* __MIDINetworkSession_h__ */
diff -ruN /Applications/Xcode_13.0.0-beta2.app/Contents/Developer/Platforms/WatchOS.platform/Developer/SDKs/WatchOS.sdk/System/Library/Frameworks/CoreMIDI.framework/Headers/MIDIServices.h /Applications/Xcode_13.0.0-beta3.app/Contents/Developer/Platforms/WatchOS.platform/Developer/SDKs/WatchOS.sdk/System/Library/Frameworks/CoreMIDI.framework/Headers/MIDIServices.h
--- /Applications/Xcode_13.0.0-beta2.app/Contents/Developer/Platforms/WatchOS.platform/Developer/SDKs/WatchOS.sdk/System/Library/Frameworks/CoreMIDI.framework/Headers/MIDIServices.h	2021-06-17 03:43:51.000000000 -0400
+++ /Applications/Xcode_13.0.0-beta3.app/Contents/Developer/Platforms/WatchOS.platform/Developer/SDKs/WatchOS.sdk/System/Library/Frameworks/CoreMIDI.framework/Headers/MIDIServices.h	2021-07-13 00:34:10.000000000 -0400
@@ -362,7 +362,7 @@
 						identifies the source of the data.
 */
 typedef void
-(*MIDIReadProc)(const MIDIPacketList *pktlist, void * __nullable readProcRefCon, void * __nullable srcConnRefCon);
+(*MIDIReadProc)(const MIDIPacketList *pktlist, void * __nullable readProcRefCon, void * __nullable srcConnRefCon) API_DEPRECATED("use MIDIReceiveBlock and MIDIEventLists", macos(10.0, API_TO_BE_DEPRECATED), ios(4.2, API_TO_BE_DEPRECATED)) __TVOS_PROHIBITED __WATCHOS_PROHIBITED;
 
 /*!
 	@typedef		MIDIReadBlock
@@ -382,7 +382,7 @@
 						identifies the source of the data.
 */
 typedef void
-(^MIDIReadBlock)(const MIDIPacketList *pktlist, void * __nullable srcConnRefCon);
+(^MIDIReadBlock)(const MIDIPacketList *pktlist, void * __nullable srcConnRefCon) API_DEPRECATED("use MIDIReceiveBlock and MIDIEventLists", macos(10.11, API_TO_BE_DEPRECATED), ios(9.0, API_TO_BE_DEPRECATED)) __TVOS_PROHIBITED __WATCHOS_PROHIBITED;
 
 /*!
 	@typedef		MIDICompletionProc
@@ -708,7 +708,7 @@
 		A setup editor may allow the user to set the names of both driver-owned and external
 		devices.
 */
-extern const CFStringRef	kMIDIPropertyName					API_AVAILABLE(macos(10.0), ios(4.2), tvos(12.0));
+extern const CFStringRef	kMIDIPropertyName					API_AVAILABLE(macos(10.0), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
 
 /*!
 	@constant		kMIDIPropertyManufacturer
@@ -721,7 +721,7 @@
 
 		Creators of virtual endpoints may set this property on their endpoints.
 */
-extern const CFStringRef	kMIDIPropertyManufacturer			API_AVAILABLE(macos(10.0), ios(4.2), tvos(12.0));
+extern const CFStringRef	kMIDIPropertyManufacturer			API_AVAILABLE(macos(10.0), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
 
 /*!
 	@constant		kMIDIPropertyModel
@@ -734,7 +734,7 @@
 
 		Creators of virtual endpoints may set this property on their endpoints.
 */
-extern const CFStringRef	kMIDIPropertyModel					API_AVAILABLE(macos(10.0), ios(4.2), tvos(12.0));
+extern const CFStringRef	kMIDIPropertyModel					API_AVAILABLE(macos(10.0), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
 
 /*!
 	@constant		kMIDIPropertyUniqueID
@@ -745,7 +745,7 @@
 		this property on their endpoints, though doing so may fail if the chosen ID is not
 		unique.
 */
-extern const CFStringRef	kMIDIPropertyUniqueID				API_AVAILABLE(macos(10.0), ios(4.2), tvos(12.0));
+extern const CFStringRef	kMIDIPropertyUniqueID				API_AVAILABLE(macos(10.0), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
 
 /*!
 	@constant		kMIDIPropertyDeviceID
@@ -758,7 +758,7 @@
 
 		Setup editors may allow the user to set this property on external devices.
 */
-extern const CFStringRef	kMIDIPropertyDeviceID				API_AVAILABLE(macos(10.0), ios(4.2), tvos(12.0));
+extern const CFStringRef	kMIDIPropertyDeviceID				API_AVAILABLE(macos(10.0), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
 
 /*!
 	@constant		kMIDIPropertyReceiveChannels
@@ -774,7 +774,7 @@
 
 		Virtual destination may set this property on their endpoints.
 */
-extern const CFStringRef	kMIDIPropertyReceiveChannels		API_AVAILABLE(macos(10.0), ios(4.2), tvos(12.0));
+extern const CFStringRef	kMIDIPropertyReceiveChannels		API_AVAILABLE(macos(10.0), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
 
 /*!
 	@constant		kMIDIPropertyTransmitChannels
@@ -784,7 +784,7 @@
 		The value is a bitmap of channels on which the object transmits: 1=ch 1, 2=ch 2, 4=ch 3
 		... 0x8000=ch 16.
 */
-extern const CFStringRef	kMIDIPropertyTransmitChannels		API_AVAILABLE(macos(10.2), ios(4.2), tvos(12.0));
+extern const CFStringRef	kMIDIPropertyTransmitChannels		API_AVAILABLE(macos(10.2), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
 
 /*!
 	@constant		kMIDIPropertyMaxSysExSpeed
@@ -795,7 +795,7 @@
 		The value is the maximum rate, in bytes/second, at which sysex messages may
 		be sent reliably to this object. (The default value is 3125, as with MIDI 1.0)
 */
-extern const CFStringRef	kMIDIPropertyMaxSysExSpeed			API_AVAILABLE(macos(10.0), ios(4.2), tvos(12.0));
+extern const CFStringRef	kMIDIPropertyMaxSysExSpeed			API_AVAILABLE(macos(10.0), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
 
 
 /*!
@@ -817,7 +817,7 @@
 		time, it receives timestamped messages as soon as they are sent, and must do its own
 		internal scheduling of received events.
 */
-extern const CFStringRef	kMIDIPropertyAdvanceScheduleTimeMuSec	API_AVAILABLE(macos(10.0), ios(4.2), tvos(12.0));
+extern const CFStringRef	kMIDIPropertyAdvanceScheduleTimeMuSec	API_AVAILABLE(macos(10.0), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
 
 /*!
 	@constant		kMIDIPropertyIsEmbeddedEntity
@@ -826,7 +826,7 @@
 
 		0 if there are external MIDI connectors, 1 if not.
 */
-extern const CFStringRef	kMIDIPropertyIsEmbeddedEntity			API_AVAILABLE(macos(10.1), ios(4.2), tvos(12.0));
+extern const CFStringRef	kMIDIPropertyIsEmbeddedEntity			API_AVAILABLE(macos(10.1), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
 
 
 /*!
@@ -837,7 +837,7 @@
 		1 if the endpoint broadcasts messages to all of the other endpoints in the device, 0 if
 		not.  Set by the owning driver; should not be touched by other clients.
 */
-extern const CFStringRef	kMIDIPropertyIsBroadcast				API_AVAILABLE(macos(10.2), ios(4.2), tvos(12.0));
+extern const CFStringRef	kMIDIPropertyIsBroadcast				API_AVAILABLE(macos(10.2), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
 
 /*!
 	@constant		kMIDIPropertySingleRealtimeEntity
@@ -852,7 +852,7 @@
 		entity on which incoming realtime messages from the device will appear to have
 		originated from.
 */
-extern const CFStringRef	kMIDIPropertySingleRealtimeEntity		API_AVAILABLE(macos(10.2), ios(4.2), tvos(12.0));
+extern const CFStringRef	kMIDIPropertySingleRealtimeEntity		API_AVAILABLE(macos(10.2), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
 
 /*!
 	@constant		kMIDIPropertyConnectionUniqueID
@@ -873,7 +873,7 @@
 		signifies a MIDI Thru connection to another external device/entity/endpoint (again,
 		it is strongly recommended that it be an endpoint).
 */
-extern const CFStringRef	kMIDIPropertyConnectionUniqueID			API_AVAILABLE(macos(10.1), ios(4.2), tvos(12.0));
+extern const CFStringRef	kMIDIPropertyConnectionUniqueID			API_AVAILABLE(macos(10.1), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
 
 
 /*!
@@ -885,7 +885,7 @@
 		the device; should not be touched by other clients. Property is inherited from the
 		device by its entities and endpoints.
 */
-extern const CFStringRef	kMIDIPropertyOffline					API_AVAILABLE(macos(10.1), ios(4.2), tvos(12.0));
+extern const CFStringRef	kMIDIPropertyOffline					API_AVAILABLE(macos(10.1), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
 
 /*!
 	@constant		kMIDIPropertyPrivate
@@ -896,7 +896,7 @@
 		but they will still appear in the API; only affects whether the owned endpoints are
 		hidden.
 */
-extern const CFStringRef	kMIDIPropertyPrivate					API_AVAILABLE(macos(10.2), ios(4.2), tvos(12.0));
+extern const CFStringRef	kMIDIPropertyPrivate					API_AVAILABLE(macos(10.2), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
 
 /*!
 	@constant		kMIDIPropertyDriverOwner
@@ -907,7 +907,7 @@
 		not be touched by other clients. Property is inherited from the device by its entities
 		and endpoints.
 */
-extern const CFStringRef	kMIDIPropertyDriverOwner				API_AVAILABLE(macos(10.1), ios(4.2), tvos(12.0));
+extern const CFStringRef	kMIDIPropertyDriverOwner				API_AVAILABLE(macos(10.1), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
 
 /*!
 	@constant		kMIDIPropertyFactoryPatchNameFile
@@ -919,7 +919,7 @@
 		Added in CoreMIDI 1.1 (Mac OS X 10.1).  DEPRECATED as of CoreMIDI 1.3. Use
 		kMIDIPropertyNameConfiguration instead.
 */
-extern const CFStringRef	kMIDIPropertyFactoryPatchNameFile		API_DEPRECATED_WITH_REPLACEMENT("kMIDIPropertyNameConfiguration", macos(10.1, 10.2)) API_UNAVAILABLE(ios, tvos);
+extern const CFStringRef	kMIDIPropertyFactoryPatchNameFile		API_DEPRECATED_WITH_REPLACEMENT("kMIDIPropertyNameConfiguration", macos(10.1, 10.2)) API_UNAVAILABLE(ios, tvos, watchos);
 
 
 /*!
@@ -932,7 +932,7 @@
 		Added in CoreMIDI 1.1 (Mac OS X 10.1).  DEPRECATED as of CoreMIDI 1.3. Use
 		kMIDIPropertyNameConfiguration instead.
 */
-extern const CFStringRef	kMIDIPropertyUserPatchNameFile			API_DEPRECATED_WITH_REPLACEMENT("kMIDIPropertyNameConfiguration", macos(10.1, 10.2)) API_UNAVAILABLE(ios, tvos);
+extern const CFStringRef	kMIDIPropertyUserPatchNameFile			API_DEPRECATED_WITH_REPLACEMENT("kMIDIPropertyNameConfiguration", macos(10.1, 10.2)) API_UNAVAILABLE(ios, tvos, watchos);
 
 /*!
 	@constant		kMIDIPropertyNameConfiguration
@@ -969,7 +969,7 @@
 		other than the ones they are interested in changing and to properly structure the
 		dictionary.
 */
-extern const CFStringRef	kMIDIPropertyNameConfiguration			API_DEPRECATED_WITH_REPLACEMENT("kMIDIPropertyNameConfigurationDictionary", macos(10.2, 10.15), ios(4.2, 13.0), tvos(12.0, 13.0));
+extern const CFStringRef	kMIDIPropertyNameConfiguration			API_DEPRECATED_WITH_REPLACEMENT("kMIDIPropertyNameConfigurationDictionary", macos(10.2, 10.15), ios(4.2, 13.0)) __TVOS_PROHIBITED __WATCHOS_PROHIBITED;
 
 /*!
     @constant        kMIDIPropertyNameConfigurationDictionary
@@ -1001,7 +1001,7 @@
         other than the ones they are interested in changing and to properly structure the
         dictionary.
 */
-extern const CFStringRef    kMIDIPropertyNameConfigurationDictionary            API_AVAILABLE(macos(10.15), ios(13.0), tvos(13.0));
+extern const CFStringRef    kMIDIPropertyNameConfigurationDictionary            API_AVAILABLE(macos(10.15), ios(13.0)) API_UNAVAILABLE(tvos, watchos);
 
 /*!
 	@constant		kMIDIPropertyImage
@@ -1015,7 +1015,7 @@
 
 		A studio setup editor should allow the user to choose icons for external devices.
 */
-extern const CFStringRef	kMIDIPropertyImage						API_AVAILABLE(macos(10.2), ios(4.2), tvos(12.0));
+extern const CFStringRef	kMIDIPropertyImage						API_AVAILABLE(macos(10.2), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
 
 /*!
 	@constant		kMIDIPropertyDriverVersion
@@ -1024,7 +1024,7 @@
 		driver (only for driver- owned devices).  Drivers need not set this property;
 		applications should not write to it.
 */
-extern const CFStringRef	kMIDIPropertyDriverVersion				API_AVAILABLE(macos(10.2), ios(4.2), tvos(12.0));
+extern const CFStringRef	kMIDIPropertyDriverVersion				API_AVAILABLE(macos(10.2), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
 
 /*!
 	@constant		kMIDIPropertySupportsGeneralMIDI
@@ -1032,7 +1032,7 @@
 		device/entity property, integer (0/1). Indicates whether the device or entity implements
 		the General MIDI specification.
 */
-extern const CFStringRef	kMIDIPropertySupportsGeneralMIDI		API_AVAILABLE(macos(10.2), ios(4.2), tvos(12.0));
+extern const CFStringRef	kMIDIPropertySupportsGeneralMIDI		API_AVAILABLE(macos(10.2), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
 
 /*!
 	@constant		kMIDIPropertySupportsMMC
@@ -1040,7 +1040,7 @@
 		device/entity property, integer (0/1). Indicates whether the device or entity implements
 		the MIDI Machine Control portion of the MIDI specification.
 */
-extern const CFStringRef	kMIDIPropertySupportsMMC				API_AVAILABLE(macos(10.2), ios(4.2), tvos(12.0));
+extern const CFStringRef	kMIDIPropertySupportsMMC				API_AVAILABLE(macos(10.2), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
 
 /*!
 	@constant		kMIDIPropertyCanRoute
@@ -1049,7 +1049,7 @@
 		MIDI messages to or from other external MIDI devices (as with MIDI patch bays). This
 		should NOT be set on devices which are controlled by drivers.
 */
-extern const CFStringRef	kMIDIPropertyCanRoute					API_AVAILABLE(macos(10.0), ios(4.2), tvos(12.0));
+extern const CFStringRef	kMIDIPropertyCanRoute					API_AVAILABLE(macos(10.0), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
 
 /*!
 	@constant		kMIDIPropertyReceivesClock
@@ -1057,7 +1057,7 @@
 		device/entity property, integer (0/1). Indicates whether the device or entity  responds
 		to MIDI beat clock messages.
 */
-extern const CFStringRef	kMIDIPropertyReceivesClock				API_AVAILABLE(macos(10.2), ios(4.2), tvos(12.0));
+extern const CFStringRef	kMIDIPropertyReceivesClock				API_AVAILABLE(macos(10.2), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
 
 /*!
 	@constant		kMIDIPropertyReceivesMTC
@@ -1065,7 +1065,7 @@
 		device/entity property, integer (0/1). Indicates whether the device or entity responds
 		to MIDI Time Code messages.
 */
-extern const CFStringRef	kMIDIPropertyReceivesMTC				API_AVAILABLE(macos(10.2), ios(4.2), tvos(12.0));
+extern const CFStringRef	kMIDIPropertyReceivesMTC				API_AVAILABLE(macos(10.2), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
 
 /*!
 	@constant		kMIDIPropertyReceivesNotes
@@ -1073,7 +1073,7 @@
 		device/entity property, integer (0/1). Indicates whether the device or entity responds
 		to MIDI Note On messages.
 */
-extern const CFStringRef	kMIDIPropertyReceivesNotes				API_AVAILABLE(macos(10.2), ios(4.2), tvos(12.0));
+extern const CFStringRef	kMIDIPropertyReceivesNotes				API_AVAILABLE(macos(10.2), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
 
 /*!
 	@constant		kMIDIPropertyReceivesProgramChanges
@@ -1081,7 +1081,7 @@
 		device/entity property, integer (0/1). Indicates whether the device or entity responds
 		to MIDI program change messages.
 */
-extern const CFStringRef	kMIDIPropertyReceivesProgramChanges		API_AVAILABLE(macos(10.2), ios(4.2), tvos(12.0));
+extern const CFStringRef	kMIDIPropertyReceivesProgramChanges		API_AVAILABLE(macos(10.2), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
 
 /*!
 	@constant		kMIDIPropertyReceivesBankSelectMSB
@@ -1089,7 +1089,7 @@
 		device/entity property, integer (0/1). Indicates whether the device or entity responds
 		to MIDI bank select MSB messages (control 0).
 */
-extern const CFStringRef	kMIDIPropertyReceivesBankSelectMSB		API_AVAILABLE(macos(10.2), ios(4.2), tvos(12.0));
+extern const CFStringRef	kMIDIPropertyReceivesBankSelectMSB		API_AVAILABLE(macos(10.2), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
 
 /*!
 	@constant		kMIDIPropertyReceivesBankSelectLSB
@@ -1097,7 +1097,7 @@
 		device/entity property, integer (0/1). Indicates whether the device or entity responds
 		to MIDI bank select LSB messages (control 32).
 */
-extern const CFStringRef	kMIDIPropertyReceivesBankSelectLSB		API_AVAILABLE(macos(10.2), ios(4.2), tvos(12.0));
+extern const CFStringRef	kMIDIPropertyReceivesBankSelectLSB		API_AVAILABLE(macos(10.2), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
 
 /*!
 	@constant		kMIDIPropertyTransmitsClock
@@ -1105,7 +1105,7 @@
 		device/entity property, integer (0/1). Indicates whether the device or entity transmits
 		MIDI beat clock messages.
 */
-extern const CFStringRef	kMIDIPropertyTransmitsClock				API_AVAILABLE(macos(10.2), ios(4.2), tvos(12.0));
+extern const CFStringRef	kMIDIPropertyTransmitsClock				API_AVAILABLE(macos(10.2), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
 
 /*!
 	@constant		kMIDIPropertyTransmitsMTC
@@ -1113,7 +1113,7 @@
 		device/entity property, integer (0/1). Indicates whether the device or entity transmits
 		MIDI Time Code messages.
 */
-extern const CFStringRef	kMIDIPropertyTransmitsMTC				API_AVAILABLE(macos(10.2), ios(4.2), tvos(12.0));
+extern const CFStringRef	kMIDIPropertyTransmitsMTC				API_AVAILABLE(macos(10.2), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
 
 /*!
 	@constant		kMIDIPropertyTransmitsNotes
@@ -1121,7 +1121,7 @@
 		device/entity property, integer (0/1). Indicates whether the device or entity transmits
 		MIDI note messages.
 */
-extern const CFStringRef	kMIDIPropertyTransmitsNotes				API_AVAILABLE(macos(10.2), ios(4.2), tvos(12.0));
+extern const CFStringRef	kMIDIPropertyTransmitsNotes				API_AVAILABLE(macos(10.2), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
 
 /*!
 	@constant		kMIDIPropertyTransmitsProgramChanges
@@ -1129,7 +1129,7 @@
 		device/entity property, integer (0/1). Indicates whether the device or entity transmits
 		MIDI program change messages.
 */
-extern const CFStringRef	kMIDIPropertyTransmitsProgramChanges	API_AVAILABLE(macos(10.2), ios(4.2), tvos(12.0));
+extern const CFStringRef	kMIDIPropertyTransmitsProgramChanges	API_AVAILABLE(macos(10.2), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
 
 /*!
 	@constant		kMIDIPropertyTransmitsBankSelectMSB
@@ -1137,7 +1137,7 @@
 		device/entity property, integer (0/1). Indicates whether the device or entity transmits
 		MIDI bank select MSB messages (control 0).
 */
-extern const CFStringRef	kMIDIPropertyTransmitsBankSelectMSB		API_AVAILABLE(macos(10.2), ios(4.2), tvos(12.0));
+extern const CFStringRef	kMIDIPropertyTransmitsBankSelectMSB		API_AVAILABLE(macos(10.2), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
 
 /*!
 	@constant		kMIDIPropertyTransmitsBankSelectLSB
@@ -1145,7 +1145,7 @@
 		device/entity property, integer (0/1). Indicates whether the device or entity transmits
 		MIDI bank select LSB messages (control 32).
 */
-extern const CFStringRef	kMIDIPropertyTransmitsBankSelectLSB		API_AVAILABLE(macos(10.2), ios(4.2), tvos(12.0));
+extern const CFStringRef	kMIDIPropertyTransmitsBankSelectLSB		API_AVAILABLE(macos(10.2), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
 
 /*!
 	@constant		kMIDIPropertyPanDisruptsStereo
@@ -1154,7 +1154,7 @@
 		10), when sent to the device or entity, cause undesirable effects when playing stereo
 		sounds (e.g. converting the signal to mono).
 */
-extern const CFStringRef	kMIDIPropertyPanDisruptsStereo			API_AVAILABLE(macos(10.2), ios(4.2), tvos(12.0));
+extern const CFStringRef	kMIDIPropertyPanDisruptsStereo			API_AVAILABLE(macos(10.2), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
 
 /*!
 	@constant		kMIDIPropertyIsSampler
@@ -1162,7 +1162,7 @@
 		device/entity property, integer (0/1). Indicates whether the device or entity plays
 		audio samples in response to MIDI note messages.
 */
-extern const CFStringRef	kMIDIPropertyIsSampler					API_AVAILABLE(macos(10.2), ios(4.2), tvos(12.0));
+extern const CFStringRef	kMIDIPropertyIsSampler					API_AVAILABLE(macos(10.2), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
 
 /*!
 	@constant		kMIDIPropertyIsDrumMachine
@@ -1170,7 +1170,7 @@
 		device/entity property, integer (0/1). Indicates whether the device or entity's sound
 		presets tend to be collections of non-transposable samples (e.g. drum kits).
 */
-extern const CFStringRef	kMIDIPropertyIsDrumMachine				API_AVAILABLE(macos(10.2), ios(4.2), tvos(12.0));
+extern const CFStringRef	kMIDIPropertyIsDrumMachine				API_AVAILABLE(macos(10.2), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
 
 /*!
 	@constant		kMIDIPropertyIsMixer
@@ -1178,7 +1178,7 @@
 		device/entity property, integer (0/1). Indicates whether the device or entity mixes
 		external audio signals, controlled by MIDI messages.
 */
-extern const CFStringRef	kMIDIPropertyIsMixer					API_AVAILABLE(macos(10.2), ios(4.2), tvos(12.0));
+extern const CFStringRef	kMIDIPropertyIsMixer					API_AVAILABLE(macos(10.2), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
 
 /*!
 	@constant		kMIDIPropertyIsEffectUnit
@@ -1186,7 +1186,7 @@
 		device/entity property, integer (0/1). Indicates whether the device or entity is
 		primarily a MIDI-controlled audio effect unit (i.e. does not generate sound on its own).
 */
-extern const CFStringRef	kMIDIPropertyIsEffectUnit				API_AVAILABLE(macos(10.2), ios(4.2), tvos(12.0));
+extern const CFStringRef	kMIDIPropertyIsEffectUnit				API_AVAILABLE(macos(10.2), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
 
 /*!
 	@constant		kMIDIPropertyMaxReceiveChannels
@@ -1197,7 +1197,7 @@
 		(fully multitimbral devices). Other values are possible, for example devices which are
 		multi-timbral but have fewer than 16 "parts".
 */
-extern const CFStringRef	kMIDIPropertyMaxReceiveChannels			API_AVAILABLE(macos(10.2), ios(4.2), tvos(12.0));
+extern const CFStringRef	kMIDIPropertyMaxReceiveChannels			API_AVAILABLE(macos(10.2), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
 
 /*!
 	@constant		kMIDIPropertyMaxTransmitChannels
@@ -1206,7 +1206,7 @@
 		which a device may simultaneously transmit MIDI Channel Messages. Common values are 0, 1
 		and 16.
 */
-extern const CFStringRef	kMIDIPropertyMaxTransmitChannels		API_AVAILABLE(macos(10.2), ios(4.2), tvos(12.0));
+extern const CFStringRef	kMIDIPropertyMaxTransmitChannels		API_AVAILABLE(macos(10.2), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
 
 /*!
 	@constant		kMIDIPropertyDriverDeviceEditorApp
@@ -1215,7 +1215,7 @@
 		configure this driver-owned devices. Drivers may set this property on their owned
 		devices. Applications must not write to it.
 */
-extern const CFStringRef	kMIDIPropertyDriverDeviceEditorApp		API_AVAILABLE(macos(10.3), ios(4.2), tvos(12.0));
+extern const CFStringRef	kMIDIPropertyDriverDeviceEditorApp		API_AVAILABLE(macos(10.3), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
 
 /*!
 	@constant		kMIDIPropertySupportsShowControl
@@ -1223,7 +1223,7 @@
 		device/entity property, integer (0/1). Indicates whether the device implements the MIDI
 		Show Control specification.
 */
-extern const CFStringRef	kMIDIPropertySupportsShowControl		API_AVAILABLE(macos(10.4), ios(4.2), tvos(12.0));
+extern const CFStringRef	kMIDIPropertySupportsShowControl		API_AVAILABLE(macos(10.4), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
 
 /*!
 	@constant		kMIDIPropertyDisplayName
@@ -1235,7 +1235,7 @@
 
 		For objects other than endpoints, the display name is the same as the name.
 */
-extern const CFStringRef	kMIDIPropertyDisplayName				API_AVAILABLE(macos(10.4), ios(4.2), tvos(12.0));
+extern const CFStringRef	kMIDIPropertyDisplayName				API_AVAILABLE(macos(10.4), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
 
 /*!
 	constant		kMIDIPropertyProtocolID
@@ -1246,7 +1246,7 @@
 		negotiation, by setting this property on the endpoint. Clients can observe changes to
 		this property.
 */
-extern const CFStringRef	kMIDIPropertyProtocolID					API_AVAILABLE(macos(11.0), ios(14.0), tvos(14.0));
+extern const CFStringRef	kMIDIPropertyProtocolID					API_AVAILABLE(macos(11.0), ios(14.0)) API_UNAVAILABLE(tvos, watchos);
 
 //==================================================================================================
 #pragma mark	Clients
@@ -1276,7 +1276,7 @@
 MIDIClientCreate(	CFStringRef					name,
 					MIDINotifyProc __nullable	notifyProc,
 					void * __nullable			notifyRefCon,
-					MIDIClientRef *				outClient )				API_AVAILABLE(macos(10.0), ios(4.2), tvos(12.0));
+					MIDIClientRef *				outClient )				API_AVAILABLE(macos(10.0), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
 
 /*!
 	@function		MIDIClientCreateWithBlock
@@ -1300,7 +1300,7 @@
 MIDIClientCreateWithBlock(
 					CFStringRef					name,
 					MIDIClientRef *				outClient,
-					MIDINotifyBlock __nullable	notifyBlock )			API_AVAILABLE(macos(10.11), ios(9.0), tvos(12.0));
+					MIDINotifyBlock __nullable	notifyBlock )			API_AVAILABLE(macos(10.11), ios(9.0)) API_UNAVAILABLE(tvos, watchos);
 
 
 /*!
@@ -1321,7 +1321,7 @@
 		disposing all of an application's MIDIClients is strongly discouraged.
 */
 extern OSStatus
-MIDIClientDispose(	MIDIClientRef client )					API_AVAILABLE(macos(10.0), ios(4.2), tvos(12.0));
+MIDIClientDispose(	MIDIClientRef client )					API_AVAILABLE(macos(10.0), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
 
 //==================================================================================================
 #pragma mark	Ports
@@ -1358,7 +1358,7 @@
 								CFStringRef		portName,
 								MIDIProtocolID	protocol,
 								MIDIPortRef *	outPort,
-								MIDIReceiveBlock receiveBlock )	API_AVAILABLE(macos(11.0), ios(14.0), tvos(14.0));
+								MIDIReceiveBlock receiveBlock )	API_AVAILABLE(macos(11.0), ios(14.0)) API_UNAVAILABLE(tvos, watchos);
 
 /*!
 	@function		MIDIInputPortCreate
@@ -1393,7 +1393,7 @@
 						void * __nullable	refCon,
 						MIDIPortRef * 		outPort )
 				API_DEPRECATED_WITH_REPLACEMENT("MIDIInputPortCreateWithProtocol",
-												macos(10.0, API_TO_BE_DEPRECATED), ios(4.2, API_TO_BE_DEPRECATED), tvos(12.0, API_TO_BE_DEPRECATED));
+												macos(10.0, API_TO_BE_DEPRECATED), ios(4.2, API_TO_BE_DEPRECATED)) __TVOS_PROHIBITED __WATCHOS_PROHIBITED;
 
 /*!
 	@function		MIDIInputPortCreateWithBlock
@@ -1425,7 +1425,7 @@
 								MIDIPortRef *	outPort,
 								MIDIReadBlock	readBlock )
 					API_DEPRECATED_WITH_REPLACEMENT("MIDIInputPortCreateWithProtocol",
-													macos(10.11, API_TO_BE_DEPRECATED), ios(9.0, API_TO_BE_DEPRECATED), tvos(12.0, API_TO_BE_DEPRECATED));
+													macos(10.11, API_TO_BE_DEPRECATED), ios(9.0, API_TO_BE_DEPRECATED)) __TVOS_PROHIBITED __WATCHOS_PROHIBITED;
 
 /*!
 	@function		MIDIOutputPortCreate
@@ -1453,7 +1453,7 @@
 extern OSStatus
 MIDIOutputPortCreate(	MIDIClientRef	client,
 						CFStringRef		portName,
-						MIDIPortRef *	outPort )			API_AVAILABLE(macos(10.0), ios(4.2), tvos(12.0));
+						MIDIPortRef *	outPort )			API_AVAILABLE(macos(10.0), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
 
 /*!
 	@function		MIDIPortDispose
@@ -1470,7 +1470,7 @@
 		client's ports are automatically disposed at that time.
 */
 extern OSStatus
-MIDIPortDispose(	MIDIPortRef port )						API_AVAILABLE(macos(10.0), ios(4.2), tvos(12.0));
+MIDIPortDispose(	MIDIPortRef port )						API_AVAILABLE(macos(10.0), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
 
 
 /*!
@@ -1491,7 +1491,7 @@
 extern OSStatus
 MIDIPortConnectSource(	MIDIPortRef		port,
 						MIDIEndpointRef	source,
-						void * __nullable			connRefCon )		API_AVAILABLE(macos(10.0), ios(4.2), tvos(12.0));
+						void * __nullable			connRefCon )		API_AVAILABLE(macos(10.0), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
 
 
 /*!
@@ -1509,7 +1509,7 @@
 */
 extern OSStatus
 MIDIPortDisconnectSource(	MIDIPortRef		port,
-							MIDIEndpointRef	source )		API_AVAILABLE(macos(10.0), ios(4.2), tvos(12.0));
+							MIDIEndpointRef	source )		API_AVAILABLE(macos(10.0), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
 
 
 //==================================================================================================
@@ -1524,7 +1524,7 @@
 					occurred.
 */
 extern ItemCount
-MIDIGetNumberOfDevices(void)								API_AVAILABLE(macos(10.0), ios(4.2), tvos(12.0));
+MIDIGetNumberOfDevices(void)								API_AVAILABLE(macos(10.0), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
 
 
 /*!
@@ -1554,7 +1554,7 @@
 		entities to locate endpoints.
 */
 extern MIDIDeviceRef
-MIDIGetDevice(	ItemCount deviceIndex0 )					API_AVAILABLE(macos(10.0), ios(4.2), tvos(12.0));
+MIDIGetDevice(	ItemCount deviceIndex0 )					API_AVAILABLE(macos(10.0), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
 
 /*!
 	@function		MIDIDeviceGetNumberOfEntities
@@ -1568,7 +1568,7 @@
 					error occurred.
 */
 extern ItemCount
-MIDIDeviceGetNumberOfEntities(	MIDIDeviceRef device )		API_AVAILABLE(macos(10.0), ios(4.2), tvos(12.0));
+MIDIDeviceGetNumberOfEntities(	MIDIDeviceRef device )		API_AVAILABLE(macos(10.0), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
 
 /*!
 	@function		MIDIDeviceGetEntity
@@ -1585,7 +1585,7 @@
 */
 extern MIDIEntityRef
 MIDIDeviceGetEntity(	MIDIDeviceRef	device,
-						ItemCount		entityIndex0 )		API_AVAILABLE(macos(10.0), ios(4.2), tvos(12.0));
+						ItemCount		entityIndex0 )		API_AVAILABLE(macos(10.0), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
 
 //==================================================================================================
 #pragma mark	Entities
@@ -1602,7 +1602,7 @@
 					error occurred.
 */
 extern ItemCount
-MIDIEntityGetNumberOfSources(	MIDIEntityRef entity )		API_AVAILABLE(macos(10.0), ios(4.2), tvos(12.0));
+MIDIEntityGetNumberOfSources(	MIDIEntityRef entity )		API_AVAILABLE(macos(10.0), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
 
 /*!
 	@function		MIDIEntityGetSource
@@ -1619,7 +1619,7 @@
 */
 extern MIDIEndpointRef
 MIDIEntityGetSource(	MIDIEntityRef entity,
-						ItemCount sourceIndex0 )			API_AVAILABLE(macos(10.0), ios(4.2), tvos(12.0));
+						ItemCount sourceIndex0 )			API_AVAILABLE(macos(10.0), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
 
 /*!
 	@function		MIDIEntityGetNumberOfDestinations
@@ -1633,7 +1633,7 @@
 					if an error occurred.
 */
 extern ItemCount
-MIDIEntityGetNumberOfDestinations(	MIDIEntityRef entity )	API_AVAILABLE(macos(10.0), ios(4.2), tvos(12.0));
+MIDIEntityGetNumberOfDestinations(	MIDIEntityRef entity )	API_AVAILABLE(macos(10.0), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
 
 /*!
 	@function		MIDIEntityGetDestination
@@ -1650,7 +1650,7 @@
 */
 extern MIDIEndpointRef
 MIDIEntityGetDestination(	MIDIEntityRef	entity,
-							ItemCount		destIndex0 )	API_AVAILABLE(macos(10.0), ios(4.2), tvos(12.0));
+							ItemCount		destIndex0 )	API_AVAILABLE(macos(10.0), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
 
 /*!
 	@function		MIDIEntityGetDevice
@@ -1664,7 +1664,7 @@
 */
 extern OSStatus
 MIDIEntityGetDevice(		MIDIEntityRef		inEntity,
-							MIDIDeviceRef * __nullable		outDevice)	API_AVAILABLE(macos(10.2), ios(4.2), tvos(12.0));
+							MIDIDeviceRef * __nullable		outDevice)	API_AVAILABLE(macos(10.2), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
 
 //==================================================================================================
 #pragma mark	Endpoints
@@ -1678,7 +1678,7 @@
 					occurred.
 */
 extern ItemCount
-MIDIGetNumberOfSources(void)								API_AVAILABLE(macos(10.0), ios(4.2), tvos(12.0));
+MIDIGetNumberOfSources(void)								API_AVAILABLE(macos(10.0), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
 
 
 /*!
@@ -1692,7 +1692,7 @@
 	@result			A reference to a source, or NULL if an error occurred.
 */
 extern MIDIEndpointRef
-MIDIGetSource(	ItemCount sourceIndex0 )					API_AVAILABLE(macos(10.0), ios(4.2), tvos(12.0));
+MIDIGetSource(	ItemCount sourceIndex0 )					API_AVAILABLE(macos(10.0), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
 
 
 /*!
@@ -1704,7 +1704,7 @@
 					occurred.
 */
 extern ItemCount
-MIDIGetNumberOfDestinations(void)							API_AVAILABLE(macos(10.0), ios(4.2), tvos(12.0));
+MIDIGetNumberOfDestinations(void)							API_AVAILABLE(macos(10.0), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
 
 
 /*!
@@ -1718,7 +1718,7 @@
 	@result			A reference to a destination, or NULL if an error occurred.
 */
 extern MIDIEndpointRef
-MIDIGetDestination(	ItemCount destIndex0 )					API_AVAILABLE(macos(10.0), ios(4.2), tvos(12.0));
+MIDIGetDestination(	ItemCount destIndex0 )					API_AVAILABLE(macos(10.0), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
 
 /*!
 	@function		MIDIEndpointGetEntity
@@ -1735,7 +1735,7 @@
 */
 extern OSStatus
 MIDIEndpointGetEntity(		MIDIEndpointRef		inEndpoint,
-							MIDIEntityRef * __nullable		outEntity)	API_AVAILABLE(macos(10.2), ios(4.2), tvos(12.0));
+							MIDIEntityRef * __nullable		outEntity)	API_AVAILABLE(macos(10.2), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
 
 /*!
 	@function		MIDIDestinationCreateWithProtocol
@@ -1777,7 +1777,7 @@
 									CFStringRef  		name,
 									MIDIProtocolID		protocol,
 									MIDIEndpointRef *	outDest,
-									MIDIReceiveBlock	readBlock ) API_AVAILABLE(macos(11.0), ios(14.0), tvos(14.0));
+									MIDIReceiveBlock	readBlock ) API_AVAILABLE(macos(11.0), ios(14.0)) API_UNAVAILABLE(tvos, watchos);
 
 /*!
 	@function		MIDIDestinationCreate
@@ -1820,7 +1820,7 @@
 						void * __nullable	refCon,
 						MIDIEndpointRef *	outDest )
 				API_DEPRECATED_WITH_REPLACEMENT("MIDIDestinationCreateWithProtocol",
-												macos(10.0, API_TO_BE_DEPRECATED), ios(4.2, API_TO_BE_DEPRECATED), tvos(12.0, API_TO_BE_DEPRECATED));
+												macos(10.0, API_TO_BE_DEPRECATED), ios(4.2, API_TO_BE_DEPRECATED)) __TVOS_PROHIBITED __WATCHOS_PROHIBITED;
 
 /*!
 	@function		MIDIDestinationCreateWithBlock
@@ -1860,7 +1860,7 @@
 								MIDIEndpointRef * 	outDest,
 								MIDIReadBlock 		readBlock )
 					API_DEPRECATED_WITH_REPLACEMENT("MIDIDestinationCreateWithProtocol",
-													macos(10.11, API_TO_BE_DEPRECATED), ios(9.0, API_TO_BE_DEPRECATED), tvos(12.0, API_TO_BE_DEPRECATED));
+													macos(10.11, API_TO_BE_DEPRECATED), ios(9.0, API_TO_BE_DEPRECATED)) __TVOS_PROHIBITED __WATCHOS_PROHIBITED;
 
 /*!
 	@function		MIDISourceCreateWithProtocol
@@ -1897,7 +1897,7 @@
 MIDISourceCreateWithProtocol(	MIDIClientRef 		client,
 								CFStringRef  		name,
 								MIDIProtocolID		protocol,
-								MIDIEndpointRef * 	outSrc ) API_AVAILABLE(macos(11.0), ios(14.0), tvos(14.0));
+								MIDIEndpointRef * 	outSrc ) API_AVAILABLE(macos(11.0), ios(14.0)) API_UNAVAILABLE(tvos, watchos);
 
 /*!
 	@function		MIDISourceCreate
@@ -1930,7 +1930,7 @@
 					CFStringRef  		name,
 					MIDIEndpointRef * 	outSrc )
 			API_DEPRECATED_WITH_REPLACEMENT("MIDISourceCreateWithProtocol",
-											macos(10.0, API_TO_BE_DEPRECATED), ios(4.2, API_TO_BE_DEPRECATED), tvos(12.0, API_TO_BE_DEPRECATED));
+											macos(10.0, API_TO_BE_DEPRECATED), ios(4.2, API_TO_BE_DEPRECATED)) __TVOS_PROHIBITED __WATCHOS_PROHIBITED;
 
 /*!
 	@function		MIDIEndpointDispose
@@ -1943,7 +1943,7 @@
 	@result			An OSStatus result code.
 */
 extern OSStatus
-MIDIEndpointDispose(	MIDIEndpointRef endpt )				API_AVAILABLE(macos(10.0), ios(4.2), tvos(12.0));
+MIDIEndpointDispose(	MIDIEndpointRef endpt )				API_AVAILABLE(macos(10.0), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
 
 
 //==================================================================================================
@@ -1963,7 +1963,7 @@
 		adds them.
 */
 extern ItemCount
-MIDIGetNumberOfExternalDevices(void)						API_AVAILABLE(macos(10.1), ios(4.2), tvos(12.0));
+MIDIGetNumberOfExternalDevices(void)						API_AVAILABLE(macos(10.1), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
 
 /*!
 	@function		MIDIGetExternalDevice
@@ -1979,7 +1979,7 @@
 		Use this to enumerate the external devices in the system.
 */
 extern MIDIDeviceRef
-MIDIGetExternalDevice(	ItemCount deviceIndex0 )			API_AVAILABLE(macos(10.1), ios(4.2), tvos(12.0));
+MIDIGetExternalDevice(	ItemCount deviceIndex0 )			API_AVAILABLE(macos(10.1), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
 
 //==================================================================================================
 #pragma mark	Objects and Properties
@@ -2003,7 +2003,7 @@
 extern OSStatus
 MIDIObjectGetIntegerProperty(	MIDIObjectRef	obj,
 								CFStringRef		propertyID,
-								SInt32 *		outValue )	API_AVAILABLE(macos(10.0), ios(4.2), tvos(12.0));
+								SInt32 *		outValue )	API_AVAILABLE(macos(10.0), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
 
 /*!
 	@function		MIDIObjectSetIntegerProperty
@@ -2024,7 +2024,7 @@
 extern OSStatus
 MIDIObjectSetIntegerProperty(	MIDIObjectRef	obj,
 								CFStringRef		propertyID,
-								SInt32			value )		API_AVAILABLE(macos(10.0), ios(4.2), tvos(12.0));
+								SInt32			value )		API_AVAILABLE(macos(10.0), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
 
 /*!
 	@function		MIDIObjectGetStringProperty
@@ -2045,7 +2045,7 @@
 extern OSStatus
 MIDIObjectGetStringProperty(	MIDIObjectRef			obj,
 								CFStringRef				propertyID,
-								CFStringRef __nullable * __nonnull str )		API_AVAILABLE(macos(10.0), ios(4.2), tvos(12.0));
+								CFStringRef __nullable * __nonnull str )		API_AVAILABLE(macos(10.0), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
 
 /*!
 	@function		MIDIObjectSetStringProperty
@@ -2066,7 +2066,7 @@
 extern OSStatus
 MIDIObjectSetStringProperty(	MIDIObjectRef	obj,
 								CFStringRef		propertyID,
-								CFStringRef		str )		API_AVAILABLE(macos(10.0), ios(4.2), tvos(12.0));
+								CFStringRef		str )		API_AVAILABLE(macos(10.0), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
 
 /*!
 	@function		MIDIObjectGetDataProperty
@@ -2088,7 +2088,7 @@
 extern OSStatus
 MIDIObjectGetDataProperty(		MIDIObjectRef			obj,
 								CFStringRef				propertyID,
-								CFDataRef __nullable * __nonnull outData )	API_AVAILABLE(macos(10.0), ios(4.2), tvos(12.0));
+								CFDataRef __nullable * __nonnull outData )	API_AVAILABLE(macos(10.0), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
 
 /*!
 	@function		MIDIObjectSetDataProperty
@@ -2109,7 +2109,7 @@
 extern OSStatus
 MIDIObjectSetDataProperty(		MIDIObjectRef	obj,
 								CFStringRef		propertyID,
-								CFDataRef		data )		API_AVAILABLE(macos(10.0), ios(4.2), tvos(12.0));
+								CFDataRef		data )		API_AVAILABLE(macos(10.0), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
 
 /*!
 	@function		MIDIObjectGetDictionaryProperty
@@ -2131,7 +2131,7 @@
 MIDIObjectGetDictionaryProperty(	MIDIObjectRef					obj,
 									CFStringRef						propertyID,
 									CFDictionaryRef __nullable * __nonnull outDict )
-															API_AVAILABLE(macos(10.2), ios(4.2), tvos(12.0));
+															API_AVAILABLE(macos(10.2), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
 
 /*!
 	@function		MIDIObjectSetDictionaryProperty
@@ -2152,7 +2152,7 @@
 extern OSStatus
 MIDIObjectSetDictionaryProperty(MIDIObjectRef	obj,
 								CFStringRef		propertyID,
-								CFDictionaryRef dict )		API_AVAILABLE(macos(10.2), ios(4.2), tvos(12.0));
+								CFDictionaryRef dict )		API_AVAILABLE(macos(10.2), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
 
 /*!
 	@function		MIDIObjectGetProperties
@@ -2178,7 +2178,7 @@
 extern OSStatus
 MIDIObjectGetProperties(		MIDIObjectRef 		obj,
 								CFPropertyListRef __nullable * __nonnull outProperties,
-								Boolean				deep )	API_AVAILABLE(macos(10.1), ios(4.2), tvos(12.0));
+								Boolean				deep )	API_AVAILABLE(macos(10.1), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
 
 /*!
 	@function		MIDIObjectRemoveProperty
@@ -2194,7 +2194,7 @@
 extern OSStatus
 MIDIObjectRemoveProperty(		MIDIObjectRef 		obj,
 								CFStringRef			propertyID )
-															API_AVAILABLE(macos(10.2), ios(4.2), tvos(12.0));
+															API_AVAILABLE(macos(10.2), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
 
 /*!
 	@function		MIDIObjectFindByUniqueID
@@ -2220,7 +2220,7 @@
 MIDIObjectFindByUniqueID(	MIDIUniqueID 		inUniqueID,
 							MIDIObjectRef * __nullable outObject,
 							MIDIObjectType * __nullable outObjectType)
-															API_AVAILABLE(macos(10.2), ios(4.2), tvos(12.0));
+															API_AVAILABLE(macos(10.2), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
 
 //==================================================================================================
 #pragma mark	MIDI I/O
@@ -2245,7 +2245,7 @@
 extern OSStatus
 MIDISendEventList(	MIDIPortRef 				port,
 					MIDIEndpointRef 			dest,
-					const MIDIEventList *		evtlist )	API_AVAILABLE(macos(11.0), ios(14.0), tvos(14.0));
+					const MIDIEventList *		evtlist )	API_AVAILABLE(macos(11.0), ios(14.0)) API_UNAVAILABLE(tvos, watchos);
 
 /*!
 	@function		MIDISend
@@ -2269,7 +2269,7 @@
 			MIDIEndpointRef 		dest,
 			const MIDIPacketList *	pktlist )
 	API_DEPRECATED_WITH_REPLACEMENT("MIDISendEventList",
-									macos(10.0, API_TO_BE_DEPRECATED), ios(4.2, API_TO_BE_DEPRECATED), tvos(12.0, API_TO_BE_DEPRECATED));
+									macos(10.0, API_TO_BE_DEPRECATED), ios(4.2, API_TO_BE_DEPRECATED)) __TVOS_PROHIBITED __WATCHOS_PROHIBITED;
     
 /*!
 	@function		MIDISendSysex
@@ -2284,7 +2284,7 @@
 		request->data must point to a single MIDI system-exclusive message, or portion thereof.
 */
 extern OSStatus
-MIDISendSysex(	MIDISysexSendRequest *request )				API_AVAILABLE(macos(10.0), ios(4.2), tvos(12.0));
+MIDISendSysex(	MIDISysexSendRequest *request )				API_AVAILABLE(macos(10.0), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
 
 /*!
 	@function		MIDIReceivedEventList
@@ -2309,7 +2309,7 @@
 */
 extern OSStatus
 MIDIReceivedEventList(	MIDIEndpointRef			src,
-						const MIDIEventList *	evtlist )	API_AVAILABLE(macos(11.0), ios(14.0), tvos(14.0));
+						const MIDIEventList *	evtlist )	API_AVAILABLE(macos(11.0), ios(14.0)) API_UNAVAILABLE(tvos, watchos);
 
 /*!
 	@function		MIDIReceived
@@ -2336,7 +2336,7 @@
 MIDIReceived(	MIDIEndpointRef			src,
 				const MIDIPacketList * 	pktlist )
 		API_DEPRECATED_WITH_REPLACEMENT("MIDIReceivedEventList",
-										macos(10.0, API_TO_BE_DEPRECATED), ios(4.2, API_TO_BE_DEPRECATED), tvos(12.0, API_TO_BE_DEPRECATED));
+										macos(10.0, API_TO_BE_DEPRECATED), ios(4.2, API_TO_BE_DEPRECATED)) __TVOS_PROHIBITED __WATCHOS_PROHIBITED;
 
 /*!
 	@function		MIDIFlushOutput
@@ -2353,7 +2353,7 @@
 		scheduled for future delivery.
 */
 extern OSStatus
-MIDIFlushOutput(	MIDIEndpointRef		dest )				API_AVAILABLE(macos(10.1), ios(4.2), tvos(12.0));
+MIDIFlushOutput(	MIDIEndpointRef		dest )				API_AVAILABLE(macos(10.1), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
 
 /*!
 	@function		MIDIRestart
@@ -2366,7 +2366,7 @@
 	@result			An OSStatus result code.
 */
 extern OSStatus
-MIDIRestart(void)											API_AVAILABLE(macos(10.1), ios(4.2), tvos(12.0));
+MIDIRestart(void)											API_AVAILABLE(macos(10.1), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
 
 
 
@@ -2404,7 +2404,7 @@
 */
 extern MIDIEventPacket *
 MIDIEventListInit(	MIDIEventList *evtlist,
-					MIDIProtocolID protocol)			API_AVAILABLE(macos(11.0), ios(14.0), tvos(14.0));
+					MIDIProtocolID protocol)			API_AVAILABLE(macos(11.0), ios(14.0), tvos(15.0), watchos(8.0));
 
 /*!
 	@function		MIDIEventListAdd
@@ -2442,7 +2442,7 @@
 					MIDIEventPacket *	curPacket,
 					MIDITimeStamp		time,
 					ByteCount			wordCount,
-					const UInt32 *		words)			API_AVAILABLE(macos(11.0), ios(14.0), tvos(14.0));
+					const UInt32 *		words)			API_AVAILABLE(macos(11.0), ios(14.0), tvos(15.0), watchos(8.0));
 
 //==================================================================================================
 #pragma mark Packet Lists (Deprecated in favor of Event Lists)
@@ -2490,7 +2490,7 @@
 extern MIDIPacket *
 MIDIPacketListInit(	MIDIPacketList *pktlist )
 			API_DEPRECATED_WITH_REPLACEMENT("MIDIEventListInit",
-											macos(10.0, API_TO_BE_DEPRECATED), ios(4.2, API_TO_BE_DEPRECATED), tvos(12.0, API_TO_BE_DEPRECATED));
+											macos(10.0, API_TO_BE_DEPRECATED), ios(4.2, API_TO_BE_DEPRECATED)) __TVOS_PROHIBITED __WATCHOS_PROHIBITED;
 
 /*!
 	@function		MIDIPacketListAdd
@@ -2528,7 +2528,7 @@
 					ByteCount			nData,
 					const Byte *		data)
 			API_DEPRECATED_WITH_REPLACEMENT("MIDIEventListAdd",
-											macos(10.0, API_TO_BE_DEPRECATED), ios(4.2, API_TO_BE_DEPRECATED), tvos(12.0, API_TO_BE_DEPRECATED));
+											macos(10.0, API_TO_BE_DEPRECATED), ios(4.2, API_TO_BE_DEPRECATED)) __TVOS_PROHIBITED __WATCHOS_PROHIBITED;
 
 
 #ifdef __cplusplus
diff -ruN /Applications/Xcode_13.0.0-beta2.app/Contents/Developer/Platforms/WatchOS.platform/Developer/SDKs/WatchOS.sdk/System/Library/Frameworks/CoreMIDI.framework/Headers/MIDISetup.h /Applications/Xcode_13.0.0-beta3.app/Contents/Developer/Platforms/WatchOS.platform/Developer/SDKs/WatchOS.sdk/System/Library/Frameworks/CoreMIDI.framework/Headers/MIDISetup.h
--- /Applications/Xcode_13.0.0-beta2.app/Contents/Developer/Platforms/WatchOS.platform/Developer/SDKs/WatchOS.sdk/System/Library/Frameworks/CoreMIDI.framework/Headers/MIDISetup.h	1969-12-31 19:00:00.000000000 -0500
+++ /Applications/Xcode_13.0.0-beta3.app/Contents/Developer/Platforms/WatchOS.platform/Developer/SDKs/WatchOS.sdk/System/Library/Frameworks/CoreMIDI.framework/Headers/MIDISetup.h	2021-07-13 00:38:06.000000000 -0400
@@ -0,0 +1,478 @@
+/*
+ 	File:   	CoreMIDI/MIDISetup.h
+ 
+ 	Contains:   Specialized configuration-editing routines for CoreMIDI.
+ 
+ 	Copyright:  (c) 2000-2015 by Apple Inc., all rights reserved.
+ 
+ 	Bugs?:  	For bug reports, consult the following page on
+ 				the World Wide Web:
+ 
+ 					http://feedbackassistant.apple.com/
+ 
+*/
+
+#ifndef __MIDISetup_h__
+#define __MIDISetup_h__
+
+#ifndef __MIDIServices_h__
+#include <CoreMIDI/MIDIServices.h>
+#endif
+
+
+//  -----------------------------------------------------------------------------
+/*!
+	@header MIDISetup.h
+
+	This header defines functions that manipulate and customize the global
+	state of the MIDI system.  These functions are generally only needed by 
+	applications which wish to allow the user some flexibility in how
+	the MIDI system's state is presented, and by MIDI drivers, which may
+	dynamically modify the system state as hardware is connected and 
+	disconnected.
+*/
+
+CF_ASSUME_NONNULL_BEGIN
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+//  -----------------------------------------------------------------------------
+/*!
+	@typedef		MIDISetupRef
+	
+	@discussion		Derives from MIDIObjectRef, does not have an owner object.
+
+					This represents the global state of the MIDI system,
+					containing lists of the MIDI devices and serial port
+					owners.
+					
+					Generally, only MIDI drivers and specialized configuration
+					editors will need to manipulate MIDISetup objects, not the
+					average MIDI client application.  As of CoreMIDI 1.1, the
+					MIDIServer maintains a single global MIDISetupRef, stored
+					persistently in a preference file.
+*/
+typedef MIDIObjectRef MIDISetupRef;
+
+// ______________________________________________________________________________
+//	MIDISetup
+// ______________________________________________________________________________
+
+//  -----------------------------------------------------------------------------
+/*!
+	@function		MIDISetupCreate
+
+	@abstract 		Interrogates drivers, to discover what hardware is present.
+	
+					As of CoreMIDI 1.1, it is usually not necessary to call
+					this function, as CoreMIDI manages a single persistent
+					MIDISetup itself.
+
+	@param			outSetup
+						On successful return, points to a newly-created MIDISetup
+						object.  The caller is responsible for disposing it,
+						or transferring ownership of the object back to the
+						system, with MIDISetupInstall.
+	@result			An OSStatus result code.
+*/
+extern OSStatus
+MIDISetupCreate(	MIDISetupRef *outSetup )					API_DEPRECATED("No longer supported", macos(10.0, 10.6)) API_UNAVAILABLE(ios, tvos, watchos);
+
+
+//  -----------------------------------------------------------------------------
+/*!
+	@function		MIDISetupDispose
+
+	@abstract 		Dispose a MIDISetup object.
+
+					As of CoreMIDI 1.1, it is usually not necessary to call
+					this function, as CoreMIDI manages a single persistent
+					MIDISetup itself.
+	
+	@param			setup
+						The MIDISetup to be disposed.
+	@result			An OSStatus result code.
+*/
+extern OSStatus
+MIDISetupDispose(	MIDISetupRef setup )						API_DEPRECATED("No longer supported", macos(10.0, 10.6)) API_UNAVAILABLE(ios, tvos, watchos);
+
+//  -----------------------------------------------------------------------------
+/*!
+	@function		MIDISetupInstall
+
+	@abstract 		Install a MIDISetup as the system's current state.
+
+					A client can create a MIDISetup object using
+					MIDISetupCreate, or MIDISetupFromData.  This function will
+					install this state as the current state of the system,
+					possibly changing the devices visible to clients.
+
+					As of CoreMIDI 1.1, it is usually not necessary to call
+					this function, as CoreMIDI manages a single persistent
+					MIDISetup itself.
+
+	@param			setup
+						The MIDISetup object to install.  Ownership of this
+						object is transferred from the client to the system; the
+						client must <b>not</b> dispose of this MIDISetup.
+	@result			An OSStatus result code.
+*/
+extern OSStatus
+MIDISetupInstall(	MIDISetupRef setup )						API_DEPRECATED("No longer supported", macos(10.0, 10.6)) API_UNAVAILABLE(ios, tvos, watchos);
+
+
+//  -----------------------------------------------------------------------------
+/*!
+	@function		MIDISetupGetCurrent
+
+	@abstract 		Return the system's current MIDISetup.
+	
+					As of CoreMIDI 1.1, it is usually not necessary to call
+					this function, as CoreMIDI manages a single persistent
+					MIDISetup itself.
+	
+	@param			outSetup
+						On successful return, points to the system's most
+						recently installed MIDISetup.  The system retains
+						ownership of the object; the client must <b>not</b>
+						dispose of this MIDISetup.
+	@result			An OSStatus result code.
+*/
+extern OSStatus
+MIDISetupGetCurrent(	MIDISetupRef *outSetup )				API_DEPRECATED("No longer supported", macos(10.0, 10.6)) API_UNAVAILABLE(ios, tvos, watchos);
+
+
+//  -----------------------------------------------------------------------------
+/*!
+	@function		MIDISetupToData
+
+	@abstract 		Create an XML representation of a MIDISetup object.
+	
+					As of CoreMIDI 1.1, it is usually not necessary to call
+					this function, as CoreMIDI manages a single persistent
+					MIDISetup itself.
+	
+	@param			setup
+						The MIDISetup object whose XML representation is to be
+						returned.
+	@param			outData
+						On successful return, points to a newly-created CFDataRef
+						containing the XML text.  The client is responsible for
+						releasing this CFData object when done with it.
+	@result			An OSStatus result code.
+*/
+extern OSStatus
+MIDISetupToData(	MIDISetupRef	setup,
+					CFDataRef __nullable * __nonnull outData )	API_DEPRECATED("No longer supported", macos(10.0, 10.6)) API_UNAVAILABLE(ios, tvos, watchos);
+
+//  -----------------------------------------------------------------------------
+/*!
+	@function		MIDISetupFromData
+
+	@abstract 		Create a MIDISetup object from an XML stream.
+	
+					As of CoreMIDI 1.1, it is usually not necessary to call
+					this function, as CoreMIDI manages a single persistent
+					MIDISetup itself.
+	
+	@param			data
+						The XML text from which a MIDISetup object is to be built.
+	@param			outSetup
+						On successful return, points to a newly-created MIDISetup
+						object.  The caller is responsible for disposing it, or
+						transferring ownership of the object back to the system,
+						with MIDISetupInstall.
+	@result			An OSStatus result code.
+*/
+extern OSStatus
+MIDISetupFromData(	CFDataRef 		data, 
+					MIDISetupRef *	outSetup)					API_DEPRECATED("No longer supported", macos(10.0, 10.6)) API_UNAVAILABLE(ios, tvos, watchos);
+
+//  -----------------------------------------------------------------------------
+/*!
+	@function		MIDIDeviceNewEntity
+
+	@discussion		Drivers call this function to specify one of the entities that
+					comprise a device.
+					
+					Non-drivers may call this function as of macOS 10.16 & iOS 14 to
+					add entities to external devices.
+	
+	@param			device
+						The device to which an entity is to be added.
+	@param			name
+						The name of the new entity.
+	@param			protocol
+						The MIDI protocol variant used by the sources and
+						destinations that comprise this entity.
+	@param			embedded
+						True if this entity is inside the device, false if the
+						entity simply consists of external connectors to which
+						other devices can be attached.
+	@param			numSourceEndpoints
+						The number of source endpoints the entity has.
+	@param			numDestinationEndpoints
+						The number of destination endpoints the entity has.
+	@param			newEntity
+						On successful return, points to the newly-created entity.
+	@result			An OSStatus result code.
+*/
+extern OSStatus
+MIDIDeviceNewEntity(MIDIDeviceRef device, CFStringRef name, MIDIProtocolID protocol,
+					Boolean embedded, ItemCount numSourceEndpoints,
+					ItemCount numDestinationEndpoints, MIDIEntityRef *newEntity)
+															API_AVAILABLE(macos(11.0), ios(14.0)) __TVOS_PROHIBITED __WATCHOS_PROHIBITED;
+
+//  -----------------------------------------------------------------------------
+/*!
+	@function		MIDIDeviceAddEntity
+
+	@discussion		Drivers call this function to specify one of the entities that 
+					comprise a device.
+					
+					Non-drivers may call this function as of CoreMIDI 1.1 to
+					add entities to external devices.
+	
+	@param			device
+						The device to which an entity is to be added.
+	@param			name
+						The name of the new entity.
+	@param			embedded
+						True if this entity is inside the device, false if the
+						entity simply consists of external connectors to which
+						other devices can be attached.
+	@param			numSourceEndpoints
+						The number of source endpoints the entity has.
+	@param			numDestinationEndpoints
+						The number of destination endpoints the entity has.
+	@param			newEntity
+						On successful return, points to the newly-created entity.
+	@result			An OSStatus result code.
+*/
+extern OSStatus		
+MIDIDeviceAddEntity(MIDIDeviceRef device, CFStringRef name, 
+					Boolean embedded, ItemCount numSourceEndpoints,
+					ItemCount numDestinationEndpoints, MIDIEntityRef *newEntity)
+				API_DEPRECATED_WITH_REPLACEMENT("MIDIDeviceNewEntity", macos(10.0, API_TO_BE_DEPRECATED), ios(4.2, API_TO_BE_DEPRECATED)) API_UNAVAILABLE(tvos, watchos);
+
+//  -----------------------------------------------------------------------------
+/*!
+	@function		MIDIDeviceRemoveEntity
+
+	@discussion		Drivers may call this function to remove one of a device's
+					entities.
+					
+					New for CoreMIDI 1.1.
+	
+	@param			device
+						The device from which an entity is to be removed.
+	@param			entity
+						The entity to be removed.
+	@result			An OSStatus result code.
+*/
+extern OSStatus
+MIDIDeviceRemoveEntity(MIDIDeviceRef device, MIDIEntityRef entity)
+																API_AVAILABLE(macos(10.1), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
+
+//  -----------------------------------------------------------------------------
+/*!
+	@function		MIDIEntityAddOrRemoveEndpoints
+
+	@discussion		Drivers and configuration editors may call this function to add to 
+					or remove an entity's endpoints.
+					
+					New for CoreMIDI 1.3.
+
+					The MIDIProtocolID of new endpoints is initially the same as that of
+					the entity.
+	
+	@param			entity
+						The entity whose endpoints are to be manipulated.
+	@param			numSourceEndpoints
+						The desired new number of source endpoints.
+	@param			numDestinationEndpoints
+						The desired new number of destination endpoints.
+	@result			An OSStatus result code.
+*/
+extern OSStatus
+MIDIEntityAddOrRemoveEndpoints(MIDIEntityRef entity, ItemCount numSourceEndpoints,
+					ItemCount numDestinationEndpoints)			API_AVAILABLE(macos(10.2), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
+
+//  -----------------------------------------------------------------------------
+/*!
+	@function		MIDISetupAddDevice
+
+	@abstract 		Adds a driver-owner MIDI device to the current MIDISetup
+	
+	@discussion		Only MIDI drivers may make this call; it is in this header
+					file only for consistency with MIDISetupRemoveDevice.
+	
+					New for CoreMIDI 1.1.
+	
+	@param			device
+						The device to be added.
+*/
+extern OSStatus
+MIDISetupAddDevice(		MIDIDeviceRef device )					API_AVAILABLE(macos(10.1), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
+
+//  -----------------------------------------------------------------------------
+/*!
+	@function		MIDISetupRemoveDevice
+
+	@abstract 		Removes a driver-owned MIDI device from the current MIDISetup
+	
+	@discussion		Generally this should only be called from a studio configuration
+					editor, to remove a device which is offline and which the user
+					has specified as being permanently missing.
+					
+					Instead of removing devices from the setup, drivers should
+					set the device's kMIDIPropertyOffline to 1 so that if the
+					device reappears later, none of its properties are lost.
+	
+					New for CoreMIDI 1.1.
+	
+	@param			device
+						The device to be added.
+*/
+extern OSStatus
+MIDISetupRemoveDevice(	MIDIDeviceRef device )				API_AVAILABLE(macos(10.1), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
+
+//  -----------------------------------------------------------------------------
+/*!
+	@function		MIDISetupAddExternalDevice
+
+	@abstract 		Adds an external MIDI device to the current MIDISetup
+	
+	@discussion		Useful for a studio configuration editor.  New for CoreMIDI 1.1.
+	
+	@param			device
+						The device to be added.
+*/
+extern OSStatus
+MIDISetupAddExternalDevice(	MIDIDeviceRef device )			API_AVAILABLE(macos(10.1), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
+
+//  -----------------------------------------------------------------------------
+/*!
+	@function		MIDISetupRemoveExternalDevice
+
+	@abstract 		Removes an external MIDI device from the current MIDISetup
+	
+	@discussion		Useful for a studio configuration editor.  New for CoreMIDI 1.1.
+	
+	@param			device
+						The device to be removed.
+*/
+extern OSStatus
+MIDISetupRemoveExternalDevice( MIDIDeviceRef device )		API_AVAILABLE(macos(10.1), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
+
+//  -----------------------------------------------------------------------------
+/*!
+	@function		MIDIGetSerialPortOwner
+
+	@abstract 		Returns the MIDI driver that owns a serial port.
+	
+	@discussion		The current MIDISetup tracks ownership of serial ports
+					to one of the MIDI drivers installed in the system.
+	
+					Serial ports can be enumerated using IOServiceMatching(
+					kIOSerialBSDServiceValue).  The port's unique name is
+					the IOService's kIOTTYDeviceKey property. 
+
+					New for CoreMIDI 1.1.
+					
+					A previous version of this documentation specified an incorrect
+					key for obtaining the port's unique name (IOTTYBaseName).
+	
+	@param			portName
+						The name of a serial port.
+	@param			outDriverName
+						On exit, the name of the driver owning the port,
+						or NULL if no driver owns it.
+
+	@result			An OSStatus result code.	
+*/
+extern OSStatus
+MIDIGetSerialPortOwner(	CFStringRef			portName, 
+						CFStringRef __nullable * __nonnull outDriverName )	API_DEPRECATED("No longer supported", macos(10.1, 10.6)) API_UNAVAILABLE(ios, tvos, watchos);
+
+//  -----------------------------------------------------------------------------
+/*!
+	@function		MIDISetSerialPortOwner
+
+	@abstract 		Specifies the MIDI driver that owns a serial port.
+	
+	@discussion		Use this to assign ownership of a serial port
+					to one of the MIDI drivers installed in the system.
+	
+					New for CoreMIDI 1.1.
+	
+	@param			portName
+						The name of a serial port.
+	@param			driverName
+						The name of the driver that owns the serial port,
+						or NULL to specify that no driver owns it.
+
+	@result			An OSStatus result code.	
+*/
+extern OSStatus
+MIDISetSerialPortOwner(	CFStringRef			portName, 
+						CFStringRef			driverName )	API_DEPRECATED("No longer supported", macos(10.1, 10.6)) API_UNAVAILABLE(ios, tvos, watchos);
+
+//  -----------------------------------------------------------------------------
+/*!
+	@function		MIDIGetSerialPortDrivers
+
+	@abstract 		Returns a list of installed MIDI drivers for serial port
+					MIDI devices.
+	
+	@discussion		Use this to determine which of the installed MIDI drivers
+					are for devices which may attach to serial ports.
+	
+					New for CoreMIDI 1.1.
+	
+	@param			outDriverNames
+						On exit, a CFArrayRef containing a list of CFStringRef's
+						which are the names of the serial port MIDI drivers.
+						The array should be released by the caller.
+
+	@result			An OSStatus result code.	
+*/
+extern OSStatus
+MIDIGetSerialPortDrivers(	CFArrayRef __nullable * __nonnull outDriverNames )	API_DEPRECATED("No longer supported", macos(10.1, 10.6)) API_UNAVAILABLE(ios, tvos, watchos);
+
+//  -----------------------------------------------------------------------------
+/*!
+	@function		MIDIExternalDeviceCreate
+
+	@abstract		Create a new external MIDI device.
+
+	@discussion		Non-drivers may call this function as of CoreMIDI 1.1, to
+					create external devices.
+
+					The new device is not added to the current MIDISetupRef;
+					to do this, use MIDISetupAddExternalDevice.
+	
+	@param			name
+						The name of the new device.
+	@param			manufacturer
+						The name of the device's manufacturer.
+	@param			model
+						The device's model name.
+	@param			outDevice
+						On successful return, points to the newly-created device.
+	@result			An OSStatus result code.
+*/
+extern OSStatus		
+MIDIExternalDeviceCreate(CFStringRef name, CFStringRef manufacturer, 
+							CFStringRef model, MIDIDeviceRef *outDevice)
+															API_AVAILABLE(macos(10.1), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
+
+#ifdef __cplusplus
+}
+#endif
+
+CF_ASSUME_NONNULL_END
+
+#endif /* __MIDISetup_h__ */
diff -ruN /Applications/Xcode_13.0.0-beta2.app/Contents/Developer/Platforms/WatchOS.platform/Developer/SDKs/WatchOS.sdk/System/Library/Frameworks/CoreMIDI.framework/Headers/MIDIThruConnection.h /Applications/Xcode_13.0.0-beta3.app/Contents/Developer/Platforms/WatchOS.platform/Developer/SDKs/WatchOS.sdk/System/Library/Frameworks/CoreMIDI.framework/Headers/MIDIThruConnection.h
--- /Applications/Xcode_13.0.0-beta2.app/Contents/Developer/Platforms/WatchOS.platform/Developer/SDKs/WatchOS.sdk/System/Library/Frameworks/CoreMIDI.framework/Headers/MIDIThruConnection.h	1969-12-31 19:00:00.000000000 -0500
+++ /Applications/Xcode_13.0.0-beta3.app/Contents/Developer/Platforms/WatchOS.platform/Developer/SDKs/WatchOS.sdk/System/Library/Frameworks/CoreMIDI.framework/Headers/MIDIThruConnection.h	2021-07-13 00:38:06.000000000 -0400
@@ -0,0 +1,378 @@
+/*
+    File:       CoreMIDI/MIDIThruConnection.h
+ 
+    Contains:   Routines for creating MIDI play-through connections.
+ 
+    Copyright:  (c) 2000-2015 by Apple Inc., all rights reserved.
+ 
+    Bugs?:      For bug reports, consult the following page on
+                the World Wide Web:
+ 
+                    http://feedbackassistant.apple.com/
+ 
+*/
+
+#ifndef __MIDIThruConnection_h__
+#define __MIDIThruConnection_h__
+
+#include <CoreFoundation/CoreFoundation.h>
+#include <CoreMIDI/MIDIServices.h>
+
+CF_ASSUME_NONNULL_BEGIN
+
+//  -----------------------------------------------------------------------------
+/*!
+    @header MIDIThruConnection.h
+
+    This header defines functions to create MIDI play-through connections
+    between the MIDI sources and destinations.  These connections may be
+    persistent or transitory, owned by a client.
+    
+    By using connections instead of doing MIDI Thru operations themselves,
+    the overhead of moving MIDI messages between the server and the client
+    for thru-ing is reduced.
+    
+    The aim of these functions is to permit as flexible a set of transformations 
+    as possible while keeping the API and data structures relatively simple.    
+*/
+//  -----------------------------------------------------------------------------
+
+/// An opaque reference to a play-through connection.
+typedef MIDIObjectRef MIDIThruConnectionRef;
+
+/*!
+    @struct         MIDIValueMap
+    
+    @abstract       A custom mapping function to transform MIDI 7-bit values,
+                    as contained in note numbers, velocities, control values,
+                    etc.  y = value[x], where x is the input MIDI value, y the
+                    output.
+*/
+struct MIDIValueMap {
+    UInt8           value[128];
+};
+typedef struct MIDIValueMap MIDIValueMap;
+
+/*!
+    @enum           MIDITransformType
+    
+    @abstract       Values specifying a type of MIDI transformation, as found in the transform member of MIDITransform.
+    
+    @constant   kMIDITransform_None
+        no transformation (param unused)
+    @constant   kMIDITransform_FilterOut
+        filter out the specified event type (param unused)
+    @constant   kMIDITransform_MapControl
+        transform one control number to another; param is destination control number
+    @constant   kMIDITransform_Add
+        add param to values
+    @constant   kMIDITransform_Scale
+        multiple value by the fixed point number in param, which is in fixed point: bbbb.bbbb bbbb bbbb
+    @constant   kMIDITransform_MinValue
+        the value's minimum value is param
+    @constant   kMIDITransform_MaxValue
+        the value's maximum value is param
+    @constant   kMIDITransform_MapValue
+        transform the value using a map; param is the index of the map in the connection's array of maps.
+*/
+typedef CF_ENUM(UInt16, MIDITransformType) {
+    kMIDITransform_None = 0,
+    kMIDITransform_FilterOut = 1,
+    kMIDITransform_MapControl = 2,
+    kMIDITransform_Add = 8,
+    kMIDITransform_Scale = 9,
+    kMIDITransform_MinValue = 10,
+    kMIDITransform_MaxValue = 11,
+    kMIDITransform_MapValue = 12
+};
+
+enum {
+    kMIDIThruConnection_MaxEndpoints = 8
+};
+
+/*!
+    @enum       MIDITransformControlType
+    
+    @abstract   Specifies how control numbers are interpreted.
+
+    @constant   kMIDIControlType_7Bit
+        control numbers may be 0-127
+    @constant   kMIDIControlType_14Bit
+        control numbers may be 0-31
+    @constant   kMIDIControlType_7BitRPN
+        control numbers may be 0-16383
+    @constant   kMIDIControlType_14BitRPN
+    @constant   kMIDIControlType_7BitNRPN
+    @constant   kMIDIControlType_14BitNRPN
+*/
+typedef CF_ENUM(UInt8, MIDITransformControlType) {
+    kMIDIControlType_7Bit = 0,
+    kMIDIControlType_14Bit = 1,
+    kMIDIControlType_7BitRPN = 2,
+    kMIDIControlType_14BitRPN = 3,
+    kMIDIControlType_7BitNRPN = 4,
+    kMIDIControlType_14BitNRPN = 5
+};
+
+/*!
+    @struct     MIDITransform
+    @abstract   Describes how a single type of MIDI event is transformed.
+
+	This structure controls the transformation of various MIDI events other than control changes.
+
+    @field      transform   The type of transformation to be applied to the event values.
+    @field      param       An argument to the transformation method (see description of MIDITransformType).
+*/
+struct MIDITransform {
+    MIDITransformType   transform;
+    SInt16              param;
+};
+typedef struct MIDITransform MIDITransform;
+
+/*!
+    @struct     MIDIControlTransform
+    @abstract   Describes a transformation of MIDI control change events.
+
+	A single MIDIThruConnectionParams may describe any number of transformations to control
+	events. It is important that multiple transformations are ordered correctly: filter out,
+	remap, then alter values.
+	
+	All transformations are done internally using 14-bit values, so for example, when doing
+	an add/min/max transform on a 7-bit control value, the parameter must be a 14-bit value.
+	For example, to add 10 to a control value, param must be (10 << 7) = 1280.
+
+	As per the MIDI specification, a number of controls are interpreted specially:
+
+	Control | Function
+	--------|---------
+	32-63   | the LSBs of 0-31
+	6/38    | data entry
+	96, 97  | data increment, decrement
+	98-101  | NRPN/RPN
+
+    @field  controlType         The type of control specified by controlNumber
+    @field  remappedControlType If transform is kMIDITransform_MapControl, the output control type
+    @field  controlNumber       The control number to be affected.
+    @field  transform           The type of transformation to be applied to the event values.
+    @field  param               An argument to the transformation method (see description of MIDITransformType).
+*/
+struct MIDIControlTransform {
+    MIDITransformControlType    controlType;
+    MIDITransformControlType    remappedControlType;
+    UInt16                      controlNumber;
+    MIDITransformType           transform;
+    SInt16                      param;
+};
+typedef struct MIDIControlTransform MIDIControlTransform;
+
+/*!
+    @struct     MIDIThruConnectionEndpoint
+    @abstract   Describes a source or destination in a MIDIThruConnection.
+
+	When creating one of these, you can leave uniqueID 0 if the endpoint exists and you are passing
+	its MIDIEndpointRef.
+	
+	When obtaining one of these from CoreMIDI, endpointRef may be NULL if it doesn't exist, but the
+	uniqueID will always be non-zero.
+
+    @field  endpointRef     The endpoint specified as a MIDIEndpointRef.
+    @field  uniqueID        The endpoint specified by its uniqueID.
+*/
+struct MIDIThruConnectionEndpoint {
+    MIDIEndpointRef         endpointRef;
+    MIDIUniqueID            uniqueID;
+};
+typedef struct MIDIThruConnectionEndpoint MIDIThruConnectionEndpoint;
+
+/*!
+    @struct     MIDIThruConnectionParams
+    @abstract   Describes a set of MIDI routings and transformations.
+
+	The remainder of the structure is variably-sized. It contains numControlTransform instances of
+	MIDIControlTransform, followed by numMaps instances of MIDIValueMap.
+
+    @field      version     Version of this structure; must be 0.
+    @field      numSources  The number of valid sources in the following array.
+    @field      sources     All MIDI generated by these sources is routed into this connection for processing
+                            and distribution to destinations.
+    @field      numDestinations The number of valid destinations in the following array.
+    @field      destinations    All MIDI output from the connection is routed to these destinations.
+    @field      channelMap      Maps each of the source 16 MIDI channels to channel 0-15 (1-16) or 0xFF when
+                                MIDI from a channel is to be filtered out.
+    @field      lowVelocity     Note events with a velocity less than this value are filtered out.
+    @field      highVelocity    Note events with a velocity greater than this, if it is not 0, are filtered out.
+    @field      lowNote         See highNote.
+    @field      highNote        If highNote >= lowNote, then notes outside this range are filtered out.
+                                If lowNote > highNote, then notes <i>inside</i> this range are filtered out.
+                                This applies to note and polyphonic key pressure events.
+                                These fields are ignored if a there is a MIDIValueMap applying to noteNumber.
+    @field      noteNumber      Specifies how MIDI note numbers are transformed.
+    @field      velocity        Specifies how MIDI note velocities are transformed.
+    @field      keyPressure     Specifies how MIDI polyphonic key pressure events are transformed.
+    @field      channelPressure Specifies how MIDI monophonic (channel) pressure events are transformed.
+    @field      programChange   Specifies how MIDI program change events are transformed.
+    @field      pitchBend       Specifies how MIDI pitch bend events are transformed.
+    @field      filterOutSysEx  If 1, specifies that system-exclusive messages are to be filtered out.
+    @field      filterOutMTC    If 1, specifies that MIDI Time Code messages are to be filtered out.
+    @field      filterOutBeatClock  If 1, specifies the MIDI clock, play, stop, and resume messages are to
+                                be filtered out.
+    @field      filterOutTuneRequest    If 1, specifies that MIDI Tune Request messages are to be filtered out.
+    @field      reserved2       Must be 0.
+    @field      filterOutAllControls    If 1, specifies that all MIDI continuous control messages are to be filtered out.
+    @field      numControlTransforms    The number of control transformations in the variable-length portion of the struct.
+    @field      numMaps                 The number of MIDIValueMaps in the variable-length portion of the struct.
+    @field      reserved3       Must be 0.
+*/
+struct MIDIThruConnectionParams {
+    UInt32                      version;
+    UInt32                      numSources;
+    MIDIThruConnectionEndpoint  sources[kMIDIThruConnection_MaxEndpoints];
+    UInt32                      numDestinations;
+    MIDIThruConnectionEndpoint  destinations[kMIDIThruConnection_MaxEndpoints];
+    
+    UInt8                   channelMap[16];
+    UInt8                   lowVelocity, highVelocity;
+    UInt8                   lowNote, highNote;
+    MIDITransform           noteNumber;
+    MIDITransform           velocity;
+    MIDITransform           keyPressure;
+    MIDITransform           channelPressure;
+    MIDITransform           programChange;
+    MIDITransform           pitchBend;
+    
+    UInt8                   filterOutSysEx;
+    UInt8                   filterOutMTC;
+    UInt8                   filterOutBeatClock;
+    UInt8                   filterOutTuneRequest;
+    UInt8                   reserved2[3];
+    UInt8                   filterOutAllControls;
+    
+    UInt16                  numControlTransforms;
+    UInt16                  numMaps;
+    UInt16                  reserved3[4];
+
+    // remainder of structure is variable-length:
+    //      MIDIControlTransform    controls[];
+    //      MIDIValueMap            maps[];
+};
+typedef struct MIDIThruConnectionParams MIDIThruConnectionParams;
+
+#ifdef CF_INLINE
+/*!
+    @defined    MIDIThruConnectionParamsSize
+    @abstract   Returns the size of a MIDIThruConnectionParams.
+
+	Accounts for the variable-length elements in the structure and returns its true
+	size in bytes.
+*/
+CF_INLINE size_t MIDIThruConnectionParamsSize(const MIDIThruConnectionParams *ptr)
+{
+    return sizeof(MIDIThruConnectionParams) + ptr->numControlTransforms * sizeof(MIDIControlTransform)
+	    + ptr->numMaps * sizeof(MIDIValueMap);
+}
+#else
+#define MIDIThruConnectionParamsSize(ptr) \
+    (sizeof(MIDIThruConnectionParams) + (ptr)->numControlTransforms * sizeof(MIDIControlTransform) \
+    + (ptr)->numMaps * sizeof(MIDIValueMap))
+#endif
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+/*!
+    @function   MIDIThruConnectionParamsInitialize
+    @abstract   Fills a MIDIThruConnectionParams with default values.
+    @param      inConnectionParams  The struct to be initialized.
+
+	This convenience function fills the connection structure with default values: no endpoints,
+	no transformations (mostly zeroes except for the channel map). Then, just filling in the
+	source and adding one destination will create a simple, unmodified thru connection.
+*/
+extern void
+MIDIThruConnectionParamsInitialize(
+                            MIDIThruConnectionParams *      inConnectionParams )
+                                                                API_AVAILABLE(macos(10.2), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
+
+/*!
+    @function   MIDIThruConnectionCreate
+    @abstract   Creates a thru connection.
+    @param      inPersistentOwnerID
+                    If null, then the connection is marked as owned by the client
+                    and will be automatically disposed with the client.  if it is non-null, then it
+                    should be a unique identifier, e.g. "com.mycompany.MyCoolProgram".
+    @param      inConnectionParams
+                    A MIDIThruConnectionParams contained in a CFDataRef.
+    @param      outConnection
+                    On successful return, a reference to the newly-created connection.
+    @result     An OSStatus result code.
+*/
+extern OSStatus
+MIDIThruConnectionCreate(   CFStringRef __nullable          inPersistentOwnerID,
+                            CFDataRef                       inConnectionParams,
+                            MIDIThruConnectionRef *         outConnection )
+                                                                API_AVAILABLE(macos(10.2), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
+
+/*!
+    @function   MIDIThruConnectionDispose
+    @abstract   Disposes a thru connection.
+    @param      connection
+                    The connection to be disposed
+    @result     An OSStatus result code.
+*/
+extern OSStatus
+MIDIThruConnectionDispose(  MIDIThruConnectionRef           connection )
+                                                                API_AVAILABLE(macos(10.2), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
+
+/*!
+    @function   MIDIThruConnectionGetParams
+    @abstract   Obtains a thru connection's MIDIThruConnectionParams.
+    @param      connection
+                    The connection to be disposed.
+    @param      outConnectionParams
+                    On successful return, the connection's MIDIThruConnectionParams in a CFDataRef
+    @result     An OSStatus result code.
+
+	The returned CFDataRef contains a MIDIThruConnectionParams structure. The caller is responsible
+	for releasing it.
+*/
+extern OSStatus
+MIDIThruConnectionGetParams(MIDIThruConnectionRef           connection,
+                            CFDataRef __nonnull * __nonnull outConnectionParams )
+                                                                API_AVAILABLE(macos(10.2), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
+
+/*!
+    @function   MIDIThruConnectionSetParams
+    @abstract   Alters a thru connection's MIDIThruConnectionParams.
+    @param      connection
+                    The connection to be modified.
+    @param      inConnectionParams
+                    The connection's new MIDIThruConnectionParams in a CFDataRef
+    @result     An OSStatus result code.
+*/
+extern OSStatus
+MIDIThruConnectionSetParams(MIDIThruConnectionRef           connection,
+                            CFDataRef                       inConnectionParams )
+                                                                API_AVAILABLE(macos(10.2), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
+
+/*!
+    @function   MIDIThruConnectionFind
+    @abstract   Returns all of the persistent thru connections created by a client.
+    @param      inPersistentOwnerID
+                    The ID of the owner whose connections are to be returned.
+    @param      outConnectionList
+                    On successful return, a CFDataRef containing an array of MIDIThruConnectionRef's.
+    @result     An OSStatus result code.
+*/
+extern OSStatus
+MIDIThruConnectionFind(     CFStringRef                     inPersistentOwnerID,
+                            CFDataRef __nonnull * __nonnull outConnectionList )
+                                                                API_AVAILABLE(macos(10.2), ios(4.2)) API_UNAVAILABLE(tvos, watchos);
+
+#ifdef __cplusplus
+}
+#endif
+
+CF_ASSUME_NONNULL_END
+
+#endif /* __MIDIThruConnection_h__ */
Clone this wiki locally