X-Git-Url: https://git.cworth.org/git?a=blobdiff_plain;f=retrace.hpp;h=33671411deb2a8b7841a078adfefc71d60fe273f;hb=8e3c2c0d01c7ec5479845fedc053da00fa88e76a;hp=05cef5970ed88cad50efb8a7bb8d338076efbc0d;hpb=f237aad2923b7d402b7fd2a0a71aa1a030ddeebb;p=apitrace diff --git a/retrace.hpp b/retrace.hpp index 05cef59..3367141 100644 --- a/retrace.hpp +++ b/retrace.hpp @@ -26,14 +26,22 @@ #ifndef _RETRACE_HPP_ #define _RETRACE_HPP_ +#include + +#include #include +#include #include "trace_model.hpp" +#include "trace_parser.hpp" namespace retrace { +extern trace::Parser parser; + + /** * Handle map. * @@ -76,13 +84,66 @@ public: }; +void +addRegion(unsigned long long address, void *buffer, unsigned long long size); + +void +delRegionByPointer(void *ptr); + +void * +toPointer(trace::Value &value, bool bind = false); + + /** * Output verbosity when retracing files. */ extern int verbosity; -void retrace_call(Trace::Call &call); +std::ostream &warning(trace::Call &call); + + +void ignore(trace::Call &call); +void unsupported(trace::Call &call); + + +typedef void (*Callback)(trace::Call &call); + +struct Entry { + const char *name; + Callback callback; +}; + + +struct stringComparer { + bool operator() (const char *a, const char *b) const { + return strcmp(a, b) < 0; + } +}; + + +extern const Entry stdc_callbacks[]; + + +class Retracer +{ + typedef std::map Map; + Map map; + + std::vector callbacks; + +public: + Retracer() { + addCallbacks(stdc_callbacks); + } + + virtual ~Retracer() {} + + void addCallback(const Entry *entry); + void addCallbacks(const Entry *entries); + + void retrace(trace::Call &call); +}; } /* namespace retrace */