49a6335be44a1dba2eb4b4b206d145983465aaf3
[babeltrace.git] / plugins / ctf / text / text.c
1 /*
2 * text.c
3 *
4 * Babeltrace CTF Text Output Plugin
5 *
6 * Copyright 2015 Jérémie Galarneau <jeremie.galarneau@efficios.com>
7 *
8 * Author: Jérémie Galarneau <jeremie.galarneau@efficios.com>
9 *
10 * Permission is hereby granted, free of charge, to any person obtaining a copy
11 * of this software and associated documentation files (the "Software"), to deal
12 * in the Software without restriction, including without limitation the rights
13 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
14 * copies of the Software, and to permit persons to whom the Software is
15 * furnished to do so, subject to the following conditions:
16 *
17 * The above copyright notice and this permission notice shall be included in
18 * all copies or substantial portions of the Software.
19 *
20 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
21 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
22 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
23 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
24 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
25 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
26 * SOFTWARE.
27 */
28
29 #include <babeltrace/plugin/plugin.h>
30 #include <babeltrace/plugin/component.h>
31 #include <babeltrace/plugin/sink.h>
32 #include <babeltrace/plugin/notification/notification.h>
33 #include <glib.h>
34 #include <stdio.h>
35
36 const char *plugin_name = "ctf-text";
37
38 static enum bt_component_status ctf_text_init(struct bt_component *);
39 static void ctf_text_exit(void);
40
41 /* Initialize plug-in entry points. */
42 BT_PLUGIN_NAME("ctf-text");
43 BT_PLUGIN_AUTHOR("Jérémie Galarneau");
44 BT_PLUGIN_LICENSE("MIT License");
45 BT_PLUGIN_EXIT(ctf_text_exit);
46
47 BT_PLUGIN_COMPONENT_CLASSES_BEGIN
48 BT_PLUGIN_SINK_COMPONENT_CLASS_ENTRY(plugin_name, ctf_text_init)
49 BT_PLUGIN_COMPONENT_CLASSES_END
50
51 enum loglevel {
52 LOGLEVEL_EMERG = 0,
53 LOGLEVEL_ALERT = 1,
54 LOGLEVEL_CRIT = 2,
55 LOGLEVEL_ERR = 3,
56 LOGLEVEL_WARNING = 4,
57 LOGLEVEL_NOTICE = 5,
58 LOGLEVEL_INFO = 6,
59 LOGLEVEL_DEBUG_SYSTEM = 7,
60 LOGLEVEL_DEBUG_PROGRAM = 8,
61 LOGLEVEL_DEBUG_PROCESS = 9,
62 LOGLEVEL_DEBUG_MODULE = 10,
63 LOGLEVEL_DEBUG_UNIT = 11,
64 LOGLEVEL_DEBUG_FUNCTION = 12,
65 LOGLEVEL_DEBUG_LINE = 13,
66 LOGLEVEL_DEBUG = 14,
67 };
68
69 const char *loglevel_str [] = {
70 [LOGLEVEL_EMERG] = "TRACE_EMERG",
71 [LOGLEVEL_ALERT] = "TRACE_ALERT",
72 [LOGLEVEL_CRIT] = "TRACE_CRIT",
73 [LOGLEVEL_ERR] = "TRACE_ERR",
74 [LOGLEVEL_WARNING] = "TRACE_WARNING",
75 [LOGLEVEL_NOTICE] = "TRACE_NOTICE",
76 [LOGLEVEL_INFO] = "TRACE_INFO",
77 [LOGLEVEL_DEBUG_SYSTEM] = "TRACE_DEBUG_SYSTEM",
78 [LOGLEVEL_DEBUG_PROGRAM] = "TRACE_DEBUG_PROGRAM",
79 [LOGLEVEL_DEBUG_PROCESS] = "TRACE_DEBUG_PROCESS",
80 [LOGLEVEL_DEBUG_MODULE] = "TRACE_DEBUG_MODULE",
81 [LOGLEVEL_DEBUG_UNIT] = "TRACE_DEBUG_UNIT",
82 [LOGLEVEL_DEBUG_FUNCTION] = "TRACE_DEBUG_FUNCTION",
83 [LOGLEVEL_DEBUG_LINE] = "TRACE_DEBUG_LINE",
84 [LOGLEVEL_DEBUG] = "TRACE_DEBUG",
85 };
86
87 struct ctf_text_component {
88 bool opt_print_all_field_names : 1;
89 bool opt_print_scope_field_names : 1;
90 bool opt_print_header_field_names : 1;
91 bool opt_print_context_field_names : 1;
92 bool opt_print_payload_field_names : 1;
93 bool opt_print_all_fields : 1;
94 bool opt_print_trace_field : 1;
95 bool opt_print_trace_domain_field : 1;
96 bool opt_print_trace_procname_field : 1;
97 bool opt_print_trace_vpid_field : 1;
98 bool opt_print_trace_hostname_field : 1;
99 bool opt_print_trace_default_fields : 1;
100 bool opt_print_loglevel_field : 1;
101 bool opt_print_emf_field : 1;
102 bool opt_print_delta_field : 1;
103 };
104
105 static
106 enum bt_component_status ctf_text_init(struct bt_component *component)
107 {
108 return BT_COMPONENT_STATUS_OK;
109 }
110
111 static
112 void ctf_text_exit(void)
113 {
114 printf("in ctf_text_exit\n");
115 }
This page took 0.031805 seconds and 3 git commands to generate.