diff options
author | Chris Robinson <[email protected]> | 2014-01-04 04:34:32 -0800 |
---|---|---|
committer | Chris Robinson <[email protected]> | 2014-01-04 04:34:32 -0800 |
commit | 86f250a3f5d19a031ae9020e2d41cff1882de9c1 (patch) | |
tree | ebd4b8cff1c04599429f8d030ec59501ba86bd26 | |
parent | 4834f56779261a7fd7761544f79c90df0d06fc39 (diff) |
Trace preset, instrument, and sample names with invalid key and velocity ranges
-rw-r--r-- | Alc/midi/sf2load.c | 16 |
1 files changed, 8 insertions, 8 deletions
diff --git a/Alc/midi/sf2load.c b/Alc/midi/sf2load.c index c960566b..2f6d3324 100644 --- a/Alc/midi/sf2load.c +++ b/Alc/midi/sf2load.c @@ -688,7 +688,7 @@ static ALboolean ensureFontSanity(const Soundfont *sfont) return AL_TRUE; } -static ALboolean ensureZoneSanity(const GenModList *zone, int instidx, int zoneidx, int splidx) +static ALboolean checkZone(const GenModList *zone, const PresetHeader *preset, const InstrumentHeader *inst, const SampleHeader *samp) { ALsizei i; @@ -699,12 +699,12 @@ static ALboolean ensureZoneSanity(const GenModList *zone, int instidx, int zonei int high = zone->gens[i].mAmount>>8; int low = zone->gens[i].mAmount&0xff; - if(!(low >= 0 && low <= 127 && low >= 0 && low <= 127 && high >= low)) + if(!(low >= 0 && high <= 127 && high >= low)) { - TRACE("Instrument %d zone %d sample %d, invalid %s range: %d...%d\n", - instidx, zoneidx, splidx, + TRACE("Preset \"%s\", inst \"%s\", sample \"%s\": invalid %s range %d...%d\n", + preset->mName, inst->mName, samp->mName, (zone->gens[i].mGenerator == 43) ? "key" : - (zone->gens[i].mGenerator == 44) ? "vel" : "(unk)", + (zone->gens[i].mGenerator == 44) ? "velocity" : "(unknown)", low, high); return AL_FALSE; } @@ -849,7 +849,7 @@ static void fillZone(ALfontsound *sound, ALCcontext *context, const GenModList * } } -static void processInstrument(ALfontsound ***sounds, ALsizei *sounds_size, ALCcontext *context, InstrumentHeader *inst, const Soundfont *sfont, const GenModList *pzone) +static void processInstrument(ALfontsound ***sounds, ALsizei *sounds_size, ALCcontext *context, InstrumentHeader *inst, const PresetHeader *preset, const Soundfont *sfont, const GenModList *pzone) { const Generator *gen, *gen_end; const Modulator *mod, *mod_end; @@ -933,7 +933,7 @@ static void processInstrument(ALfontsound ***sounds, ALsizei *sounds_size, ALCco for(;mod != mod_end;mod++) GenModList_accumMod(&lzone, mod); - if(!ensureZoneSanity(&lzone, inst-sfont->inst, zone-sfont->ibag, samp-sfont->shdr)) + if(!checkZone(&lzone, preset, inst, samp)) break; (*sounds)[*sounds_size] = NewFontsound(context); @@ -1236,7 +1236,7 @@ ALboolean loadSf2(Reader *stream, ALsoundfont *soundfont, ALCcontext *context) (long)(gen-sfont.pgen), gen->mAmount, sfont.inst_size-1); else processInstrument(&sounds, &sounds_size, context, - &sfont.inst[gen->mAmount], &sfont, &lzone); + &sfont.inst[gen->mAmount], &sfont.phdr[i], &sfont, &lzone); break; } GenModList_insertGen(&lzone, gen, AL_TRUE); |