mirror of
https://github.com/TomHarte/CLK.git
synced 2025-01-12 15:31:09 +00:00
Corrects warnings in the CSW, CPC DSK, ZX8081 data encoding, and PRG and binary cartridges.
This commit is contained in:
parent
d2ba7d7430
commit
792061a82b
@ -19,12 +19,12 @@ BinaryDump::BinaryDump(const char *file_name) {
|
||||
stat(file_name, &file_stats);
|
||||
|
||||
// grab contents
|
||||
FILE *file = fopen(file_name, "rb");
|
||||
FILE *file = std::fopen(file_name, "rb");
|
||||
if(!file) throw ErrorNotAccessible;
|
||||
std::size_t data_length = static_cast<std::size_t>(file_stats.st_size);
|
||||
std::vector<uint8_t> contents(data_length);
|
||||
fread(&contents[0], 1, static_cast<std::size_t>(data_length), file);
|
||||
fclose(file);
|
||||
contents.resize(std::fread(&contents[0], 1, static_cast<std::size_t>(data_length), file));
|
||||
std::fclose(file);
|
||||
|
||||
// enshrine
|
||||
segments_.emplace_back(
|
||||
|
@ -10,6 +10,7 @@
|
||||
|
||||
#include <cstdio>
|
||||
#include <sys/stat.h>
|
||||
|
||||
#include "../Encodings/CommodoreROM.hpp"
|
||||
|
||||
using namespace Storage::Cartridge;
|
||||
@ -23,7 +24,7 @@ PRG::PRG(const char *file_name) {
|
||||
throw ErrorNotROM;
|
||||
|
||||
// get the loading address, and the rest of the contents
|
||||
FILE *file = fopen(file_name, "rb");
|
||||
FILE *file = std::fopen(file_name, "rb");
|
||||
|
||||
int loading_address = fgetc(file);
|
||||
loading_address |= fgetc(file) << 8;
|
||||
@ -32,11 +33,11 @@ PRG::PRG(const char *file_name) {
|
||||
std::size_t padded_data_length = 1;
|
||||
while(padded_data_length < data_length) padded_data_length <<= 1;
|
||||
std::vector<uint8_t> contents(padded_data_length);
|
||||
fread(&contents[0], 1, static_cast<std::size_t>(data_length), file);
|
||||
fclose(file);
|
||||
std::size_t length = std::fread(contents.data(), 1, static_cast<std::size_t>(data_length), file);
|
||||
std::fclose(file);
|
||||
|
||||
// accept only files intended to load at 0xa000
|
||||
if(loading_address != 0xa000)
|
||||
if(loading_address != 0xa000 || length != static_cast<std::size_t>(data_length))
|
||||
throw ErrorNotROM;
|
||||
|
||||
// also accept only cartridges with the proper signature
|
||||
|
@ -27,7 +27,7 @@ static std::shared_ptr<File> ZX80FileFromData(const std::vector<uint8_t> &data)
|
||||
uint16_t display_address = short_at(0xc, data);
|
||||
|
||||
// check that the end of file is contained within the supplied data
|
||||
if(end_of_file - 0x4000 > data.size()) return nullptr;
|
||||
if(static_cast<size_t>(end_of_file - 0x4000) > data.size()) return nullptr;
|
||||
|
||||
// check for the proper ordering of buffers
|
||||
if(vars > end_of_file) return nullptr;
|
||||
|
@ -365,7 +365,7 @@ void CPCDSK::set_tracks(const std::map<::Storage::Disk::Track::Address, std::sha
|
||||
}
|
||||
|
||||
// Move to next 256-byte boundary.
|
||||
long distance = (256 - output.tell()&255)&255;
|
||||
long distance = (256 - (output.tell()&255))&255;
|
||||
output.putn(static_cast<std::size_t>(distance), 0);
|
||||
|
||||
// Output sector contents.
|
||||
@ -376,7 +376,7 @@ void CPCDSK::set_tracks(const std::map<::Storage::Disk::Track::Address, std::sha
|
||||
}
|
||||
|
||||
// Move to next 256-byte boundary.
|
||||
distance = (256 - output.tell()&255)&255;
|
||||
distance = (256 - (output.tell()&255))&255;
|
||||
output.putn(static_cast<std::size_t>(distance), 0);
|
||||
}
|
||||
}
|
||||
|
@ -8,6 +8,8 @@
|
||||
|
||||
#include "CSW.hpp"
|
||||
|
||||
#include <cassert>
|
||||
|
||||
using namespace Storage::Tape;
|
||||
|
||||
CSW::CSW(const char *file_name) :
|
||||
@ -90,6 +92,8 @@ uint8_t CSW::get_next_byte() {
|
||||
source_data_pointer_++;
|
||||
return result;
|
||||
}
|
||||
|
||||
default: assert(false); break;
|
||||
}
|
||||
}
|
||||
|
||||
@ -107,7 +111,7 @@ uint32_t CSW::get_next_int32le() {
|
||||
return result;
|
||||
}
|
||||
|
||||
default: return 0;
|
||||
default: assert(false); break;
|
||||
}
|
||||
}
|
||||
|
||||
@ -120,7 +124,7 @@ bool CSW::is_at_end() {
|
||||
case CompressionType::RLE: return file_.eof();
|
||||
case CompressionType::ZRLE: return source_data_pointer_ == source_data_.size();
|
||||
|
||||
default: return true;
|
||||
default: assert(false); break;
|
||||
}
|
||||
}
|
||||
|
||||
@ -129,7 +133,7 @@ void CSW::virtual_reset() {
|
||||
case CompressionType::RLE: file_.seek(rle_start_, SEEK_SET); break;
|
||||
case CompressionType::ZRLE: source_data_pointer_ = 0; break;
|
||||
|
||||
default: break;
|
||||
default: assert(false); break;
|
||||
}
|
||||
}
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user