X-Git-Url: https://git.cworth.org/git?a=blobdiff_plain;f=common%2Ftrace_parser.hpp;h=7bf0a7dce1058f2fd111ab45b2aa5ba5f1d34ca7;hb=b34c6756b2e1abb6be20770f43f44d0b5e90f677;hp=73bb7764d6cd05195622bccd7312f4110b97133d;hpb=d31700077ae75f450b12ad7d9276c08cbad57d1b;p=apitrace diff --git a/common/trace_parser.hpp b/common/trace_parser.hpp index 73bb776..7bf0a7d 100644 --- a/common/trace_parser.hpp +++ b/common/trace_parser.hpp @@ -33,6 +33,7 @@ #include "trace_file.hpp" #include "trace_format.hpp" #include "trace_model.hpp" +#include "trace_api.hpp" namespace trace { @@ -70,23 +71,26 @@ protected: // Offset in the file of where signature was defined. It is used when // reparsing to determine whether the signature definition is to be // expected next or not. - File::Offset offset; + File::Offset fileOffset; }; typedef SigState FunctionSigState; typedef SigState StructSigState; typedef SigState EnumSigState; typedef SigState BitmaskSigState; + typedef SigState StackFrameState; typedef std::vector FunctionMap; typedef std::vector StructMap; typedef std::vector EnumMap; typedef std::vector BitmaskMap; + typedef std::vector StackFrameMap; FunctionMap functions; StructMap structs; EnumMap enums; BitmaskMap bitmasks; + StackFrameMap frames; FunctionSig *glGetErrorSig; @@ -94,6 +98,7 @@ protected: public: unsigned long long version; + API api; Parser(); @@ -130,6 +135,7 @@ protected: FunctionSigFlags *parse_function_sig(void); StructSig *parse_struct_sig(); + EnumSig *parse_old_enum_sig(); EnumSig *parse_enum_sig(); BitmaskSig *parse_bitmask_sig(); @@ -144,6 +150,9 @@ protected: bool parse_call_details(Call *call, Mode mode); + bool parse_call_backtrace(Call *call, Mode mode); + StackFrame * parse_backtrace_frame(Mode mode); + void adjust_call_flags(Call *call); void parse_arg(Call *call, Mode mode); @@ -192,9 +201,15 @@ protected: Value *parse_opaque(); void scan_opaque(); + Value *parse_repr(); + void scan_repr(); + const char * read_string(void); void skip_string(void); + signed long long read_sint(void); + void skip_sint(void); + unsigned long long read_uint(void); void skip_uint(void);