mirror of
https://github.com/michaelcmartin/Ophis.git
synced 2025-01-02 14:29:35 +00:00
make addressing mode cooercion work with varying addressing mode
lists.
This commit is contained in:
parent
5c162d2407
commit
591fc2fe35
@ -476,7 +476,7 @@ class Collapse(PCTracker):
|
|||||||
|
|
||||||
def visitZeroPage(self, node, env):
|
def visitZeroPage(self, node, env):
|
||||||
if node.data[1].value(env) >= 0x100:
|
if node.data[1].value(env) >= 0x100:
|
||||||
if Ops.opcodes[node.data[0]][5] is not None:
|
if Ops.opcodes[node.data[0]][Ops.modes.index("Absolute")] is not None:
|
||||||
node.nodetype = "Absolute"
|
node.nodetype = "Absolute"
|
||||||
PCTracker.visitAbsolute(self, node, env)
|
PCTracker.visitAbsolute(self, node, env)
|
||||||
self.changed = True
|
self.changed = True
|
||||||
@ -485,7 +485,7 @@ class Collapse(PCTracker):
|
|||||||
|
|
||||||
def visitZeroPageX(self, node, env):
|
def visitZeroPageX(self, node, env):
|
||||||
if node.data[1].value(env) >= 0x100:
|
if node.data[1].value(env) >= 0x100:
|
||||||
if Ops.opcodes[node.data[0]][6] is not None:
|
if Ops.opcodes[node.data[0]][Ops.modes.index("Absolute, X")] is not None:
|
||||||
node.nodetype = "AbsoluteX"
|
node.nodetype = "AbsoluteX"
|
||||||
PCTracker.visitAbsoluteX(self, node, env)
|
PCTracker.visitAbsoluteX(self, node, env)
|
||||||
self.changed = True
|
self.changed = True
|
||||||
@ -494,7 +494,7 @@ class Collapse(PCTracker):
|
|||||||
|
|
||||||
def visitZeroPageY(self, node, env):
|
def visitZeroPageY(self, node, env):
|
||||||
if node.data[1].value(env) >= 0x100:
|
if node.data[1].value(env) >= 0x100:
|
||||||
if Ops.opcodes[node.data[0]][7] is not None:
|
if Ops.opcodes[node.data[0]][Ops.modes.index("Absolute, Y")] is not None:
|
||||||
node.nodetype = "AbsoluteY"
|
node.nodetype = "AbsoluteY"
|
||||||
PCTracker.visitAbsoluteY(self, node, env)
|
PCTracker.visitAbsoluteY(self, node, env)
|
||||||
self.changed = True
|
self.changed = True
|
||||||
@ -506,7 +506,7 @@ def collapse_no_index(node, env):
|
|||||||
"""Transforms a Memory node into a ZeroPage one if possible.
|
"""Transforms a Memory node into a ZeroPage one if possible.
|
||||||
Returns boolean indicating whether or not it made the collapse."""
|
Returns boolean indicating whether or not it made the collapse."""
|
||||||
if node.data[1].value(env) < 0x100:
|
if node.data[1].value(env) < 0x100:
|
||||||
if Ops.opcodes[node.data[0]][2] is not None:
|
if Ops.opcodes[node.data[0]][Ops.modes.index("Zero Page")] is not None:
|
||||||
node.nodetype = "ZeroPage"
|
node.nodetype = "ZeroPage"
|
||||||
return True
|
return True
|
||||||
return False
|
return False
|
||||||
@ -516,7 +516,7 @@ def collapse_x(node, env):
|
|||||||
"""Transforms a MemoryX node into a ZeroPageX one if possible.
|
"""Transforms a MemoryX node into a ZeroPageX one if possible.
|
||||||
Returns boolean indicating whether or not it made the collapse."""
|
Returns boolean indicating whether or not it made the collapse."""
|
||||||
if node.data[1].value(env) < 0x100:
|
if node.data[1].value(env) < 0x100:
|
||||||
if Ops.opcodes[node.data[0]][3] is not None:
|
if Ops.opcodes[node.data[0]][Ops.modes.index("Zero Page, X")] is not None:
|
||||||
node.nodetype = "ZeroPageX"
|
node.nodetype = "ZeroPageX"
|
||||||
return True
|
return True
|
||||||
return False
|
return False
|
||||||
@ -526,7 +526,7 @@ def collapse_y(node, env):
|
|||||||
"""Transforms a MemoryY node into a ZeroPageY one if possible.
|
"""Transforms a MemoryY node into a ZeroPageY one if possible.
|
||||||
Returns boolean indicating whether or not it made the collapse."""
|
Returns boolean indicating whether or not it made the collapse."""
|
||||||
if node.data[1].value(env) < 0x100:
|
if node.data[1].value(env) < 0x100:
|
||||||
if Ops.opcodes[node.data[0]][4] is not None:
|
if Ops.opcodes[node.data[0]][Ops.modes.index("Zero Page, Y")] is not None:
|
||||||
node.nodetype = "ZeroPageY"
|
node.nodetype = "ZeroPageY"
|
||||||
return True
|
return True
|
||||||
return False
|
return False
|
||||||
@ -535,7 +535,7 @@ def collapse_no_index_ind(node, env):
|
|||||||
"""Transforms a Pointer node into a ZPIndirect one if possible.
|
"""Transforms a Pointer node into a ZPIndirect one if possible.
|
||||||
Returns boolean indicating whether or not it made the collapse."""
|
Returns boolean indicating whether or not it made the collapse."""
|
||||||
if node.data[1].value(env) < 0x100:
|
if node.data[1].value(env) < 0x100:
|
||||||
if Ops.opcodes[node.data[0]][11] is not None:
|
if Ops.opcodes[node.data[0]][Ops.modes.index("(Zero Page)")] is not None:
|
||||||
node.nodetype = "ZPIndirect"
|
node.nodetype = "ZPIndirect"
|
||||||
return True
|
return True
|
||||||
return False
|
return False
|
||||||
@ -545,7 +545,7 @@ def collapse_x_ind(node, env):
|
|||||||
"""Transforms a PointerX node into an IndirectX one if possible.
|
"""Transforms a PointerX node into an IndirectX one if possible.
|
||||||
Returns boolean indicating whether or not it made the collapse."""
|
Returns boolean indicating whether or not it made the collapse."""
|
||||||
if node.data[1].value(env) < 0x100:
|
if node.data[1].value(env) < 0x100:
|
||||||
if Ops.opcodes[node.data[0]][12] is not None:
|
if Ops.opcodes[node.data[0]][Ops.modes.index("(Zero Page, X)")] is not None:
|
||||||
node.nodetype = "IndirectX"
|
node.nodetype = "IndirectX"
|
||||||
return True
|
return True
|
||||||
return False
|
return False
|
||||||
@ -555,7 +555,7 @@ def collapse_y_ind(node, env):
|
|||||||
"""Transforms a PointerY node into an IndirectY one if possible.
|
"""Transforms a PointerY node into an IndirectY one if possible.
|
||||||
Returns boolean indicating whether or not it made the collapse."""
|
Returns boolean indicating whether or not it made the collapse."""
|
||||||
if node.data[1].value(env) < 0x100:
|
if node.data[1].value(env) < 0x100:
|
||||||
if Ops.opcodes[node.data[0]][13] is not None:
|
if Ops.opcodes[node.data[0]][Ops.modes.index("(Zero Page), Y")] is not None:
|
||||||
node.nodetype = "IndirectY"
|
node.nodetype = "IndirectY"
|
||||||
return True
|
return True
|
||||||
return False
|
return False
|
||||||
@ -564,7 +564,7 @@ def collapse_spy_ind(node, env):
|
|||||||
"""Transforms a PointerSPY node into an IndirectY one if possible.
|
"""Transforms a PointerSPY node into an IndirectY one if possible.
|
||||||
Returns boolean indicating whether or not it made the collapse."""
|
Returns boolean indicating whether or not it made the collapse."""
|
||||||
if node.data[1].value(env) < 0x100:
|
if node.data[1].value(env) < 0x100:
|
||||||
if Ops.opcodes[node.data[0]][13] is not None:
|
if Ops.opcodes[node.data[0]][Ops.modes.index("(Zero Page, SP), Y")] is not None:
|
||||||
node.nodetype = "IndirectSPY"
|
node.nodetype = "IndirectSPY"
|
||||||
return True
|
return True
|
||||||
return False
|
return False
|
||||||
@ -573,7 +573,7 @@ def collapse_z_ind(node, env):
|
|||||||
"""Transforms a PointerZ node into an IndirectZ one if possible.
|
"""Transforms a PointerZ node into an IndirectZ one if possible.
|
||||||
Returns boolean indicating whether or not it made the collapse."""
|
Returns boolean indicating whether or not it made the collapse."""
|
||||||
if node.data[1].value(env) < 0x100:
|
if node.data[1].value(env) < 0x100:
|
||||||
if Ops.opcodes[node.data[0]][13] is not None:
|
if Ops.opcodes[node.data[0]][Ops.modes.index("(Zero Page), Z")] is not None:
|
||||||
node.nodetype = "IndirectZ"
|
node.nodetype = "IndirectZ"
|
||||||
return True
|
return True
|
||||||
return False
|
return False
|
||||||
|
Loading…
Reference in New Issue
Block a user