From 105932305adf830ec8116827761a8a8c8aff4523 Mon Sep 17 00:00:00 2001 From: Florian Jung Date: Wed, 12 Jan 2011 12:06:35 +0100 Subject: Non-releasing Envelopes now work --- TODO | 4 +++- TODO.done | 7 ++++++- synth/envelope.cpp | 5 +++-- synth/parser.cpp | 19 ++++++++++++++++++- synth/programs.h | 2 +- 5 files changed, 31 insertions(+), 6 deletions(-) diff --git a/TODO b/TODO index 4b10c50..32debfe 100644 --- a/TODO +++ b/TODO @@ -2,7 +2,9 @@ wenn man danach die noten spielen will. nicht reproduzierbar TODO für den synth - o bei envelopes: releasephase abschalten (bei sustain bleiben) + o zu testen: funktionieren no-release-envs auch in compilierten noten? + o fehlerklassen für fatale fehler (von string abgeleitet) + o im cli dürfen warnungen nicht mehr fatal sein o on-the-fly die LFOs ändern (frequenz, wellenform) o RAM aufräumen? diff --git a/TODO.done b/TODO.done index f0e9552..7e0af0c 100644 --- a/TODO.done +++ b/TODO.done @@ -61,7 +61,12 @@ TODO für den synth x parser-klasse durch parse-funktion ersetzen x sostenuto-, halte-, legato-, soft-pedal x programme on-the-fly (um)laden - + x bei envelopes: releasephase abschalten (bei sustain bleiben) + x parser: programm nicht laden, wenn nonconst- oder nonzero-osc + eine envelope ohne release hat (wenn output!=0 und + wenn in der controller-formel-liste iwas über diesen + osc steht) + TODO fürs CLI x filter_update_frames, lfo_update_frames in config, in sec (auch im CLI) diff --git a/synth/envelope.cpp b/synth/envelope.cpp index 5678fd3..2f06a4e 100644 --- a/synth/envelope.cpp +++ b/synth/envelope.cpp @@ -1,7 +1,5 @@ #include "envelope.h" -#include - Envelope::Envelope(env_settings_t s, int frames) { level=0; @@ -14,6 +12,9 @@ Envelope::Envelope(env_settings_t s, int frames) set_ratefactor(1.0); has_release_phase=(s.release>=0); + + if (has_release_phase) + s.hold=false; set_attack(s.attack); set_decay(s.decay); diff --git a/synth/parser.cpp b/synth/parser.cpp index 5da2175..10accac 100644 --- a/synth/parser.cpp +++ b/synth/parser.cpp @@ -594,7 +594,24 @@ program_t parse(string fn) } } - + + bool neverending_tone=false; + + for (map< parameter_t, list >::iterator it=formula.begin(); it!=formula.end(); it++) + if ((it->first.par==OUTPUT) && (env[it->first.osc].release<0)) + neverending_tone=true; + + for (int i=0;i