Allow backward compatibility to ustctl <= 0.11 for some commands
authorJason Wessel <jason.wessel@windriver.com>
Thu, 24 Feb 2011 20:40:12 +0000 (21:40 +0100)
committerNils Carlson <nils.carlson@ericsson.com>
Fri, 25 Feb 2011 08:32:04 +0000 (09:32 +0100)
The rewrite of the ustctl broke all the existing scripts
that make use of ustctl.  This allows the original commands,
examples, and external scripts to continue working properly.

This covers the commands:

--list-markers
--list-trace-events
--alloc-trace
--start-trace
--stop-trace
--create-trace
--destroy-trace
--enable-marker
--disable-marker

Signed-off-by: Jason Wessel <jason.wessel@windriver.com>
Signed-off-by: Nils Carlson <nils.carlson@ericsson.com>
ustctl/ustctl.c

index b9acc238670ac13a3bd545fb330df5482b3ff26e..d642178a0a5c0019aa05e86c9fb2ace38ec4403a 100644 (file)
@@ -45,8 +45,33 @@ void usage(const char *process_name)
        list_cli_cmds(CLI_DESCRIPTIVE_LIST);
 }
 
+/*
+ * Provide backward compatibility for scripts that make use of the
+ * --commands in ustctl version <= 0.11
+ */
+enum command {
+       CREATE_TRACE=1000,
+       ALLOC_TRACE,
+       START_TRACE,
+       STOP_TRACE,
+       DESTROY_TRACE,
+       LIST_MARKERS,
+       LIST_TRACE_EVENTS,
+       ENABLE_MARKER,
+       DISABLE_MARKER,
+};
+
 struct option options[] =
 {
+       { "create-trace", 0, 0, CREATE_TRACE },
+       { "alloc-trace", 0, 0, ALLOC_TRACE },
+       { "start-trace", 0, 0, START_TRACE },
+       { "stop-trace", 0, 0, STOP_TRACE },
+       { "destroy-trace", 0, 0, DESTROY_TRACE },
+       { "list-markers", 0, 0, LIST_MARKERS },
+       { "list-trace-events", 0, 0, LIST_TRACE_EVENTS},
+       { "enable-marker", 0, 0, ENABLE_MARKER },
+       { "disable-marker", 0, 0, DISABLE_MARKER },
        {"help", 2, NULL, 'h'},
        {"list", 0, NULL, 'l'},
        {"extended-list", 0, NULL, 'e'},
@@ -56,7 +81,9 @@ struct option options[] =
 int main(int argc, char *argv[])
 {
        struct cli_cmd *cli_cmd;
+       char **args = argv;
        int opt;
+       int i;
 
        if(argc <= 1) {
                fprintf(stderr, "No operation specified.\n");
@@ -85,20 +112,48 @@ int main(int argc, char *argv[])
                case 'e':
                        list_cli_cmds(CLI_EXTENDED_LIST);
                        exit(EXIT_FAILURE);
+               case LIST_MARKERS:
+               case LIST_TRACE_EVENTS:
+               case CREATE_TRACE:
+               case ALLOC_TRACE:
+               case START_TRACE:
+               case STOP_TRACE:
+               case DESTROY_TRACE:
+               case ENABLE_MARKER:
+               case DISABLE_MARKER:
+                       args = (char **)malloc(sizeof(char **) * argc + 3);
+                       optind--;
+                       args[optind] = strdup(&argv[optind][2]);
+                       for (i = optind + 1; i < argc; i++) {
+                               args[i] = argv[i];
+                       }
+                       if (opt >= CREATE_TRACE && opt <= DESTROY_TRACE) {
+                               args[argc] = strdup("auto");
+                               argc++;
+                       }
+                       if (opt >= ENABLE_MARKER && opt <= DISABLE_MARKER) {
+                               args[argc] = args[argc - 2];
+                               args[argc - 2] = args[argc - 1];
+                               args[argc - 1] = strdup("auto");
+                               argc++;
+                       }
+                       args[argc] = NULL;
+                       goto do_cli;
                default:
                        fprintf(stderr, "Unknown option\n");
                        break;
                }
        }
 
-       cli_cmd = find_cli_cmd(argv[optind]);
+do_cli:
+       cli_cmd = find_cli_cmd(args[optind]);
        if (!cli_cmd) {
                fprintf(stderr, "No such command %s\n",
-                       argv[optind]);
+                       args[optind]);
                exit(EXIT_FAILURE);
        }
 
-       cli_dispatch_cmd(cli_cmd, argc - optind, &argv[optind]);
+       cli_dispatch_cmd(cli_cmd, argc - optind, &args[optind]);
 
        return 0;
 }
This page took 0.026584 seconds and 4 git commands to generate.