blob: 3b3ed0aa4482a283f3dec218877d9245daef9a90 [file] [log] [blame]
José Fonseca7e329022010-11-19 17:05:18 +00001/**************************************************************************
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
José Fonseca4a826ed2010-11-30 16:58:22 +000027/*
28 * Simple utility to dump a trace to standard output.
29 */
30
31
José Fonseca822d20a2011-08-20 13:49:40 +010032#include <string.h>
33
José Fonseca7e329022010-11-19 17:05:18 +000034#include "trace_parser.hpp"
35
36
Carl Worthe525e6f2011-10-20 15:22:09 -070037enum ColorOption {
38 COLOR_OPTION_NEVER = 0,
39 COLOR_OPTION_ALWAYS = 1,
40 COLOR_OPTION_AUTO = -1
41};
42
43static ColorOption color = COLOR_OPTION_AUTO;
José Fonseca822d20a2011-08-20 13:49:40 +010044
45
46static void usage(void) {
47 std::cout <<
Carl Worthe525e6f2011-10-20 15:22:09 -070048 "Usage: tracedump [OPTION] [TRACE]...\n"
José Fonseca822d20a2011-08-20 13:49:40 +010049 "Dump TRACE to standard output.\n"
50 "\n"
Carl Worthe525e6f2011-10-20 15:22:09 -070051 " --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"
José Fonseca822d20a2011-08-20 13:49:40 +010055 ;
56}
57
58
José Fonseca7e329022010-11-19 17:05:18 +000059int main(int argc, char **argv)
60{
José Fonseca822d20a2011-08-20 13:49:40 +010061 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;
Carl Worthe525e6f2011-10-20 15:22:09 -070072 } 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") ||
José Fonseca822d20a2011-08-20 13:49:40 +010086 !strcmp(arg, "--no-colour")) {
Carl Worthe525e6f2011-10-20 15:22:09 -070087 color = COLOR_OPTION_NEVER;
José Fonseca822d20a2011-08-20 13:49:40 +010088 } else {
89 std::cerr << "error: unknown option " << arg << "\n";
90 usage();
91 return 1;
92 }
93 }
94
Carl Worthe525e6f2011-10-20 15:22:09 -070095 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
José Fonseca822d20a2011-08-20 13:49:40 +0100103 for (; i < argc; ++i) {
José Fonseca19828972010-11-29 20:34:32 +0000104 Trace::Parser p;
José Fonseca610ed332011-06-04 22:55:42 +0100105
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())) {
José Fonseca822d20a2011-08-20 13:49:40 +0100113 call->dump(std::cout, color);
José Fonseca610ed332011-06-04 22:55:42 +0100114 delete call;
José Fonseca19828972010-11-29 20:34:32 +0000115 }
116 }
José Fonseca822d20a2011-08-20 13:49:40 +0100117
José Fonseca19828972010-11-29 20:34:32 +0000118 return 0;
José Fonseca7e329022010-11-19 17:05:18 +0000119}