]> git.cworth.org Git - apitrace/blobdiff - trace_model.hpp
Handle VBO draw elements .
[apitrace] / trace_model.hpp
index 9e2ae97ae7b73334278df8b767c1e4c7c3cd702e..71581e88e27a21a31844aec7f3102f33b90627f0 100644 (file)
@@ -104,6 +104,8 @@ public:
 };
 
 
+#undef Bool
+
 class Bool : public Value
 {
 public:
@@ -159,10 +161,10 @@ public:
 };
 
 
-class Const : public Value
+class Enum : public Value
 {
 public:
-   Const(std::string _name, Value *_value) : name(_name), value(_value) {}
+   Enum(std::string &_name, Value *_value) : name(_name), value(_value) {}
 
    void visit(Visitor &visitor);
 
@@ -185,6 +187,23 @@ public:
 };
 
 
+class Struct : public Value
+{
+public:
+   struct Signature {
+      std::string name;
+      std::vector<std::string> member_names;
+   };
+
+   Struct(Signature *_sig) : sig(_sig), members(_sig->member_names.size()) { }
+
+   void visit(Visitor &visitor);
+
+   const Signature *sig;
+   std::vector<Value *> members;
+};
+
+
 class Array : public Value
 {
 public:
@@ -224,8 +243,9 @@ public:
    virtual void visit(UInt *) {assert(0);}
    virtual void visit(Float *) {assert(0);}
    virtual void visit(String *) {assert(0);}
-   virtual void visit(Const *) {assert(0);}
+   virtual void visit(Enum *) {assert(0);}
    virtual void visit(Bitmask *bitmask) {visit(static_cast<UInt *>(bitmask));}
+   virtual void visit(Struct *) {assert(0);}
    virtual void visit(Array *) {assert(0);}
    virtual void visit(Blob *) {assert(0);}
 
@@ -259,7 +279,7 @@ public:
    std::vector<Value *> args;
    Value *ret;
 
-   Call(Signature *_sig) : sig(_sig), ret(0) { }
+   Call(Signature *_sig) : sig(_sig), args(_sig->arg_names.size()), ret(0) { }
 
    inline const std::string name(void) const {
        return sig->name;
@@ -271,7 +291,6 @@ public:
 };
 
 
-
 std::ostream & operator <<(std::ostream &os, Call &call);