mirror of
https://github.com/cookiengineer/audacity
synced 2025-09-19 17:40:51 +02:00
220 lines
5.8 KiB
C
220 lines
5.8 KiB
C
/* SLV2
|
|
* Copyright (C) 2007 Dave Robillard <http://drobilla.net>
|
|
*
|
|
* This library is free software; you can redistribute it and/or modify it
|
|
* under the terms of the GNU General Public License as published by the Free
|
|
* Software Foundation; either version 2 of the License, or (at your option)
|
|
* any later version.
|
|
*
|
|
* This library is distributed in the hope that it will be useful, but WITHOUT
|
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
|
* for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License along
|
|
* with this program; if not, write to the Free Software Foundation, Inc.,
|
|
* 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
|
*/
|
|
|
|
#ifndef __SLV2_PLUGININSTANCE_H__
|
|
#define __SLV2_PLUGININSTANCE_H__
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
#include <assert.h>
|
|
#include <slv2/lv2.h>
|
|
#include <slv2/plugin.h>
|
|
#include <slv2/port.h>
|
|
|
|
typedef struct _InstanceImpl* SLV2InstanceImpl;
|
|
|
|
/** \cond IGNORE */
|
|
|
|
/* Instance of a plugin.
|
|
*
|
|
* The LV2 descriptor and handle of this are exposed to allow inlining of
|
|
* performance critical functions like slv2_instance_run (which are exposed
|
|
* in lv2.h anyway). This is for performance only, this struct is not
|
|
* documented and should not be used directly. The remaining implementation
|
|
* details are in the opaque pimpl member.
|
|
*/
|
|
typedef struct _Instance {
|
|
const LV2_Descriptor* lv2_descriptor;
|
|
LV2_Handle lv2_handle;
|
|
SLV2InstanceImpl pimpl; ///< Private implementation
|
|
}* SLV2Instance;
|
|
|
|
/** \endcond */
|
|
|
|
|
|
/** \defgroup slv2_library Plugin library access
|
|
*
|
|
* An SLV2Instance is an instantiated SLV2Plugin (ie a loaded dynamic
|
|
* library). These functions interact with the binary library code only,
|
|
* they do not read data files in any way.
|
|
*
|
|
* @{
|
|
*/
|
|
|
|
/** Instantiate a plugin.
|
|
*
|
|
* The returned object represents shared library objects loaded into memory,
|
|
* it must be cleaned up with slv2_instance_free when no longer
|
|
* needed.
|
|
*
|
|
* \a plugin is not modified or directly referenced by the returned object
|
|
* (instances store only a copy of the plugin's URI).
|
|
*
|
|
* \a host_features NULL-terminated array of features the host supports.
|
|
* NULL may be passed if the host supports no additional features (unlike
|
|
* the LV2 specification - SLV2 takes care of it).
|
|
*
|
|
* \return NULL if instantiation failed.
|
|
*/
|
|
SLV2Instance
|
|
slv2_plugin_instantiate(SLV2Plugin plugin,
|
|
double sample_rate,
|
|
const LV2_Feature*const* features);
|
|
|
|
|
|
/** Free a plugin instance.
|
|
*
|
|
* \a instance is invalid after this call.
|
|
*/
|
|
void
|
|
slv2_instance_free(SLV2Instance instance);
|
|
|
|
#ifndef LIBSLV2_SOURCE
|
|
|
|
/** Get the URI of the plugin which \a instance is an instance of.
|
|
*
|
|
* Returned string is shared and must not be modified or deleted.
|
|
*/
|
|
static inline const char*
|
|
slv2_instance_get_uri(SLV2Instance instance)
|
|
{
|
|
assert(instance);
|
|
assert(instance->lv2_descriptor);
|
|
|
|
return instance->lv2_descriptor->URI;
|
|
}
|
|
|
|
|
|
/** Connect a port to a data location.
|
|
*
|
|
* This may be called regardless of whether the plugin is activated,
|
|
* activation and deactivation does not destroy port connections.
|
|
*/
|
|
static inline void
|
|
slv2_instance_connect_port(SLV2Instance instance,
|
|
uint32_t port_index,
|
|
void* data_location)
|
|
{
|
|
assert(instance);
|
|
assert(instance->lv2_descriptor);
|
|
assert(instance->lv2_descriptor->connect_port);
|
|
|
|
instance->lv2_descriptor->connect_port
|
|
(instance->lv2_handle, port_index, data_location);
|
|
}
|
|
|
|
|
|
/** Activate a plugin instance.
|
|
*
|
|
* This resets all state information in the plugin, except for port data
|
|
* locations (as set by slv2_instance_connect_port). This MUST be called
|
|
* before calling slv2_instance_run.
|
|
*/
|
|
static inline void
|
|
slv2_instance_activate(SLV2Instance instance)
|
|
{
|
|
assert(instance);
|
|
assert(instance->lv2_descriptor);
|
|
|
|
if (instance->lv2_descriptor->activate)
|
|
instance->lv2_descriptor->activate(instance->lv2_handle);
|
|
}
|
|
|
|
|
|
/** Run \a instance for \a sample_count frames.
|
|
*
|
|
* If the hint lv2:hardRtCapable is set for this plugin, this function is
|
|
* guaranteed not to block.
|
|
*/
|
|
static inline void
|
|
slv2_instance_run(SLV2Instance instance,
|
|
uint32_t sample_count)
|
|
{
|
|
assert(instance);
|
|
assert(instance->lv2_descriptor);
|
|
assert(instance->lv2_handle);
|
|
|
|
/*if (instance->lv2_descriptor->run)*/
|
|
instance->lv2_descriptor->run(instance->lv2_handle, sample_count);
|
|
}
|
|
|
|
|
|
/** Deactivate a plugin instance.
|
|
*
|
|
* Note that to run the plugin after this you must activate it, which will
|
|
* reset all state information (except port connections).
|
|
*/
|
|
static inline void
|
|
slv2_instance_deactivate(SLV2Instance instance)
|
|
{
|
|
assert(instance);
|
|
assert(instance->lv2_descriptor);
|
|
assert(instance->lv2_handle);
|
|
|
|
if (instance->lv2_descriptor->deactivate)
|
|
instance->lv2_descriptor->deactivate(instance->lv2_handle);
|
|
}
|
|
|
|
|
|
/** Get the LV2_Descriptor of the plugin instance.
|
|
*
|
|
* Normally hosts should not need to access the LV2_Descriptor directly,
|
|
* use the slv2_instance_* functions.
|
|
*
|
|
* The returned descriptor is shared and must not be deleted.
|
|
*/
|
|
static inline const LV2_Descriptor*
|
|
slv2_instance_get_descriptor(SLV2Instance instance)
|
|
{
|
|
assert(instance);
|
|
assert(instance->lv2_descriptor);
|
|
|
|
return instance->lv2_descriptor;
|
|
}
|
|
|
|
|
|
/** Get the LV2_Handle of the plugin instance.
|
|
*
|
|
* Normally hosts should not need to access the LV2_Handle directly,
|
|
* use the slv2_instance_* functions.
|
|
*
|
|
* The returned handle is shared and must not be deleted.
|
|
*/
|
|
static inline LV2_Handle
|
|
slv2_instance_get_handle(SLV2Instance instance)
|
|
{
|
|
assert(instance);
|
|
assert(instance->lv2_descriptor);
|
|
|
|
return instance->lv2_handle;
|
|
}
|
|
|
|
#endif /* LIBSLV2_SOURCE */
|
|
|
|
/** @} */
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
|
|
|
|
#endif /* __SLV2_PLUGININSTANCE_H__ */
|
|
|