Don't process audio for bypassed plugins
This commit is contained in:
parent
c6a34a63c4
commit
0cb26b5b4c
2 changed files with 24 additions and 11 deletions
|
@ -1170,10 +1170,17 @@ impl<P: ClapPlugin> Wrapper<P> {
|
|||
}
|
||||
}
|
||||
|
||||
let mut plugin = wrapper.plugin.write();
|
||||
let mut context = wrapper.make_process_context(transport);
|
||||
let result = plugin.process(&mut output_buffer, &mut context);
|
||||
wrapper.last_process_status.store(result);
|
||||
// Only process audio if the plugin is not currently bypassed
|
||||
let result = if !wrapper.bypass_state.load(Ordering::Relaxed) {
|
||||
let mut plugin = wrapper.plugin.write();
|
||||
let mut context = wrapper.make_process_context(transport);
|
||||
let result = plugin.process(&mut output_buffer, &mut context);
|
||||
wrapper.last_process_status.store(result);
|
||||
result
|
||||
} else {
|
||||
wrapper.last_process_status.store(ProcessStatus::Normal);
|
||||
ProcessStatus::Normal
|
||||
};
|
||||
|
||||
let clap_result = match result {
|
||||
ProcessStatus::Error(err) => {
|
||||
|
|
|
@ -921,15 +921,21 @@ impl<P: Vst3Plugin> IAudioProcessor for Wrapper<P> {
|
|||
let mut plugin = self.inner.plugin.write();
|
||||
let mut context = self.inner.make_process_context(transport);
|
||||
|
||||
let result = plugin.process(&mut output_buffer, &mut context);
|
||||
self.inner.last_process_status.store(result);
|
||||
match result {
|
||||
ProcessStatus::Error(err) => {
|
||||
nih_debug_assert_failure!("Process error: {}", err);
|
||||
// Only process audio if the plugin isn't bypassed
|
||||
if !self.inner.bypass_state.load(Ordering::Relaxed) {
|
||||
let result = plugin.process(&mut output_buffer, &mut context);
|
||||
self.inner.last_process_status.store(result);
|
||||
match result {
|
||||
ProcessStatus::Error(err) => {
|
||||
nih_debug_assert_failure!("Process error: {}", err);
|
||||
|
||||
return kResultFalse;
|
||||
return kResultFalse;
|
||||
}
|
||||
_ => kResultOk,
|
||||
}
|
||||
_ => kResultOk,
|
||||
} else {
|
||||
self.inner.last_process_status.store(ProcessStatus::Normal);
|
||||
kResultOk
|
||||
}
|
||||
};
|
||||
|
||||
|
|
Loading…
Add table
Reference in a new issue