atrcopy/atrcopy/dos33.py

106 lines
3.1 KiB
Python
Raw Normal View History

2016-07-20 15:13:44 +00:00
import numpy as np
from errors import *
2016-07-20 17:03:29 +00:00
from diskimages import AtrHeader, DiskImageBase
2016-07-20 15:13:44 +00:00
from segments import DefaultSegment, EmptySegment, ObjSegment, RawSectorsSegment, SegmentSaver
import logging
log = logging.getLogger(__name__)
2016-07-20 17:03:29 +00:00
class Dos33Header(AtrHeader):
2016-07-20 15:13:44 +00:00
file_format = "DOS 3.3"
def __init__(self):
2016-07-20 17:03:29 +00:00
AtrHeader.__init__(self, None, 256, 0)
2016-07-20 15:13:44 +00:00
self.header_offset = 0
2016-07-20 17:03:29 +00:00
self.sector_order = range(16)
2016-07-20 15:13:44 +00:00
def __str__(self):
return "%s Disk Image (size=%d (%dx%db)" % (self.file_format, self.image_size, self.max_sectors, self.sector_size)
def __len__(self):
return 0
def to_array(self):
raw = np.zeros([0], dtype=np.uint8)
return raw
def check_size(self, size):
2016-07-20 17:03:29 +00:00
AtrHeader.check_size(self, size)
if size != 143360:
2016-07-20 15:13:44 +00:00
raise InvalidDiskImage("Incorrect size for DOS 3.3 image")
2016-07-20 17:03:29 +00:00
def sector_is_valid(self, sector):
# DOS 3.3 sectors count from 0
return sector >= 0 and sector < self.max_sectors
def get_pos(self, sector):
if not self.sector_is_valid(sector):
raise ByteNotInFile166("Sector %d out of range" % sector)
pos = sector * self.sector_size
size = self.sector_size
return pos, size
2016-07-20 15:13:44 +00:00
class Dos33DiskImage(DiskImageBase):
def __init__(self, rawdata, filename=""):
DiskImageBase.__init__(self, rawdata, filename)
def __str__(self):
return str(self.header)
def read_header(self):
self.header = Dos33Header()
2016-07-20 17:03:29 +00:00
def get_boot_sector_info(self):
# based on logic from a2server
data, style = self.get_sectors(0)
magic = data[0:4]
if (magic == [1, 56, 176, 3]).all():
raise InvalidDiskImage("ProDOS format found; not DOS 3.3 image")
swap_order = False
data, style = self.get_sectors(17 * 16)
if data[3] == 3:
if data[1] < 35 and data[2] < 16:
data, style = self.get_sectors(17 * 16 + 14)
if data[2] != 13:
swap_order = True
else:
raise InvalidDiskImage("Invalid VTOC location for DOS 3.3")
print "swap", swap_order
2016-07-20 15:13:44 +00:00
def get_boot_segments(self):
return []
2016-07-20 17:03:29 +00:00
class ProdosHeader(Dos33Header):
file_format = "ProDOS"
class ProdosDiskImage(Dos33DiskImage):
def read_header(self):
self.header = ProdosHeader()
print "HI"
def get_boot_sector_info(self):
# based on logic from a2server
data, style = self.get_sectors(0)
magic = data[0:4]
swap_order = False
if (magic == [1, 56, 176, 3]).all():
data, style = self.get_sectors(1)
prodos = data[3:9].tostring()
if prodos == "PRODOS":
pass
else:
data, style = self.get_sectors(14)
prodos = data[3:9].tostring()
if prodos == "PRODOS":
swap_order = True
else:
raise InvalidDiskImage("No ProDOS header info found")
print "swap", swap_order