mirror of
https://github.com/robmcmullen/atrcopy.git
synced 2025-01-21 03:31:39 +00:00
Changed get_filename() into a property
This commit is contained in:
parent
3007e384a6
commit
9733aa4777
@ -84,7 +84,7 @@ class AtariDosDirent(object):
|
|||||||
self.deleted = False
|
self.deleted = False
|
||||||
self.num_sectors = 0
|
self.num_sectors = 0
|
||||||
self.starting_sector = 0
|
self.starting_sector = 0
|
||||||
self.filename = ""
|
self.basename = ""
|
||||||
self.ext = ""
|
self.ext = ""
|
||||||
self.is_sane = True
|
self.is_sane = True
|
||||||
self.current_sector = 0
|
self.current_sector = 0
|
||||||
@ -94,7 +94,12 @@ class AtariDosDirent(object):
|
|||||||
|
|
||||||
def __str__(self):
|
def __str__(self):
|
||||||
flags = self.summary()
|
flags = self.summary()
|
||||||
return "File #%-2d (%s) %03d %-8s%-3s %03d" % (self.file_num, flags, self.starting_sector, self.filename, self.ext, self.num_sectors)
|
return "File #%-2d (%s) %03d %-8s%-3s %03d" % (self.file_num, flags, self.starting_sector, self.basename, self.ext, self.num_sectors)
|
||||||
|
|
||||||
|
@property
|
||||||
|
def filename(self):
|
||||||
|
ext = ("." + self.ext) if self.ext else ""
|
||||||
|
return self.basename + ext
|
||||||
|
|
||||||
def summary(self):
|
def summary(self):
|
||||||
output = "o" if self.opened_output else "."
|
output = "o" if self.opened_output else "."
|
||||||
@ -132,7 +137,7 @@ class AtariDosDirent(object):
|
|||||||
self.deleted = (flag&0x80) > 0
|
self.deleted = (flag&0x80) > 0
|
||||||
self.num_sectors = int(values[1])
|
self.num_sectors = int(values[1])
|
||||||
self.starting_sector = int(values[2])
|
self.starting_sector = int(values[2])
|
||||||
self.filename = str(values[3]).rstrip()
|
self.basename = str(values[3]).rstrip()
|
||||||
self.ext = str(values[4]).rstrip()
|
self.ext = str(values[4]).rstrip()
|
||||||
self.is_sane = self.sanity_check(image)
|
self.is_sane = self.sanity_check(image)
|
||||||
|
|
||||||
@ -143,7 +148,7 @@ class AtariDosDirent(object):
|
|||||||
values[0] = flag
|
values[0] = flag
|
||||||
values[1] = self.num_sectors
|
values[1] = self.num_sectors
|
||||||
values[2] = self.starting_sector
|
values[2] = self.starting_sector
|
||||||
values[3] = self.filename
|
values[3] = self.basename
|
||||||
values[4] = self.ext
|
values[4] = self.ext
|
||||||
return data
|
return data
|
||||||
|
|
||||||
@ -204,16 +209,12 @@ class AtariDosDirent(object):
|
|||||||
num_bytes = raw[-1]
|
num_bytes = raw[-1]
|
||||||
return raw[0:num_bytes], num_bytes
|
return raw[0:num_bytes], num_bytes
|
||||||
|
|
||||||
def get_filename(self):
|
|
||||||
ext = ("." + self.ext) if self.ext else ""
|
|
||||||
return self.filename + ext
|
|
||||||
|
|
||||||
def set_values(self, filename, filetype, index):
|
def set_values(self, filename, filetype, index):
|
||||||
if "." in filename:
|
if "." in filename:
|
||||||
filename, ext = filename.split(".", 1)
|
filename, ext = filename.split(".", 1)
|
||||||
else:
|
else:
|
||||||
ext = " "
|
ext = " "
|
||||||
self.filename = "%-8s" % filename[0:8]
|
self.basename = "%-8s" % filename[0:8]
|
||||||
self.ext = ext
|
self.ext = ext
|
||||||
self.file_num = index
|
self.file_num = index
|
||||||
self.dos_2 = True
|
self.dos_2 = True
|
||||||
@ -591,12 +592,12 @@ class AtariDosDiskImage(DiskImageBase):
|
|||||||
if last:
|
if last:
|
||||||
break
|
break
|
||||||
if len(byte_order) > 0:
|
if len(byte_order) > 0:
|
||||||
name = "%s %ds@%d" % (dirent.get_filename(), dirent.num_sectors, dirent.starting_sector)
|
name = "%s %ds@%d" % (dirent.filename, dirent.num_sectors, dirent.starting_sector)
|
||||||
verbose_name = "%s (%d sectors, first@%d) %s" % (dirent.get_filename(), dirent.num_sectors, dirent.starting_sector, dirent.verbose_info)
|
verbose_name = "%s (%d sectors, first@%d) %s" % (dirent.filename, dirent.num_sectors, dirent.starting_sector, dirent.verbose_info)
|
||||||
raw = self.rawdata.get_indexed(byte_order)
|
raw = self.rawdata.get_indexed(byte_order)
|
||||||
segment = DefaultSegment(raw, name=name, verbose_name=verbose_name)
|
segment = DefaultSegment(raw, name=name, verbose_name=verbose_name)
|
||||||
else:
|
else:
|
||||||
segment = EmptySegment(self.rawdata, name=dirent.get_filename())
|
segment = EmptySegment(self.rawdata, name=dirent.filename)
|
||||||
return segment
|
return segment
|
||||||
|
|
||||||
def get_file_segments(self):
|
def get_file_segments(self):
|
||||||
|
@ -275,7 +275,7 @@ class DiskImageBase(object):
|
|||||||
|
|
||||||
def find_dirent(self, filename):
|
def find_dirent(self, filename):
|
||||||
for dirent in self.files:
|
for dirent in self.files:
|
||||||
if filename == dirent.get_filename():
|
if filename == dirent.filename:
|
||||||
return dirent
|
return dirent
|
||||||
raise FileNotFound("%s not found on disk" % filename)
|
raise FileNotFound("%s not found on disk" % filename)
|
||||||
|
|
||||||
@ -296,7 +296,7 @@ class DiskImageBase(object):
|
|||||||
try:
|
try:
|
||||||
segment = self.get_file_segment(dirent)
|
segment = self.get_file_segment(dirent)
|
||||||
except InvalidFile, e:
|
except InvalidFile, e:
|
||||||
segment = EmptySegment(self.rawdata, name=dirent.get_filename(), error=str(e))
|
segment = EmptySegment(self.rawdata, name=dirent.filename, error=str(e))
|
||||||
segments.append(segment)
|
segments.append(segment)
|
||||||
return segments
|
return segments
|
||||||
|
|
||||||
|
@ -511,12 +511,12 @@ class Dos33DiskImage(DiskImageBase):
|
|||||||
if last:
|
if last:
|
||||||
break
|
break
|
||||||
if len(byte_order) > 0:
|
if len(byte_order) > 0:
|
||||||
name = "%s %ds@%d" % (dirent.get_filename(), dirent.num_sectors, dirent.sector_map[0])
|
name = "%s %ds@%d" % (dirent.filename, dirent.num_sectors, dirent.sector_map[0])
|
||||||
verbose_name = "%s (%d sectors, first@%d) %s" % (dirent.get_filename(), dirent.num_sectors, dirent.sector_map[0], dirent.verbose_info)
|
verbose_name = "%s (%d sectors, first@%d) %s" % (dirent.filename, dirent.num_sectors, dirent.sector_map[0], dirent.verbose_info)
|
||||||
raw = self.rawdata.get_indexed(byte_order)
|
raw = self.rawdata.get_indexed(byte_order)
|
||||||
segment = DefaultSegment(raw, name=name, verbose_name=verbose_name)
|
segment = DefaultSegment(raw, name=name, verbose_name=verbose_name)
|
||||||
else:
|
else:
|
||||||
segment = EmptySegment(self.rawdata, name=dirent.get_filename())
|
segment = EmptySegment(self.rawdata, name=dirent.filename)
|
||||||
return segment
|
return segment
|
||||||
|
|
||||||
|
|
||||||
|
@ -9,10 +9,10 @@ class KBootDirent(AtariDosDirent):
|
|||||||
AtariDosDirent.__init__(self, image)
|
AtariDosDirent.__init__(self, image)
|
||||||
self.in_use = True
|
self.in_use = True
|
||||||
self.starting_sector = 4
|
self.starting_sector = 4
|
||||||
self.filename = image.filename
|
self.basename = image.filename
|
||||||
if not self.filename:
|
if not self.basename:
|
||||||
self.filename = "KBOOT"
|
self.basename = "KBOOT"
|
||||||
if self.filename == self.filename.upper():
|
if self.basename == self.basename.upper():
|
||||||
self.ext = "XEX"
|
self.ext = "XEX"
|
||||||
else:
|
else:
|
||||||
self.ext = "xex"
|
self.ext = "xex"
|
||||||
|
@ -148,7 +148,7 @@ class Directory(BaseSectorList):
|
|||||||
|
|
||||||
def find_dirent(self, filename):
|
def find_dirent(self, filename):
|
||||||
for dirent in self.dirents.values():
|
for dirent in self.dirents.values():
|
||||||
if filename == dirent.get_filename():
|
if filename == dirent.filename:
|
||||||
return dirent
|
return dirent
|
||||||
raise FileNotFound("%s not found on disk" % filename)
|
raise FileNotFound("%s not found on disk" % filename)
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user