projects
/
lttng-tools.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Save filter expression as part of agent events and save them
[lttng-tools.git]
/
src
/
bin
/
lttng-sessiond
/
agent.c
diff --git
a/src/bin/lttng-sessiond/agent.c
b/src/bin/lttng-sessiond/agent.c
index 9ec98167eb5a3c4db7c6f428cca926ac6b2f42d6..c438191658b848a98ea8ff6172b7a6b3c873b36a 100644
(file)
--- a/
src/bin/lttng-sessiond/agent.c
+++ b/
src/bin/lttng-sessiond/agent.c
@@
-820,33
+820,37
@@
error:
}
/*
}
/*
- * Create a newly allocated agent event data structure.
If name is valid, it's
- *
copied into the created event
.
+ * Create a newly allocated agent event data structure.
+ *
Ownership of filter_expression is taken
.
*
* Return a new object else NULL on error.
*/
struct agent_event *agent_create_event(const char *name,
*
* Return a new object else NULL on error.
*/
struct agent_event *agent_create_event(const char *name,
- struct lttng_filter_bytecode *filter)
+ int loglevel, enum lttng_loglevel_type loglevel_type,
+ struct lttng_filter_bytecode *filter, char *filter_expression)
{
{
- struct agent_event *event;
+ struct agent_event *event
= NULL
;
DBG3("Agent create new event with name %s", name);
DBG3("Agent create new event with name %s", name);
- event = zmalloc(sizeof(*event));
- if (!event) {
+ if (!name) {
+ ERR("Failed to create agent event; no name provided.");
goto error;
}
goto error;
}
- if (name) {
- strncpy(event->name, name, sizeof(event->name));
- event->name[sizeof(event->name) - 1] = '\0';
- lttng_ht_node_init_str(&event->node, event->name);
+ event = zmalloc(sizeof(*event));
+ if (!event) {
+ goto error;
}
}
- if (filter) {
-
event->filter = filter
;
- }
+ strncpy(event->name, name, sizeof(event->name));
+
event->name[sizeof(event->name) - 1] = '\0'
;
+ lttng_ht_node_init_str(&event->node, event->name);
+ event->loglevel = loglevel;
+ event->loglevel_type = loglevel_type;
+ event->filter = filter;
+ event->filter_expression = filter_expression;
error:
return event;
}
error:
return event;
}
@@
-951,6
+955,7
@@
void agent_destroy_event(struct agent_event *event)
free(event->filter);
free(event->filter_expression);
free(event->filter);
free(event->filter_expression);
+ free(event->exclusion);
free(event);
}
free(event);
}
This page took
0.023562 seconds
and
4
git commands to generate.