summaryrefslogtreecommitdiffstats
path: root/src/server/internals
diff options
context:
space:
mode:
Diffstat (limited to 'src/server/internals')
-rw-r--r--src/server/internals/Controller.cpp3
-rw-r--r--src/server/internals/Note.cpp15
2 files changed, 12 insertions, 6 deletions
diff --git a/src/server/internals/Controller.cpp b/src/server/internals/Controller.cpp
index 0366cbf0..36c735ce 100644
--- a/src/server/internals/Controller.cpp
+++ b/src/server/internals/Controller.cpp
@@ -157,8 +157,9 @@ ControllerNode::control(RunContext& context, uint8_t control_num, uint8_t val, F
if (log_port_val > 0.0f) {
// haaaaack, stupid negatives and logarithms
Sample log_offset = 0;
- if (min_port_val < 0)
+ if (min_port_val < 0) {
log_offset = fabs(min_port_val);
+ }
const Sample min = log(min_port_val + 1 + log_offset);
const Sample max = log(max_port_val + 1 + log_offset);
scaled_value = expf(nval * (max - min) + min) - 1 - log_offset;
diff --git a/src/server/internals/Note.cpp b/src/server/internals/Note.cpp
index 9b157d54..dc282417 100644
--- a/src/server/internals/Note.cpp
+++ b/src/server/internals/Note.cpp
@@ -130,13 +130,15 @@ NoteNode::NoteNode(InternalPlugin* plugin,
bool
NoteNode::prepare_poly(BufferFactory& bufs, uint32_t poly)
{
- if (!_polyphonic)
+ if (!_polyphonic) {
return true;
+ }
BlockImpl::prepare_poly(bufs, poly);
- if (_prepared_voices && poly <= _prepared_voices->size())
+ if (_prepared_voices && poly <= _prepared_voices->size()) {
return true;
+ }
_prepared_voices = bufs.maid().make_managed<Voices>(
poly, *_voices, Voice());
@@ -147,8 +149,9 @@ NoteNode::prepare_poly(BufferFactory& bufs, uint32_t poly)
bool
NoteNode::apply_poly(RunContext& context, uint32_t poly)
{
- if (!BlockImpl::apply_poly(context, poly))
+ if (!BlockImpl::apply_poly(context, poly)) {
return false;
+ }
if (_prepared_voices) {
assert(_polyphony <= _prepared_voices->size());
@@ -383,9 +386,11 @@ NoteNode::sustain_off(RunContext& context, FrameTime time)
_sustain = false;
- for (uint32_t i=0; i < _polyphony; ++i)
- if ((*_voices)[i].state == Voice::State::HOLDING)
+ for (uint32_t i=0; i < _polyphony; ++i) {
+ if ((*_voices)[i].state == Voice::State::HOLDING) {
free_voice(context, i, time);
+ }
+ }
}
void