|
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932 |
- /*
- * Carla Plugin Host
- * Copyright (C) 2011-2020 Filipe Coelho <falktx@falktx.com>
- *
- * This program 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 any later version.
- *
- * This program 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.
- *
- * For a full copy of the GNU General Public License see the doc/GPL.txt file.
- */
-
- #ifndef CARLA_BACKEND_H_INCLUDED
- #define CARLA_BACKEND_H_INCLUDED
-
- #include "CarlaDefines.h"
-
- #ifdef CARLA_PROPER_CPP11_SUPPORT
- # include <cstdint>
- #else
- # include <stdint.h>
- #endif
-
- #define STR_MAX 0xFF
-
- #ifdef __cplusplus
- # define CARLA_BACKEND_START_NAMESPACE namespace CarlaBackend {
- # define CARLA_BACKEND_END_NAMESPACE }
- # define CARLA_BACKEND_USE_NAMESPACE using namespace CarlaBackend;
- # include <algorithm>
- # include <cmath>
- # include <limits>
- /* Start namespace */
- CARLA_BACKEND_START_NAMESPACE
- #endif
-
- /*!
- * @defgroup CarlaBackendAPI Carla Backend API
- *
- * The Carla Backend API.
- *
- * These are the base definitions for everything in the Carla backend code.
- * @{
- */
-
- /* ------------------------------------------------------------------------------------------------------------
- * Carla Backend API (base definitions) */
-
- /*!
- * Maximum default number of loadable plugins.
- */
- static const uint MAX_DEFAULT_PLUGINS = 512;
-
- /*!
- * Maximum number of loadable plugins in rack mode.
- */
- static const uint MAX_RACK_PLUGINS = 64;
-
- /*!
- * Maximum number of loadable plugins in patchbay mode.
- */
- static const uint MAX_PATCHBAY_PLUGINS = 255;
-
- /*!
- * Maximum default number of parameters allowed.
- * @see ENGINE_OPTION_MAX_PARAMETERS
- */
- static const uint MAX_DEFAULT_PARAMETERS = 200;
-
- /*!
- * The "plugin Id" for the global Carla instance.
- * Currently only used for audio peaks.
- */
- static const uint MAIN_CARLA_PLUGIN_ID = 0xFFFF;
-
- /* ------------------------------------------------------------------------------------------------------------
- * Engine Driver Device Hints */
-
- /*!
- * @defgroup EngineDriverHints Engine Driver Device Hints
- *
- * Various engine driver device hints.
- * @see CarlaEngine::getHints(), CarlaEngine::getDriverDeviceInfo() and carla_get_engine_driver_device_info()
- * @{
- */
-
- /*!
- * Engine driver device has custom control-panel.
- */
- static const uint ENGINE_DRIVER_DEVICE_HAS_CONTROL_PANEL = 0x1;
-
- /*!
- * Engine driver device can use a triple-buffer (3 number of periods instead of the usual 2).
- * @see ENGINE_OPTION_AUDIO_NUM_PERIODS
- */
- static const uint ENGINE_DRIVER_DEVICE_CAN_TRIPLE_BUFFER = 0x2;
-
- /*!
- * Engine driver device can change buffer-size on the fly.
- * @see ENGINE_OPTION_AUDIO_BUFFER_SIZE
- */
- static const uint ENGINE_DRIVER_DEVICE_VARIABLE_BUFFER_SIZE = 0x4;
-
- /*!
- * Engine driver device can change sample-rate on the fly.
- * @see ENGINE_OPTION_AUDIO_SAMPLE_RATE
- */
- static const uint ENGINE_DRIVER_DEVICE_VARIABLE_SAMPLE_RATE = 0x8;
-
- /** @} */
-
- /* ------------------------------------------------------------------------------------------------------------
- * Plugin Hints */
-
- /*!
- * @defgroup PluginHints Plugin Hints
- *
- * Various plugin hints.
- * @see CarlaPlugin::getHints() and carla_get_plugin_info()
- * @{
- */
-
- /*!
- * Plugin is a bridge.
- * This hint is required because "bridge" itself is not a plugin type.
- */
- static const uint PLUGIN_IS_BRIDGE = 0x001;
-
- /*!
- * Plugin is hard real-time safe.
- */
- static const uint PLUGIN_IS_RTSAFE = 0x002;
-
- /*!
- * Plugin is a synth (produces sound).
- */
- static const uint PLUGIN_IS_SYNTH = 0x004;
-
- /*!
- * Plugin has its own custom UI.
- * @see CarlaPlugin::showCustomUI() and carla_show_custom_ui()
- */
- static const uint PLUGIN_HAS_CUSTOM_UI = 0x008;
-
- /*!
- * Plugin can use internal Dry/Wet control.
- */
- static const uint PLUGIN_CAN_DRYWET = 0x010;
-
- /*!
- * Plugin can use internal Volume control.
- */
- static const uint PLUGIN_CAN_VOLUME = 0x020;
-
- /*!
- * Plugin can use internal (Stereo) Balance controls.
- */
- static const uint PLUGIN_CAN_BALANCE = 0x040;
-
- /*!
- * Plugin can use internal (Mono) Panning control.
- */
- static const uint PLUGIN_CAN_PANNING = 0x080;
-
- /*!
- * Plugin needs a constant, fixed-size audio buffer.
- */
- static const uint PLUGIN_NEEDS_FIXED_BUFFERS = 0x100;
-
- /*!
- * Plugin needs to receive all UI events in the main thread.
- */
- static const uint PLUGIN_NEEDS_UI_MAIN_THREAD = 0x200;
-
- /*!
- * Plugin uses 1 program per MIDI channel.
- * @note: Only used in some internal plugins and sf2 files.
- */
- static const uint PLUGIN_USES_MULTI_PROGS = 0x400;
-
- /*!
- * Plugin can make use of inline display API.
- */
- static const uint PLUGIN_HAS_INLINE_DISPLAY = 0x800;
-
- /*!
- * Plugin has its own custom UI which can be embed into another Window.
- * @see CarlaPlugin::embedCustomUI() and carla_embed_custom_ui()
- * @note This is very experimental and subject to change at this point
- */
- static const uint PLUGIN_HAS_CUSTOM_EMBED_UI = 0x1000;
-
- /** @} */
-
- /* ------------------------------------------------------------------------------------------------------------
- * Plugin Options */
-
- /*!
- * @defgroup PluginOptions Plugin Options
- *
- * Various plugin options.
- * @note Do not modify these values, as they are saved as-is in project files.
- * @see CarlaPlugin::getOptionsAvailable(), CarlaPlugin::getOptionsEnabled(), carla_get_plugin_info() and carla_set_option()
- * @{
- */
-
- /*!
- * Use constant/fixed-size audio buffers.
- */
- static const uint PLUGIN_OPTION_FIXED_BUFFERS = 0x001;
-
- /*!
- * Force mono plugin as stereo.
- */
- static const uint PLUGIN_OPTION_FORCE_STEREO = 0x002;
-
- /*!
- * Map MIDI programs to plugin programs.
- */
- static const uint PLUGIN_OPTION_MAP_PROGRAM_CHANGES = 0x004;
-
- /*!
- * Use chunks to save and restore data instead of parameter values.
- */
- static const uint PLUGIN_OPTION_USE_CHUNKS = 0x008;
-
- /*!
- * Send MIDI control change events.
- */
- static const uint PLUGIN_OPTION_SEND_CONTROL_CHANGES = 0x010;
-
- /*!
- * Send MIDI channel pressure events.
- */
- static const uint PLUGIN_OPTION_SEND_CHANNEL_PRESSURE = 0x020;
-
- /*!
- * Send MIDI note after-touch events.
- */
- static const uint PLUGIN_OPTION_SEND_NOTE_AFTERTOUCH = 0x040;
-
- /*!
- * Send MIDI pitch-bend events.
- */
- static const uint PLUGIN_OPTION_SEND_PITCHBEND = 0x080;
-
- /*!
- * Send MIDI all-sounds/notes-off events, single note-offs otherwise.
- */
- static const uint PLUGIN_OPTION_SEND_ALL_SOUND_OFF = 0x100;
-
- /*!
- * Send MIDI bank/program changes.
- * @note: This option conflicts with PLUGIN_OPTION_MAP_PROGRAM_CHANGES and cannot be used at the same time.
- */
- static const uint PLUGIN_OPTION_SEND_PROGRAM_CHANGES = 0x200;
-
- /*!
- * Skip sending MIDI note events.
- * This if off-by-default as a way to keep backwards compatibility.
- * We always want notes enabled by default, not the contrary.
- */
- static const uint PLUGIN_OPTION_SKIP_SENDING_NOTES = 0x400;
-
- /*!
- * Special flag to indicate that plugin options are not yet set.
- * This flag exists because 0x0 as an option value is a valid one, so we need something else to indicate "null-ness".
- */
- static const uint PLUGIN_OPTIONS_NULL = 0x10000;
-
- /** @} */
-
- /* ------------------------------------------------------------------------------------------------------------
- * Parameter Hints */
-
- /*!
- * @defgroup ParameterHints Parameter Hints
- *
- * Various parameter hints.
- * @see CarlaPlugin::getParameterData() and carla_get_parameter_data()
- * @{
- */
-
- /*!
- * Parameter value is boolean.
- * It's always at either minimum or maximum value.
- */
- static const uint PARAMETER_IS_BOOLEAN = 0x001;
-
- /*!
- * Parameter value is integer.
- */
- static const uint PARAMETER_IS_INTEGER = 0x002;
-
- /*!
- * Parameter value is logarithmic.
- */
- static const uint PARAMETER_IS_LOGARITHMIC = 0x004;
-
- /*!
- * Parameter is enabled.
- * It can be viewed, changed and stored.
- */
- static const uint PARAMETER_IS_ENABLED = 0x010;
-
- /*!
- * Parameter is automable (real-time safe).
- */
- static const uint PARAMETER_IS_AUTOMABLE = 0x020;
-
- /*!
- * Parameter is read-only.
- * It cannot be changed.
- */
- static const uint PARAMETER_IS_READ_ONLY = 0x040;
-
- /*!
- * Parameter needs sample rate to work.
- * Value and ranges are multiplied by sample rate on usage and divided by sample rate on save.
- */
- static const uint PARAMETER_USES_SAMPLERATE = 0x100;
-
- /*!
- * Parameter uses scale points to define internal values in a meaningful way.
- */
- static const uint PARAMETER_USES_SCALEPOINTS = 0x200;
-
- /*!
- * Parameter uses custom text for displaying its value.
- * @see CarlaPlugin::getParameterText() and carla_get_parameter_text()
- */
- static const uint PARAMETER_USES_CUSTOM_TEXT = 0x400;
-
- /*!
- * Parameter can be turned into a CV control.
- */
- static const uint PARAMETER_CAN_BE_CV_CONTROLLED = 0x800;
-
- /*!
- * Parameter should not be saved as part of the project/session.
- * @note only valid for parameter inputs.
- */
- static const uint PARAMETER_IS_NOT_SAVED = 0x1000;
-
- /** @} */
-
- /* ------------------------------------------------------------------------------------------------------------
- * Mapped Parameter Flags */
-
- /*!
- * @defgroup MappedParameterFlags Mapped Parameter Flags
- *
- * Various flags for parameter mappings.
- * @see ParameterData::mappedFlags
- * @{
- */
-
- /*!
- * Parameter mapping uses delta value instead of full scale.
- * Only relevant for MIDI CC mappings.
- */
- static const uint PARAMETER_MAPPING_MIDI_DELTA = 0x001;
-
- /** @} */
-
- /* ------------------------------------------------------------------------------------------------------------
- * Patchbay Port Hints */
-
- /*!
- * @defgroup PatchbayPortHints Patchbay Port Hints
- *
- * Various patchbay port hints.
- * @{
- */
-
- /*!
- * Patchbay port is input.
- * When this hint is not set, port is assumed to be output.
- */
- static const uint PATCHBAY_PORT_IS_INPUT = 0x01;
-
- /*!
- * Patchbay port is of Audio type.
- */
- static const uint PATCHBAY_PORT_TYPE_AUDIO = 0x02;
-
- /*!
- * Patchbay port is of CV type (Control Voltage).
- */
- static const uint PATCHBAY_PORT_TYPE_CV = 0x04;
-
- /*!
- * Patchbay port is of MIDI type.
- */
- static const uint PATCHBAY_PORT_TYPE_MIDI = 0x08;
-
- /*!
- * Patchbay port is of OSC type.
- */
- static const uint PATCHBAY_PORT_TYPE_OSC = 0x10;
-
- /** @} */
-
- /* ------------------------------------------------------------------------------------------------------------
- * Patchbay Port Group Hints */
-
- /*!
- * @defgroup PatchbayPortGroupHints Patchbay Port Group Hints
- *
- * Various patchbay port group hints.
- * @{
- */
-
- /*!
- * Indicates that this group should be considered the "main" input.
- */
- static const uint PATCHBAY_PORT_GROUP_MAIN_INPUT = 0x01;
-
- /*!
- * Indicates that this group should be considered the "main" output.
- */
- static const uint PATCHBAY_PORT_GROUP_MAIN_OUTPUT = 0x02;
-
- /*!
- * A stereo port group, where the 1st port is left and the 2nd is right.
- */
- static const uint PATCHBAY_PORT_GROUP_STEREO = 0x04;
-
- /*!
- * A mid-side stereo group, where the 1st port is center and the 2nd is side.
- */
- static const uint PATCHBAY_PORT_GROUP_MID_SIDE = 0x08;
-
- /** @} */
-
- /* ------------------------------------------------------------------------------------------------------------
- * Custom Data Types */
-
- /*!
- * @defgroup CustomDataTypes Custom Data Types
- *
- * These types define how the value in the CustomData struct is stored.
- * @see CustomData::type
- * @{
- */
-
- /*!
- * Boolean string type URI.
- * Only "true" and "false" are valid values.
- */
- static const char* const CUSTOM_DATA_TYPE_BOOLEAN = "http://kxstudio.sf.net/ns/carla/boolean";
-
- /*!
- * Chunk type URI.
- */
- static const char* const CUSTOM_DATA_TYPE_CHUNK = "http://kxstudio.sf.net/ns/carla/chunk";
-
- /*!
- * Property type URI.
- */
- static const char* const CUSTOM_DATA_TYPE_PROPERTY = "http://kxstudio.sf.net/ns/carla/property";
-
- /*!
- * String type URI.
- */
- static const char* const CUSTOM_DATA_TYPE_STRING = "http://kxstudio.sf.net/ns/carla/string";
-
- /** @} */
-
- /* ------------------------------------------------------------------------------------------------------------
- * Custom Data Keys */
-
- /*!
- * @defgroup CustomDataKeys Custom Data Keys
- *
- * Pre-defined keys used internally in Carla.
- * @see CustomData::key
- * @{
- */
-
- /*!
- * UI position key.
- */
- static const char* const CUSTOM_DATA_KEY_UI_POSITION = "CarlaUiPosition";
-
- /*!
- * UI size key.
- */
- static const char* const CUSTOM_DATA_KEY_UI_SIZE = "CarlaUiSize";
-
- /*!
- * UI visible key.
- */
- static const char* const CUSTOM_DATA_KEY_UI_VISIBLE = "CarlaUiVisible";
-
- /** @} */
-
- /* ------------------------------------------------------------------------------------------------------------
- * Binary Type */
-
- /*!
- * The binary type of a plugin.
- */
- typedef enum {
- /*!
- * Null binary type.
- */
- BINARY_NONE = 0,
-
- /*!
- * POSIX 32bit binary.
- */
- BINARY_POSIX32 = 1,
-
- /*!
- * POSIX 64bit binary.
- */
- BINARY_POSIX64 = 2,
-
- /*!
- * Windows 32bit binary.
- */
- BINARY_WIN32 = 3,
-
- /*!
- * Windows 64bit binary.
- */
- BINARY_WIN64 = 4,
-
- /*!
- * Other binary type.
- */
- BINARY_OTHER = 5
-
- } BinaryType;
-
- /* ------------------------------------------------------------------------------------------------------------
- * File Type */
-
- /*!
- * File type.
- */
- typedef enum {
- /*!
- * Null file type.
- */
- FILE_NONE = 0,
-
- /*!
- * Audio file.
- */
- FILE_AUDIO = 1,
-
- /*!
- * MIDI file.
- */
- FILE_MIDI = 2
-
- } FileType;
-
- /* ------------------------------------------------------------------------------------------------------------
- * Plugin Type */
-
- /*!
- * Plugin type.
- * Some files are handled as if they were plugins.
- */
- typedef enum {
- /*!
- * Null plugin type.
- */
- PLUGIN_NONE = 0,
-
- /*!
- * Internal plugin.
- */
- PLUGIN_INTERNAL = 1,
-
- /*!
- * LADSPA plugin.
- */
- PLUGIN_LADSPA = 2,
-
- /*!
- * DSSI plugin.
- */
- PLUGIN_DSSI = 3,
-
- /*!
- * LV2 plugin.
- */
- PLUGIN_LV2 = 4,
-
- /*!
- * VST2 plugin.
- */
- PLUGIN_VST2 = 5,
-
- /*!
- * VST3 plugin.
- * @note Windows and MacOS only
- */
- PLUGIN_VST3 = 6,
-
- /*!
- * AU plugin.
- * @note MacOS only
- */
- PLUGIN_AU = 7,
-
- /*!
- * DLS file.
- */
- PLUGIN_DLS = 8,
-
- /*!
- * GIG file.
- */
- PLUGIN_GIG = 9,
-
- /*!
- * SF2/3 file (SoundFont).
- */
- PLUGIN_SF2 = 10,
-
- /*!
- * SFZ file.
- */
- PLUGIN_SFZ = 11,
-
- /*!
- * JACK application.
- */
- PLUGIN_JACK = 12
-
- } PluginType;
-
- /* ------------------------------------------------------------------------------------------------------------
- * Plugin Category */
-
- /*!
- * Plugin category, which describes the functionality of a plugin.
- */
- typedef enum {
- /*!
- * Null plugin category.
- */
- PLUGIN_CATEGORY_NONE = 0,
-
- /*!
- * A synthesizer or generator.
- */
- PLUGIN_CATEGORY_SYNTH = 1,
-
- /*!
- * A delay or reverb.
- */
- PLUGIN_CATEGORY_DELAY = 2,
-
- /*!
- * An equalizer.
- */
- PLUGIN_CATEGORY_EQ = 3,
-
- /*!
- * A filter.
- */
- PLUGIN_CATEGORY_FILTER = 4,
-
- /*!
- * A distortion plugin.
- */
- PLUGIN_CATEGORY_DISTORTION = 5,
-
- /*!
- * A 'dynamic' plugin (amplifier, compressor, gate, etc).
- */
- PLUGIN_CATEGORY_DYNAMICS = 6,
-
- /*!
- * A 'modulator' plugin (chorus, flanger, phaser, etc).
- */
- PLUGIN_CATEGORY_MODULATOR = 7,
-
- /*!
- * An 'utility' plugin (analyzer, converter, mixer, etc).
- */
- PLUGIN_CATEGORY_UTILITY = 8,
-
- /*!
- * Miscellaneous plugin (used to check if the plugin has a category).
- */
- PLUGIN_CATEGORY_OTHER = 9
-
- } PluginCategory;
-
- /* ------------------------------------------------------------------------------------------------------------
- * Parameter Type */
-
- /*!
- * Plugin parameter type.
- */
- typedef enum {
- /*!
- * Null parameter type.
- */
- PARAMETER_UNKNOWN = 0,
-
- /*!
- * Input parameter.
- */
- PARAMETER_INPUT = 1,
-
- /*!
- * Output parameter.
- */
- PARAMETER_OUTPUT = 2
-
- } ParameterType;
-
- /* ------------------------------------------------------------------------------------------------------------
- * Internal Parameter Index */
-
- /*!
- * Special parameters used internally in Carla.
- * Plugins do not know about their existence.
- */
- typedef enum {
- /*!
- * Null parameter.
- */
- PARAMETER_NULL = -1,
-
- #ifndef BUILD_BRIDGE_ALTERNATIVE_ARCH
- /*!
- * Active parameter, boolean type.
- * Default is 'false'.
- */
- PARAMETER_ACTIVE = -2,
-
- /*!
- * Dry/Wet parameter.
- * Range 0.0...1.0; default is 1.0.
- */
- PARAMETER_DRYWET = -3,
-
- /*!
- * Volume parameter.
- * Range 0.0...1.27; default is 1.0.
- */
- PARAMETER_VOLUME = -4,
-
- /*!
- * Stereo Balance-Left parameter.
- * Range -1.0...1.0; default is -1.0.
- */
- PARAMETER_BALANCE_LEFT = -5,
-
- /*!
- * Stereo Balance-Right parameter.
- * Range -1.0...1.0; default is 1.0.
- */
- PARAMETER_BALANCE_RIGHT = -6,
-
- /*!
- * Mono Panning parameter.
- * Range -1.0...1.0; default is 0.0.
- */
- PARAMETER_PANNING = -7,
-
- /*!
- * MIDI Control channel, integer type.
- * Range -1...15 (-1 = off).
- */
- PARAMETER_CTRL_CHANNEL = -8,
- #endif
-
- /*!
- * Max value, defined only for convenience.
- */
- PARAMETER_MAX = -9
-
- } InternalParameterIndex;
-
- /* ------------------------------------------------------------------------------------------------------------
- * Special Mapped Control Index */
-
- /*!
- * Specially designated mapped control indexes.
- * Values between 0 and 119 (0x77) are reserved for MIDI CC, which uses direct values.
- * @see ParameterData::mappedControlIndex
- */
- typedef enum {
- /*!
- * Unused control index, meaning no mapping is enabled.
- */
- CONTROL_INDEX_NONE = -1,
-
- /*!
- * CV control index, meaning the parameter is exposed as CV port.
- */
- CONTROL_INDEX_CV = 130,
-
- /*!
- * Special value to indicate MIDI pitchbend.
- */
- CONTROL_INDEX_MIDI_PITCHBEND = 131,
-
- /*!
- * Special value to indicate MIDI learn.
- */
- CONTROL_INDEX_MIDI_LEARN = 132,
-
- /*!
- * Highest index allowed for mappings.
- */
- CONTROL_INDEX_MAX_ALLOWED = CONTROL_INDEX_MIDI_LEARN
-
- } SpecialMappedControlIndex;
-
- /* ------------------------------------------------------------------------------------------------------------
- * Engine Callback Opcode */
-
- /*!
- * Engine callback opcodes.
- * Front-ends must never block indefinitely during a callback.
- * @see EngineCallbackFunc, CarlaEngine::setCallback() and carla_set_engine_callback()
- */
- typedef enum {
- /*!
- * Debug.
- * This opcode is undefined and used only for testing purposes.
- */
- ENGINE_CALLBACK_DEBUG = 0,
-
- /*!
- * A plugin has been added.
- * @a pluginId Plugin Id
- * @a valueStr Plugin name
- */
- ENGINE_CALLBACK_PLUGIN_ADDED = 1,
-
- /*!
- * A plugin has been removed.
- * @a pluginId Plugin Id
- */
- ENGINE_CALLBACK_PLUGIN_REMOVED = 2,
-
- /*!
- * A plugin has been renamed.
- * @a pluginId Plugin Id
- * @a valueStr New plugin name
- */
- ENGINE_CALLBACK_PLUGIN_RENAMED = 3,
-
- /*!
- * A plugin has become unavailable.
- * @a pluginId Plugin Id
- * @a valueStr Related error string
- */
- ENGINE_CALLBACK_PLUGIN_UNAVAILABLE = 4,
-
- /*!
- * A parameter value has changed.
- * @a pluginId Plugin Id
- * @a value1 Parameter index
- * @a valuef New parameter value
- */
- ENGINE_CALLBACK_PARAMETER_VALUE_CHANGED = 5,
-
- /*!
- * A parameter default has changed.
- * @a pluginId Plugin Id
- * @a value1 Parameter index
- * @a valuef New default value
- */
- ENGINE_CALLBACK_PARAMETER_DEFAULT_CHANGED = 6,
-
- #ifndef BUILD_BRIDGE_ALTERNATIVE_ARCH
- /*!
- * A parameter's mapped control index has changed.
- * @a pluginId Plugin Id
- * @a value1 Parameter index
- * @a value2 New control index
- */
- ENGINE_CALLBACK_PARAMETER_MAPPED_CONTROL_INDEX_CHANGED = 7,
-
- /*!
- * A parameter's MIDI channel has changed.
- * @a pluginId Plugin Id
- * @a value1 Parameter index
- * @a value2 New MIDI channel
- */
- ENGINE_CALLBACK_PARAMETER_MIDI_CHANNEL_CHANGED = 8,
-
- /*!
- * A plugin option has changed.
- * @a pluginId Plugin Id
- * @a value1 Option
- * @a value2 New on/off state (1 for on, 0 for off)
- * @see PluginOptions
- */
- ENGINE_CALLBACK_OPTION_CHANGED = 9,
- #endif
-
- /*!
- * The current program of a plugin has changed.
- * @a pluginId Plugin Id
- * @a value1 New program index
- */
- ENGINE_CALLBACK_PROGRAM_CHANGED = 10,
-
- /*!
- * The current MIDI program of a plugin has changed.
- * @a pluginId Plugin Id
- * @a value1 New MIDI program index
- */
- ENGINE_CALLBACK_MIDI_PROGRAM_CHANGED = 11,
-
- /*!
- * A plugin's custom UI state has changed.
- * @a pluginId Plugin Id
- * @a value1 New state, as follows:
- * 0: UI is now hidden
- * 1: UI is now visible
- * -1: UI has crashed and should not be shown again
- */
- ENGINE_CALLBACK_UI_STATE_CHANGED = 12,
-
- /*!
- * A note has been pressed.
- * @a pluginId Plugin Id
- * @a value1 Channel
- * @a value2 Note
- * @a value3 Velocity
- */
- ENGINE_CALLBACK_NOTE_ON = 13,
-
- /*!
- * A note has been released.
- * @a pluginId Plugin Id
- * @a value1 Channel
- * @a value2 Note
- */
- ENGINE_CALLBACK_NOTE_OFF = 14,
-
- /*!
- * A plugin needs update.
- * @a pluginId Plugin Id
- */
- ENGINE_CALLBACK_UPDATE = 15,
-
- /*!
- * A plugin's data/information has changed.
- * @a pluginId Plugin Id
- */
- ENGINE_CALLBACK_RELOAD_INFO = 16,
-
- /*!
- * A plugin's parameters have changed.
- * @a pluginId Plugin Id
- */
- ENGINE_CALLBACK_RELOAD_PARAMETERS = 17,
-
- /*!
- * A plugin's programs have changed.
- * @a pluginId Plugin Id
- */
- ENGINE_CALLBACK_RELOAD_PROGRAMS = 18,
-
- /*!
- * A plugin state has changed.
- * @a pluginId Plugin Id
- */
- ENGINE_CALLBACK_RELOAD_ALL = 19,
-
- #ifndef BUILD_BRIDGE_ALTERNATIVE_ARCH
- /*!
- * A patchbay client has been added.
- * @a pluginId Client Id
- * @a value1 Client icon
- * @a value2 Plugin Id (-1 if not a plugin)
- * @a valueStr Client name
- * @see PatchbayIcon
- */
- ENGINE_CALLBACK_PATCHBAY_CLIENT_ADDED = 20,
-
- /*!
- * A patchbay client has been removed.
- * @a pluginId Client Id
- */
- ENGINE_CALLBACK_PATCHBAY_CLIENT_REMOVED = 21,
-
- /*!
- * A patchbay client has been renamed.
- * @a pluginId Client Id
- * @a valueStr New client name
- */
- ENGINE_CALLBACK_PATCHBAY_CLIENT_RENAMED = 22,
-
- /*!
- * A patchbay client data has changed.
- * @a pluginId Client Id
- * @a value1 New icon
- * @a value2 New plugin Id (-1 if not a plugin)
- * @see PatchbayIcon
- */
- ENGINE_CALLBACK_PATCHBAY_CLIENT_DATA_CHANGED = 23,
-
- /*!
- * A patchbay port has been added.
- * @a pluginId Client Id
- * @a value1 Port Id
- * @a value2 Port hints
- * @a value3 Port group Id (0 for none)
- * @a valueStr Port name
- * @see PatchbayPortHints
- */
- ENGINE_CALLBACK_PATCHBAY_PORT_ADDED = 24,
-
- /*!
- * A patchbay port has been removed.
- * @a pluginId Client Id
- * @a value1 Port Id
- */
- ENGINE_CALLBACK_PATCHBAY_PORT_REMOVED = 25,
-
- /*!
- * A patchbay port has changed (like the name or group Id).
- * @a pluginId Client Id
- * @a value1 Port Id
- * @a value2 Port hints
- * @a value3 Port group Id (0 for none)
- * @a valueStr Port name
- */
- ENGINE_CALLBACK_PATCHBAY_PORT_CHANGED = 26,
-
- /*!
- * A patchbay connection has been added.
- * @a pluginId Connection Id
- * @a valueStr Out group and port plus in group and port, in "og:op:ig:ip" syntax.
- */
- ENGINE_CALLBACK_PATCHBAY_CONNECTION_ADDED = 27,
-
- /*!
- * A patchbay connection has been removed.
- * @a pluginId Connection Id
- */
- ENGINE_CALLBACK_PATCHBAY_CONNECTION_REMOVED = 28,
- #endif
-
- /*!
- * Engine started.
- * @a pluginId How many plugins are known to be running
- * @a value1 Process mode
- * @a value2 Transport mode
- * @a value3 Buffer size
- * @a valuef Sample rate
- * @a valuestr Engine driver
- * @see EngineProcessMode
- * @see EngineTransportMode
- */
- ENGINE_CALLBACK_ENGINE_STARTED = 29,
-
- /*!
- * Engine stopped.
- */
- ENGINE_CALLBACK_ENGINE_STOPPED = 30,
-
- /*!
- * Engine process mode has changed.
- * @a value1 New process mode
- * @see EngineProcessMode
- */
- ENGINE_CALLBACK_PROCESS_MODE_CHANGED = 31,
-
- /*!
- * Engine transport mode has changed.
- * @a value1 New transport mode
- * @a valueStr New transport features enabled
- * @see EngineTransportMode
- */
- ENGINE_CALLBACK_TRANSPORT_MODE_CHANGED = 32,
-
- /*!
- * Engine buffer-size changed.
- * @a value1 New buffer size
- */
- ENGINE_CALLBACK_BUFFER_SIZE_CHANGED = 33,
-
- /*!
- * Engine sample-rate changed.
- * @a valuef New sample rate
- */
- ENGINE_CALLBACK_SAMPLE_RATE_CHANGED = 34,
-
- /*!
- * A cancelable action has been started or stopped.
- * @a pluginId Plugin Id the action relates to, -1 for none
- * @a value1 1 for action started, 0 for stopped
- * @a valueStr Action name
- */
- ENGINE_CALLBACK_CANCELABLE_ACTION = 35,
-
- /*!
- * Project has finished loading.
- */
- ENGINE_CALLBACK_PROJECT_LOAD_FINISHED = 36,
-
- /*!
- * NSM callback, to be handled by a frontend.
- * Frontend must call carla_nsm_ready() with opcode as parameter as a response
- * @a value1 NSM opcode
- * @a value2 Integer value
- * @a valueStr String value
- * @see NsmCallbackOpcode
- */
- ENGINE_CALLBACK_NSM = 37,
-
- /*!
- * Idle frontend.
- * This is used by the engine during long operations that might block the frontend,
- * giving it the possibility to idle while the operation is still in place.
- */
- ENGINE_CALLBACK_IDLE = 38,
-
- /*!
- * Show a message as information.
- * @a valueStr The message
- */
- ENGINE_CALLBACK_INFO = 39,
-
- /*!
- * Show a message as an error.
- * @a valueStr The message
- */
- ENGINE_CALLBACK_ERROR = 40,
-
- /*!
- * The engine has crashed or malfunctioned and will no longer work.
- */
- ENGINE_CALLBACK_QUIT = 41,
-
- /*!
- * A plugin requested for its inline display to be redrawn.
- * @a pluginId Plugin Id to redraw
- */
- ENGINE_CALLBACK_INLINE_DISPLAY_REDRAW = 42,
-
- /*!
- * A patchbay port group has been added.
- * @a pluginId Client Id
- * @a value1 Group Id (unique value within this client)
- * @a value2 Group hints
- * @a valueStr Group name
- * @see PatchbayPortGroupHints
- */
- ENGINE_CALLBACK_PATCHBAY_PORT_GROUP_ADDED = 43,
-
- /*!
- * A patchbay port group has been removed.
- * @a pluginId Client Id
- * @a value1 Group Id
- */
- ENGINE_CALLBACK_PATCHBAY_PORT_GROUP_REMOVED = 44,
-
- /*!
- * A patchbay port group has changed.
- * @a pluginId Client Id
- * @a value1 Group Id
- * @a value2 Group hints
- * @a valueStr Group name
- * @see PatchbayPortGroupHints
- */
- ENGINE_CALLBACK_PATCHBAY_PORT_GROUP_CHANGED = 45,
-
- /*!
- * A parameter's mapped range has changed.
- * @a pluginId Plugin Id
- * @a value1 Parameter index
- * @a valueStr New mapped range as "%f:%f" syntax
- */
- ENGINE_CALLBACK_PARAMETER_MAPPED_RANGE_CHANGED = 46,
-
- /*!
- * A patchbay client position has changed.
- * @a pluginId Client Id
- * @a value1 X position 1
- * @a value2 Y position 1
- * @a value3 X position 2
- * @a valuef Y position 2
- */
- ENGINE_CALLBACK_PATCHBAY_CLIENT_POSITION_CHANGED = 47,
-
- /*!
- * A plugin embed UI has been resized.
- * @a pluginId Plugin Id to resize
- * @a value1 New width
- * @a value2 New height
- */
- ENGINE_CALLBACK_EMBED_UI_RESIZED = 48
-
- } EngineCallbackOpcode;
-
- /* ------------------------------------------------------------------------------------------------------------
- * NSM Callback Opcode */
-
- /*!
- * NSM callback opcodes.
- * @see ENGINE_CALLBACK_NSM
- */
- typedef enum {
- /*!
- * NSM is available and initialized.
- */
- NSM_CALLBACK_INIT = 0,
-
- /*!
- * Error from NSM side.
- * @a valueInt Error code
- * @a valueStr Error string
- */
- NSM_CALLBACK_ERROR = 1,
-
- /*!
- * Announce message.
- * @a valueInt SM Flags (WIP, to be defined)
- * @a valueStr SM Name
- */
- NSM_CALLBACK_ANNOUNCE = 2,
-
- /*!
- * Open message.
- * @a valueStr Project filename
- */
- NSM_CALLBACK_OPEN = 3,
-
- /*!
- * Save message.
- */
- NSM_CALLBACK_SAVE = 4,
-
- /*!
- * Session-is-loaded message.
- */
- NSM_CALLBACK_SESSION_IS_LOADED = 5,
-
- /*!
- * Show-optional-gui message.
- */
- NSM_CALLBACK_SHOW_OPTIONAL_GUI = 6,
-
- /*!
- * Hide-optional-gui message.
- */
- NSM_CALLBACK_HIDE_OPTIONAL_GUI = 7
-
- } NsmCallbackOpcode;
-
- /* ------------------------------------------------------------------------------------------------------------
- * Engine Option */
-
- /*!
- * Engine options.
- * @see CarlaEngine::getOptions(), CarlaEngine::setOption() and carla_set_engine_option()
- */
- typedef enum {
- /*!
- * Debug.
- * This option is undefined and used only for testing purposes.
- */
- ENGINE_OPTION_DEBUG = 0,
-
- /*!
- * Set the engine processing mode.
- * Default is ENGINE_PROCESS_MODE_MULTIPLE_CLIENTS on Linux and ENGINE_PROCESS_MODE_PATCHBAY for all other OSes.
- * @see EngineProcessMode
- */
- ENGINE_OPTION_PROCESS_MODE = 1,
-
- /*!
- * Set the engine transport mode.
- * Default is ENGINE_TRANSPORT_MODE_JACK on Linux and ENGINE_TRANSPORT_MODE_INTERNAL for all other OSes.
- * @see EngineTransportMode
- */
- ENGINE_OPTION_TRANSPORT_MODE = 2,
-
- /*!
- * Force mono plugins as stereo, by running 2 instances at the same time.
- * Default is false, but always true when process mode is ENGINE_PROCESS_MODE_CONTINUOUS_RACK.
- * @note Not supported by all plugins
- * @see PLUGIN_OPTION_FORCE_STEREO
- */
- ENGINE_OPTION_FORCE_STEREO = 3,
-
- /*!
- * Use plugin bridges whenever possible.
- * Default is no, EXPERIMENTAL.
- */
- ENGINE_OPTION_PREFER_PLUGIN_BRIDGES = 4,
-
- /*!
- * Use UI bridges whenever possible, otherwise UIs will be directly handled in the main backend thread.
- * Default is yes.
- */
- ENGINE_OPTION_PREFER_UI_BRIDGES = 5,
-
- /*!
- * Make custom plugin UIs always-on-top.
- * Default is yes.
- */
- ENGINE_OPTION_UIS_ALWAYS_ON_TOP = 6,
-
- /*!
- * Maximum number of parameters allowed.
- * Default is MAX_DEFAULT_PARAMETERS.
- */
- ENGINE_OPTION_MAX_PARAMETERS = 7,
-
- /*!
- * Reset Xrun counter after project load.
- */
- ENGINE_OPTION_RESET_XRUNS = 8,
-
- /*!
- * Timeout value for how much to wait for UI bridges to respond, in milliseconds.
- * Default is 4000 (4 seconds).
- */
- ENGINE_OPTION_UI_BRIDGES_TIMEOUT = 9,
-
- /*!
- * Audio buffer size.
- * Default is 512.
- */
- ENGINE_OPTION_AUDIO_BUFFER_SIZE = 10,
-
- /*!
- * Audio sample rate.
- * Default is 44100.
- */
- ENGINE_OPTION_AUDIO_SAMPLE_RATE = 11,
-
- /*!
- * Wherever to use 3 audio periods instead of the default 2.
- * Default is false.
- */
- ENGINE_OPTION_AUDIO_TRIPLE_BUFFER = 12,
-
- /*!
- * Audio driver.
- * Default depends on platform.
- */
- ENGINE_OPTION_AUDIO_DRIVER = 13,
-
- /*!
- * Audio device (within a driver).
- * Default unset.
- */
- ENGINE_OPTION_AUDIO_DEVICE = 14,
-
- /*!
- * Wherever to enable OSC support in the engine.
- */
- ENGINE_OPTION_OSC_ENABLED = 15,
-
- /*!
- * The network TCP port to use for OSC.
- * A value of 0 means use a random port.
- * A value of < 0 means to not enable the TCP port for OSC.
- * @note Valid ports begin at 1024 and end at 32767 (inclusive)
- */
- ENGINE_OPTION_OSC_PORT_TCP = 16,
-
- /*!
- * The network UDP port to use for OSC.
- * A value of 0 means use a random port.
- * A value of < 0 means to not enable the UDP port for OSC.
- * @note Disabling this option prevents DSSI UIs from working!
- * @note Valid ports begin at 1024 and end at 32767 (inclusive)
- */
- ENGINE_OPTION_OSC_PORT_UDP = 17,
-
- /*!
- * Set path used for a specific file type.
- * Uses value as the file format, valueStr as actual path.
- */
- ENGINE_OPTION_FILE_PATH = 18,
-
- /*!
- * Set path used for a specific plugin type.
- * Uses value as the plugin format, valueStr as actual path.
- * @see PluginType
- */
- ENGINE_OPTION_PLUGIN_PATH = 19,
-
- /*!
- * Set path to the binary files.
- * Default unset.
- * @note Must be set for plugin and UI bridges to work
- */
- ENGINE_OPTION_PATH_BINARIES = 20,
-
- /*!
- * Set path to the resource files.
- * Default unset.
- * @note Must be set for some internal plugins to work
- */
- ENGINE_OPTION_PATH_RESOURCES = 21,
-
- /*!
- * Prevent bad plugin and UI behaviour.
- * @note: Linux only
- */
- ENGINE_OPTION_PREVENT_BAD_BEHAVIOUR = 22,
-
- /*!
- * Set background color used in the frontend, so backend can do the same for plugin UIs.
- */
- ENGINE_OPTION_FRONTEND_BACKGROUND_COLOR = 23,
-
- /*!
- * Set foreground color used in the frontend, so backend can do the same for plugin UIs.
- */
- ENGINE_OPTION_FRONTEND_FOREGROUND_COLOR = 24,
-
- /*!
- * Set UI scaling used in the frontend, so backend can do the same for plugin UIs.
- */
- ENGINE_OPTION_FRONTEND_UI_SCALE = 25,
-
- /*!
- * Set frontend winId, used to define as parent window for plugin UIs.
- */
- ENGINE_OPTION_FRONTEND_WIN_ID = 26,
-
- #if !defined(BUILD_BRIDGE_ALTERNATIVE_ARCH) && !defined(CARLA_OS_WIN)
- /*!
- * Set path to wine executable.
- */
- ENGINE_OPTION_WINE_EXECUTABLE = 27,
-
- /*!
- * Enable automatic wineprefix detection.
- */
- ENGINE_OPTION_WINE_AUTO_PREFIX = 28,
-
- /*!
- * Fallback wineprefix to use if automatic detection fails or is disabled, and WINEPREFIX is not set.
- */
- ENGINE_OPTION_WINE_FALLBACK_PREFIX = 29,
-
- /*!
- * Enable realtime priority for Wine application and server threads.
- */
- ENGINE_OPTION_WINE_RT_PRIO_ENABLED = 30,
-
- /*!
- * Base realtime priority for Wine threads.
- */
- ENGINE_OPTION_WINE_BASE_RT_PRIO = 31,
-
- /*!
- * Wine server realtime priority.
- */
- ENGINE_OPTION_WINE_SERVER_RT_PRIO = 32,
- #endif
-
- /*!
- * Capture console output into debug callbacks.
- */
- ENGINE_OPTION_DEBUG_CONSOLE_OUTPUT = 33,
-
- /*!
- * A prefix to give to all plugin clients created by Carla.
- * Mostly useful for JACK multi-client mode.
- * @note MUST include at least one "." (dot).
- */
- ENGINE_OPTION_CLIENT_NAME_PREFIX = 34
-
- } EngineOption;
-
- /* ------------------------------------------------------------------------------------------------------------
- * Engine Process Mode */
-
- /*!
- * Engine process mode.
- * @see ENGINE_OPTION_PROCESS_MODE
- */
- typedef enum {
- /*!
- * Single client mode.
- * Inputs and outputs are added dynamically as needed by plugins.
- */
- ENGINE_PROCESS_MODE_SINGLE_CLIENT = 0,
-
- /*!
- * Multiple client mode.
- * It has 1 master client + 1 client per plugin.
- */
- ENGINE_PROCESS_MODE_MULTIPLE_CLIENTS = 1,
-
- /*!
- * Single client, 'rack' mode.
- * Processes plugins in order of Id, with forced stereo always on.
- */
- ENGINE_PROCESS_MODE_CONTINUOUS_RACK = 2,
-
- /*!
- * Single client, 'patchbay' mode.
- */
- ENGINE_PROCESS_MODE_PATCHBAY = 3,
-
- /*!
- * Special mode, used in plugin-bridges only.
- */
- ENGINE_PROCESS_MODE_BRIDGE = 4
-
- } EngineProcessMode;
-
- /* ------------------------------------------------------------------------------------------------------------
- * Engine Transport Mode */
-
- /*!
- * Engine transport mode.
- * @see ENGINE_OPTION_TRANSPORT_MODE
- */
- typedef enum {
- /*!
- * No transport.
- */
- ENGINE_TRANSPORT_MODE_DISABLED = 0,
-
- /*!
- * Internal transport mode.
- */
- ENGINE_TRANSPORT_MODE_INTERNAL = 1,
-
- /*!
- * Transport from JACK.
- * Only available if driver name is "JACK".
- */
- ENGINE_TRANSPORT_MODE_JACK = 2,
-
- /*!
- * Transport from host, used when Carla is a plugin.
- */
- ENGINE_TRANSPORT_MODE_PLUGIN = 3,
-
- /*!
- * Special mode, used in plugin-bridges only.
- */
- ENGINE_TRANSPORT_MODE_BRIDGE = 4
-
- } EngineTransportMode;
-
- /* ------------------------------------------------------------------------------------------------------------
- * File Callback Opcode */
-
- /*!
- * File callback opcodes.
- * Front-ends must always block-wait for user input.
- * @see FileCallbackFunc, CarlaEngine::setFileCallback() and carla_set_file_callback()
- */
- typedef enum {
- /*!
- * Debug.
- * This opcode is undefined and used only for testing purposes.
- */
- FILE_CALLBACK_DEBUG = 0,
-
- /*!
- * Open file or folder.
- */
- FILE_CALLBACK_OPEN = 1,
-
- /*!
- * Save file or folder.
- */
- FILE_CALLBACK_SAVE = 2
-
- } FileCallbackOpcode;
-
- /* ------------------------------------------------------------------------------------------------------------
- * Patchbay Icon */
-
- /*!
- * The icon of a patchbay client/group.
- */
- enum PatchbayIcon {
- /*!
- * Generic application icon.
- * Used for all non-plugin clients that don't have a specific icon.
- */
- PATCHBAY_ICON_APPLICATION = 0,
-
- /*!
- * Plugin icon.
- * Used for all plugin clients that don't have a specific icon.
- */
- PATCHBAY_ICON_PLUGIN = 1,
-
- /*!
- * Hardware icon.
- * Used for hardware (audio or MIDI) clients.
- */
- PATCHBAY_ICON_HARDWARE = 2,
-
- /*!
- * Carla icon.
- * Used for the main app.
- */
- PATCHBAY_ICON_CARLA = 3,
-
- /*!
- * DISTRHO icon.
- * Used for DISTRHO based plugins.
- */
- PATCHBAY_ICON_DISTRHO = 4,
-
- /*!
- * File icon.
- * Used for file type plugins (like SF2 snd SFZ).
- */
- PATCHBAY_ICON_FILE = 5
- };
-
- /* ------------------------------------------------------------------------------------------------------------
- * Carla Backend API (C stuff) */
-
- /*!
- * Engine callback function.
- * Front-ends must never block indefinitely during a callback.
- * @see EngineCallbackOpcode, CarlaEngine::setCallback() and carla_set_engine_callback()
- */
- typedef void (*EngineCallbackFunc)(void* ptr, EngineCallbackOpcode action, uint pluginId,
- int value1, int value2, int value3,
- float valuef, const char* valueStr);
-
- /*!
- * File callback function.
- * @see FileCallbackOpcode
- */
- typedef const char* (*FileCallbackFunc)(void* ptr, FileCallbackOpcode action, bool isDir, const char* title, const char* filter);
-
- /*!
- * Parameter data.
- */
- typedef struct {
- /*!
- * This parameter type.
- */
- ParameterType type;
-
- /*!
- * This parameter hints.
- * @see ParameterHints
- */
- uint hints;
-
- /*!
- * Index as seen by Carla.
- */
- int32_t index;
-
- /*!
- * Real index as seen by plugins.
- */
- int32_t rindex;
-
- /*!
- * Currently mapped MIDI channel.
- * Counts from 0 to 15.
- */
- uint8_t midiChannel;
-
- /*!
- * Currently mapped index.
- * @see SpecialMappedControlIndex
- */
- int16_t mappedControlIndex;
-
- /*!
- * Minimum value that this parameter maps to.
- */
- float mappedMinimum;
-
- /*!
- * Maximum value that this parameter maps to.
- */
- float mappedMaximum;
-
- /*!
- * Flags related to the current mapping of this parameter.
- * @see MappedParameterFlags
- */
- uint mappedFlags;
-
- } ParameterData;
-
- /*!
- * Parameter ranges.
- */
- typedef struct _ParameterRanges {
- /*!
- * Default value.
- */
- float def;
-
- /*!
- * Minimum value.
- */
- float min;
-
- /*!
- * Maximum value.
- */
- float max;
-
- /*!
- * Regular, single step value.
- */
- float step;
-
- /*!
- * Small step value.
- */
- float stepSmall;
-
- /*!
- * Large step value.
- */
- float stepLarge;
-
- #ifdef __cplusplus
- /*!
- * Fix the default value within range.
- */
- void fixDefault() noexcept
- {
- fixValue(def);
- }
-
- /*!
- * Fix a value within range.
- */
- void fixValue(float& value) const noexcept
- {
- if (value < min)
- value = min;
- else if (value > max)
- value = max;
- }
-
- /*!
- * Get a fixed value within range.
- */
- const float& getFixedValue(const float& value) const noexcept
- {
- if (value <= min)
- return min;
- if (value >= max)
- return max;
- return value;
- }
-
- /*!
- * Get a value normalized to 0.0<->1.0.
- */
- float getNormalizedValue(const float& value) const noexcept
- {
- const float normValue((value - min) / (max - min));
-
- if (normValue <= 0.0f)
- return 0.0f;
- if (normValue >= 1.0f)
- return 1.0f;
- return normValue;
- }
-
- /*!
- * Get a value normalized to 0.0<->1.0, fixed within range.
- */
- float getFixedAndNormalizedValue(const float& value) const noexcept
- {
- if (value <= min)
- return 0.0f;
- if (value >= max)
- return 1.0f;
-
- const float normValue((value - min) / (max - min));
-
- if (normValue <= 0.0f)
- return 0.0f;
- if (normValue >= 1.0f)
- return 1.0f;
-
- return normValue;
- }
-
- /*!
- * Get a proper value previously normalized to 0.0<->1.0.
- */
- float getUnnormalizedValue(const float& value) const noexcept
- {
- if (value <= 0.0f)
- return min;
- if (value >= 1.0f)
- return max;
-
- return value * (max - min) + min;
- }
-
- /*!
- * Get a logarithmic value previously normalized to 0.0<->1.0.
- */
- float getUnnormalizedLogValue(const float& value) const noexcept
- {
- if (value <= 0.0f)
- return min;
- if (value >= 1.0f)
- return max;
-
- float rmin = min;
-
- if (std::abs(min) < std::numeric_limits<float>::epsilon())
- rmin = 0.00001f;
-
- return rmin * std::pow(max/rmin, value);
- }
- #endif /* __cplusplus */
-
- } ParameterRanges;
-
- /*!
- * MIDI Program data.
- */
- typedef struct {
- /*!
- * MIDI bank.
- */
- uint32_t bank;
-
- /*!
- * MIDI program.
- */
- uint32_t program;
-
- /*!
- * MIDI program name.
- */
- const char* name;
-
- } MidiProgramData;
-
- /*!
- * Custom data, used for saving key:value 'dictionaries'.
- */
- typedef struct {
- /*!
- * Value type, in URI form.
- * @see CustomDataTypes
- */
- const char* type;
-
- /*!
- * Key.
- * @see CustomDataKeys
- */
- const char* key;
-
- /*!
- * Value.
- */
- const char* value;
-
- #ifdef __cplusplus
- /*!
- * Check if valid.
- */
- bool isValid() const noexcept
- {
- if (type == nullptr || type[0] == '\0') return false;
- if (key == nullptr || key [0] == '\0') return false;
- if (value == nullptr) return false;
- return true;
- }
- #endif /* __cplusplus */
-
- } CustomData;
-
- /*!
- * Engine driver device information.
- */
- typedef struct {
- /*!
- * This driver device hints.
- * @see EngineDriverHints
- */
- uint hints;
-
- /*!
- * Available buffer sizes.
- * Terminated with 0.
- */
- const uint32_t* bufferSizes;
-
- /*!
- * Available sample rates.
- * Terminated with 0.0.
- */
- const double* sampleRates;
-
- } EngineDriverDeviceInfo;
-
- /** @} */
-
- #ifdef __cplusplus
- /* Forward declarations of commonly used Carla classes */
- class CarlaEngine;
- class CarlaEngineClient;
- class CarlaEngineCVSourcePorts;
- class CarlaPlugin;
- /* End namespace */
- CARLA_BACKEND_END_NAMESPACE
- #endif
-
- #endif /* CARLA_BACKEND_H_INCLUDED */
|