blob: 3a428dbb7909456221dc147f5a142b5f490dcc6b [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
José Fonseca71913ee2011-10-30 13:35:33 +000026#include <string.h>
27
José Fonseca5cc28b02011-10-30 13:38:25 +000028#include "cli.hpp"
José Fonseca822d20a2011-08-20 13:49:40 +010029
José Fonseca7e329022010-11-19 17:05:18 +000030#include "trace_parser.hpp"
31
Carl Worthe525e6f2011-10-20 15:22:09 -070032enum ColorOption {
33 COLOR_OPTION_NEVER = 0,
34 COLOR_OPTION_ALWAYS = 1,
35 COLOR_OPTION_AUTO = -1
36};
37
38static ColorOption color = COLOR_OPTION_AUTO;
José Fonseca822d20a2011-08-20 13:49:40 +010039
Carl Worthbd5e1642011-10-21 20:40:56 -070040void
José Fonseca646a00d2011-10-30 14:07:20 +000041apitrace_dump_usage(void)
Carl Worthbd5e1642011-10-21 20:40:56 -070042{
José Fonseca646a00d2011-10-30 14:07:20 +000043 std::cout << "usage: apitrace dump [OPTIONS] <trace-file>...\n"
44 APITRACE_DUMP_SYNOPSIS "\n"
45 "\n"
46 " --color=<WHEN>\n"
47 " --colour=<WHEN> Colored syntax highlighting\n"
48 " WHEN is 'auto', 'always', or 'never'\n";
José Fonseca822d20a2011-08-20 13:49:40 +010049}
50
Carl Worthbd5e1642011-10-21 20:40:56 -070051int
52apitrace_dump_command(int argc, char *argv[], int first_arg_command)
José Fonseca7e329022010-11-19 17:05:18 +000053{
José Fonseca822d20a2011-08-20 13:49:40 +010054 int i;
55
Carl Worthbd5e1642011-10-21 20:40:56 -070056 for (i = first_arg_command; i < argc; ++i) {
José Fonseca822d20a2011-08-20 13:49:40 +010057 const char *arg = argv[i];
58
59 if (arg[0] != '-') {
60 break;
61 }
62
63 if (!strcmp(arg, "--")) {
64 break;
José Fonseca646a00d2011-10-30 14:07:20 +000065 } else if (!strcmp(arg, "--help")) {
66 apitrace_dump_usage();
67 return 0;
Carl Worthe525e6f2011-10-20 15:22:09 -070068 } else if (!strcmp(arg, "--color=auto") ||
69 !strcmp(arg, "--colour=auto")) {
70 color = COLOR_OPTION_AUTO;
71 } else if (!strcmp(arg, "--color") ||
72 !strcmp(arg, "--colour") ||
73 !strcmp(arg, "--color=always") ||
74 !strcmp(arg, "--colour=always")) {
75 color = COLOR_OPTION_ALWAYS;
76 } else if (!strcmp(arg, "--color=never") ||
77 !strcmp(arg, "--colour=never") ||
78 !strcmp(arg, "--no-color") ||
José Fonseca822d20a2011-08-20 13:49:40 +010079 !strcmp(arg, "--no-colour")) {
Carl Worthe525e6f2011-10-20 15:22:09 -070080 color = COLOR_OPTION_NEVER;
José Fonseca822d20a2011-08-20 13:49:40 +010081 } else {
82 std::cerr << "error: unknown option " << arg << "\n";
José Fonseca646a00d2011-10-30 14:07:20 +000083 apitrace_dump_usage();
José Fonseca822d20a2011-08-20 13:49:40 +010084 return 1;
85 }
86 }
87
Carl Worthe525e6f2011-10-20 15:22:09 -070088 if (color == COLOR_OPTION_AUTO) {
89#ifdef _WIN32
90 color = COLOR_OPTION_ALWAYS;
91#else
92 color = isatty(1) ? COLOR_OPTION_ALWAYS : COLOR_OPTION_NEVER;
93#endif
94 }
95
José Fonseca822d20a2011-08-20 13:49:40 +010096 for (; i < argc; ++i) {
José Fonsecab4a3d142011-10-27 07:43:19 +010097 trace::Parser p;
José Fonseca610ed332011-06-04 22:55:42 +010098
99 if (!p.open(argv[i])) {
100 std::cerr << "error: failed to open " << argv[i] << "\n";
101 return 1;
102 }
103
José Fonsecab4a3d142011-10-27 07:43:19 +0100104 trace::Call *call;
José Fonseca610ed332011-06-04 22:55:42 +0100105 while ((call = p.parse_call())) {
José Fonseca822d20a2011-08-20 13:49:40 +0100106 call->dump(std::cout, color);
José Fonseca610ed332011-06-04 22:55:42 +0100107 delete call;
José Fonseca19828972010-11-29 20:34:32 +0000108 }
109 }
José Fonseca822d20a2011-08-20 13:49:40 +0100110
José Fonseca19828972010-11-29 20:34:32 +0000111 return 0;
José Fonseca7e329022010-11-19 17:05:18 +0000112}