1
0
mirror of https://github.com/TomHarte/CLK.git synced 2025-02-18 01:30:56 +00:00

Make a prima facie attempt to adapt the Qt build.

This commit is contained in:
Thomas Harte 2021-06-06 20:47:25 -04:00
parent f27e331462
commit 4a2673d757
2 changed files with 36 additions and 56 deletions

View File

@ -251,33 +251,33 @@ void MainWindow::tile(const QMainWindow *previous) {
void MainWindow::launchMachine() { void MainWindow::launchMachine() {
const QStringList appDataLocations = QStandardPaths::standardLocations(QStandardPaths::AppDataLocation); const QStringList appDataLocations = QStandardPaths::standardLocations(QStandardPaths::AppDataLocation);
missingRoms.clear();
ROMMachine::ROMFetcher rom_fetcher = [&appDataLocations, this] ROMMachine::ROMFetcher rom_fetcher = [&appDataLocations, this]
(const std::vector<ROMMachine::ROM> &roms) -> std::vector<std::unique_ptr<std::vector<uint8_t>>> { (const ROM::Request &roms) -> std::vector<std::unique_ptr<std::vector<uint8_t>>> {
std::vector<std::unique_ptr<std::vector<uint8_t>>> results; ROM::Map results;
for(const auto &rom: roms) { for(const auto &description: roms.all_descriptions()) {
FILE *file = nullptr; for(const auto &file_name: description.file_names) {
for(const auto &path: appDataLocations) { FILE *file = nullptr;
const std::string source = path.toStdString() + "/ROMImages/" + rom.machine_name + "/" + rom.file_name; for(const auto &path: appDataLocations) {
const std::string nativeSource = QDir::toNativeSeparators(QString::fromStdString(source)).toStdString(); const std::string source = path.toStdString() + "/ROMImages/" + description.machine_name + "/" + file_name;
const std::string nativeSource = QDir::toNativeSeparators(QString::fromStdString(source)).toStdString();
file = fopen(nativeSource.c_str(), "rb"); file = fopen(nativeSource.c_str(), "rb");
if(file) break; if(file) break;
} }
if(file) { if(file) {
auto data = fileContentsAndClose(file); auto data = fileContentsAndClose(file);
if(data) { if(data) {
results.push_back(std::move(data)); results[description.name] = std::move(data);
continue; continue;
}
} }
} }
results.push_back(nullptr);
missingRoms.push_back(rom);
} }
missingRoms = roms.subtract(results);
return results; return results;
}; };
Machine::Error error; Machine::Error error;
@ -291,22 +291,7 @@ void MainWindow::launchMachine() {
// Populate request text. // Populate request text.
QString requestText = romRequestBaseText; QString requestText = romRequestBaseText;
size_t index = 0; requestText += missingRoms.description(0, L'');
for(const auto &rom: missingRoms) {
requestText += "";
requestText += rom.descriptive_name.c_str();
++index;
if(index == missingRoms.size()) {
requestText += ".\n";
continue;
}
if(index == missingRoms.size() - 1) {
requestText += "; and\n";
continue;
}
requestText += ";\n";
}
ui->missingROMsBox->setPlainText(requestText); ui->missingROMsBox->setPlainText(requestText);
} break; } break;
} }
@ -736,28 +721,23 @@ void MainWindow::dropEvent(QDropEvent* event) {
CRC::CRC32 generator; CRC::CRC32 generator;
const uint32_t crc = generator.compute_crc(*contents); const uint32_t crc = generator.compute_crc(*contents);
bool wasUsed = false; std::optional<ROM::Description> target = ROM::Description::from_crc(crc);
for(const auto &rom: missingRoms) { if(target) {
if(std::find(rom.crc32s.begin(), rom.crc32s.end(), crc) != rom.crc32s.end()) { // Ensure the destination folder exists.
foundROM = true; const std::string path = appDataLocation + "/ROMImages/" + rom.machine_name;
const QDir dir(QString::fromStdString(path));
if (!dir.exists())
dir.mkpath(".");
// Ensure the destination folder exists. // Write into place.
const std::string path = appDataLocation + "/ROMImages/" + rom.machine_name; const std::string destination = QDir::toNativeSeparators(QString::fromStdString(path+ "/" + rom.file_name)).toStdString();
const QDir dir(QString::fromStdString(path)); FILE *const target = fopen(destination.c_str(), "wb");
if (!dir.exists()) fwrite(contents->data(), 1, contents->size(), target);
dir.mkpath("."); fclose(target);
// Write into place. // Note that at least one meaningful ROM was supplied.
const std::string destination = QDir::toNativeSeparators(QString::fromStdString(path+ "/" + rom.file_name)).toStdString(); foundROM = true;
FILE *const target = fopen(destination.c_str(), "wb"); } else {
fwrite(contents->data(), 1, contents->size(), target);
fclose(target);
wasUsed = true;
}
}
if(!wasUsed) {
if(!unusedRoms.isEmpty()) unusedRoms += ", "; if(!unusedRoms.isEmpty()) unusedRoms += ", ";
unusedRoms += url.fileName(); unusedRoms += url.fileName();
} }

View File

@ -60,7 +60,7 @@ class MainWindow : public QMainWindow, public Outputs::Speaker::Speaker::Delegat
void launchMachine(); void launchMachine();
QString romRequestBaseText; QString romRequestBaseText;
std::vector<ROMMachine::ROM> missingRoms; ROM::Request missingRoms;
// File drag and drop is supported. // File drag and drop is supported.
void dragEnterEvent(QDragEnterEvent* event) override; void dragEnterEvent(QDragEnterEvent* event) override;