mirror of
https://github.com/tildearrow/furnace.git
synced 2025-01-03 22:21:09 +00:00
try fixing .dmp loading
what a mess this format was before 1.0
This commit is contained in:
parent
971db17d29
commit
227fff021e
2 changed files with 58 additions and 16 deletions
|
@ -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();
|
||||||
|
|
|
@ -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
|
||||||
|
|
Loading…
Reference in a new issue