| @@ -84,19 +84,19 @@ typedef enum _ParameterHints { | |||
| typedef enum _PluginDispatcherOpcode { | |||
| PLUGIN_OPCODE_NULL = 0, // nothing | |||
| PLUGIN_OPCODE_BUFFER_SIZE_CHANGED = 1, // nothing | |||
| PLUGIN_OPCODE_SAMPLE_RATE_CHANGED = 2, // nothing | |||
| PLUGIN_OPCODE_OFFLINE_CHANGED = 3, // nothing | |||
| PLUGIN_OPCODE_UI_NAME_CHANGED = 4 // nothing | |||
| PLUGIN_OPCODE_BUFFER_SIZE_CHANGED = 1, // uses value | |||
| PLUGIN_OPCODE_SAMPLE_RATE_CHANGED = 2, // uses opt | |||
| PLUGIN_OPCODE_OFFLINE_CHANGED = 3, // uses value | |||
| PLUGIN_OPCODE_UI_NAME_CHANGED = 4 // uses ptr | |||
| } PluginDispatcherOpcode; | |||
| typedef enum _HostDispatcherOpcode { | |||
| HOST_OPCODE_NULL = 0, // nothing | |||
| HOST_OPCODE_SET_VOLUME = 1, // uses value | |||
| HOST_OPCODE_SET_DRYWET = 2, // uses value | |||
| HOST_OPCODE_SET_BALANCE_LEFT = 3, // uses value | |||
| HOST_OPCODE_SET_BALANCE_RIGHT = 4, // uses value | |||
| HOST_OPCODE_SET_PANNING = 5, // uses value | |||
| HOST_OPCODE_SET_VOLUME = 1, // uses opt | |||
| HOST_OPCODE_SET_DRYWET = 2, // uses opt | |||
| HOST_OPCODE_SET_BALANCE_LEFT = 3, // uses opt | |||
| HOST_OPCODE_SET_BALANCE_RIGHT = 4, // uses opt | |||
| HOST_OPCODE_SET_PANNING = 5, // uses opt | |||
| HOST_OPCODE_SET_PROCESS_PRECISION = 6, // uses value | |||
| HOST_OPCODE_UI_UNAVAILABLE = 7 // nothing | |||
| } HostDispatcherOpcode; | |||
| @@ -184,7 +184,7 @@ typedef struct _HostDescriptor { | |||
| const char* (*ui_open_file)(HostHandle handle, bool isDir, const char* title, const char* filter); | |||
| const char* (*ui_save_file)(HostHandle handle, bool isDir, const char* title, const char* filter); | |||
| intptr_t (*dispatcher)(HostHandle handle, HostDispatcherOpcode opcode, int32_t index, intptr_t value, void* ptr); | |||
| intptr_t (*dispatcher)(HostHandle handle, HostDispatcherOpcode opcode, int32_t index, intptr_t value, void* ptr, float opt); | |||
| } HostDescriptor; | |||
| @@ -232,7 +232,7 @@ typedef struct _PluginDescriptor { | |||
| char* (*get_state)(PluginHandle handle); | |||
| void (*set_state)(PluginHandle handle, const char* data); | |||
| intptr_t (*dispatcher)(PluginHandle handle, PluginDispatcherOpcode opcode, int32_t index, intptr_t value, void* ptr); | |||
| intptr_t (*dispatcher)(PluginHandle handle, PluginDispatcherOpcode opcode, int32_t index, intptr_t value, void* ptr, float opt); | |||
| } PluginDescriptor; | |||
| @@ -169,12 +169,12 @@ protected: | |||
| return nullptr; | |||
| } | |||
| intptr_t hostDispatcher(const HostDispatcherOpcode opcode, const int32_t index, const intptr_t value, void* const ptr) | |||
| intptr_t hostDispatcher(const HostDispatcherOpcode opcode, const int32_t index, const intptr_t value, void* const ptr, const float opt) | |||
| { | |||
| CARLA_ASSERT(kHost != nullptr); | |||
| if (kHost != nullptr) | |||
| return kHost->dispatcher(kHost->handle, opcode, index, value, ptr); | |||
| return kHost->dispatcher(kHost->handle, opcode, index, value, ptr, opt); | |||
| return 0; | |||
| } | |||
| @@ -346,7 +346,7 @@ protected: | |||
| // ------------------------------------------------------------------- | |||
| // Plugin dispatcher | |||
| virtual intptr_t pluginDispatcher(const PluginDispatcherOpcode opcode, const int32_t index, const intptr_t value, void* const ptr) | |||
| virtual intptr_t pluginDispatcher(const PluginDispatcherOpcode opcode, const int32_t index, const intptr_t value, void* const ptr, const float opt) | |||
| { | |||
| return 0; | |||
| @@ -355,6 +355,7 @@ protected: | |||
| (void)index; | |||
| (void)value; | |||
| (void)ptr; | |||
| (void)opt; | |||
| } | |||
| // ------------------------------------------------------------------- | |||
| @@ -463,9 +464,9 @@ public: | |||
| handlePtr->setState(data); | |||
| } | |||
| static intptr_t _dispatcher(PluginHandle handle, PluginDispatcherOpcode opcode, int32_t index, intptr_t value, void* ptr) | |||
| static intptr_t _dispatcher(PluginHandle handle, PluginDispatcherOpcode opcode, int32_t index, intptr_t value, void* ptr, float opt) | |||
| { | |||
| return handlePtr->pluginDispatcher(opcode, index, value, ptr); | |||
| return handlePtr->pluginDispatcher(opcode, index, value, ptr, opt); | |||
| } | |||
| #undef handlePtr | |||
| @@ -50,7 +50,7 @@ static PluginHandle lfo_instantiate(const PluginDescriptor* _this_, HostDescript | |||
| if (handle == NULL) | |||
| return NULL; | |||
| host->dispatcher(host->handle, HOST_OPCODE_SET_PROCESS_PRECISION, 0, 32, NULL); | |||
| host->dispatcher(host->handle, HOST_OPCODE_SET_PROCESS_PRECISION, 0, 32, NULL, 0.0f); | |||
| handle->host = host; | |||
| handle->mode = 1; | |||
| @@ -368,7 +368,7 @@ void nekofilter_ui_show( | |||
| if (nekofilter_ptr->ui != NULL) | |||
| nekoui_show(nekofilter_ptr->ui); | |||
| else | |||
| nekofilter_ptr->host->dispatcher(nekofilter_ptr->host->handle, HOST_OPCODE_UI_UNAVAILABLE, 0, 0, NULL); | |||
| nekofilter_ptr->host->dispatcher(nekofilter_ptr->host->handle, HOST_OPCODE_UI_UNAVAILABLE, 0, 0, NULL, 0.0f); | |||
| } | |||
| else if (nekofilter_ptr->ui != NULL) | |||
| nekoui_hide(nekofilter_ptr->ui); | |||
| @@ -586,7 +586,7 @@ protected: | |||
| kParamCount(paramCount-2), // volume and pan handled by host | |||
| kProgramCount(programCount) | |||
| { | |||
| hostDispatcher(HOST_OPCODE_SET_DRYWET, 0, 0.5f, nullptr); | |||
| hostDispatcher(HOST_OPCODE_SET_DRYWET, 0, 0, nullptr, 0.5f); | |||
| } | |||
| ~FxAbstractPlugin() override | |||
| @@ -646,11 +646,11 @@ protected: | |||
| fEffect->setpreset(program); | |||
| const float volume(float(fEffect->getpar(0))/127.0f); | |||
| hostDispatcher(HOST_OPCODE_SET_VOLUME, 0, volume, nullptr); | |||
| hostDispatcher(HOST_OPCODE_SET_VOLUME, 0, 0, nullptr, volume); | |||
| const unsigned char pan(fEffect->getpar(1)); | |||
| const float panning(float(pan)/63.5f-1.0f); | |||
| hostDispatcher(HOST_OPCODE_SET_PANNING, 0, (pan == 64) ? 0.0f : panning, nullptr); | |||
| hostDispatcher(HOST_OPCODE_SET_PANNING, 0, 0, nullptr, (pan == 64) ? 0.0f : panning); | |||
| } | |||
| // ------------------------------------------------------------------- | |||
| @@ -685,7 +685,7 @@ protected: | |||
| // ------------------------------------------------------------------- | |||
| // Plugin dispatcher | |||
| intptr_t pluginDispatcher(const PluginDispatcherOpcode opcode, const int32_t, const intptr_t, void* const) final | |||
| intptr_t pluginDispatcher(const PluginDispatcherOpcode opcode, const int32_t, const intptr_t, void* const, const float) final | |||
| { | |||
| switch (opcode) | |||
| { | |||
| @@ -1599,7 +1599,7 @@ protected: | |||
| // ------------------------------------------------------------------- | |||
| // Plugin dispatcher | |||
| intptr_t pluginDispatcher(const PluginDispatcherOpcode opcode, const int32_t index, const intptr_t value, void* const ptr) override | |||
| intptr_t pluginDispatcher(const PluginDispatcherOpcode opcode, const int32_t index, const intptr_t value, void* const ptr, const float) override | |||
| { | |||
| switch (opcode) | |||
| { | |||
| @@ -1453,18 +1453,11 @@ void CarlaPlugin::setProgram(int32_t index, const bool sendGui, const bool sendO | |||
| if (index > static_cast<int32_t>(kData->prog.count)) | |||
| return; | |||
| const int32_t fixedIndex(carla_fixValue<int32_t>(-1, kData->prog.count, index)); | |||
| const int32_t fixedIndex = carla_fixValue<int32_t>(-1, kData->prog.count, index); | |||
| kData->prog.current = fixedIndex; | |||
| #ifndef BUILD_BRIDGE | |||
| if (sendOsc) | |||
| kData->engine->osc_send_control_set_program(fId, fixedIndex); | |||
| #endif | |||
| if (sendCallback) | |||
| kData->engine->callback(CALLBACK_PROGRAM_CHANGED, fId, fixedIndex, 0, 0.0f, nullptr); | |||
| // Change default parameter values | |||
| if (fixedIndex >= 0) | |||
| { | |||
| #ifndef BUILD_BRIDGE | |||
| @@ -1472,30 +1465,30 @@ void CarlaPlugin::setProgram(int32_t index, const bool sendGui, const bool sendO | |||
| uiProgramChange(fixedIndex); | |||
| #endif | |||
| if (type() == PLUGIN_GIG || type() == PLUGIN_SF2 || type() == PLUGIN_SFZ) | |||
| return; | |||
| for (uint32_t i=0; i < kData->param.count; ++i) | |||
| { | |||
| const float value(kData->param.ranges[i].fixValue(getParameterValue(i))); | |||
| kData->param.ranges[i].def = value;; | |||
| // FIXME? | |||
| kData->param.ranges[i].def = getParameterValue(i); | |||
| kData->param.ranges[i].fixDefault(); | |||
| #ifndef BUILD_BRIDGE | |||
| if (sendOsc) | |||
| { | |||
| kData->engine->osc_send_control_set_default_value(fId, i, value); | |||
| kData->engine->osc_send_control_set_parameter_value(fId, i, value); | |||
| kData->engine->osc_send_control_set_default_value(fId, i, kData->param.ranges[i].def); | |||
| kData->engine->osc_send_control_set_parameter_value(fId, i, kData->param.ranges[i].def); | |||
| } | |||
| #endif | |||
| if (sendCallback) | |||
| { | |||
| kData->engine->callback(CALLBACK_PARAMETER_VALUE_CHANGED, fId, i, 0, value, nullptr); | |||
| kData->engine->callback(CALLBACK_PARAMETER_DEFAULT_CHANGED, fId, i, 0, value, nullptr); | |||
| } | |||
| } | |||
| } | |||
| #ifndef BUILD_BRIDGE | |||
| if (sendOsc) | |||
| kData->engine->osc_send_control_set_program(fId, fixedIndex); | |||
| #endif | |||
| if (sendCallback) | |||
| kData->engine->callback(CALLBACK_PROGRAM_CHANGED, fId, fixedIndex, 0, 0.0f, nullptr); | |||
| #ifdef BUILD_BRIDGE | |||
| return; | |||
| @@ -1515,18 +1508,10 @@ void CarlaPlugin::setMidiProgram(int32_t index, const bool sendGui, const bool s | |||
| if (index > static_cast<int32_t>(kData->midiprog.count)) | |||
| return; | |||
| const int32_t fixedIndex(carla_fixValue<int32_t>(-1, kData->midiprog.count, index)); | |||
| const int32_t fixedIndex = carla_fixValue<int32_t>(-1, kData->midiprog.count, index); | |||
| kData->midiprog.current = fixedIndex; | |||
| #ifndef BUILD_BRIDGE | |||
| if (sendOsc) | |||
| kData->engine->osc_send_control_set_midi_program(fId, fixedIndex); | |||
| #endif | |||
| if (sendCallback) | |||
| kData->engine->callback(CALLBACK_MIDI_PROGRAM_CHANGED, fId, fixedIndex, 0, 0.0f, nullptr); | |||
| if (fixedIndex >= 0) | |||
| { | |||
| #ifndef BUILD_BRIDGE | |||
| @@ -1534,30 +1519,34 @@ void CarlaPlugin::setMidiProgram(int32_t index, const bool sendGui, const bool s | |||
| uiMidiProgramChange(fixedIndex); | |||
| #endif | |||
| if (type() == PLUGIN_GIG || type() == PLUGIN_SF2 || type() == PLUGIN_SFZ) | |||
| return; | |||
| for (uint32_t i=0; i < kData->param.count; ++i) | |||
| // Change default parameter values (sound banks never change defaults) | |||
| if (type() != PLUGIN_GIG && type() != PLUGIN_SF2 && type() != PLUGIN_SFZ) | |||
| { | |||
| const float value(kData->param.ranges[i].fixValue(getParameterValue(i))); | |||
| kData->param.ranges[i].def = value;; | |||
| for (uint32_t i=0; i < kData->param.count; ++i) | |||
| { | |||
| // FIXME? | |||
| kData->param.ranges[i].def = getParameterValue(i); | |||
| kData->param.ranges[i].fixDefault(); | |||
| #ifndef BUILD_BRIDGE | |||
| if (sendOsc) | |||
| { | |||
| kData->engine->osc_send_control_set_default_value(fId, i, value); | |||
| kData->engine->osc_send_control_set_parameter_value(fId, i, value); | |||
| } | |||
| if (sendOsc) | |||
| { | |||
| kData->engine->osc_send_control_set_default_value(fId, i, kData->param.ranges[i].def); | |||
| kData->engine->osc_send_control_set_parameter_value(fId, i, kData->param.ranges[i].def); | |||
| } | |||
| #endif | |||
| if (sendCallback) | |||
| { | |||
| kData->engine->callback(CALLBACK_PARAMETER_VALUE_CHANGED, fId, i, 0, value, nullptr); | |||
| kData->engine->callback(CALLBACK_PARAMETER_DEFAULT_CHANGED, fId, i, 0, value, nullptr); | |||
| } | |||
| } | |||
| } | |||
| #ifndef BUILD_BRIDGE | |||
| if (sendOsc) | |||
| kData->engine->osc_send_control_set_midi_program(fId, fixedIndex); | |||
| #endif | |||
| if (sendCallback) | |||
| kData->engine->callback(CALLBACK_MIDI_PROGRAM_CHANGED, fId, fixedIndex, 0, 0.0f, nullptr); | |||
| #ifdef BUILD_BRIDGE | |||
| return; | |||
| @@ -1885,10 +1885,10 @@ public: | |||
| if (fDescriptor != nullptr && fDescriptor->dispatcher != nullptr) | |||
| { | |||
| fDescriptor->dispatcher(fHandle, PLUGIN_OPCODE_BUFFER_SIZE_CHANGED, 0, 0, nullptr); | |||
| fDescriptor->dispatcher(fHandle, PLUGIN_OPCODE_BUFFER_SIZE_CHANGED, 0, newBufferSize, nullptr, 0.0f); | |||
| if (fHandle2 != nullptr) | |||
| fDescriptor->dispatcher(fHandle2, PLUGIN_OPCODE_BUFFER_SIZE_CHANGED, 0, 0, nullptr); | |||
| fDescriptor->dispatcher(fHandle2, PLUGIN_OPCODE_BUFFER_SIZE_CHANGED, 0, newBufferSize, nullptr, 0.0f); | |||
| } | |||
| } | |||
| @@ -1899,21 +1899,21 @@ public: | |||
| if (fDescriptor != nullptr && fDescriptor->dispatcher != nullptr) | |||
| { | |||
| fDescriptor->dispatcher(fHandle, PLUGIN_OPCODE_SAMPLE_RATE_CHANGED, 0, 0, nullptr); | |||
| fDescriptor->dispatcher(fHandle, PLUGIN_OPCODE_SAMPLE_RATE_CHANGED, 0, 0, nullptr, newSampleRate); | |||
| if (fHandle2 != nullptr) | |||
| fDescriptor->dispatcher(fHandle2, PLUGIN_OPCODE_SAMPLE_RATE_CHANGED, 0, 0, nullptr); | |||
| fDescriptor->dispatcher(fHandle2, PLUGIN_OPCODE_SAMPLE_RATE_CHANGED, 0, 0, nullptr, newSampleRate); | |||
| } | |||
| } | |||
| void offlineModeChanged(const bool) override | |||
| void offlineModeChanged(const bool isOffline) override | |||
| { | |||
| if (fDescriptor != nullptr && fDescriptor->dispatcher != nullptr) | |||
| { | |||
| fDescriptor->dispatcher(fHandle, PLUGIN_OPCODE_OFFLINE_CHANGED, 0, 0, nullptr); | |||
| fDescriptor->dispatcher(fHandle, PLUGIN_OPCODE_OFFLINE_CHANGED, 0, isOffline ? 1 : 0, nullptr, 0.0f); | |||
| if (fHandle2 != nullptr) | |||
| fDescriptor->dispatcher(fHandle2, PLUGIN_OPCODE_OFFLINE_CHANGED, 0, 0, nullptr); | |||
| fDescriptor->dispatcher(fHandle2, PLUGIN_OPCODE_OFFLINE_CHANGED, 0, isOffline ? 1 : 0, nullptr, 0.0f); | |||
| } | |||
| } | |||
| @@ -2147,15 +2147,32 @@ protected: | |||
| return retStr.isNotEmpty() ? (const char*)retStr : nullptr; | |||
| } | |||
| intptr_t handleDispatcher(HostDispatcherOpcode opcode, int32_t index, intptr_t value, void* ptr) | |||
| intptr_t handleDispatcher(const HostDispatcherOpcode opcode, const int32_t index, const intptr_t value, void* const ptr, const float opt) | |||
| { | |||
| carla_stdout("NativePlugin::handleDispatcher(%i, %i, " P_INTPTR ", %p, %f", opcode, index, value, ptr, opt); | |||
| intptr_t ret = 0; | |||
| switch (opcode) | |||
| { | |||
| case HOST_OPCODE_NULL: | |||
| case ::HOST_OPCODE_NULL: | |||
| break; | |||
| case ::HOST_OPCODE_SET_VOLUME: | |||
| setVolume(opt, true, true); | |||
| break; | |||
| case ::HOST_OPCODE_SET_DRYWET: | |||
| setDryWet(opt, true, true); | |||
| break; | |||
| case ::HOST_OPCODE_SET_BALANCE_LEFT: | |||
| setBalanceLeft(opt, true, true); | |||
| break; | |||
| case ::HOST_OPCODE_SET_BALANCE_RIGHT: | |||
| setBalanceRight(opt, true, true); | |||
| break; | |||
| case ::HOST_OPCODE_SET_PANNING: | |||
| setPanning(opt, true, true); | |||
| break; | |||
| case HOST_OPCODE_SET_PROCESS_PRECISION: | |||
| case ::HOST_OPCODE_SET_PROCESS_PRECISION: | |||
| // TODO | |||
| break; | |||
| case HOST_OPCODE_UI_UNAVAILABLE: | |||
| @@ -2437,9 +2454,9 @@ private: | |||
| return handlePtr->handleUiSaveFile(isDir, title, filter); | |||
| } | |||
| static intptr_t carla_host_dispatcher(HostHandle handle, HostDispatcherOpcode opcode, int32_t index, intptr_t value, void* ptr) | |||
| static intptr_t carla_host_dispatcher(HostHandle handle, HostDispatcherOpcode opcode, int32_t index, intptr_t value, void* ptr, float opt) | |||
| { | |||
| return handlePtr->handleDispatcher(opcode, index, value, ptr); | |||
| return handlePtr->handleDispatcher(opcode, index, value, ptr, opt); | |||
| } | |||
| #undef handlePtr | |||