lib: compile liblttng-ctl as C++
[lttng-tools.git] / include / lttng / error-query.h
CommitLineData
b99a0cb3
JG
1/*
2 * error-query.h
3 *
4 * Copyright (C) 2021 Jérémie Galarneau <jeremie.galarneau@efficios.com>
5 *
6 * SPDX-License-Identifier: GPL-2.1-only
7 *
8 */
9
10#ifndef LTTNG_ERROR_QUERY_H
11#define LTTNG_ERROR_QUERY_H
12
13#include <lttng/lttng.h>
4bd69c5f 14#include <lttng/lttng-export.h>
b99a0cb3
JG
15#include <lttng/trigger/trigger.h>
16#include <stdint.h>
17
18#ifdef __cplusplus
19extern "C" {
20#endif
21
22/* An error query. */
23struct lttng_error_query;
24
25/*
26 * A collection of "lttng_error_query_result" returned after executing an error
27 * query against an endpoint.
28 */
29struct lttng_error_query_results;
30
31/* A 'result' is an opaque error type. */
32struct lttng_error_query_result;
33
34enum lttng_error_query_status {
35 LTTNG_ERROR_QUERY_STATUS_OK = 0,
36 /* An error occurred while querying for errors. */
37 LTTNG_ERROR_QUERY_STATUS_ERROR = -1,
38 /* The target of the query does not make sense for this endpoint. */
39 LTTNG_ERROR_QUERY_STATUS_INVALID_QUERY_TARGET = -2,
40 LTTNG_ERROR_QUERY_STATUS_INVALID_PARAMETER = -3,
41};
42
43enum lttng_error_query_result_type {
44 /* A count of errors provided as an unsigned integral value. */
45 LTTNG_ERROR_QUERY_RESULT_TYPE_COUNTER = 0,
46 LTTNG_ERROR_QUERY_RESULT_TYPE_UNKNOWN = -1,
47};
48
49enum lttng_error_query_result_status {
50 LTTNG_ERROR_QUERY_RESULT_STATUS_OK = 0,
51 LTTNG_ERROR_QUERY_RESULT_STATUS_ERROR = -1,
52 LTTNG_ERROR_QUERY_RESULT_STATUS_INVALID_PARAMETER = -2,
53};
54
55enum lttng_error_query_results_status {
56 LTTNG_ERROR_QUERY_RESULTS_STATUS_OK = 0,
57 LTTNG_ERROR_QUERY_RESULTS_STATUS_ERROR = -1,
58 LTTNG_ERROR_QUERY_RESULTS_STATUS_INVALID_PARAMETER = -2,
59};
60
61/* Create an error query targetting a trigger object. */
4bd69c5f 62LTTNG_EXPORT extern struct lttng_error_query *lttng_error_query_trigger_create(
b99a0cb3
JG
63 const struct lttng_trigger *trigger);
64
63dd3d7b 65/* Create an error query targetting a trigger's condition object. */
4bd69c5f 66LTTNG_EXPORT extern struct lttng_error_query *lttng_error_query_condition_create(
63dd3d7b
JG
67 const struct lttng_trigger *trigger);
68
cb9222ff
JG
69/*
70 * Create an error query targetting an action object.
71 *
72 * `action_path` is copied internally. The root of the `action_path` is the
73 * action of `trigger`.
74 */
4bd69c5f 75LTTNG_EXPORT extern struct lttng_error_query *lttng_error_query_action_create(
b99a0cb3 76 const struct lttng_trigger *trigger,
cb9222ff 77 const struct lttng_action_path *action_path);
b99a0cb3
JG
78
79/* Destroy an error query. */
4bd69c5f 80LTTNG_EXPORT extern void lttng_error_query_destroy(struct lttng_error_query *query);
b99a0cb3
JG
81
82/*
83 * Run an error query against an endpoint.
84 *
85 * Currently, only the `lttng_session_daemon_command_endpoint` is supported,
86 * see `lttng/endpoint.h`.
87 */
4bd69c5f 88LTTNG_EXPORT extern enum lttng_error_code lttng_error_query_execute(
b99a0cb3
JG
89 const struct lttng_error_query *query,
90 const struct lttng_endpoint *endpoint,
91 struct lttng_error_query_results **results);
92
93/* Get the number of results in a result set. */
4bd69c5f 94LTTNG_EXPORT LTTNG_EXPORT extern enum lttng_error_query_results_status
b99a0cb3
JG
95lttng_error_query_results_get_count(
96 const struct lttng_error_query_results *results,
97 unsigned int *count);
98
99/* Get a result from a result set by index. */
4bd69c5f 100LTTNG_EXPORT extern enum lttng_error_query_results_status
b99a0cb3
JG
101lttng_error_query_results_get_result(
102 const struct lttng_error_query_results *results,
103 const struct lttng_error_query_result **result,
104 unsigned int index);
105
106/* Destroy an error query result set. */
4bd69c5f 107LTTNG_EXPORT extern void lttng_error_query_results_destroy(
b99a0cb3
JG
108 struct lttng_error_query_results *results);
109
110/* Get the type of an error query result. */
4bd69c5f 111LTTNG_EXPORT extern enum lttng_error_query_result_type lttng_error_query_result_get_type(
b99a0cb3
JG
112 const struct lttng_error_query_result *result);
113
114/* Get the name of result. */
4bd69c5f 115LTTNG_EXPORT extern enum lttng_error_query_result_status lttng_error_query_result_get_name(
b99a0cb3
JG
116 const struct lttng_error_query_result *result,
117 const char **name);
118
119/* Get the description of a result. */
4bd69c5f 120LTTNG_EXPORT extern enum lttng_error_query_result_status
b99a0cb3
JG
121lttng_error_query_result_get_description(
122 const struct lttng_error_query_result *result,
123 const char **description);
124
125/* Get the value of an error counter. */
4bd69c5f 126LTTNG_EXPORT extern enum lttng_error_query_result_status
b99a0cb3
JG
127lttng_error_query_result_counter_get_value(
128 const struct lttng_error_query_result *result, uint64_t *value);
129
130#ifdef __cplusplus
131}
132#endif
133
134#endif /* LTTNG_ERROR_QUERY_H */
This page took 0.028655 seconds and 4 git commands to generate.