mirror of
https://github.com/italicsjenga/agb.git
synced 2025-01-09 08:31:33 +11:00
Correctly handle no sample set
This commit is contained in:
parent
b583ba22a9
commit
a36b06b35c
|
@ -229,7 +229,11 @@ pub fn parse_midi(midi_info: &MidiInfo) -> TokenStream {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
let preset = &sf2.get_presets()[channel_data.current_sample];
|
let Some(current_sample) = channel_data.current_sample else {
|
||||||
|
continue;
|
||||||
|
};
|
||||||
|
|
||||||
|
let preset = &sf2.get_presets()[current_sample];
|
||||||
let region = preset
|
let region = preset
|
||||||
.get_regions()
|
.get_regions()
|
||||||
.iter()
|
.iter()
|
||||||
|
@ -293,7 +297,7 @@ pub fn parse_midi(midi_info: &MidiInfo) -> TokenStream {
|
||||||
lookup_id += 128 << 16;
|
lookup_id += 128 << 16;
|
||||||
}
|
}
|
||||||
|
|
||||||
channel_data.current_sample = *preset_lookup.get(&lookup_id).unwrap_or(&0);
|
channel_data.current_sample = preset_lookup.get(&lookup_id).copied();
|
||||||
}
|
}
|
||||||
midly::MidiMessage::Controller { controller, value } => {
|
midly::MidiMessage::Controller { controller, value } => {
|
||||||
match controller.as_int() {
|
match controller.as_int() {
|
||||||
|
@ -436,9 +440,9 @@ pub fn parse_midi(midi_info: &MidiInfo) -> TokenStream {
|
||||||
quote!(#track)
|
quote!(#track)
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Default, Clone)]
|
#[derive(Clone, Default)]
|
||||||
struct ChannelData {
|
struct ChannelData {
|
||||||
current_sample: usize,
|
current_sample: Option<usize>,
|
||||||
volume: f32,
|
volume: f32,
|
||||||
panning: f32,
|
panning: f32,
|
||||||
rpn: i32,
|
rpn: i32,
|
||||||
|
@ -479,11 +483,13 @@ struct SampleData {
|
||||||
envelope: Option<usize>,
|
envelope: Option<usize>,
|
||||||
}
|
}
|
||||||
|
|
||||||
fn midi_key_to_speed(key: i16, sample: &SampleData, _tune: f64) -> Num<u16, 8> {
|
fn midi_key_to_speed(key: i16, sample: &SampleData, tune: f64) -> Num<u16, 8> {
|
||||||
let sample_rate = sample.sample_rate as f64;
|
let sample_rate = sample.sample_rate as f64;
|
||||||
let relative_note = sample.note_offset as f64;
|
let relative_note = sample.note_offset as f64;
|
||||||
|
|
||||||
Num::from_f64(2f64.powf((key as f64 - relative_note) / 12.0) * sample_rate / 32768.0)
|
Num::from_f64(
|
||||||
|
2f64.powf((key as f64 - relative_note + tune + 1.0) / 12.0) * sample_rate / 32768.0,
|
||||||
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Clone, PartialEq)]
|
#[derive(Clone, PartialEq)]
|
||||||
|
|
Loading…
Reference in a new issue