X-Git-Url: https://git.cworth.org/git?a=blobdiff_plain;f=trace_model.hpp;h=ddbcabd2993e357687588f7d3c0c549b609e715a;hb=14b78f815fa02ffda48f8a6599d6af45868266ff;hp=f978435f74f4907f9b97c4376660d8a27bd7bbb4;hpb=9922183f368ba2bfbe3bce18320684212cef8c2e;p=apitrace diff --git a/trace_model.hpp b/trace_model.hpp index f978435..ddbcabd 100644 --- a/trace_model.hpp +++ b/trace_model.hpp @@ -31,11 +31,9 @@ #define _TRACE_MODEL_HPP_ -#include +#include -#include #include -#include #include #include @@ -43,60 +41,63 @@ namespace Trace { -class Visitor; -class Dumper; -class UInt; +typedef unsigned Id; -class Value -{ -public: - virtual ~Value() {} - virtual void visit(Visitor &visitor) = 0; +struct FunctionSig { + Id id; + const char *name; + unsigned num_args; + const char **arg_names; +}; - operator bool (void) const; - operator signed long long (void) const; - operator unsigned long long (void) const; - operator double (void) const; - void *blob(void) const; - const char *string(void) const; +struct StructSig { + Id id; + const char *name; + unsigned num_members; + const char **member_names; +}; - inline operator signed char (void) const { - return static_cast(*this); - } - inline operator unsigned char (void) const { - return static_cast(*this); - } +struct EnumSig { + Id id; + const char *name; + signed long long value; +}; - inline operator signed short (void) const { - return static_cast(*this); - } - inline operator unsigned short (void) const { - return static_cast(*this); - } +struct BitmaskFlag { + const char *name; + unsigned long long value; +}; - inline operator signed (void) const { - return static_cast(*this); - } - inline operator unsigned (void) const { - return static_cast(*this); - } +struct BitmaskSig { + Id id; + unsigned num_flags; + const BitmaskFlag *flags; +}; - inline operator signed long (void) const { - return static_cast(*this); - } - inline operator unsigned long (void) const { - return static_cast(*this); - } +class Visitor; - inline operator float (void) const { - return static_cast(*this); - } + +class Value +{ +public: + virtual ~Value() {} + virtual void visit(Visitor &visitor) = 0; + + virtual bool toBool(void) const = 0; + virtual signed long long toSInt(void) const; + virtual unsigned long long toUInt(void) const; + virtual float toFloat(void) const; + virtual double toDouble(void) const; + + virtual void *toPointer(void) const; + virtual unsigned long long toUIntPtr(void) const; + virtual const char *toString(void) const; const Value & operator[](size_t index) const; }; @@ -105,17 +106,28 @@ public: class Null : public Value { public: + bool toBool(void) const; + signed long long toSInt(void) const; + unsigned long long toUInt(void) const; + virtual float toFloat(void) const; + virtual double toDouble(void) const; + void *toPointer(void) const; + unsigned long long toUIntPtr(void) const; + const char *toString(void) const; void visit(Visitor &visitor); }; -#undef Bool - class Bool : public Value { public: Bool(bool _value) : value(_value) {} + bool toBool(void) const; + signed long long toSInt(void) const; + unsigned long long toUInt(void) const; + virtual float toFloat(void) const; + virtual double toDouble(void) const; void visit(Visitor &visitor); bool value; @@ -127,6 +139,11 @@ class SInt : public Value public: SInt(signed long long _value) : value(_value) {} + bool toBool(void) const; + signed long long toSInt(void) const; + unsigned long long toUInt(void) const; + virtual float toFloat(void) const; + virtual double toDouble(void) const; void visit(Visitor &visitor); signed long long value; @@ -138,6 +155,11 @@ class UInt : public Value public: UInt(unsigned long long _value) : value(_value) {} + bool toBool(void) const; + signed long long toSInt(void) const; + unsigned long long toUInt(void) const; + virtual float toFloat(void) const; + virtual double toDouble(void) const; void visit(Visitor &visitor); unsigned long long value; @@ -149,6 +171,11 @@ class Float : public Value public: Float(double _value) : value(_value) {} + bool toBool(void) const; + signed long long toSInt(void) const; + unsigned long long toUInt(void) const; + virtual float toFloat(void) const; + virtual double toDouble(void) const; void visit(Visitor &visitor); double value; @@ -158,55 +185,53 @@ public: class String : public Value { public: - String(std::string _value) : value(_value) {} + String(const char * _value) : value(_value) {} + bool toBool(void) const; + const char *toString(void) const; void visit(Visitor &visitor); - std::string value; + const char * value; }; class Enum : public Value { public: - typedef std::pair Signature; - - Enum(const Signature *_sig) : sig(_sig) {} + Enum(const EnumSig *_sig) : sig(_sig) {} + bool toBool(void) const; + signed long long toSInt(void) const; + unsigned long long toUInt(void) const; + virtual float toFloat(void) const; + virtual double toDouble(void) const; void visit(Visitor &visitor); - const Signature *sig; + const EnumSig *sig; }; class Bitmask : public UInt { public: - typedef std::pair Pair; - typedef std::vector Signature; - - Bitmask(const Signature *_sig, unsigned long long _value) : UInt(_value), sig(_sig) {} + Bitmask(const BitmaskSig *_sig, unsigned long long _value) : UInt(_value), sig(_sig) {} void visit(Visitor &visitor); - const Signature *sig; + const BitmaskSig *sig; }; class Struct : public Value { public: - struct Signature { - std::string name; - std::vector member_names; - }; - - Struct(Signature *_sig) : sig(_sig), members(_sig->member_names.size()) { } + Struct(StructSig *_sig) : sig(_sig), members(_sig->num_members) { } ~Struct(); + bool toBool(void) const; void visit(Visitor &visitor); - const Signature *sig; + const StructSig *sig; std::vector members; }; @@ -217,6 +242,7 @@ public: Array(size_t len) : values(len) {} ~Array(); + bool toBool(void) const; void visit(Visitor &visitor); std::vector values; @@ -233,6 +259,8 @@ public: ~Blob(); + bool toBool(void) const; + void *toPointer(void) const; void visit(Visitor &visitor); size_t size; @@ -245,6 +273,9 @@ class Pointer : public UInt public: Pointer(unsigned long long value) : UInt(value) {} + bool toBool(void) const; + void *toPointer(void) const; + unsigned long long toUIntPtr(void) const; void visit(Visitor &visitor); }; @@ -252,18 +283,18 @@ public: class Visitor { public: - virtual void visit(Null *) {assert(0);} - virtual void visit(Bool *) {assert(0);} - virtual void visit(SInt *) {assert(0);} - virtual void visit(UInt *) {assert(0);} - virtual void visit(Float *) {assert(0);} - virtual void visit(String *) {assert(0);} - virtual void visit(Enum *) {assert(0);} - virtual void visit(Bitmask *bitmask) {visit(static_cast(bitmask));} - virtual void visit(Struct *) {assert(0);} - virtual void visit(Array *) {assert(0);} - virtual void visit(Blob *) {assert(0);} - virtual void visit(Pointer *) {assert(0);} + virtual void visit(Null *); + virtual void visit(Bool *); + virtual void visit(SInt *); + virtual void visit(UInt *); + virtual void visit(Float *); + virtual void visit(String *); + virtual void visit(Enum *); + virtual void visit(Bitmask *); + virtual void visit(Struct *); + virtual void visit(Array *); + virtual void visit(Blob *); + virtual void visit(Pointer *); protected: inline void _visit(Value *value) { @@ -277,32 +308,23 @@ protected: std::ostream & operator <<(std::ostream &os, Value *value); -signed long long asSInt(const Value &node); -unsigned long long asUInt(const Value &node); -double asFloat(const Value &node); - - class Call { public: - struct Signature { - std::string name; - std::vector arg_names; - }; - unsigned no; - const Signature *sig; + const FunctionSig *sig; std::vector args; Value *ret; - Call(Signature *_sig) : sig(_sig), args(_sig->arg_names.size()), ret(0) { } + Call(FunctionSig *_sig) : sig(_sig), args(_sig->num_args), ret(0) { } ~Call(); - inline const std::string name(void) const { + inline const char * name(void) const { return sig->name; } inline Value & arg(unsigned index) { + assert(index < args.size()); return *(args[index]); } };