try fixing .dmp loading

what a mess this format was before 1.0
This commit is contained in:
tildearrow 2022-02-01 00:58:00 -05:00
parent 971db17d29
commit 227fff021e
2 changed files with 58 additions and 16 deletions

View file

@ -4418,7 +4418,8 @@ bool DivEngine::addInstrumentFromFile(const char *path) {
return false; return false;
} }
if (version>=10) { // 1.0 if (version>=11) { // 1.0
logI("version 10 or higher, so load\n");
try { try {
sys=reader.readC(); sys=reader.readC();
@ -4464,16 +4465,28 @@ bool DivEngine::addInstrumentFromFile(const char *path) {
} }
try { try {
bool mode=reader.readC(); bool mode=true;
if (mode==0 && ins->type==DIV_INS_FM) { if (version>1) {
mode=reader.readC();
if (mode==0) {
if (version<11) {
ins->type=DIV_INS_STD; ins->type=DIV_INS_STD;
} }
} else {
ins->type=DIV_INS_FM;
}
} else {
ins->type=DIV_INS_FM;
}
if (mode) { // FM if (mode) { // FM
if (version<0x0a) ins->fm.ops=reader.readC(); if (version<10) ins->fm.ops=reader.readC()?2:4;
if (version>1) { // HELP! in which version of the format did we start storing FMS!
ins->fm.fms=reader.readC(); ins->fm.fms=reader.readC();
}
ins->fm.fb=reader.readC(); ins->fm.fb=reader.readC();
ins->fm.alg=reader.readC(); ins->fm.alg=reader.readC();
// DITTO
if (sys!=1) ins->fm.ams=reader.readC(); if (sys!=1) ins->fm.ams=reader.readC();
for (int j=0; j<ins->fm.ops; j++) { for (int j=0; j<ins->fm.ops; j++) {
@ -4484,6 +4497,7 @@ bool DivEngine::addInstrumentFromFile(const char *path) {
ins->fm.op[j].sl=reader.readC(); ins->fm.op[j].sl=reader.readC();
ins->fm.op[j].rr=reader.readC(); ins->fm.op[j].rr=reader.readC();
ins->fm.op[j].am=reader.readC(); ins->fm.op[j].am=reader.readC();
// what the hell how do I tell!
if (sys==1) { // YMU759 if (sys==1) { // YMU759
ins->fm.op[j].ws=reader.readC(); ins->fm.op[j].ws=reader.readC();
ins->fm.op[j].ksl=reader.readC(); ins->fm.op[j].ksl=reader.readC();
@ -4505,9 +4519,18 @@ bool DivEngine::addInstrumentFromFile(const char *path) {
} else { // STD } else { // STD
if (ins->type!=DIV_INS_GB) { if (ins->type!=DIV_INS_GB) {
ins->std.volMacroLen=reader.readC(); ins->std.volMacroLen=reader.readC();
if (version>5) {
for (int i=0; i<ins->std.volMacroLen; i++) { for (int i=0; i<ins->std.volMacroLen; i++) {
ins->std.volMacro[i]=reader.readI(); ins->std.volMacro[i]=reader.readI();
} }
} else {
for (int i=0; i<ins->std.volMacroLen; i++) {
ins->std.volMacro[i]=reader.readC();
}
}
if (version<11) for (int i=0; i<ins->std.volMacroLen; i++) {
if (ins->std.volMacro[i]>15 && ins->type==DIV_INS_STD) ins->type=DIV_INS_PCE;
}
if (ins->std.volMacroLen>0) { if (ins->std.volMacroLen>0) {
ins->std.volMacroOpen=true; ins->std.volMacroOpen=true;
ins->std.volMacroLoop=reader.readC(); ins->std.volMacroLoop=reader.readC();
@ -4517,21 +4540,35 @@ bool DivEngine::addInstrumentFromFile(const char *path) {
} }
ins->std.arpMacroLen=reader.readC(); ins->std.arpMacroLen=reader.readC();
if (version>5) {
for (int i=0; i<ins->std.arpMacroLen; i++) { for (int i=0; i<ins->std.arpMacroLen; i++) {
ins->std.arpMacro[i]=reader.readI(); ins->std.arpMacro[i]=reader.readI();
} }
} else {
for (int i=0; i<ins->std.arpMacroLen; i++) {
ins->std.arpMacro[i]=reader.readC();
}
}
if (ins->std.arpMacroLen>0) { if (ins->std.arpMacroLen>0) {
ins->std.arpMacroOpen=true; ins->std.arpMacroOpen=true;
ins->std.arpMacroLoop=reader.readC(); ins->std.arpMacroLoop=reader.readC();
} else { } else {
ins->std.arpMacroOpen=false; ins->std.arpMacroOpen=false;
} }
if (version>8) { // TODO: when?
ins->std.arpMacroMode=reader.readC(); ins->std.arpMacroMode=reader.readC();
}
ins->std.dutyMacroLen=reader.readC(); ins->std.dutyMacroLen=reader.readC();
if (version>5) {
for (int i=0; i<ins->std.dutyMacroLen; i++) { for (int i=0; i<ins->std.dutyMacroLen; i++) {
ins->std.dutyMacro[i]=reader.readI(); ins->std.dutyMacro[i]=reader.readI();
} }
} else {
for (int i=0; i<ins->std.dutyMacroLen; i++) {
ins->std.dutyMacro[i]=reader.readC();
}
}
if (ins->std.dutyMacroLen>0) { if (ins->std.dutyMacroLen>0) {
ins->std.dutyMacroOpen=true; ins->std.dutyMacroOpen=true;
ins->std.dutyMacroLoop=reader.readC(); ins->std.dutyMacroLoop=reader.readC();
@ -4540,9 +4577,15 @@ bool DivEngine::addInstrumentFromFile(const char *path) {
} }
ins->std.waveMacroLen=reader.readC(); ins->std.waveMacroLen=reader.readC();
if (version>5) {
for (int i=0; i<ins->std.waveMacroLen; i++) { for (int i=0; i<ins->std.waveMacroLen; i++) {
ins->std.waveMacro[i]=reader.readI(); ins->std.waveMacro[i]=reader.readI();
} }
} else {
for (int i=0; i<ins->std.waveMacroLen; i++) {
ins->std.waveMacro[i]=reader.readC();
}
}
if (ins->std.waveMacroLen>0) { if (ins->std.waveMacroLen>0) {
ins->std.waveMacroOpen=true; ins->std.waveMacroOpen=true;
ins->std.waveMacroLoop=reader.readC(); ins->std.waveMacroLoop=reader.readC();

View file

@ -39,7 +39,6 @@ enum DivSystem {
struct DivSong { struct DivSong {
// version number used for saving the song. // version number used for saving the song.
// Furnace will save using the latest possible version, // Furnace will save using the latest possible version,
// but eventually I will and 0x80 to this value to indicate a Furnace module
// known version numbers: // known version numbers:
// - 24: v0.12/0.13/1.0 // - 24: v0.12/0.13/1.0
// - current format version // - current format version