-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathARAAudioUnit_v3.h
131 lines (111 loc) · 6.11 KB
/
ARAAudioUnit_v3.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
//------------------------------------------------------------------------------
//! \file ARAAudioUnit_v3.h
//! integrates ARA into Audio Unit v3 App Extension plug-ins
//! \project ARA API Specification
//! \copyright Copyright (c) 2021-2025, Celemony Software GmbH, All Rights Reserved.
//! Developed in cooperation with PreSonus Software Ltd.
//! \license Licensed under the Apache License, Version 2.0 (the "License");
//! you may not use this file except in compliance with the License.
//! You may obtain a copy of the License at
//!
//! http://www.apache.org/licenses/LICENSE-2.0
//!
//! Unless required by applicable law or agreed to in writing, software
//! distributed under the License is distributed on an "AS IS" BASIS,
//! WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
//! See the License for the specific language governing permissions and
//! limitations under the License.
//------------------------------------------------------------------------------
#ifndef ARAAudioUnit_v3_h
#define ARAAudioUnit_v3_h
#include "ARAInterface.h"
#import <AudioUnit/AUAudioUnit.h>
#if defined(__GNUC__)
_Pragma ("GCC diagnostic push")
_Pragma ("GCC diagnostic ignored \"-Wpedantic\"")
#endif
#warning "AudioUnit v3 App Extension support is still work-in-progress and will change in potentially incompatible ways (e.g. out-of-process loading)"
#if defined(__GNUC__)
_Pragma ("GCC diagnostic pop")
#endif
//! @defgroup Companion_APIs Companion APIs
//! @{
/***************************************************************************************************/
//! @defgroup Audio_Unit_v3 Audio Unit V3
//! Experimental support for Audio Unit v3 (App Extension)
//! @{
//! Integration with the system-wide Audio Unit cache.
//! To allow hosts to defer opening any Audio Unit v3 App Extensions until the user explicitly
//! requests it, the system caches various information about the Audio Unit.
//! To support this optimization also when ARA is used, plug-ins must be marked as ARA-compatible
//! at the Audio Component level inside its NSExtensionAttributes by including the tag "ARA" in
//! its Info.plist file, like in this example:
//! \code{.xml}
//! <key>NSExtension</key>
//! <dict>
//! <key>NSExtensionAttributes</key>
//! <dict>
//! <key>AudioComponentBundle</key>
//! <string>your.identifier.goes.here</string>
//! <key>AudioComponents</key>
//! <array>
//! <dict>
//! ...
//! <key>manufacturer</key>
//! <string>Demo</string>
//! <key>subtype</key>
//! <string>Test</string>
//! <key>type</key>
//! <string>aufx</string>
//! ...
//! <key>tags</key>
//! <array>
//! <string>Effects</string>
//! ...
//! <string>ARA</string>
//! </array>
//! </dict>
//! ...
//! \endcode
#define /*ARA_DRAFT*/ kARAAudioComponentTag "ARA"
//! Protocol to be implemented by ARA-compatible subclasses AUAudioUnit.
//! This protocol may or may not be replaced with the AUMessageChannel based communication defined below.
ARA_DRAFT @protocol ARAAudioUnit <NSObject>
@required
//! Get the ARA factory.
//! The returned pointer must remain valid throughout the lifetime of the App Extension that contains
//! the AUAudioUnit.
@property (nonatomic, readonly, nonnull) const ARA_NAMESPACE ARAFactory * araFactory;
//! Bind the AUAudioUnit instance to an ARA document controller, switching it from "normal" operation
//! to ARA mode, and exposing the ARA plug-in extension.
//! \p knownRoles encodes all roles that the host considered in its implementation and will explicitly
//! assign to some plug-in instance(s), while \p assignedRoles describes the roles that this specific
//! instance will fulfill.
//! This may be called only once during the lifetime of the AUAudioUnit instance, before
//! the first call to allocateRenderResourcesAndReturnError: or writing to fullState,
//! fullStateForDocument or currentPreset, or the creation of the GUI (see NSExtensionRequestHandling).
//! The ARA document controller must remain valid as long as the plug-in is in use - rendering,
//! showing its UI, etc. However, when tearing down the plug-in, the actual order for deleting
//! the AUAudioUnit instance and for deleting ARA document controller is undefined.
//! Plug-ins must handle both potential destruction orders to allow for a simpler reference
//! counting implementation on the host side.
- (nonnull const ARA_NAMESPACE ARAPlugInExtensionInstance *) bindToDocumentController:(nonnull ARA_NAMESPACE ARADocumentControllerRef) documentControllerRef
withRoles:(ARA_NAMESPACE ARAPlugInInstanceRoleFlags) assignedRoles
knownRoles:(ARA_NAMESPACE ARAPlugInInstanceRoleFlags) knownRoles;
//! When loading ARA Audio Units out-of-process, the host only operates on a CoreAudio proxy instance
//! of the actual AUAudioUnit. When performing the binding, the remote side must identify the actual
//! instance that should be bound, so this getter is added to access the self pointer of that instance
//! encoded as NSUInteger (equivalent to size_t) so that it can be sent back and forth across the XPC.
@property (nonatomic, readonly) NSUInteger araRemoteInstanceRef;
@end
//! UTIs for ARA message protocols used for [AUAudioUnit messageChannelFor:] (added in macOS 13)
//! The message channels should only be obtained and configured once per remote process
//! and be shared across all ARA Audio Unit or ARA document controller communications.
//! This API may eventually replace the above ARAAudioUnit <NSObject> draft.
//@{
#define ARA_AUDIOUNIT_MAIN_THREAD_MESSAGES_UTI /*ARA_DRAFT*/ @"org.ara-audio.main.draft.1"
#define ARA_AUDIOUNIT_OTHER_THREADS_MESSAGES_UTI /*ARA_DRAFT*/ @"org.ara-audio.other.draft.1"
//@}
//! @}
//! @}
#endif // ARAAudioUnit_v3_h