Skip to content

Commit

Permalink
Merge pull request #12 from Birch-san/restore-program
Browse files Browse the repository at this point in the history
restore preset and bank _after_ soundfont
  • Loading branch information
Birch-san authored Aug 10, 2019
2 parents f9a28c3 + 9d39d3c commit aabb0b1
Show file tree
Hide file tree
Showing 2 changed files with 16 additions and 21 deletions.
23 changes: 8 additions & 15 deletions Source/FluidSynthModel.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -73,10 +73,6 @@ void FluidSynthModel::initialise() {

synth = { new_fluid_synth(settings.get()), delete_fluid_synth };
fluid_synth_set_sample_rate(synth.get(), currentSampleRate);

ValueTree soundFont{valueTreeState.state.getChildWithName("soundFont")};
String path = soundFont.getProperty("path", "");
loadFont(path);

// I can't hear a damned thing
fluid_synth_set_gain(synth.get(), 2.0);
Expand All @@ -88,17 +84,9 @@ void FluidSynthModel::initialise() {
// and yet, I'm finding that default modulators start at MIN,
// i.e. we are forced to start at 0 and climb from there
// --
// let's loop through all audio params that we manage,
// restore them to whatever value we have stored for them
// (which by default would be 0)
// super likely to be 0 regardless, since JuicySFAudioProcessor::initialise()
// runs earlier than JuicySFAudioProcessor::setStateInformation()
for (const auto &[controller, parameterID]: controllerToParam) {
RangedAudioParameter *param{valueTreeState.getParameter(parameterID)};
jassert(dynamic_cast<AudioParameterInt*>(param) != nullptr);
AudioParameterInt* castParam{dynamic_cast<AudioParameterInt*>(param)};
int value{castParam->get()};
setControllerValue(static_cast<int>(controller), value);
// let's zero out every audio param that we manage
for (const auto &[controller, param]: controllerToParam) {
setControllerValue(static_cast<int>(controller), 0);
}

// http://www.synthfont.com/SoundFont_NRPNs.PDF
Expand Down Expand Up @@ -355,6 +343,11 @@ void FluidSynthModel::processBlock(AudioBuffer<float>& buffer, MidiBuffer& midiM
*castParam = m.getControllerValue();
}
} else if (m.isProgramChange()) {
#if JUCE_DEBUG
String debug{"MIDI program change: "};
debug << m.getProgramChangeNumber();
Logger::outputDebugString(debug);
#endif
int result{fluid_synth_program_change(
synth.get(),
channel,
Expand Down
14 changes: 8 additions & 6 deletions Source/PluginProcessor.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -260,12 +260,6 @@ void JuicySFAudioProcessor::setStateInformation (const void* data, int sizeInByt
if (xmlState.get() != nullptr) {
// make sure that it's actually our type of XML object..
if (xmlState->hasTagName(valueTreeState.state.getType())) {
XmlElement* params{xmlState->getChildByName("params")};
if (params)
for (auto* param : getParameters())
if (auto* p = dynamic_cast<AudioProcessorParameterWithID*>(param))
p->setValue(static_cast<float>(params->getDoubleAttribute(p->paramID, p->getValue())));

{
XmlElement* xmlElement{xmlState->getChildByName("soundFont")};
if (xmlElement) {
Expand All @@ -288,6 +282,14 @@ void JuicySFAudioProcessor::setStateInformation (const void* data, int sizeInByt
}
}
}
XmlElement* params{xmlState->getChildByName("params")};
if (params) {
for (auto* param : getParameters()) {
if (auto* p = dynamic_cast<AudioProcessorParameterWithID*>(param)) {
p->setValueNotifyingHost(static_cast<float>(params->getDoubleAttribute(p->paramID, p->getValue())));
}
}
}
}
}
}
Expand Down

0 comments on commit aabb0b1

Please sign in to comment.