blob: adecb22e4abd1d0178f0f25d64a13f8d669756fe [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"
José Fonseca0af96702011-12-22 21:35:10 +000061 " --thread-ids Dump thread ids\n"
José Fonseca946da142011-12-11 14:32:50 +000062 ;
José Fonseca822d20a2011-08-20 13:49:40 +010063}
64
José Fonseca3c167fe2011-10-30 14:21:03 +000065static int
José Fonsecaffba5972011-10-30 14:29:28 +000066command(int argc, char *argv[])
José Fonseca7e329022010-11-19 17:05:18 +000067{
José Fonseca946da142011-12-11 14:32:50 +000068 trace::DumpFlags dumpFlags = 0;
José Fonseca0af96702011-12-22 21:35:10 +000069 bool dumpThreadIds = false;
José Fonseca946da142011-12-11 14:32:50 +000070
José Fonseca822d20a2011-08-20 13:49:40 +010071 int i;
72
José Fonsecaffba5972011-10-30 14:29:28 +000073 for (i = 0; i < argc; ++i) {
José Fonseca822d20a2011-08-20 13:49:40 +010074 const char *arg = argv[i];
75
76 if (arg[0] != '-') {
77 break;
78 }
79
80 if (!strcmp(arg, "--")) {
81 break;
José Fonseca646a00d2011-10-30 14:07:20 +000082 } else if (!strcmp(arg, "--help")) {
José Fonseca3c167fe2011-10-30 14:21:03 +000083 usage();
José Fonseca646a00d2011-10-30 14:07:20 +000084 return 0;
José Fonseca340f5692011-11-30 07:04:44 +000085 } else if (strcmp(arg, "-v") == 0 ||
86 strcmp(arg, "--verbose") == 0) {
87 verbose = true;
Carl Worthe525e6f2011-10-20 15:22:09 -070088 } else if (!strcmp(arg, "--color=auto") ||
89 !strcmp(arg, "--colour=auto")) {
90 color = COLOR_OPTION_AUTO;
91 } else if (!strcmp(arg, "--color") ||
92 !strcmp(arg, "--colour") ||
93 !strcmp(arg, "--color=always") ||
94 !strcmp(arg, "--colour=always")) {
95 color = COLOR_OPTION_ALWAYS;
96 } else if (!strcmp(arg, "--color=never") ||
97 !strcmp(arg, "--colour=never") ||
98 !strcmp(arg, "--no-color") ||
José Fonseca822d20a2011-08-20 13:49:40 +010099 !strcmp(arg, "--no-colour")) {
Carl Worthe525e6f2011-10-20 15:22:09 -0700100 color = COLOR_OPTION_NEVER;
José Fonseca946da142011-12-11 14:32:50 +0000101 } else if (!strcmp(arg, "--no-arg-names")) {
102 dumpFlags |= trace::DUMP_FLAG_NO_ARG_NAMES;
José Fonseca0af96702011-12-22 21:35:10 +0000103 } else if (!strcmp(arg, "--thread-ids")) {
104 dumpThreadIds = true;
José Fonseca822d20a2011-08-20 13:49:40 +0100105 } else {
106 std::cerr << "error: unknown option " << arg << "\n";
José Fonseca3c167fe2011-10-30 14:21:03 +0000107 usage();
José Fonseca822d20a2011-08-20 13:49:40 +0100108 return 1;
109 }
110 }
111
Carl Worthe525e6f2011-10-20 15:22:09 -0700112 if (color == COLOR_OPTION_AUTO) {
113#ifdef _WIN32
114 color = COLOR_OPTION_ALWAYS;
115#else
116 color = isatty(1) ? COLOR_OPTION_ALWAYS : COLOR_OPTION_NEVER;
José Fonsecab122f502011-12-10 18:07:25 +0000117 pipepager();
Carl Worthe525e6f2011-10-20 15:22:09 -0700118#endif
119 }
120
José Fonseca946da142011-12-11 14:32:50 +0000121 if (color == COLOR_OPTION_NEVER) {
122 dumpFlags |= trace::DUMP_FLAG_NO_COLOR;
123 }
124
José Fonseca822d20a2011-08-20 13:49:40 +0100125 for (; i < argc; ++i) {
José Fonsecab4a3d142011-10-27 07:43:19 +0100126 trace::Parser p;
José Fonseca610ed332011-06-04 22:55:42 +0100127
128 if (!p.open(argv[i])) {
129 std::cerr << "error: failed to open " << argv[i] << "\n";
130 return 1;
131 }
132
José Fonsecab4a3d142011-10-27 07:43:19 +0100133 trace::Call *call;
José Fonseca610ed332011-06-04 22:55:42 +0100134 while ((call = p.parse_call())) {
José Fonseca340f5692011-11-30 07:04:44 +0000135 if (verbose ||
136 !(call->flags & trace::CALL_FLAG_VERBOSE)) {
José Fonseca0af96702011-12-22 21:35:10 +0000137 if (dumpThreadIds) {
138 std::cout << std::hex << call->thread_id << std::dec << " ";
139 }
José Fonseca946da142011-12-11 14:32:50 +0000140 trace::dump(*call, std::cout, dumpFlags);
José Fonseca340f5692011-11-30 07:04:44 +0000141 }
José Fonseca610ed332011-06-04 22:55:42 +0100142 delete call;
José Fonseca19828972010-11-29 20:34:32 +0000143 }
144 }
José Fonseca822d20a2011-08-20 13:49:40 +0100145
José Fonseca19828972010-11-29 20:34:32 +0000146 return 0;
José Fonseca7e329022010-11-19 17:05:18 +0000147}
José Fonseca3c167fe2011-10-30 14:21:03 +0000148
Carl Worth68f7c982011-11-01 13:47:26 -0700149const Command dump_command = {
José Fonseca3c167fe2011-10-30 14:21:03 +0000150 "dump",
151 synopsis,
152 usage,
153 command
154};