mirror of
https://github.com/robbert-vdh/yabridge.git
synced 2026-06-14 23:43:52 +02:00
Implement IEditController2::setKnobMode
This commit is contained in:
@@ -253,6 +253,15 @@ bool Vst3Logger::log_request(bool is_host_vst,
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool Vst3Logger::log_request(bool is_host_vst,
|
||||||
|
const YaEditController2::SetKnobMode& request) {
|
||||||
|
return log_request_base(is_host_vst, [&](auto& message) {
|
||||||
|
message << request.instance_id
|
||||||
|
<< ": IEditController2::setKnobMode(mode = " << request.mode
|
||||||
|
<< ")";
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
bool Vst3Logger::log_request(
|
bool Vst3Logger::log_request(
|
||||||
bool is_host_vst,
|
bool is_host_vst,
|
||||||
const YaPlugView::IsPlatformTypeSupported& request) {
|
const YaPlugView::IsPlatformTypeSupported& request) {
|
||||||
|
|||||||
@@ -88,6 +88,7 @@ class Vst3Logger {
|
|||||||
bool log_request(bool is_host_vst,
|
bool log_request(bool is_host_vst,
|
||||||
const YaEditController::SetComponentHandler&);
|
const YaEditController::SetComponentHandler&);
|
||||||
bool log_request(bool is_host_vst, const YaEditController::CreateView&);
|
bool log_request(bool is_host_vst, const YaEditController::CreateView&);
|
||||||
|
bool log_request(bool is_host_vst, const YaEditController2::SetKnobMode&);
|
||||||
bool log_request(bool is_host_vst,
|
bool log_request(bool is_host_vst,
|
||||||
const YaPlugView::IsPlatformTypeSupported&);
|
const YaPlugView::IsPlatformTypeSupported&);
|
||||||
bool log_request(bool is_host_vst, const YaPlugView::Attached&);
|
bool log_request(bool is_host_vst, const YaPlugView::Attached&);
|
||||||
|
|||||||
@@ -81,6 +81,7 @@ using ControlRequest = std::variant<Vst3PlugViewProxy::Destruct,
|
|||||||
YaEditController::SetParamNormalized,
|
YaEditController::SetParamNormalized,
|
||||||
YaEditController::SetComponentHandler,
|
YaEditController::SetComponentHandler,
|
||||||
YaEditController::CreateView,
|
YaEditController::CreateView,
|
||||||
|
YaEditController2::SetKnobMode,
|
||||||
YaPlugView::IsPlatformTypeSupported,
|
YaPlugView::IsPlatformTypeSupported,
|
||||||
YaPlugView::Attached,
|
YaPlugView::Attached,
|
||||||
YaPlugView::Removed,
|
YaPlugView::Removed,
|
||||||
|
|||||||
@@ -61,6 +61,24 @@ class YaEditController2 : public Steinberg::Vst::IEditController2 {
|
|||||||
|
|
||||||
inline bool supported() const { return arguments.supported; }
|
inline bool supported() const { return arguments.supported; }
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Message to pass through a call to `IEditController2::setKnobMode(mode)`
|
||||||
|
* to the Wine plugin host.
|
||||||
|
*/
|
||||||
|
struct SetKnobMode {
|
||||||
|
using Response = UniversalTResult;
|
||||||
|
|
||||||
|
native_size_t instance_id;
|
||||||
|
|
||||||
|
Steinberg::Vst::KnobMode mode;
|
||||||
|
|
||||||
|
template <typename S>
|
||||||
|
void serialize(S& s) {
|
||||||
|
s.value8b(instance_id);
|
||||||
|
s.value4b(mode);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
virtual tresult PLUGIN_API
|
virtual tresult PLUGIN_API
|
||||||
setKnobMode(Steinberg::Vst::KnobMode mode) override = 0;
|
setKnobMode(Steinberg::Vst::KnobMode mode) override = 0;
|
||||||
virtual tresult PLUGIN_API openHelp(TBool onlyCheck) override = 0;
|
virtual tresult PLUGIN_API openHelp(TBool onlyCheck) override = 0;
|
||||||
|
|||||||
@@ -394,9 +394,8 @@ Vst3PluginProxyImpl::createView(Steinberg::FIDString name) {
|
|||||||
|
|
||||||
tresult PLUGIN_API
|
tresult PLUGIN_API
|
||||||
Vst3PluginProxyImpl::setKnobMode(Steinberg::Vst::KnobMode mode) {
|
Vst3PluginProxyImpl::setKnobMode(Steinberg::Vst::KnobMode mode) {
|
||||||
// TODO: Implement
|
return bridge.send_message(YaEditController2::SetKnobMode{
|
||||||
bridge.logger.log("TODO: IEditController2::setKnobMode()");
|
.instance_id = instance_id(), .mode = mode});
|
||||||
return Steinberg::kNotImplemented;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
tresult PLUGIN_API Vst3PluginProxyImpl::openHelp(TBool onlyCheck) {
|
tresult PLUGIN_API Vst3PluginProxyImpl::openHelp(TBool onlyCheck) {
|
||||||
|
|||||||
@@ -34,6 +34,7 @@ InstanceInterfaces::InstanceInterfaces(
|
|||||||
component(object),
|
component(object),
|
||||||
connection_point(object),
|
connection_point(object),
|
||||||
edit_controller(object),
|
edit_controller(object),
|
||||||
|
edit_controller_2(object),
|
||||||
plugin_base(object) {}
|
plugin_base(object) {}
|
||||||
|
|
||||||
Vst3Bridge::Vst3Bridge(MainContext& main_context,
|
Vst3Bridge::Vst3Bridge(MainContext& main_context,
|
||||||
@@ -335,6 +336,11 @@ void Vst3Bridge::run() {
|
|||||||
request.instance_id)
|
request.instance_id)
|
||||||
: std::nullopt)};
|
: std::nullopt)};
|
||||||
},
|
},
|
||||||
|
[&](const YaEditController2::SetKnobMode& request)
|
||||||
|
-> YaEditController2::SetKnobMode::Response {
|
||||||
|
return object_instances[request.instance_id]
|
||||||
|
.edit_controller_2->setKnobMode(request.mode);
|
||||||
|
},
|
||||||
[&](const YaPlugView::IsPlatformTypeSupported& request)
|
[&](const YaPlugView::IsPlatformTypeSupported& request)
|
||||||
-> YaPlugView::IsPlatformTypeSupported::Response {
|
-> YaPlugView::IsPlatformTypeSupported::Response {
|
||||||
// The host will of course want to pass an X11 window ID for the
|
// The host will of course want to pass an X11 window ID for the
|
||||||
|
|||||||
@@ -113,6 +113,7 @@ struct InstanceInterfaces {
|
|||||||
Steinberg::FUnknownPtr<Steinberg::Vst::IComponent> component;
|
Steinberg::FUnknownPtr<Steinberg::Vst::IComponent> component;
|
||||||
Steinberg::FUnknownPtr<Steinberg::Vst::IConnectionPoint> connection_point;
|
Steinberg::FUnknownPtr<Steinberg::Vst::IConnectionPoint> connection_point;
|
||||||
Steinberg::FUnknownPtr<Steinberg::Vst::IEditController> edit_controller;
|
Steinberg::FUnknownPtr<Steinberg::Vst::IEditController> edit_controller;
|
||||||
|
Steinberg::FUnknownPtr<Steinberg::Vst::IEditController2> edit_controller_2;
|
||||||
Steinberg::FUnknownPtr<Steinberg::IPluginBase> plugin_base;
|
Steinberg::FUnknownPtr<Steinberg::IPluginBase> plugin_base;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user