comparison DPF-Prymula-audioplugins/dpf/distrho/src/lv2/lv2.h @ 3:84e66ea83026

DPF-Prymula-audioplugins-0.231015-2
author prymula <prymula76@outlook.com>
date Mon, 16 Oct 2023 21:53:34 +0200
parents
children
comparison
equal deleted inserted replaced
2:cf2cb71d31dd 3:84e66ea83026
1 /*
2 LV2 - An audio plugin interface specification.
3 Copyright 2006-2012 Steve Harris, David Robillard.
4
5 Based on LADSPA, Copyright 2000-2002 Richard W.E. Furse,
6 Paul Barton-Davis, Stefan Westerfeld.
7
8 Permission to use, copy, modify, and/or distribute this software for any
9 purpose with or without fee is hereby granted, provided that the above
10 copyright notice and this permission notice appear in all copies.
11
12 THIS SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
13 WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
14 MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
15 ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
16 WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
17 ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
18 OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
19 */
20
21 /**
22 @defgroup lv2core LV2 Core
23
24 Core LV2 specification, see <http://lv2plug.in/ns/lv2core> for details.
25
26 @{
27 */
28
29 #ifndef LV2_H_INCLUDED
30 #define LV2_H_INCLUDED
31
32 #include <stdint.h>
33
34 #define LV2_CORE_URI "http://lv2plug.in/ns/lv2core" ///< http://lv2plug.in/ns/lv2core
35 #define LV2_CORE_PREFIX LV2_CORE_URI "#" ///< http://lv2plug.in/ns/lv2core#
36
37 #define LV2_CORE__AllpassPlugin LV2_CORE_PREFIX "AllpassPlugin" ///< http://lv2plug.in/ns/lv2core#AllpassPlugin
38 #define LV2_CORE__AmplifierPlugin LV2_CORE_PREFIX "AmplifierPlugin" ///< http://lv2plug.in/ns/lv2core#AmplifierPlugin
39 #define LV2_CORE__AnalyserPlugin LV2_CORE_PREFIX "AnalyserPlugin" ///< http://lv2plug.in/ns/lv2core#AnalyserPlugin
40 #define LV2_CORE__AudioPort LV2_CORE_PREFIX "AudioPort" ///< http://lv2plug.in/ns/lv2core#AudioPort
41 #define LV2_CORE__BandpassPlugin LV2_CORE_PREFIX "BandpassPlugin" ///< http://lv2plug.in/ns/lv2core#BandpassPlugin
42 #define LV2_CORE__CVPort LV2_CORE_PREFIX "CVPort" ///< http://lv2plug.in/ns/lv2core#CVPort
43 #define LV2_CORE__ChorusPlugin LV2_CORE_PREFIX "ChorusPlugin" ///< http://lv2plug.in/ns/lv2core#ChorusPlugin
44 #define LV2_CORE__CombPlugin LV2_CORE_PREFIX "CombPlugin" ///< http://lv2plug.in/ns/lv2core#CombPlugin
45 #define LV2_CORE__CompressorPlugin LV2_CORE_PREFIX "CompressorPlugin" ///< http://lv2plug.in/ns/lv2core#CompressorPlugin
46 #define LV2_CORE__ConstantPlugin LV2_CORE_PREFIX "ConstantPlugin" ///< http://lv2plug.in/ns/lv2core#ConstantPlugin
47 #define LV2_CORE__ControlPort LV2_CORE_PREFIX "ControlPort" ///< http://lv2plug.in/ns/lv2core#ControlPort
48 #define LV2_CORE__ConverterPlugin LV2_CORE_PREFIX "ConverterPlugin" ///< http://lv2plug.in/ns/lv2core#ConverterPlugin
49 #define LV2_CORE__DelayPlugin LV2_CORE_PREFIX "DelayPlugin" ///< http://lv2plug.in/ns/lv2core#DelayPlugin
50 #define LV2_CORE__DistortionPlugin LV2_CORE_PREFIX "DistortionPlugin" ///< http://lv2plug.in/ns/lv2core#DistortionPlugin
51 #define LV2_CORE__DynamicsPlugin LV2_CORE_PREFIX "DynamicsPlugin" ///< http://lv2plug.in/ns/lv2core#DynamicsPlugin
52 #define LV2_CORE__EQPlugin LV2_CORE_PREFIX "EQPlugin" ///< http://lv2plug.in/ns/lv2core#EQPlugin
53 #define LV2_CORE__EnvelopePlugin LV2_CORE_PREFIX "EnvelopePlugin" ///< http://lv2plug.in/ns/lv2core#EnvelopePlugin
54 #define LV2_CORE__ExpanderPlugin LV2_CORE_PREFIX "ExpanderPlugin" ///< http://lv2plug.in/ns/lv2core#ExpanderPlugin
55 #define LV2_CORE__ExtensionData LV2_CORE_PREFIX "ExtensionData" ///< http://lv2plug.in/ns/lv2core#ExtensionData
56 #define LV2_CORE__Feature LV2_CORE_PREFIX "Feature" ///< http://lv2plug.in/ns/lv2core#Feature
57 #define LV2_CORE__FilterPlugin LV2_CORE_PREFIX "FilterPlugin" ///< http://lv2plug.in/ns/lv2core#FilterPlugin
58 #define LV2_CORE__FlangerPlugin LV2_CORE_PREFIX "FlangerPlugin" ///< http://lv2plug.in/ns/lv2core#FlangerPlugin
59 #define LV2_CORE__FunctionPlugin LV2_CORE_PREFIX "FunctionPlugin" ///< http://lv2plug.in/ns/lv2core#FunctionPlugin
60 #define LV2_CORE__GatePlugin LV2_CORE_PREFIX "GatePlugin" ///< http://lv2plug.in/ns/lv2core#GatePlugin
61 #define LV2_CORE__GeneratorPlugin LV2_CORE_PREFIX "GeneratorPlugin" ///< http://lv2plug.in/ns/lv2core#GeneratorPlugin
62 #define LV2_CORE__HighpassPlugin LV2_CORE_PREFIX "HighpassPlugin" ///< http://lv2plug.in/ns/lv2core#HighpassPlugin
63 #define LV2_CORE__InputPort LV2_CORE_PREFIX "InputPort" ///< http://lv2plug.in/ns/lv2core#InputPort
64 #define LV2_CORE__InstrumentPlugin LV2_CORE_PREFIX "InstrumentPlugin" ///< http://lv2plug.in/ns/lv2core#InstrumentPlugin
65 #define LV2_CORE__LimiterPlugin LV2_CORE_PREFIX "LimiterPlugin" ///< http://lv2plug.in/ns/lv2core#LimiterPlugin
66 #define LV2_CORE__LowpassPlugin LV2_CORE_PREFIX "LowpassPlugin" ///< http://lv2plug.in/ns/lv2core#LowpassPlugin
67 #define LV2_CORE__MixerPlugin LV2_CORE_PREFIX "MixerPlugin" ///< http://lv2plug.in/ns/lv2core#MixerPlugin
68 #define LV2_CORE__ModulatorPlugin LV2_CORE_PREFIX "ModulatorPlugin" ///< http://lv2plug.in/ns/lv2core#ModulatorPlugin
69 #define LV2_CORE__MultiEQPlugin LV2_CORE_PREFIX "MultiEQPlugin" ///< http://lv2plug.in/ns/lv2core#MultiEQPlugin
70 #define LV2_CORE__OscillatorPlugin LV2_CORE_PREFIX "OscillatorPlugin" ///< http://lv2plug.in/ns/lv2core#OscillatorPlugin
71 #define LV2_CORE__OutputPort LV2_CORE_PREFIX "OutputPort" ///< http://lv2plug.in/ns/lv2core#OutputPort
72 #define LV2_CORE__ParaEQPlugin LV2_CORE_PREFIX "ParaEQPlugin" ///< http://lv2plug.in/ns/lv2core#ParaEQPlugin
73 #define LV2_CORE__PhaserPlugin LV2_CORE_PREFIX "PhaserPlugin" ///< http://lv2plug.in/ns/lv2core#PhaserPlugin
74 #define LV2_CORE__PitchPlugin LV2_CORE_PREFIX "PitchPlugin" ///< http://lv2plug.in/ns/lv2core#PitchPlugin
75 #define LV2_CORE__Plugin LV2_CORE_PREFIX "Plugin" ///< http://lv2plug.in/ns/lv2core#Plugin
76 #define LV2_CORE__PluginBase LV2_CORE_PREFIX "PluginBase" ///< http://lv2plug.in/ns/lv2core#PluginBase
77 #define LV2_CORE__Point LV2_CORE_PREFIX "Point" ///< http://lv2plug.in/ns/lv2core#Point
78 #define LV2_CORE__Port LV2_CORE_PREFIX "Port" ///< http://lv2plug.in/ns/lv2core#Port
79 #define LV2_CORE__PortProperty LV2_CORE_PREFIX "PortProperty" ///< http://lv2plug.in/ns/lv2core#PortProperty
80 #define LV2_CORE__Resource LV2_CORE_PREFIX "Resource" ///< http://lv2plug.in/ns/lv2core#Resource
81 #define LV2_CORE__ReverbPlugin LV2_CORE_PREFIX "ReverbPlugin" ///< http://lv2plug.in/ns/lv2core#ReverbPlugin
82 #define LV2_CORE__ScalePoint LV2_CORE_PREFIX "ScalePoint" ///< http://lv2plug.in/ns/lv2core#ScalePoint
83 #define LV2_CORE__SimulatorPlugin LV2_CORE_PREFIX "SimulatorPlugin" ///< http://lv2plug.in/ns/lv2core#SimulatorPlugin
84 #define LV2_CORE__SpatialPlugin LV2_CORE_PREFIX "SpatialPlugin" ///< http://lv2plug.in/ns/lv2core#SpatialPlugin
85 #define LV2_CORE__Specification LV2_CORE_PREFIX "Specification" ///< http://lv2plug.in/ns/lv2core#Specification
86 #define LV2_CORE__SpectralPlugin LV2_CORE_PREFIX "SpectralPlugin" ///< http://lv2plug.in/ns/lv2core#SpectralPlugin
87 #define LV2_CORE__UtilityPlugin LV2_CORE_PREFIX "UtilityPlugin" ///< http://lv2plug.in/ns/lv2core#UtilityPlugin
88 #define LV2_CORE__WaveshaperPlugin LV2_CORE_PREFIX "WaveshaperPlugin" ///< http://lv2plug.in/ns/lv2core#WaveshaperPlugin
89 #define LV2_CORE__appliesTo LV2_CORE_PREFIX "appliesTo" ///< http://lv2plug.in/ns/lv2core#appliesTo
90 #define LV2_CORE__binary LV2_CORE_PREFIX "binary" ///< http://lv2plug.in/ns/lv2core#binary
91 #define LV2_CORE__connectionOptional LV2_CORE_PREFIX "connectionOptional" ///< http://lv2plug.in/ns/lv2core#connectionOptional
92 #define LV2_CORE__control LV2_CORE_PREFIX "control" ///< http://lv2plug.in/ns/lv2core#control
93 #define LV2_CORE__default LV2_CORE_PREFIX "default" ///< http://lv2plug.in/ns/lv2core#default
94 #define LV2_CORE__designation LV2_CORE_PREFIX "designation" ///< http://lv2plug.in/ns/lv2core#designation
95 #define LV2_CORE__documentation LV2_CORE_PREFIX "documentation" ///< http://lv2plug.in/ns/lv2core#documentation
96 #define LV2_CORE__enumeration LV2_CORE_PREFIX "enumeration" ///< http://lv2plug.in/ns/lv2core#enumeration
97 #define LV2_CORE__extensionData LV2_CORE_PREFIX "extensionData" ///< http://lv2plug.in/ns/lv2core#extensionData
98 #define LV2_CORE__freeWheeling LV2_CORE_PREFIX "freeWheeling" ///< http://lv2plug.in/ns/lv2core#freeWheeling
99 #define LV2_CORE__hardRTCapable LV2_CORE_PREFIX "hardRTCapable" ///< http://lv2plug.in/ns/lv2core#hardRTCapable
100 #define LV2_CORE__inPlaceBroken LV2_CORE_PREFIX "inPlaceBroken" ///< http://lv2plug.in/ns/lv2core#inPlaceBroken
101 #define LV2_CORE__index LV2_CORE_PREFIX "index" ///< http://lv2plug.in/ns/lv2core#index
102 #define LV2_CORE__integer LV2_CORE_PREFIX "integer" ///< http://lv2plug.in/ns/lv2core#integer
103 #define LV2_CORE__isLive LV2_CORE_PREFIX "isLive" ///< http://lv2plug.in/ns/lv2core#isLive
104 #define LV2_CORE__latency LV2_CORE_PREFIX "latency" ///< http://lv2plug.in/ns/lv2core#latency
105 #define LV2_CORE__maximum LV2_CORE_PREFIX "maximum" ///< http://lv2plug.in/ns/lv2core#maximum
106 #define LV2_CORE__microVersion LV2_CORE_PREFIX "microVersion" ///< http://lv2plug.in/ns/lv2core#microVersion
107 #define LV2_CORE__minimum LV2_CORE_PREFIX "minimum" ///< http://lv2plug.in/ns/lv2core#minimum
108 #define LV2_CORE__minorVersion LV2_CORE_PREFIX "minorVersion" ///< http://lv2plug.in/ns/lv2core#minorVersion
109 #define LV2_CORE__name LV2_CORE_PREFIX "name" ///< http://lv2plug.in/ns/lv2core#name
110 #define LV2_CORE__optionalFeature LV2_CORE_PREFIX "optionalFeature" ///< http://lv2plug.in/ns/lv2core#optionalFeature
111 #define LV2_CORE__port LV2_CORE_PREFIX "port" ///< http://lv2plug.in/ns/lv2core#port
112 #define LV2_CORE__portProperty LV2_CORE_PREFIX "portProperty" ///< http://lv2plug.in/ns/lv2core#portProperty
113 #define LV2_CORE__project LV2_CORE_PREFIX "project" ///< http://lv2plug.in/ns/lv2core#project
114 #define LV2_CORE__prototype LV2_CORE_PREFIX "prototype" ///< http://lv2plug.in/ns/lv2core#prototype
115 #define LV2_CORE__reportsLatency LV2_CORE_PREFIX "reportsLatency" ///< http://lv2plug.in/ns/lv2core#reportsLatency
116 #define LV2_CORE__requiredFeature LV2_CORE_PREFIX "requiredFeature" ///< http://lv2plug.in/ns/lv2core#requiredFeature
117 #define LV2_CORE__sampleRate LV2_CORE_PREFIX "sampleRate" ///< http://lv2plug.in/ns/lv2core#sampleRate
118 #define LV2_CORE__scalePoint LV2_CORE_PREFIX "scalePoint" ///< http://lv2plug.in/ns/lv2core#scalePoint
119 #define LV2_CORE__symbol LV2_CORE_PREFIX "symbol" ///< http://lv2plug.in/ns/lv2core#symbol
120 #define LV2_CORE__toggled LV2_CORE_PREFIX "toggled" ///< http://lv2plug.in/ns/lv2core#toggled
121
122 #ifdef __cplusplus
123 extern "C" {
124 #endif
125
126 /**
127 Plugin Instance Handle.
128
129 This is a handle for one particular instance of a plugin. It is valid to
130 compare to NULL (or 0 for C++) but otherwise the host MUST NOT attempt to
131 interpret it.
132 */
133 typedef void * LV2_Handle;
134
135 /**
136 Feature.
137
138 Features allow hosts to make additional functionality available to plugins
139 without requiring modification to the LV2 API. Extensions may define new
140 features and specify the `URI` and `data` to be used if necessary.
141 Some features, such as lv2:isLive, do not require the host to pass data.
142 */
143 typedef struct _LV2_Feature {
144 /**
145 A globally unique, case-sensitive identifier (URI) for this feature.
146
147 This MUST be a valid URI string as defined by RFC 3986.
148 */
149 const char * URI;
150
151 /**
152 Pointer to arbitrary data.
153
154 The format of this data is defined by the extension which describes the
155 feature with the given `URI`.
156 */
157 void * data;
158 } LV2_Feature;
159
160 /**
161 Plugin Descriptor.
162
163 This structure provides the core functions necessary to instantiate and use
164 a plugin.
165 */
166 typedef struct _LV2_Descriptor {
167 /**
168 A globally unique, case-sensitive identifier for this plugin.
169
170 This MUST be a valid URI string as defined by RFC 3986. All plugins with
171 the same URI MUST be compatible to some degree, see
172 http://lv2plug.in/ns/lv2core for details.
173 */
174 const char * URI;
175
176 /**
177 Instantiate the plugin.
178
179 Note that instance initialisation should generally occur in activate()
180 rather than here. If a host calls instantiate(), it MUST call cleanup()
181 at some point in the future.
182
183 @param descriptor Descriptor of the plugin to instantiate.
184
185 @param sample_rate Sample rate, in Hz, for the new plugin instance.
186
187 @param bundle_path Path to the LV2 bundle which contains this plugin
188 binary. It MUST include the trailing directory separator (e.g. '/') so
189 that simply appending a filename will yield the path to that file in the
190 bundle.
191
192 @param features A NULL terminated array of LV2_Feature structs which
193 represent the features the host supports. Plugins may refuse to
194 instantiate if required features are not found here. However, hosts MUST
195 NOT use this as a discovery mechanism: instead, use the RDF data to
196 determine which features are required and do not attempt to instantiate
197 unsupported plugins at all. This parameter MUST NOT be NULL, i.e. a host
198 that supports no features MUST pass a single element array containing
199 NULL.
200
201 @return A handle for the new plugin instance, or NULL if instantiation
202 has failed.
203 */
204 LV2_Handle (*instantiate)(const struct _LV2_Descriptor * descriptor,
205 double sample_rate,
206 const char * bundle_path,
207 const LV2_Feature *const * features);
208
209 /**
210 Connect a port on a plugin instance to a memory location.
211
212 Plugin writers should be aware that the host may elect to use the same
213 buffer for more than one port and even use the same buffer for both
214 input and output (see lv2:inPlaceBroken in lv2.ttl).
215
216 If the plugin has the feature lv2:hardRTCapable then there are various
217 things that the plugin MUST NOT do within the connect_port() function;
218 see lv2core.ttl for details.
219
220 connect_port() MUST be called at least once for each port before run()
221 is called, unless that port is lv2:connectionOptional. The plugin must
222 pay careful attention to the block size passed to run() since the block
223 allocated may only just be large enough to contain the data, and is not
224 guaranteed to remain constant between run() calls.
225
226 connect_port() may be called more than once for a plugin instance to
227 allow the host to change the buffers that the plugin is reading or
228 writing. These calls may be made before or after activate() or
229 deactivate() calls.
230
231 @param instance Plugin instance containing the port.
232
233 @param port Index of the port to connect. The host MUST NOT try to
234 connect a port index that is not defined in the plugin's RDF data. If
235 it does, the plugin's behaviour is undefined (a crash is likely).
236
237 @param data_location Pointer to data of the type defined by the port
238 type in the plugin's RDF data (e.g. an array of float for an
239 lv2:AudioPort). This pointer must be stored by the plugin instance and
240 used to read/write data when run() is called. Data present at the time
241 of the connect_port() call MUST NOT be considered meaningful.
242 */
243 void (*connect_port)(LV2_Handle instance,
244 uint32_t port,
245 void * data_location);
246
247 /**
248 Initialise a plugin instance and activate it for use.
249
250 This is separated from instantiate() to aid real-time support and so
251 that hosts can reinitialise a plugin instance by calling deactivate()
252 and then activate(). In this case the plugin instance MUST reset all
253 state information dependent on the history of the plugin instance except
254 for any data locations provided by connect_port(). If there is nothing
255 for activate() to do then this field may be NULL.
256
257 When present, hosts MUST call this function once before run() is called
258 for the first time. This call SHOULD be made as close to the run() call
259 as possible and indicates to real-time plugins that they are now live,
260 however plugins MUST NOT rely on a prompt call to run() after
261 activate().
262
263 The host MUST NOT call activate() again until deactivate() has been
264 called first. If a host calls activate(), it MUST call deactivate() at
265 some point in the future. Note that connect_port() may be called before
266 or after activate().
267 */
268 void (*activate)(LV2_Handle instance);
269
270 /**
271 Run a plugin instance for a block.
272
273 Note that if an activate() function exists then it must be called before
274 run(). If deactivate() is called for a plugin instance then run() may
275 not be called until activate() has been called again.
276
277 If the plugin has the feature lv2:hardRTCapable then there are various
278 things that the plugin MUST NOT do within the run() function (see
279 lv2core.ttl for details).
280
281 As a special case, when `sample_count` is 0, the plugin should update
282 any output ports that represent a single instant in time (e.g. control
283 ports, but not audio ports). This is particularly useful for latent
284 plugins, which should update their latency output port so hosts can
285 pre-roll plugins to compute latency. Plugins MUST NOT crash when
286 `sample_count` is 0.
287
288 @param instance Instance to be run.
289
290 @param sample_count The block size (in samples) for which the plugin
291 instance must run.
292 */
293 void (*run)(LV2_Handle instance,
294 uint32_t sample_count);
295
296 /**
297 Deactivate a plugin instance (counterpart to activate()).
298
299 Hosts MUST deactivate all activated instances after they have been run()
300 for the last time. This call SHOULD be made as close to the last run()
301 call as possible and indicates to real-time plugins that they are no
302 longer live, however plugins MUST NOT rely on prompt deactivation. If
303 there is nothing for deactivate() to do then this field may be NULL
304
305 Deactivation is not similar to pausing since the plugin instance will be
306 reinitialised by activate(). However, deactivate() itself MUST NOT fully
307 reset plugin state. For example, the host may deactivate a plugin, then
308 store its state (using some extension to do so).
309
310 Hosts MUST NOT call deactivate() unless activate() was previously
311 called. Note that connect_port() may be called before or after
312 deactivate().
313 */
314 void (*deactivate)(LV2_Handle instance);
315
316 /**
317 Clean up a plugin instance (counterpart to instantiate()).
318
319 Once an instance of a plugin has been finished with it must be deleted
320 using this function. The instance handle passed ceases to be valid after
321 this call.
322
323 If activate() was called for a plugin instance then a corresponding call
324 to deactivate() MUST be made before cleanup() is called. Hosts MUST NOT
325 call cleanup() unless instantiate() was previously called.
326 */
327 void (*cleanup)(LV2_Handle instance);
328
329 /**
330 Return additional plugin data defined by some extenion.
331
332 A typical use of this facility is to return a struct containing function
333 pointers to extend the LV2_Descriptor API.
334
335 The actual type and meaning of the returned object MUST be specified
336 precisely by the extension. This function MUST return NULL for any
337 unsupported URI. If a plugin does not support any extension data, this
338 field may be NULL.
339
340 The host is never responsible for freeing the returned value.
341 */
342 const void * (*extension_data)(const char * uri);
343 } LV2_Descriptor;
344
345 /**
346 Helper macro needed for LV2_SYMBOL_EXPORT when using C++.
347 */
348 #ifdef __cplusplus
349 # define LV2_SYMBOL_EXTERN extern "C"
350 #else
351 # define LV2_SYMBOL_EXTERN
352 #endif
353
354 /**
355 Put this (LV2_SYMBOL_EXPORT) before any functions that are to be loaded
356 by the host as a symbol from the dynamic library.
357 */
358 #if defined(__EMSCRIPTEN__)
359 # define LV2_SYMBOL_EXPORT LV2_SYMBOL_EXTERN __attribute__((used))
360 #elif defined(_WIN32)
361 # define LV2_SYMBOL_EXPORT LV2_SYMBOL_EXTERN __declspec(dllexport)
362 #else
363 # define LV2_SYMBOL_EXPORT LV2_SYMBOL_EXTERN __attribute__((visibility("default")))
364 #endif
365
366 /**
367 Prototype for plugin accessor function.
368
369 Plugins are discovered by hosts using RDF data (not by loading libraries).
370 See http://lv2plug.in for details on the discovery process, though most
371 hosts should use an existing library to implement this functionality.
372
373 This is the simple plugin discovery API, suitable for most statically
374 defined plugins. Advanced plugins that need access to their bundle during
375 discovery can use lv2_lib_descriptor() instead. Plugin libraries MUST
376 include a function called "lv2_descriptor" or "lv2_lib_descriptor" with
377 C-style linkage, but SHOULD provide "lv2_descriptor" wherever possible.
378
379 When it is time to load a plugin (designated by its URI), the host loads the
380 plugin's library, gets the lv2_descriptor() function from it, and uses this
381 function to find the LV2_Descriptor for the desired plugin. Plugins are
382 accessed by index using values from 0 upwards. This function MUST return
383 NULL for out of range indices, so the host can enumerate plugins by
384 increasing `index` until NULL is returned.
385
386 Note that `index` has no meaning, hosts MUST NOT depend on it remaining
387 consistent between loads of the plugin library.
388 */
389 LV2_SYMBOL_EXPORT
390 const LV2_Descriptor * lv2_descriptor(uint32_t index);
391
392 /**
393 Type of the lv2_descriptor() function in a library (old discovery API).
394 */
395 typedef const LV2_Descriptor *
396 (*LV2_Descriptor_Function)(uint32_t index);
397
398 /**
399 Handle for a library descriptor.
400 */
401 typedef void* LV2_Lib_Handle;
402
403 /**
404 Descriptor for a plugin library.
405
406 To access a plugin library, the host creates an LV2_Lib_Descriptor via the
407 lv2_lib_descriptor() function in the shared object.
408 */
409 typedef struct {
410 /**
411 Opaque library data which must be passed as the first parameter to all
412 the methods of this struct.
413 */
414 LV2_Lib_Handle handle;
415
416 /**
417 The total size of this struct. This allows for this struct to be
418 expanded in the future if necessary. This MUST be set by the library to
419 sizeof(LV2_Lib_Descriptor). The host MUST NOT access any fields of this
420 struct beyond get_plugin() unless this field indicates they are present.
421 */
422 uint32_t size;
423
424 /**
425 Destroy this library descriptor and free all related resources.
426 */
427 void (*cleanup)(LV2_Lib_Handle handle);
428
429 /**
430 Plugin accessor.
431
432 Plugins are accessed by index using values from 0 upwards. Out of range
433 indices MUST result in this function returning NULL, so the host can
434 enumerate plugins by increasing `index` until NULL is returned.
435 */
436 const LV2_Descriptor * (*get_plugin)(LV2_Lib_Handle handle,
437 uint32_t index);
438 } LV2_Lib_Descriptor;
439
440 /**
441 Prototype for library accessor function.
442
443 This is the more advanced discovery API, which allows plugin libraries to
444 access their bundles during discovery, which makes it possible for plugins to
445 be dynamically defined by files in their bundle. This API also has an
446 explicit cleanup function, removing any need for non-portable shared library
447 destructors. Simple plugins that do not require these features may use
448 lv2_descriptor() instead.
449
450 This is the entry point for a plugin library. Hosts load this symbol from
451 the library and call this function to obtain a library descriptor which can
452 be used to access all the contained plugins. The returned object must not
453 be destroyed (using LV2_Lib_Descriptor::cleanup()) until all plugins loaded
454 from that library have been destroyed.
455 */
456 LV2_SYMBOL_EXPORT
457 const LV2_Lib_Descriptor *
458 lv2_lib_descriptor(const char * bundle_path,
459 const LV2_Feature *const * features);
460
461 /**
462 Type of the lv2_lib_descriptor() function in an LV2 library.
463 */
464 typedef const LV2_Lib_Descriptor *
465 (*LV2_Lib_Descriptor_Function)(const char * bundle_path,
466 const LV2_Feature *const * features);
467
468 #ifdef __cplusplus
469 }
470 #endif
471
472 #endif /* LV2_H_INCLUDED */
473
474 /**
475 @}
476 */