blob: 2164518d5e264712f7729596bfc90048f5b5b3c4 [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
José Fonseca3c167fe2011-10-30 14:21:03 +000040static const char *synopsis = "Dump given trace(s) to standard output.";
41
42static void
43usage(void)
Carl Worthbd5e1642011-10-21 20:40:56 -070044{
José Fonseca3c167fe2011-10-30 14:21:03 +000045 std::cout
46 << "usage: apitrace dump [OPTIONS] <trace-file>...\n"
47 << synopsis << "\n"
José Fonseca646a00d2011-10-30 14:07:20 +000048 "\n"
49 " --color=<WHEN>\n"
50 " --colour=<WHEN> Colored syntax highlighting\n"
51 " WHEN is 'auto', 'always', or 'never'\n";
José Fonseca822d20a2011-08-20 13:49:40 +010052}
53
José Fonseca3c167fe2011-10-30 14:21:03 +000054static int
José Fonsecaffba5972011-10-30 14:29:28 +000055command(int argc, char *argv[])
José Fonseca7e329022010-11-19 17:05:18 +000056{
José Fonseca822d20a2011-08-20 13:49:40 +010057 int i;
58
José Fonsecaffba5972011-10-30 14:29:28 +000059 for (i = 0; i < argc; ++i) {
José Fonseca822d20a2011-08-20 13:49:40 +010060 const char *arg = argv[i];
61
62 if (arg[0] != '-') {
63 break;
64 }
65
66 if (!strcmp(arg, "--")) {
67 break;
José Fonseca646a00d2011-10-30 14:07:20 +000068 } else if (!strcmp(arg, "--help")) {
José Fonseca3c167fe2011-10-30 14:21:03 +000069 usage();
José Fonseca646a00d2011-10-30 14:07:20 +000070 return 0;
Carl Worthe525e6f2011-10-20 15:22:09 -070071 } else if (!strcmp(arg, "--color=auto") ||
72 !strcmp(arg, "--colour=auto")) {
73 color = COLOR_OPTION_AUTO;
74 } else if (!strcmp(arg, "--color") ||
75 !strcmp(arg, "--colour") ||
76 !strcmp(arg, "--color=always") ||
77 !strcmp(arg, "--colour=always")) {
78 color = COLOR_OPTION_ALWAYS;
79 } else if (!strcmp(arg, "--color=never") ||
80 !strcmp(arg, "--colour=never") ||
81 !strcmp(arg, "--no-color") ||
José Fonseca822d20a2011-08-20 13:49:40 +010082 !strcmp(arg, "--no-colour")) {
Carl Worthe525e6f2011-10-20 15:22:09 -070083 color = COLOR_OPTION_NEVER;
José Fonseca822d20a2011-08-20 13:49:40 +010084 } else {
85 std::cerr << "error: unknown option " << arg << "\n";
José Fonseca3c167fe2011-10-30 14:21:03 +000086 usage();
José Fonseca822d20a2011-08-20 13:49:40 +010087 return 1;
88 }
89 }
90
Carl Worthe525e6f2011-10-20 15:22:09 -070091 if (color == COLOR_OPTION_AUTO) {
92#ifdef _WIN32
93 color = COLOR_OPTION_ALWAYS;
94#else
95 color = isatty(1) ? COLOR_OPTION_ALWAYS : COLOR_OPTION_NEVER;
96#endif
97 }
98
José Fonseca822d20a2011-08-20 13:49:40 +010099 for (; i < argc; ++i) {
José Fonsecab4a3d142011-10-27 07:43:19 +0100100 trace::Parser p;
José Fonseca610ed332011-06-04 22:55:42 +0100101
102 if (!p.open(argv[i])) {
103 std::cerr << "error: failed to open " << argv[i] << "\n";
104 return 1;
105 }
106
José Fonsecab4a3d142011-10-27 07:43:19 +0100107 trace::Call *call;
José Fonseca610ed332011-06-04 22:55:42 +0100108 while ((call = p.parse_call())) {
José Fonseca822d20a2011-08-20 13:49:40 +0100109 call->dump(std::cout, color);
José Fonseca610ed332011-06-04 22:55:42 +0100110 delete call;
José Fonseca19828972010-11-29 20:34:32 +0000111 }
112 }
José Fonseca822d20a2011-08-20 13:49:40 +0100113
José Fonseca19828972010-11-29 20:34:32 +0000114 return 0;
José Fonseca7e329022010-11-19 17:05:18 +0000115}
José Fonseca3c167fe2011-10-30 14:21:03 +0000116
117const Command dump = {
118 "dump",
119 synopsis,
120 usage,
121 command
122};