blob: f6c51291af3597e6d5f2067a1c7a2bb401ed491a [file] [log] [blame]
José Fonseca7e329022010-11-19 17:05:18 +00001/**************************************************************************
2 *
José Fonseca946da142011-12-11 14:32:50 +00003 * Copyright 2011 Jose Fonseca
José Fonseca7e329022010-11-19 17:05:18 +00004 * Copyright 2010 VMware, Inc.
5 * All Rights Reserved.
6 *
7 * Permission is hereby granted, free of charge, to any person obtaining a copy
8 * of this software and associated documentation files (the "Software"), to deal
9 * in the Software without restriction, including without limitation the rights
10 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
11 * copies of the Software, and to permit persons to whom the Software is
12 * furnished to do so, subject to the following conditions:
13 *
14 * The above copyright notice and this permission notice shall be included in
15 * all copies or substantial portions of the Software.
16 *
17 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
18 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
19 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
20 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
21 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
22 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
23 * THE SOFTWARE.
24 *
25 **************************************************************************/
26
José Fonseca946da142011-12-11 14:32:50 +000027
José Fonseca71913ee2011-10-30 13:35:33 +000028#include <string.h>
29
José Fonseca5cc28b02011-10-30 13:38:25 +000030#include "cli.hpp"
José Fonsecab122f502011-12-10 18:07:25 +000031#include "cli_pager.hpp"
José Fonseca822d20a2011-08-20 13:49:40 +010032
José Fonseca7e329022010-11-19 17:05:18 +000033#include "trace_parser.hpp"
José Fonseca946da142011-12-11 14:32:50 +000034#include "trace_dump.hpp"
35
José Fonseca7e329022010-11-19 17:05:18 +000036
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
José Fonseca340f5692011-11-30 07:04:44 +000045static bool verbose = false;
46
José Fonseca3c167fe2011-10-30 14:21:03 +000047static const char *synopsis = "Dump given trace(s) to standard output.";
48
49static void
50usage(void)
Carl Worthbd5e1642011-10-21 20:40:56 -070051{
José Fonseca3c167fe2011-10-30 14:21:03 +000052 std::cout
53 << "usage: apitrace dump [OPTIONS] <trace-file>...\n"
54 << synopsis << "\n"
José Fonseca646a00d2011-10-30 14:07:20 +000055 "\n"
José Fonseca340f5692011-11-30 07:04:44 +000056 " -v, --verbose verbose output\n"
José Fonseca646a00d2011-10-30 14:07:20 +000057 " --color=<WHEN>\n"
58 " --colour=<WHEN> Colored syntax highlighting\n"
José Fonseca946da142011-12-11 14:32:50 +000059 " WHEN is 'auto', 'always', or 'never'\n"
60 " --no-arg-names Don't dump argument names\n"
61 ;
José Fonseca822d20a2011-08-20 13:49:40 +010062}
63
José Fonseca3c167fe2011-10-30 14:21:03 +000064static int
José Fonsecaffba5972011-10-30 14:29:28 +000065command(int argc, char *argv[])
José Fonseca7e329022010-11-19 17:05:18 +000066{
José Fonseca946da142011-12-11 14:32:50 +000067 trace::DumpFlags dumpFlags = 0;
68
José Fonseca822d20a2011-08-20 13:49:40 +010069 int i;
70
José Fonsecaffba5972011-10-30 14:29:28 +000071 for (i = 0; i < argc; ++i) {
José Fonseca822d20a2011-08-20 13:49:40 +010072 const char *arg = argv[i];
73
74 if (arg[0] != '-') {
75 break;
76 }
77
78 if (!strcmp(arg, "--")) {
79 break;
José Fonseca646a00d2011-10-30 14:07:20 +000080 } else if (!strcmp(arg, "--help")) {
José Fonseca3c167fe2011-10-30 14:21:03 +000081 usage();
José Fonseca646a00d2011-10-30 14:07:20 +000082 return 0;
José Fonseca340f5692011-11-30 07:04:44 +000083 } else if (strcmp(arg, "-v") == 0 ||
84 strcmp(arg, "--verbose") == 0) {
85 verbose = true;
Carl Worthe525e6f2011-10-20 15:22:09 -070086 } else if (!strcmp(arg, "--color=auto") ||
87 !strcmp(arg, "--colour=auto")) {
88 color = COLOR_OPTION_AUTO;
89 } else if (!strcmp(arg, "--color") ||
90 !strcmp(arg, "--colour") ||
91 !strcmp(arg, "--color=always") ||
92 !strcmp(arg, "--colour=always")) {
93 color = COLOR_OPTION_ALWAYS;
94 } else if (!strcmp(arg, "--color=never") ||
95 !strcmp(arg, "--colour=never") ||
96 !strcmp(arg, "--no-color") ||
José Fonseca822d20a2011-08-20 13:49:40 +010097 !strcmp(arg, "--no-colour")) {
Carl Worthe525e6f2011-10-20 15:22:09 -070098 color = COLOR_OPTION_NEVER;
José Fonseca946da142011-12-11 14:32:50 +000099 } else if (!strcmp(arg, "--no-arg-names")) {
100 dumpFlags |= trace::DUMP_FLAG_NO_ARG_NAMES;
José Fonseca822d20a2011-08-20 13:49:40 +0100101 } else {
102 std::cerr << "error: unknown option " << arg << "\n";
José Fonseca3c167fe2011-10-30 14:21:03 +0000103 usage();
José Fonseca822d20a2011-08-20 13:49:40 +0100104 return 1;
105 }
106 }
107
Carl Worthe525e6f2011-10-20 15:22:09 -0700108 if (color == COLOR_OPTION_AUTO) {
109#ifdef _WIN32
110 color = COLOR_OPTION_ALWAYS;
111#else
112 color = isatty(1) ? COLOR_OPTION_ALWAYS : COLOR_OPTION_NEVER;
José Fonsecab122f502011-12-10 18:07:25 +0000113 pipepager();
Carl Worthe525e6f2011-10-20 15:22:09 -0700114#endif
115 }
116
José Fonseca946da142011-12-11 14:32:50 +0000117 if (color == COLOR_OPTION_NEVER) {
118 dumpFlags |= trace::DUMP_FLAG_NO_COLOR;
119 }
120
José Fonseca822d20a2011-08-20 13:49:40 +0100121 for (; i < argc; ++i) {
José Fonsecab4a3d142011-10-27 07:43:19 +0100122 trace::Parser p;
José Fonseca610ed332011-06-04 22:55:42 +0100123
124 if (!p.open(argv[i])) {
125 std::cerr << "error: failed to open " << argv[i] << "\n";
126 return 1;
127 }
128
José Fonsecab4a3d142011-10-27 07:43:19 +0100129 trace::Call *call;
José Fonseca610ed332011-06-04 22:55:42 +0100130 while ((call = p.parse_call())) {
José Fonseca340f5692011-11-30 07:04:44 +0000131 if (verbose ||
132 !(call->flags & trace::CALL_FLAG_VERBOSE)) {
José Fonseca946da142011-12-11 14:32:50 +0000133 trace::dump(*call, std::cout, dumpFlags);
José Fonseca340f5692011-11-30 07:04:44 +0000134 }
José Fonseca610ed332011-06-04 22:55:42 +0100135 delete call;
José Fonseca19828972010-11-29 20:34:32 +0000136 }
137 }
José Fonseca822d20a2011-08-20 13:49:40 +0100138
José Fonseca19828972010-11-29 20:34:32 +0000139 return 0;
José Fonseca7e329022010-11-19 17:05:18 +0000140}
José Fonseca3c167fe2011-10-30 14:21:03 +0000141
Carl Worth68f7c982011-11-01 13:47:26 -0700142const Command dump_command = {
José Fonseca3c167fe2011-10-30 14:21:03 +0000143 "dump",
144 synopsis,
145 usage,
146 command
147};