]> git.cworth.org Git - apitrace/commitdiff
Use regular C strings everywhere.
authorJosé Fonseca <jose.r.fonseca@gmail.com>
Sat, 28 May 2011 10:47:48 +0000 (11:47 +0100)
committerJosé Fonseca <jose.r.fonseca@gmail.com>
Sat, 28 May 2011 10:47:48 +0000 (11:47 +0100)
glretrace_cgl.cpp
glretrace_glx.cpp
glretrace_main.cpp
glretrace_wgl.cpp
retrace.py
trace_model.cpp
trace_model.hpp
trace_parser.cpp
trace_parser.hpp

index c42dd813edf65cc0506fa0d1ad89fd928ea1d20a..8cb5786d4fc9053caa02c7183cb743cb10535727 100644 (file)
@@ -113,7 +113,7 @@ static void retrace_CGLFlushDrawable(Trace::Call &call) {
 
 
 void glretrace::retrace_call_cgl(Trace::Call &call) {
-    const char *name = call.name().c_str();
+    const char *name = call.name();
 
     if (strcmp(name, "CGLSetCurrentContext") == 0) {
        retrace_CGLSetCurrentContext(call);
index 7edcfa0ffeeefc3d4caa1cd70cb4a638d892cf58..0b2c141c902ae179e923b1e4eb1f25b623db8e54 100644 (file)
@@ -235,7 +235,7 @@ static void retrace_glXGetProcAddress(Trace::Call &call) {
 }
 
 void glretrace::retrace_call_glx(Trace::Call &call) {
-    const char *name = call.name().c_str();
+    const char *name = call.name();
 
     switch (name[3]) {
     case 'C':
index 6a740d3f7e7ec9161ef07ba6e57683935c136fa7..7f7b876d5a6231021458d24408caca5605a905a4 100644 (file)
@@ -156,7 +156,7 @@ static void display(void) {
     Trace::Call *call;
 
     while ((call = parser.parse_call())) {
-        const std::string &name = call->name();
+        const char *name = call->name();
 
         if (retrace::verbosity >= 1) {
             std::cout << *call;
index a7185f76b4c0fa5e7df63d3bdd5589dda6a5178f..a3ca05b8f0c2c6c1962ecae1befaf68d592b2df4 100644 (file)
@@ -243,7 +243,7 @@ static void retrace_wglGetProcAddress(Trace::Call &call) {
 }
 
 void glretrace::retrace_call_wgl(Trace::Call &call) {
-    const char *name = call.name().c_str();
+    const char *name = call.name();
 
     switch (name[0]) {
     case 'g':
index 3b68d6018eee0ac19e4ce6138e8d198dff9ed9a4..c4750d4e6f24f261cbb05b30dd2913a4de4a3156 100644 (file)
@@ -254,7 +254,7 @@ class Retracer:
             self.retrace_function(function)
 
         print 'void retrace::retrace_call(Trace::Call &call) {'
-        print '    const char *name = call.name().c_str();'
+        print '    const char *name = call.name();'
         print
 
         func_dict = dict([(function.name, function) for function in functions])
index e8bb3e41ce761302678f4dea889a07289184b805..75ad9e395560fc1a64ed45e15b397a1ac2527c47 100644 (file)
@@ -132,7 +132,7 @@ unsigned long long Pointer::toUIntPtr(void) const { return value; }
 // string cast
 const char * Value ::toString(void) const { assert(0); return NULL; }
 const char * Null  ::toString(void) const { return NULL; }
-const char * String::toString(void) const { return value.c_str(); }
+const char * String::toString(void) const { return value; }
 
 
 // virtual Value::visit()
@@ -219,7 +219,7 @@ public:
 
     void visit(String *node) {
         os << literal << "\"";
-        for (std::string::const_iterator it = node->value.begin(); it != node->value.end(); ++it) {
+        for (const char *it = node->value; *it; ++it) {
             unsigned char c = (unsigned char) *it;
             if (c == '\"')
                 os << "\\\"";
index e7a2249c7c979833fbd8e7519ef3f18a5a9c22c0..1864b03c390615703d1c2c0377a67ed4496d4289 100644 (file)
@@ -33,7 +33,6 @@
 
 #include <assert.h>
 
-#include <string>
 #include <map>
 #include <list>
 #include <vector>
@@ -44,8 +43,6 @@ namespace Trace {
 
 
 class Visitor;
-class Dumper;
-class UInt;
 
 
 class Value
@@ -150,26 +147,26 @@ 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:
-    struct Signature : public std::pair<std::string, Value *>
+    struct Signature : public std::pair<const char *, Value *>
     {
         Signature()
-            : std::pair<std::string, Value *>()
+            : std::pair<const char *, Value *>()
         {}
-        Signature(const std::string &n, Trace::Value *val)
-            : std::pair<std::string, Value *>(n, val)
+        Signature(const char *n, Trace::Value *val)
+            : std::pair<const char *, Value *>(n, val)
         {}
         ~Signature()
         {
@@ -193,7 +190,7 @@ public:
 class Bitmask : public UInt
 {
 public:
-    typedef std::pair<std::string, unsigned long long> Pair;
+    typedef std::pair<const char *, unsigned long long> Pair;
     typedef std::vector<Pair> Signature;
 
     Bitmask(const Signature *_sig, unsigned long long _value) : UInt(_value), sig(_sig) {}
@@ -208,8 +205,8 @@ class Struct : public Value
 {
 public:
     struct Signature {
-        std::string name;
-        std::vector<std::string> member_names;
+        const char *name;
+        std::vector<const char *> member_names;
     };
 
     Struct(Signature *_sig) : sig(_sig), members(_sig->member_names.size()) { }
@@ -299,8 +296,8 @@ class Call
 {
 public:
     struct Signature {
-        std::string name;
-        std::vector<std::string> arg_names;
+        const char * name;
+        std::vector<const char *> arg_names;
     };
 
     unsigned no;
@@ -311,7 +308,7 @@ public:
     Call(Signature *_sig) : sig(_sig), args(_sig->arg_names.size()), ret(0) { }
     ~Call();
 
-    inline const std::string & name(void) const {
+    inline const char * name(void) const {
         return sig->name;
     }
 
index 1e00665e27faa313a221f0887c78bd5a27a84d15..e615ed7aa65bd9c4f861924cbc85ddee94483beb 100644 (file)
@@ -311,7 +311,7 @@ Value *Parser::parse_enum() {
     size_t id = read_uint();
     Enum::Signature *sig = lookup(enums, id);
     if (!sig) {
-        std::string name = read_string();
+        const char *name = read_string();
         Value *value = parse_value();
         sig = new Enum::Signature(name, value);
         enums[id] = sig;
@@ -396,15 +396,13 @@ Value *Parser::parse_opaque() {
 }
 
 
-std::string Parser::read_string(void) {
+const char * Parser::read_string(void) {
     size_t len = read_uint();
-    if (!len) {
-        return std::string();
+    char * value = new char[len + 1];
+    if (len) {
+        gzread(file, value, (unsigned)len);
     }
-    char * buf = new char[len];
-    gzread(file, buf, (unsigned)len);
-    std::string value(buf, len);
-    delete [] buf;
+    value[len] = 0;
 #if TRACE_VERBOSE
     std::cerr << "\tSTRING \"" << value << "\"\n";
 #endif
index 7a88d272d1b7fd50bf59d42bc745f79c72b3ec9e..c9f92fc8877a054f9f03ee7a98f36554cd52bf4f 100644 (file)
@@ -29,7 +29,6 @@
 
 #include <iostream>
 #include <list>
-#include <string>
 
 #include "trace_format.hpp"
 #include "trace_model.hpp"
@@ -106,7 +105,7 @@ protected:
 
     Value *parse_opaque();
 
-    std::string read_string(void);
+    const char * read_string(void);
 
     unsigned long long read_uint(void);