diff options
author | Walter van Niftrik | 2016-03-26 01:01:10 +0100 |
---|---|---|
committer | Walter van Niftrik | 2016-06-06 20:35:49 +0200 |
commit | 7ee183ca481c2729cb703ced3b6a3fa4ad7d73a3 (patch) | |
tree | 84315570e13fda3b82e43a627ee5eada22d30b1c /engines/adl/disk.cpp | |
parent | 02563df42218d103a80e9bc5463cc63909b2f495 (diff) | |
download | scummvm-rg350-7ee183ca481c2729cb703ced3b6a3fa4ad7d73a3.tar.gz scummvm-rg350-7ee183ca481c2729cb703ced3b6a3fa4ad7d73a3.tar.bz2 scummvm-rg350-7ee183ca481c2729cb703ced3b6a3fa4ad7d73a3.zip |
ADL: Refactor disk classes
Diffstat (limited to 'engines/adl/disk.cpp')
-rw-r--r-- | engines/adl/disk.cpp | 49 |
1 files changed, 10 insertions, 39 deletions
diff --git a/engines/adl/disk.cpp b/engines/adl/disk.cpp index b7de55a78e..22a7d7a431 100644 --- a/engines/adl/disk.cpp +++ b/engines/adl/disk.cpp @@ -28,35 +28,8 @@ namespace Adl { -DiskImage::DiskImage() : - _tracks(0), - _sectorsPerTrack(0), - _bytesPerSector(0) { - _f = new Common::File(); -} - -DiskImage::~DiskImage() { - delete _f; -} - -DiskImageDataBlock::DiskImageDataBlock(const DiskImage *disk, uint track, uint sector, uint offset, uint size) : - _track(track), - _sector(sector), - _offset(offset), - _size(size), - _disk(disk) { } - -bool DiskImageDataBlock::isValid() const { - return _track != 0 || _sector != 0 || _offset != 0 || _size != 0; -} - -Common::SeekableReadStream *DiskImageDataBlock::createReadStream() const { - return _disk->createReadStream(_track, _sector, _offset, _size); -} - -// .DSK disk image - 35 tracks, 16 sectors per track, 256 bytes per sector, raw sector layout const DataBlockPtr DiskImage_DSK::getDataBlock(uint track, uint sector, uint offset, uint size) const { - return Common::SharedPtr<DiskImageDataBlock>(new DiskImageDataBlock(this, track, sector, offset, size)); + return Common::SharedPtr<DiskImage::DataBlock>(new DiskImage::DataBlock(this, track, sector, offset, size)); } Common::SeekableReadStream *DiskImage_DSK::createReadStream(uint track, uint sector, uint offset, uint size) const { @@ -81,22 +54,20 @@ bool DiskImage_DSK::open(const Common::String &filename) { _tracks = 35; _sectorsPerTrack = 16; _bytesPerSector = 256; - return true; + break; + default: + warning("Unrecognized disk image '%s' of size %d bytes", filename.c_str(), filesize); + return false; } - warning("Unrecognized disk image '%s' of size %d bytes", filename.c_str(), filesize); - return false; -} - -Common::SeekableReadStream *FilesDataBlock::createReadStream() const { - return _files->createReadStream(_filename, _offset); + return true; } -const DataBlockPtr PlainFiles::getDataBlock(const Common::String &filename, uint offset) const { - return Common::SharedPtr<FilesDataBlock>(new FilesDataBlock(this, filename, offset)); +const DataBlockPtr Files_Plain::getDataBlock(const Common::String &filename, uint offset) const { + return Common::SharedPtr<Files::DataBlock>(new Files::DataBlock(this, filename, offset)); } -Common::SeekableReadStream *PlainFiles::createReadStream(const Common::String &filename, uint offset) const { +Common::SeekableReadStream *Files_Plain::createReadStream(const Common::String &filename, uint offset) const { Common::File *f(new Common::File()); if (!f->open(filename)) @@ -194,7 +165,7 @@ void Files_DOS33::readVTOC() { } const DataBlockPtr Files_DOS33::getDataBlock(const Common::String &filename, uint offset) const { - return Common::SharedPtr<FilesDataBlock>(new FilesDataBlock(this, filename, offset)); + return Common::SharedPtr<Files::DataBlock>(new Files::DataBlock(this, filename, offset)); } Common::SeekableReadStream *Files_DOS33::createReadStreamText(const TOCEntry &entry) const { |