Fix: lttng: poptGetArg doesn't provide string ownership
[lttng-tools.git] / src / bin / lttng / commands / clear.cpp
index 6c2399181105cae25aa366ccf3d71f7a8de11082..887c61f0ef99569e07afd36c16893e5460f2658c 100644 (file)
@@ -56,7 +56,6 @@ static int clear_session(struct lttng_session *session)
        struct lttng_clear_handle *handle = NULL;
        enum lttng_error_code ret_code;
        bool printed_wait_msg = false;
-       char *session_name = NULL;
        int ret;
 
        ret = lttng_clear_session(session->name, &handle);
@@ -117,7 +116,6 @@ error:
                MSG("");
        }
        lttng_clear_handle_destroy(handle);
-       free(session_name);
        return ret;
 }
 
@@ -156,8 +154,8 @@ int cmd_clear(int argc, const char **argv)
        int ret = CMD_SUCCESS , i, command_ret = CMD_SUCCESS, success = 1;
        static poptContext pc;
        char *session_name = NULL;
+       const char *arg_session_name = NULL;
        const char *leftover = NULL;
-       bool free_session_name = false;
        struct lttng_session *sessions = NULL;
        int count;
        int found;
@@ -213,19 +211,22 @@ int cmd_clear(int argc, const char **argv)
        }
 
        if (!opt_clear_all) {
-               session_name = (char *) poptGetArg(pc);
-               if (!session_name) {
+               arg_session_name = poptGetArg(pc);
+               if (!arg_session_name) {
                        /* No session name specified, lookup default */
                        session_name = get_session_name();
+               } else {
+                       session_name = strdup(arg_session_name);
                        if (session_name == NULL) {
-                               command_ret = CMD_ERROR;
-                               success = 0;
-                               goto mi_closing;
+                               PERROR("Failed to copy session name");
                        }
-                       free_session_name = true;
                }
-       } else {
-               session_name = NULL;
+
+               if (session_name == NULL) {
+                       command_ret = CMD_ERROR;
+                       success = 0;
+                       goto mi_closing;
+               }
        }
 
        leftover = poptGetArg(pc);
@@ -307,9 +308,7 @@ end:
        }
 
        free(sessions);
-       if (free_session_name) {
-               free(session_name);
-       }
+       free(session_name);
 
        /* Overwrite ret if an error occurred during clear_session/all */
        ret = command_ret ? command_ret : ret;
This page took 0.024712 seconds and 4 git commands to generate.