diff --git a/src/mcu.cpp b/src/mcu.cpp index d5cc046d..09883640 100644 --- a/src/mcu.cpp +++ b/src/mcu.cpp @@ -1291,6 +1291,7 @@ int main(int argc, char *argv[]) { (void)argc; std::string basePath; + std::string romPath; int port = 0; int audioDeviceIndex = -1; @@ -1312,6 +1313,13 @@ int main(int argc, char *argv[]) { audioDeviceIndex = atoi(argv[i] + 3); } + else if (!strncmp(argv[i], "-d:", 3)) + { + romPath = argv[i] + 3; + while (romPath.find_last_of("/") == romPath.length()-1) { + romPath.erase(romPath.length()-1); + } + } else if (!strncmp(argv[i], "-ab:", 4)) { char* pColon = argv[i] + 3; @@ -1386,6 +1394,7 @@ int main(int argc, char *argv[]) printf(" -p: Set MIDI port.\n"); printf(" -a: Set Audio Device index.\n"); printf(" -ab::[page_count] Set Audio Buffer size.\n"); + printf(" -d: Set ROM directory.\n"); printf("\n"); printf(" -mk2 Use SC-55mk2 ROM set.\n"); printf(" -st Use SC-55st ROM set.\n"); @@ -1419,6 +1428,11 @@ int main(int argc, char *argv[]) if(Files::dirExists(basePath + "/../share/nuked-sc55")) basePath += "/../share/nuked-sc55"; + if (romPath.empty()) { + romPath = basePath; + } + printf("ROM path is: %s\n", romPath.c_str()); + if (autodetect) { for (size_t i = 0; i < ROM_SET_COUNT; i++) @@ -1428,7 +1442,7 @@ int main(int argc, char *argv[]) { if (roms[i][j][0] == '\0') continue; - std::string path = basePath + "/" + roms[i][j]; + std::string path = romPath + "/" + roms[i][j]; auto h = Files::utf8_fopen(path.c_str(), "rb"); if (!h) { @@ -1487,7 +1501,7 @@ int main(int argc, char *argv[]) rpaths[i] = ""; continue; } - rpaths[i] = basePath + "/" + roms[romset][i]; + rpaths[i] = romPath + "/" + roms[romset][i]; s_rf[i] = Files::utf8_fopen(rpaths[i].c_str(), "rb"); bool optional = mcu_jv880 && i == 4; r_ok &= optional || (s_rf[i] != nullptr);