X-Git-Url: https://git.cworth.org/git?a=blobdiff_plain;f=cli%2Fcli_trim.cpp;h=d9446822748e07913e13416aac8629a30eb97e90;hb=e7cb2b98575d5ff3801bd3527a648e0dbfdebdad;hp=2ea525103991ba574e3f4a59aa38916926ad55e4;hpb=2e93bcb671b82e75289cdd868bb5d4f9fc2c9134;p=apitrace diff --git a/cli/cli_trim.cpp b/cli/cli_trim.cpp index 2ea5251..d944682 100644 --- a/cli/cli_trim.cpp +++ b/cli/cli_trim.cpp @@ -47,24 +47,27 @@ usage(void) << synopsis << "\n" "\n" " -h, --help show this help message and exit\n" - " --calls=CALLSET only trim specified calls\n" + " --calls=CALLSET only retain specified calls\n" + " --thread=THREAD_ID only retain calls from specified thread\n" " -o, --output=TRACE_FILE output trace file\n" "\n" ; } enum { - CALLS_OPT = CHAR_MAX + 1, + CALLS_OPT = CHAR_MAX + 1, + THREAD_OPT, }; const static char * -shortOptions = "ho"; +shortOptions = "ho:"; const static struct option longOptions[] = { {"help", no_argument, 0, 'h'}, {"calls", required_argument, 0, CALLS_OPT}, - {"output", optional_argument, 0, 'o'}, + {"thread", required_argument, 0, THREAD_OPT}, + {"output", required_argument, 0, 'o'}, {0, 0, 0, 0} }; @@ -73,6 +76,7 @@ command(int argc, char *argv[]) { std::string output; trace::CallSet calls(trace::FREQUENCY_ALL); + int thread = -1; int i; int opt; @@ -84,6 +88,9 @@ command(int argc, char *argv[]) case CALLS_OPT: calls = trace::CallSet(optarg); break; + case THREAD_OPT: + thread = atoi(optarg); + break; case 'o': output = optarg; break; @@ -122,7 +129,8 @@ command(int argc, char *argv[]) trace::Call *call; while ((call = p.parse_call())) { - if (calls.contains(*call)) { + if (calls.contains(*call) && + (thread == -1 || call->thread_id == thread)) { writer.writeCall(call); } delete call;