[swfinterp] Allow function patching

pull/4237/head
Philipp Hagemeister 10 years ago
parent a0f59cdcb4
commit b7558d9881

@ -150,6 +150,7 @@ def _read_byte(reader):
class SWFInterpreter(object): class SWFInterpreter(object):
def __init__(self, file_contents): def __init__(self, file_contents):
self._patched_functions = {}
code_tag = next(tag code_tag = next(tag
for tag_code, tag in _extract_tags(file_contents) for tag_code, tag in _extract_tags(file_contents)
if tag_code == 82) if tag_code == 82)
@ -354,6 +355,9 @@ class SWFInterpreter(object):
assert p + code_reader.tell() == len(code_tag) assert p + code_reader.tell() == len(code_tag)
def patch_function(self, avm_class, func_name, f):
self._patched_functions[(avm_class, func_name)] = f
def extract_class(self, class_name): def extract_class(self, class_name):
try: try:
return self._classes_by_name[class_name] return self._classes_by_name[class_name]
@ -361,6 +365,9 @@ class SWFInterpreter(object):
raise ExtractorError('Class %r not found' % class_name) raise ExtractorError('Class %r not found' % class_name)
def extract_function(self, avm_class, func_name): def extract_function(self, avm_class, func_name):
p = self._patched_functions.get((avm_class, func_name))
if p:
return p
if func_name in avm_class.method_pyfunctions: if func_name in avm_class.method_pyfunctions:
return avm_class.method_pyfunctions[func_name] return avm_class.method_pyfunctions[func_name]
if func_name in self._classes_by_name: if func_name in self._classes_by_name:

Loading…
Cancel
Save