[lttng-dev] [PATCH] lttng-tools lttng commands add_context.c : Return values of the cmd_add_context() chain of functions
Thibault, Daniel
Daniel.Thibault at drdc-rddc.gc.ca
Thu Jan 26 16:27:58 EST 2012
Document and ensure the return values of the cmd_add_context() chain of functions.
Make add_context() stop looping over lttng_add_context() upon failure (otherwise it reports success or failure depending only on the last call's result).
Also patches lib/lttng-ctl/lttng-ctl.c
------------------------------
>From 9de81398942fe0adeb5288483ecb70e2573e69f0 Thu, 26 Jan 2012 16:23:05 -0500
From: Daniel U. Thibault <daniel.thibault at drdc-rddc.gc.ca>
Date: Thu, 26 Jan 2012 16:22:54 -0500
Subject: [PATCH] lttng-tools lttng commands add_context.c : Return values of the cmd_add_context() chain of functions
diff --git a/src/bin/lttng/commands/add_context.c b/src/bin/lttng/commands/add_context.c
index d0f5b6f..1c63d90 100644
--- a/src/bin/lttng/commands/add_context.c
+++ b/src/bin/lttng/commands/add_context.c
@@ -358,6 +358,7 @@
/*
* Add context to channel or event.
+ * Returns one of the CMD_* result constants.
*/
static int add_context(char *session_name)
{
@@ -379,7 +380,7 @@
handle = lttng_create_handle(session_name, &dom);
if (handle == NULL) {
- ret = -1;
+ ret = CMD_ERROR;
goto error;
}
@@ -400,11 +401,17 @@
}
DBG("Adding context...");
+ /*
+ * lttng_add_context() returns the size
+ * of the returned payload data
+ * or a negative error code.
+ */
ret = lttng_add_context(handle, &context, opt_event_name,
opt_channel_name);
+ /* Stop looping upon error */
if (ret < 0) {
fprintf(stderr, "%s: ", type->opt->symbol);
- continue;
+ goto error;
} else {
MSG("%s context %s added to %s event in %s",
opt_kernel ? "kernel" : "UST", type->opt->symbol,
@@ -412,7 +419,8 @@
opt_channel_name ? opt_channel_name : "all channels");
}
}
-
+ /* Normalise return code upon success */
+ ret = CMD_SUCCESS;
error:
lttng_destroy_handle(handle);
@@ -421,6 +429,7 @@
/*
* Add context to channel or event.
+ * Returns one of the CMD_* result constants.
*/
int cmd_add_context(int argc, const char **argv)
{
@@ -445,8 +454,10 @@
ret = CMD_SUCCESS;
goto end;
case OPT_TYPE:
- //Look up the index of opt_type in ctx_opts[] first,
- //so we don't have to free(type) on failure
+ /*
+ * Look up the index of opt_type in ctx_opts[] first,
+ * so we don't have to free(type) on failure
+ */
index = find_ctx_type_idx(opt_type);
if (index < 0) {
ERR("Unknown context type %s", opt_type);
diff --git a/src/lib/lttng-ctl/lttng-ctl.c b/src/lib/lttng-ctl/lttng-ctl.c
index e7ebab5..ebb76ec 100644
--- a/src/lib/lttng-ctl/lttng-ctl.c
+++ b/src/lib/lttng-ctl/lttng-ctl.c
@@ -462,6 +462,7 @@
/*
* Add context to event or/and channel.
+ * Returns the size of the returned payload data or a negative error code.
*/
int lttng_add_context(struct lttng_handle *handle,
struct lttng_event_context *ctx, const char *event_name,
------------------------------
Daniel U. Thibault
R & D pour la défense Canada - Valcartier (RDDC Valcartier) / Defence R&D Canada - Valcartier (DRDC Valcartier)
Système de systèmes (SdS) / System of Systems (SoS)
Solutions informatiques et expérimentations (SIE) / Computing Solutions and Experimentations (CSE)
2459 Boul. Pie XI Nord
Québec, QC G3J 1X5
CANADA
Vox : (418) 844-4000 x4245
Fax : (418) 844-4538
NAC: 918V QSDJ
Gouvernement du Canada / Government of Canada
<http://www.valcartier.drdc-rddc.gc.ca/>
More information about the lttng-dev
mailing list