]> git.cworth.org Git - apitrace/blob - tracedump.cpp
3b3ed0aa4482a283f3dec218877d9245daef9a90
[apitrace] / tracedump.cpp
1 /**************************************************************************
2  *
3  * Copyright 2010 VMware, Inc.
4  * All Rights Reserved.
5  *
6  * Permission is hereby granted, free of charge, to any person obtaining a copy
7  * of this software and associated documentation files (the "Software"), to deal
8  * in the Software without restriction, including without limitation the rights
9  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
10  * copies of the Software, and to permit persons to whom the Software is
11  * furnished to do so, subject to the following conditions:
12  *
13  * The above copyright notice and this permission notice shall be included in
14  * all copies or substantial portions of the Software.
15  *
16  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
17  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
18  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
19  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
20  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
21  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
22  * THE SOFTWARE.
23  *
24  **************************************************************************/
25
26
27 /*
28  * Simple utility to dump a trace to standard output.
29  */
30
31
32 #include <string.h>
33
34 #include "trace_parser.hpp"
35
36
37 enum ColorOption {
38     COLOR_OPTION_NEVER = 0,
39     COLOR_OPTION_ALWAYS = 1,
40     COLOR_OPTION_AUTO = -1
41 };
42
43 static ColorOption color = COLOR_OPTION_AUTO;
44
45
46 static void usage(void) {
47     std::cout <<
48         "Usage: tracedump [OPTION] [TRACE]...\n"
49         "Dump TRACE to standard output.\n"
50         "\n"
51         "  --help               display this help and exit\n"
52         "  --color[=WHEN]\n"
53         "  --colour[=WHEN]      colored syntax highlighting;\n"
54         "                       WHEN is 'always', 'never', or 'auto'\n"
55     ;
56 }
57
58
59 int main(int argc, char **argv)
60 {
61     int i;
62
63     for (i = 1; i < argc; ++i) {
64         const char *arg = argv[i];
65
66         if (arg[0] != '-') {
67             break;
68         }
69
70         if (!strcmp(arg, "--")) {
71             break;
72         } else if (!strcmp(arg, "--help")) {
73             usage();
74             return 0;
75         } else if (!strcmp(arg, "--color=auto") ||
76                    !strcmp(arg, "--colour=auto")) {
77             color = COLOR_OPTION_AUTO;
78         } else if (!strcmp(arg, "--color") ||
79                    !strcmp(arg, "--colour") ||
80                    !strcmp(arg, "--color=always") ||
81                    !strcmp(arg, "--colour=always")) {
82             color = COLOR_OPTION_ALWAYS;
83         } else if (!strcmp(arg, "--color=never") ||
84                    !strcmp(arg, "--colour=never") ||
85                    !strcmp(arg, "--no-color") ||
86                    !strcmp(arg, "--no-colour")) {
87             color = COLOR_OPTION_NEVER;
88         } else {
89             std::cerr << "error: unknown option " << arg << "\n";
90             usage();
91             return 1;
92         }
93     }
94
95     if (color == COLOR_OPTION_AUTO) {
96 #ifdef _WIN32
97         color = COLOR_OPTION_ALWAYS;
98 #else
99         color = isatty(1) ? COLOR_OPTION_ALWAYS : COLOR_OPTION_NEVER;
100 #endif
101     }
102
103     for (; i < argc; ++i) {
104         Trace::Parser p;
105
106         if (!p.open(argv[i])) {
107             std::cerr << "error: failed to open " << argv[i] << "\n";
108             return 1;
109         }
110
111         Trace::Call *call;
112         while ((call = p.parse_call())) {
113             call->dump(std::cout, color);
114             delete call;
115         }
116     }
117
118     return 0;
119 }