xref: /aosp_15_r20/external/libxkbcommon/test/log.c (revision 2b949d0487e80d67f1fda82db69e101e761f8064)
1*2b949d04SAndroid Build Coastguard Worker /*
2*2b949d04SAndroid Build Coastguard Worker  * Copyright © 2012 Ran Benita <[email protected]>
3*2b949d04SAndroid Build Coastguard Worker  *
4*2b949d04SAndroid Build Coastguard Worker  * Permission is hereby granted, free of charge, to any person obtaining a
5*2b949d04SAndroid Build Coastguard Worker  * copy of this software and associated documentation files (the "Software"),
6*2b949d04SAndroid Build Coastguard Worker  * to deal in the Software without restriction, including without limitation
7*2b949d04SAndroid Build Coastguard Worker  * the rights to use, copy, modify, merge, publish, distribute, sublicense,
8*2b949d04SAndroid Build Coastguard Worker  * and/or sell copies of the Software, and to permit persons to whom the
9*2b949d04SAndroid Build Coastguard Worker  * Software is furnished to do so, subject to the following conditions:
10*2b949d04SAndroid Build Coastguard Worker  *
11*2b949d04SAndroid Build Coastguard Worker  * The above copyright notice and this permission notice (including the next
12*2b949d04SAndroid Build Coastguard Worker  * paragraph) shall be included in all copies or substantial portions of the
13*2b949d04SAndroid Build Coastguard Worker  * Software.
14*2b949d04SAndroid Build Coastguard Worker  *
15*2b949d04SAndroid Build Coastguard Worker  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16*2b949d04SAndroid Build Coastguard Worker  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17*2b949d04SAndroid Build Coastguard Worker  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
18*2b949d04SAndroid Build Coastguard Worker  * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19*2b949d04SAndroid Build Coastguard Worker  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
20*2b949d04SAndroid Build Coastguard Worker  * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
21*2b949d04SAndroid Build Coastguard Worker  * DEALINGS IN THE SOFTWARE.
22*2b949d04SAndroid Build Coastguard Worker  */
23*2b949d04SAndroid Build Coastguard Worker 
24*2b949d04SAndroid Build Coastguard Worker #include "config.h"
25*2b949d04SAndroid Build Coastguard Worker 
26*2b949d04SAndroid Build Coastguard Worker #include "test.h"
27*2b949d04SAndroid Build Coastguard Worker #include "context.h"
28*2b949d04SAndroid Build Coastguard Worker 
29*2b949d04SAndroid Build Coastguard Worker #ifdef __GNUC__
30*2b949d04SAndroid Build Coastguard Worker #pragma GCC diagnostic ignored "-Wmissing-format-attribute"
31*2b949d04SAndroid Build Coastguard Worker #endif
32*2b949d04SAndroid Build Coastguard Worker 
33*2b949d04SAndroid Build Coastguard Worker static const char *
log_level_to_string(enum xkb_log_level level)34*2b949d04SAndroid Build Coastguard Worker log_level_to_string(enum xkb_log_level level)
35*2b949d04SAndroid Build Coastguard Worker {
36*2b949d04SAndroid Build Coastguard Worker     switch (level) {
37*2b949d04SAndroid Build Coastguard Worker     case XKB_LOG_LEVEL_CRITICAL:
38*2b949d04SAndroid Build Coastguard Worker         return "critical";
39*2b949d04SAndroid Build Coastguard Worker     case XKB_LOG_LEVEL_ERROR:
40*2b949d04SAndroid Build Coastguard Worker         return "error";
41*2b949d04SAndroid Build Coastguard Worker     case XKB_LOG_LEVEL_WARNING:
42*2b949d04SAndroid Build Coastguard Worker         return "warning";
43*2b949d04SAndroid Build Coastguard Worker     case XKB_LOG_LEVEL_INFO:
44*2b949d04SAndroid Build Coastguard Worker         return "info";
45*2b949d04SAndroid Build Coastguard Worker     case XKB_LOG_LEVEL_DEBUG:
46*2b949d04SAndroid Build Coastguard Worker         return "debug";
47*2b949d04SAndroid Build Coastguard Worker     }
48*2b949d04SAndroid Build Coastguard Worker 
49*2b949d04SAndroid Build Coastguard Worker     return "unknown";
50*2b949d04SAndroid Build Coastguard Worker }
51*2b949d04SAndroid Build Coastguard Worker 
52*2b949d04SAndroid Build Coastguard Worker ATTR_PRINTF(3, 0) static void
log_fn(struct xkb_context * ctx,enum xkb_log_level level,const char * fmt,va_list args)53*2b949d04SAndroid Build Coastguard Worker log_fn(struct xkb_context *ctx, enum xkb_log_level level,
54*2b949d04SAndroid Build Coastguard Worker        const char *fmt, va_list args)
55*2b949d04SAndroid Build Coastguard Worker {
56*2b949d04SAndroid Build Coastguard Worker     char *s;
57*2b949d04SAndroid Build Coastguard Worker     int size;
58*2b949d04SAndroid Build Coastguard Worker     darray_char *ls = xkb_context_get_user_data(ctx);
59*2b949d04SAndroid Build Coastguard Worker     assert(ls);
60*2b949d04SAndroid Build Coastguard Worker 
61*2b949d04SAndroid Build Coastguard Worker     size = vasprintf(&s, fmt, args);
62*2b949d04SAndroid Build Coastguard Worker     assert(size != -1);
63*2b949d04SAndroid Build Coastguard Worker 
64*2b949d04SAndroid Build Coastguard Worker     darray_append_string(*ls, log_level_to_string(level));
65*2b949d04SAndroid Build Coastguard Worker     darray_append_lit(*ls, ": ");
66*2b949d04SAndroid Build Coastguard Worker     darray_append_string(*ls, s);
67*2b949d04SAndroid Build Coastguard Worker     free(s);
68*2b949d04SAndroid Build Coastguard Worker }
69*2b949d04SAndroid Build Coastguard Worker 
70*2b949d04SAndroid Build Coastguard Worker int
main(void)71*2b949d04SAndroid Build Coastguard Worker main(void)
72*2b949d04SAndroid Build Coastguard Worker {
73*2b949d04SAndroid Build Coastguard Worker     darray_char log_string;
74*2b949d04SAndroid Build Coastguard Worker     struct xkb_context *ctx;
75*2b949d04SAndroid Build Coastguard Worker     int ret;
76*2b949d04SAndroid Build Coastguard Worker 
77*2b949d04SAndroid Build Coastguard Worker     ret = setenv("XKB_LOG_LEVEL", "warn", 1);
78*2b949d04SAndroid Build Coastguard Worker     assert(ret == 0);
79*2b949d04SAndroid Build Coastguard Worker     ret = setenv("XKB_LOG_VERBOSITY", "5", 1);
80*2b949d04SAndroid Build Coastguard Worker     assert(ret == 0);
81*2b949d04SAndroid Build Coastguard Worker     ctx = test_get_context(0);
82*2b949d04SAndroid Build Coastguard Worker     assert(ctx);
83*2b949d04SAndroid Build Coastguard Worker 
84*2b949d04SAndroid Build Coastguard Worker     darray_init(log_string);
85*2b949d04SAndroid Build Coastguard Worker     xkb_context_set_user_data(ctx, &log_string);
86*2b949d04SAndroid Build Coastguard Worker     xkb_context_set_log_fn(ctx, log_fn);
87*2b949d04SAndroid Build Coastguard Worker 
88*2b949d04SAndroid Build Coastguard Worker     log_warn(ctx, "first warning: %d\n", 87);
89*2b949d04SAndroid Build Coastguard Worker     log_info(ctx, "first info\n");
90*2b949d04SAndroid Build Coastguard Worker     log_dbg(ctx, "first debug: %s\n", "hello");
91*2b949d04SAndroid Build Coastguard Worker     log_err(ctx, "first error: %lu\n", 115415UL);
92*2b949d04SAndroid Build Coastguard Worker     log_vrb(ctx, 5, "first verbose 5\n");
93*2b949d04SAndroid Build Coastguard Worker 
94*2b949d04SAndroid Build Coastguard Worker     xkb_context_set_log_level(ctx, XKB_LOG_LEVEL_DEBUG);
95*2b949d04SAndroid Build Coastguard Worker     log_warn(ctx, "second warning: %d\n", 87);
96*2b949d04SAndroid Build Coastguard Worker     log_dbg(ctx, "second debug: %s %s\n", "hello", "world");
97*2b949d04SAndroid Build Coastguard Worker     log_info(ctx, "second info\n");
98*2b949d04SAndroid Build Coastguard Worker     log_err(ctx, "second error: %lu\n", 115415UL);
99*2b949d04SAndroid Build Coastguard Worker     log_vrb(ctx, 6, "second verbose 6\n");
100*2b949d04SAndroid Build Coastguard Worker 
101*2b949d04SAndroid Build Coastguard Worker     xkb_context_set_log_verbosity(ctx, 0);
102*2b949d04SAndroid Build Coastguard Worker     xkb_context_set_log_level(ctx, XKB_LOG_LEVEL_CRITICAL);
103*2b949d04SAndroid Build Coastguard Worker     log_warn(ctx, "third warning: %d\n", 87);
104*2b949d04SAndroid Build Coastguard Worker     log_dbg(ctx, "third debug: %s %s\n", "hello", "world");
105*2b949d04SAndroid Build Coastguard Worker     log_info(ctx, "third info\n");
106*2b949d04SAndroid Build Coastguard Worker     log_err(ctx, "third error: %lu\n", 115415UL);
107*2b949d04SAndroid Build Coastguard Worker     log_vrb(ctx, 0, "third verbose 0\n");
108*2b949d04SAndroid Build Coastguard Worker 
109*2b949d04SAndroid Build Coastguard Worker     printf("%s", log_string.item);
110*2b949d04SAndroid Build Coastguard Worker 
111*2b949d04SAndroid Build Coastguard Worker     assert(streq(log_string.item,
112*2b949d04SAndroid Build Coastguard Worker                  "warning: first warning: 87\n"
113*2b949d04SAndroid Build Coastguard Worker                  "error: first error: 115415\n"
114*2b949d04SAndroid Build Coastguard Worker                  "warning: first verbose 5\n"
115*2b949d04SAndroid Build Coastguard Worker                  "warning: second warning: 87\n"
116*2b949d04SAndroid Build Coastguard Worker                  "debug: second debug: hello world\n"
117*2b949d04SAndroid Build Coastguard Worker                  "info: second info\n"
118*2b949d04SAndroid Build Coastguard Worker                  "error: second error: 115415\n"));
119*2b949d04SAndroid Build Coastguard Worker 
120*2b949d04SAndroid Build Coastguard Worker     xkb_context_unref(ctx);
121*2b949d04SAndroid Build Coastguard Worker     darray_free(log_string);
122*2b949d04SAndroid Build Coastguard Worker     return 0;
123*2b949d04SAndroid Build Coastguard Worker }
124