mirror of
https://github.com/robbert-vdh/yabridge.git
synced 2026-05-09 20:29:10 +02:00
Remove null pointer support in setComponentHandler
This should be an implementation fault.
This commit is contained in:
@@ -209,13 +209,8 @@ bool Vst3Logger::log_request(
|
|||||||
const YaEditController::SetComponentHandler& request) {
|
const YaEditController::SetComponentHandler& request) {
|
||||||
return log_request_base(is_host_vst, [&](auto& message) {
|
return log_request_base(is_host_vst, [&](auto& message) {
|
||||||
message << request.instance_id
|
message << request.instance_id
|
||||||
<< ": IEditController::setComponentHandler(handler = ";
|
<< ": IEditController::setComponentHandler(handler = "
|
||||||
if (request.component_handler_proxy_args) {
|
"<IComponentHandler*>)";
|
||||||
message << "<IComponentHandler*>";
|
|
||||||
} else {
|
|
||||||
message << "<nullptr>";
|
|
||||||
}
|
|
||||||
message << ")";
|
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -345,18 +345,12 @@ class YaEditController : public Steinberg::Vst::IEditController {
|
|||||||
|
|
||||||
native_size_t instance_id;
|
native_size_t instance_id;
|
||||||
|
|
||||||
/**
|
Vst3ComponentHandlerProxy::ConstructArgs component_handler_proxy_args;
|
||||||
* Arguments for instantiating the proxy object. Even though it should
|
|
||||||
* never happen, if the host passed a null pointer to this function
|
|
||||||
* we'll mimic that as well.
|
|
||||||
*/
|
|
||||||
std::optional<Vst3ComponentHandlerProxy::ConstructArgs>
|
|
||||||
component_handler_proxy_args;
|
|
||||||
|
|
||||||
template <typename S>
|
template <typename S>
|
||||||
void serialize(S& s) {
|
void serialize(S& s) {
|
||||||
s.value8b(instance_id);
|
s.value8b(instance_id);
|
||||||
s.ext(component_handler_proxy_args, bitsery::ext::StdOptional{});
|
s.object(component_handler_proxy_args);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|||||||
@@ -337,28 +337,26 @@ Vst3PluginProxyImpl::setParamNormalized(Steinberg::Vst::ParamID id,
|
|||||||
|
|
||||||
tresult PLUGIN_API Vst3PluginProxyImpl::setComponentHandler(
|
tresult PLUGIN_API Vst3PluginProxyImpl::setComponentHandler(
|
||||||
Steinberg::Vst::IComponentHandler* handler) {
|
Steinberg::Vst::IComponentHandler* handler) {
|
||||||
// We'll store the pointer for when the plugin later makes a callback to
|
|
||||||
// this component handler
|
|
||||||
component_handler = handler;
|
|
||||||
|
|
||||||
// Automatically converted smart pointers for when the plugin performs a
|
|
||||||
// callback later
|
|
||||||
host_application = host_context;
|
|
||||||
|
|
||||||
std::optional<Vst3ComponentHandlerProxy::ConstructArgs>
|
|
||||||
component_handler_proxy_args = std::nullopt;
|
|
||||||
if (handler) {
|
if (handler) {
|
||||||
component_handler_proxy_args = Vst3ComponentHandlerProxy::ConstructArgs(
|
// We'll store the pointer for when the plugin later makes a callback to
|
||||||
component_handler, instance_id());
|
// this component handler
|
||||||
|
component_handler = handler;
|
||||||
|
|
||||||
|
// Automatically converted smart pointers for when the plugin performs a
|
||||||
|
// callback later
|
||||||
|
host_application = host_context;
|
||||||
|
|
||||||
|
return bridge.send_message(YaEditController::SetComponentHandler{
|
||||||
|
.instance_id = instance_id(),
|
||||||
|
.component_handler_proxy_args =
|
||||||
|
Vst3ComponentHandlerProxy::ConstructArgs(component_handler,
|
||||||
|
instance_id())});
|
||||||
} else {
|
} else {
|
||||||
bridge.logger.log(
|
bridge.logger.log(
|
||||||
"Null pointer passed to 'IEditController::setComponentHandler()'");
|
"WARNING: Null pointer passed to "
|
||||||
|
"'IEditController::setComponentHandler()'");
|
||||||
|
return Steinberg::kInvalidArgument;
|
||||||
}
|
}
|
||||||
|
|
||||||
return bridge.send_message(YaEditController::SetComponentHandler{
|
|
||||||
.instance_id = instance_id(),
|
|
||||||
.component_handler_proxy_args =
|
|
||||||
std::move(component_handler_proxy_args)});
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Steinberg::IPlugView* PLUGIN_API
|
Steinberg::IPlugView* PLUGIN_API
|
||||||
|
|||||||
@@ -255,22 +255,16 @@ void Vst3Bridge::run() {
|
|||||||
},
|
},
|
||||||
[&](YaEditController::SetComponentHandler& request)
|
[&](YaEditController::SetComponentHandler& request)
|
||||||
-> YaEditController::SetComponentHandler::Response {
|
-> YaEditController::SetComponentHandler::Response {
|
||||||
// If we got passed a component handler, we'll create a proxy
|
// We'll create a proxy object for the component handler and
|
||||||
// object and pass that to the initialize function. The lifetime
|
// pass that to the initialize function. The lifetime of this
|
||||||
// of this object is tied to that of the actual plugin object
|
// object is tied to that of the actual plugin object we're
|
||||||
// we're proxying for.
|
// proxying for.
|
||||||
// TODO: Does this have to be run from the UI thread? Figure out
|
// TODO: Does this have to be run from the UI thread? Figure out
|
||||||
// if it does
|
// if it does
|
||||||
if (request.component_handler_proxy_args) {
|
object_instances[request.instance_id].component_handler_proxy =
|
||||||
object_instances[request.instance_id]
|
Steinberg::owned(new Vst3ComponentHandlerProxyImpl(
|
||||||
.component_handler_proxy =
|
*this,
|
||||||
Steinberg::owned(new Vst3ComponentHandlerProxyImpl(
|
std::move(request.component_handler_proxy_args)));
|
||||||
*this,
|
|
||||||
std::move(*request.component_handler_proxy_args)));
|
|
||||||
} else {
|
|
||||||
object_instances[request.instance_id]
|
|
||||||
.component_handler_proxy = nullptr;
|
|
||||||
}
|
|
||||||
|
|
||||||
return object_instances[request.instance_id]
|
return object_instances[request.instance_id]
|
||||||
.edit_controller->setComponentHandler(
|
.edit_controller->setComponentHandler(
|
||||||
|
|||||||
Reference in New Issue
Block a user