mirror of
https://github.com/catseye/SixtyPical.git
synced 2025-02-01 23:33:28 +00:00
Attempt to flatten the code for generating code for copy
.
This commit is contained in:
parent
c194808e64
commit
1180d2fe2a
@ -396,17 +396,13 @@ class Compiler(object):
|
|||||||
raise NotImplementedError((src, dest))
|
raise NotImplementedError((src, dest))
|
||||||
else:
|
else:
|
||||||
raise NotImplementedError((src, dest))
|
raise NotImplementedError((src, dest))
|
||||||
elif isinstance(src, IndirectRef) and isinstance(dest, LocationRef):
|
elif isinstance(src, IndirectRef) and isinstance(dest, LocationRef) and dest.type == TYPE_BYTE and isinstance(src.ref.type, PointerType):
|
||||||
if dest.type == TYPE_BYTE and isinstance(src.ref.type, PointerType):
|
|
||||||
### copy [ptr] + y, b
|
### copy [ptr] + y, b
|
||||||
src_label = self.get_label(src.ref.name)
|
src_label = self.get_label(src.ref.name)
|
||||||
dest_label = self.get_label(dest.name)
|
dest_label = self.get_label(dest.name)
|
||||||
self.emitter.emit(LDA(IndirectY(src_label)))
|
self.emitter.emit(LDA(IndirectY(src_label)))
|
||||||
self.emitter.emit(STA(Absolute(dest_label)))
|
self.emitter.emit(STA(Absolute(dest_label)))
|
||||||
else:
|
elif isinstance(src, AddressRef) and isinstance(dest, LocationRef) and isinstance(src.ref.type, BufferType) and isinstance(dest.type, PointerType):
|
||||||
raise NotImplementedError((src, dest))
|
|
||||||
elif isinstance(src, AddressRef) and isinstance(dest, LocationRef) and \
|
|
||||||
isinstance(src.ref.type, BufferType) and isinstance(dest.type, PointerType):
|
|
||||||
### copy ^buf, ptr
|
### copy ^buf, ptr
|
||||||
src_label = self.get_label(src.ref.name)
|
src_label = self.get_label(src.ref.name)
|
||||||
dest_label = self.get_label(dest.name)
|
dest_label = self.get_label(dest.name)
|
||||||
@ -414,8 +410,7 @@ class Compiler(object):
|
|||||||
self.emitter.emit(STA(ZeroPage(dest_label)))
|
self.emitter.emit(STA(ZeroPage(dest_label)))
|
||||||
self.emitter.emit(LDA(Immediate(LowAddressByte(src_label))))
|
self.emitter.emit(LDA(Immediate(LowAddressByte(src_label))))
|
||||||
self.emitter.emit(STA(ZeroPage(Offset(dest_label, 1))))
|
self.emitter.emit(STA(ZeroPage(Offset(dest_label, 1))))
|
||||||
elif isinstance(src, LocationRef) and isinstance(dest, IndexedRef):
|
elif isinstance(src, LocationRef) and isinstance(dest, IndexedRef) and src.type == TYPE_WORD and TableType.is_a_table_type(dest.ref.type, TYPE_WORD):
|
||||||
if src.type == TYPE_WORD and TableType.is_a_table_type(dest.ref.type, TYPE_WORD):
|
|
||||||
### copy w, wtab + y
|
### copy w, wtab + y
|
||||||
src_label = self.get_label(src.name)
|
src_label = self.get_label(src.name)
|
||||||
dest_label = self.get_label(dest.ref.name)
|
dest_label = self.get_label(dest.ref.name)
|
||||||
@ -423,7 +418,7 @@ class Compiler(object):
|
|||||||
self.emitter.emit(STA(self.addressing_mode_for_index(dest.index)(dest_label)))
|
self.emitter.emit(STA(self.addressing_mode_for_index(dest.index)(dest_label)))
|
||||||
self.emitter.emit(LDA(Absolute(Offset(src_label, 1))))
|
self.emitter.emit(LDA(Absolute(Offset(src_label, 1))))
|
||||||
self.emitter.emit(STA(self.addressing_mode_for_index(dest.index)(Offset(dest_label, 256))))
|
self.emitter.emit(STA(self.addressing_mode_for_index(dest.index)(Offset(dest_label, 256))))
|
||||||
elif isinstance(src.type, VectorType) and isinstance(dest.ref.type, TableType) and isinstance(dest.ref.type.of_type, VectorType):
|
elif isinstance(src, LocationRef) and isinstance(dest, IndexedRef) and isinstance(src.type, VectorType) and isinstance(dest.ref.type, TableType) and isinstance(dest.ref.type.of_type, VectorType):
|
||||||
### copy vec, vtab + y
|
### copy vec, vtab + y
|
||||||
# FIXME this is the exact same as above - can this be simplified?
|
# FIXME this is the exact same as above - can this be simplified?
|
||||||
src_label = self.get_label(src.name)
|
src_label = self.get_label(src.name)
|
||||||
@ -432,7 +427,7 @@ class Compiler(object):
|
|||||||
self.emitter.emit(STA(self.addressing_mode_for_index(dest.index)(dest_label)))
|
self.emitter.emit(STA(self.addressing_mode_for_index(dest.index)(dest_label)))
|
||||||
self.emitter.emit(LDA(Absolute(Offset(src_label, 1))))
|
self.emitter.emit(LDA(Absolute(Offset(src_label, 1))))
|
||||||
self.emitter.emit(STA(self.addressing_mode_for_index(dest.index)(Offset(dest_label, 256))))
|
self.emitter.emit(STA(self.addressing_mode_for_index(dest.index)(Offset(dest_label, 256))))
|
||||||
elif isinstance(src.type, RoutineType) and isinstance(dest.ref.type, TableType) and isinstance(dest.ref.type.of_type, VectorType):
|
elif isinstance(src, LocationRef) and isinstance(dest, IndexedRef) and isinstance(src.type, RoutineType) and isinstance(dest.ref.type, TableType) and isinstance(dest.ref.type.of_type, VectorType):
|
||||||
### copy routine, vtab + y
|
### copy routine, vtab + y
|
||||||
src_label = self.get_label(src.name)
|
src_label = self.get_label(src.name)
|
||||||
dest_label = self.get_label(dest.ref.name)
|
dest_label = self.get_label(dest.ref.name)
|
||||||
@ -440,20 +435,14 @@ class Compiler(object):
|
|||||||
self.emitter.emit(STA(self.addressing_mode_for_index(dest.index)(dest_label)))
|
self.emitter.emit(STA(self.addressing_mode_for_index(dest.index)(dest_label)))
|
||||||
self.emitter.emit(LDA(Immediate(LowAddressByte(src_label))))
|
self.emitter.emit(LDA(Immediate(LowAddressByte(src_label))))
|
||||||
self.emitter.emit(STA(self.addressing_mode_for_index(dest.index)(Offset(dest_label, 256))))
|
self.emitter.emit(STA(self.addressing_mode_for_index(dest.index)(Offset(dest_label, 256))))
|
||||||
else:
|
elif isinstance(src, ConstantRef) and isinstance(dest, IndexedRef) and src.type == TYPE_WORD and TableType.is_a_table_type(dest.ref.type, TYPE_WORD):
|
||||||
raise NotImplementedError
|
|
||||||
elif isinstance(src, ConstantRef) and isinstance(dest, IndexedRef):
|
|
||||||
if src.type == TYPE_WORD and TableType.is_a_table_type(dest.ref.type, TYPE_WORD):
|
|
||||||
### copy 9999, wtab + y
|
### copy 9999, wtab + y
|
||||||
dest_label = self.get_label(dest.ref.name)
|
dest_label = self.get_label(dest.ref.name)
|
||||||
self.emitter.emit(LDA(Immediate(Byte(src.low_byte()))))
|
self.emitter.emit(LDA(Immediate(Byte(src.low_byte()))))
|
||||||
self.emitter.emit(STA(self.addressing_mode_for_index(dest.index)(dest_label)))
|
self.emitter.emit(STA(self.addressing_mode_for_index(dest.index)(dest_label)))
|
||||||
self.emitter.emit(LDA(Immediate(Byte(src.high_byte()))))
|
self.emitter.emit(LDA(Immediate(Byte(src.high_byte()))))
|
||||||
self.emitter.emit(STA(self.addressing_mode_for_index(dest.index)(Offset(dest_label, 256))))
|
self.emitter.emit(STA(self.addressing_mode_for_index(dest.index)(Offset(dest_label, 256))))
|
||||||
else:
|
elif isinstance(src, IndexedRef) and isinstance(dest, LocationRef) and TableType.is_a_table_type(src.ref.type, TYPE_WORD) and dest.type == TYPE_WORD:
|
||||||
raise NotImplementedError
|
|
||||||
elif isinstance(src, IndexedRef) and isinstance(dest, LocationRef):
|
|
||||||
if TableType.is_a_table_type(src.ref.type, TYPE_WORD) and dest.type == TYPE_WORD:
|
|
||||||
### copy wtab + y, w
|
### copy wtab + y, w
|
||||||
src_label = self.get_label(src.ref.name)
|
src_label = self.get_label(src.ref.name)
|
||||||
dest_label = self.get_label(dest.name)
|
dest_label = self.get_label(dest.name)
|
||||||
@ -461,7 +450,7 @@ class Compiler(object):
|
|||||||
self.emitter.emit(STA(Absolute(dest_label)))
|
self.emitter.emit(STA(Absolute(dest_label)))
|
||||||
self.emitter.emit(LDA(self.addressing_mode_for_index(src.index)(Offset(src_label, 256))))
|
self.emitter.emit(LDA(self.addressing_mode_for_index(src.index)(Offset(src_label, 256))))
|
||||||
self.emitter.emit(STA(Absolute(Offset(dest_label, 1))))
|
self.emitter.emit(STA(Absolute(Offset(dest_label, 1))))
|
||||||
elif isinstance(dest.type, VectorType) and isinstance(src.ref.type, TableType) and isinstance(src.ref.type.of_type, VectorType):
|
elif isinstance(src, IndexedRef) and isinstance(dest, LocationRef) and isinstance(dest.type, VectorType) and isinstance(src.ref.type, TableType) and isinstance(src.ref.type.of_type, VectorType):
|
||||||
### copy vtab + y, vec
|
### copy vtab + y, vec
|
||||||
# FIXME this is the exact same as above - can this be simplified?
|
# FIXME this is the exact same as above - can this be simplified?
|
||||||
src_label = self.get_label(src.ref.name)
|
src_label = self.get_label(src.ref.name)
|
||||||
@ -470,29 +459,20 @@ class Compiler(object):
|
|||||||
self.emitter.emit(STA(Absolute(dest_label)))
|
self.emitter.emit(STA(Absolute(dest_label)))
|
||||||
self.emitter.emit(LDA(self.addressing_mode_for_index(src.index)(Offset(src_label, 256))))
|
self.emitter.emit(LDA(self.addressing_mode_for_index(src.index)(Offset(src_label, 256))))
|
||||||
self.emitter.emit(STA(Absolute(Offset(dest_label, 1))))
|
self.emitter.emit(STA(Absolute(Offset(dest_label, 1))))
|
||||||
else:
|
elif src.type == TYPE_BYTE and dest.type == TYPE_BYTE and not isinstance(src, ConstantRef):
|
||||||
raise NotImplementedError
|
|
||||||
|
|
||||||
elif not isinstance(src, (ConstantRef, LocationRef)) or not isinstance(dest, LocationRef):
|
|
||||||
raise NotImplementedError((src, dest))
|
|
||||||
elif src.type == TYPE_BYTE and dest.type == TYPE_BYTE:
|
|
||||||
if isinstance(src, ConstantRef):
|
|
||||||
raise NotImplementedError
|
|
||||||
else:
|
|
||||||
### copy b1, b2
|
### copy b1, b2
|
||||||
src_label = self.get_label(src.name)
|
src_label = self.get_label(src.name)
|
||||||
dest_label = self.get_label(dest.name)
|
dest_label = self.get_label(dest.name)
|
||||||
self.emitter.emit(LDA(Absolute(src_label)))
|
self.emitter.emit(LDA(Absolute(src_label)))
|
||||||
self.emitter.emit(STA(Absolute(dest_label)))
|
self.emitter.emit(STA(Absolute(dest_label)))
|
||||||
elif src.type == TYPE_WORD and dest.type == TYPE_WORD:
|
elif src.type == TYPE_WORD and dest.type == TYPE_WORD and isinstance(src, ConstantRef):
|
||||||
if isinstance(src, ConstantRef):
|
|
||||||
### copy 9999, w
|
### copy 9999, w
|
||||||
dest_label = self.get_label(dest.name)
|
dest_label = self.get_label(dest.name)
|
||||||
self.emitter.emit(LDA(Immediate(Byte(src.low_byte()))))
|
self.emitter.emit(LDA(Immediate(Byte(src.low_byte()))))
|
||||||
self.emitter.emit(STA(Absolute(dest_label)))
|
self.emitter.emit(STA(Absolute(dest_label)))
|
||||||
self.emitter.emit(LDA(Immediate(Byte(src.high_byte()))))
|
self.emitter.emit(LDA(Immediate(Byte(src.high_byte()))))
|
||||||
self.emitter.emit(STA(Absolute(Offset(dest_label, 1))))
|
self.emitter.emit(STA(Absolute(Offset(dest_label, 1))))
|
||||||
else:
|
elif src.type == TYPE_WORD and dest.type == TYPE_WORD and not isinstance(src, ConstantRef):
|
||||||
### copy w1, w2
|
### copy w1, w2
|
||||||
src_label = self.get_label(src.name)
|
src_label = self.get_label(src.name)
|
||||||
dest_label = self.get_label(dest.name)
|
dest_label = self.get_label(dest.name)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user