X-Git-Url: https://git.cworth.org/git?a=blobdiff_plain;f=retrace%2Fretrace.py;h=ecad9f45615497c6657e419f2ef2cd813ab79326;hb=fbcb5d9fc467da2d91b330bfd62f15e7d07ed1c2;hp=51da6fec24ff2ec78beeb280fd3f591b9a62178e;hpb=84cea3b6f23efbd60bf57a642459e402247f8902;p=apitrace diff --git a/retrace/retrace.py b/retrace/retrace.py index 51da6fe..ecad9f4 100644 --- a/retrace/retrace.py +++ b/retrace/retrace.py @@ -34,7 +34,6 @@ sys.path.insert(0, os.path.join(os.path.dirname(__file__), '..')) import specs.stdapi as stdapi -import specs.glapi as glapi class UnsupportedType(Exception): @@ -151,12 +150,7 @@ class ValueDeserializer(stdapi.Visitor): print ' %s = static_cast<%s>((%s).toPointer());' % (lvalue, pointer, rvalue) def visitObjPointer(self, pointer, lvalue, rvalue): - old_lvalue = '(%s).toUIntPtr()' % (rvalue,) - new_lvalue = '_obj_map[%s]' % (old_lvalue,) - print ' if (retrace::verbosity >= 2) {' - print ' std::cout << std::hex << "obj 0x" << size_t(%s) << " <- 0x" << size_t(%s) << std::dec <<"\\n";' % (old_lvalue, new_lvalue) - print ' }' - print ' %s = static_cast<%s>(%s);' % (lvalue, pointer, new_lvalue) + print ' %s = static_cast<%s>(retrace::toObjPointer(call, %s));' % (lvalue, pointer, rvalue) def visitLinearPointer(self, pointer, lvalue, rvalue): print ' %s = static_cast<%s>(retrace::toPointer(%s));' % (lvalue, pointer, rvalue) @@ -248,7 +242,7 @@ class SwizzledValueRegistrator(stdapi.Visitor): pass def visitObjPointer(self, pointer, lvalue, rvalue): - print r' _obj_map[(%s).toUIntPtr()] = %s;' % (rvalue, lvalue) + print r' retrace::addObj(%s, %s);' % (rvalue, lvalue) def visitLinearPointer(self, pointer, lvalue, rvalue): assert pointer.size is not None @@ -328,6 +322,7 @@ class Retracer: self.deserializeArgs(function) + self.declareRet(function) self.invokeFunction(function) self.swizzleValues(function) @@ -342,6 +337,7 @@ class Retracer: self.deserializeArgs(method) + self.declareRet(method) self.invokeInterfaceMethod(interface, method) self.swizzleValues(method) @@ -360,9 +356,8 @@ class Retracer: def deserializeThisPointer(self, interface): print r' %s *_this;' % (interface.name,) - print r' _this = static_cast<%s *>(_obj_map[call.arg(0).toUIntPtr()]);' % (interface.name,) + print r' _this = static_cast<%s *>(retrace::toObjPointer(call, call.arg(0)));' % (interface.name,) print r' if (!_this) {' - print r' retrace::warning(call) << "NULL this pointer\n";' print r' return;' print r' }' @@ -430,10 +425,13 @@ class Retracer: visitor = SwizzledValueRegistrator() visitor.visit(type, lvalue, rvalue) + def declareRet(self, function): + if function.type is not stdapi.Void: + print ' %s _result;' % (function.type) + def invokeFunction(self, function): arg_names = ", ".join(function.argNames()) if function.type is not stdapi.Void: - print ' %s _result;' % (function.type) print ' _result = %s(%s);' % (function.name, arg_names) print ' (void)_result;' else: @@ -446,11 +444,10 @@ class Retracer: print ' if (call.ret->toUInt()) {' print ' return;' print ' }' - print ' _obj_map.erase(call.arg(0).toUIntPtr());' + print ' retrace::delObj(call.arg(0));' arg_names = ", ".join(method.argNames()) if method.type is not stdapi.Void: - print ' %s _result;' % (method.type) print ' _result = _this->%s(%s);' % (method.name, arg_names) print ' (void)_result;' else: @@ -466,6 +463,7 @@ class Retracer: print '#include "os_time.hpp"' print '#include "trace_parser.hpp"' print '#include "retrace.hpp"' + print '#include "retrace_swizzle.hpp"' print types = api.getAllTypes() @@ -481,10 +479,7 @@ class Retracer: handle_names.add(handle.name) print - print 'static std::map _obj_map;' - print - - functions = filter(self.filterFunction, api.functions) + functions = filter(self.filterFunction, api.getAllFunctions()) for function in functions: if function.sideeffects and not function.internal: self.retraceFunction(function)