53c3acb3d20b302d87576496f8aa2acf9497eb56
[protos/libecoli.git] / lib / ecoli_log.c
1 /*
2  * Copyright (c) 2016, Olivier MATZ <zer0@droids-corp.org>
3  *
4  * Redistribution and use in source and binary forms, with or without
5  * modification, are permitted provided that the following conditions are met:
6  *
7  *     * Redistributions of source code must retain the above copyright
8  *       notice, this list of conditions and the following disclaimer.
9  *     * Redistributions in binary form must reproduce the above copyright
10  *       notice, this list of conditions and the following disclaimer in the
11  *       documentation and/or other materials provided with the distribution.
12  *     * Neither the name of the University of California, Berkeley nor the
13  *       names of its contributors may be used to endorse or promote products
14  *       derived from this software without specific prior written permission.
15  *
16  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND ANY
17  * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
18  * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
19  * DISCLAIMED. IN NO EVENT SHALL THE REGENTS AND CONTRIBUTORS BE LIABLE FOR ANY
20  * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
21  * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
22  * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
23  * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
24  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
25  * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
26  */
27
28 #define _GNU_SOURCE /* for vasprintf */
29 #include <stdio.h>
30 #include <stdlib.h>
31 #include <string.h>
32 #include <errno.h>
33
34 #include <ecoli_log.h>
35
36 static ec_log_t ec_log_fct = ec_log_default;
37 static void *ec_log_opaque;
38
39 int ec_log_default(unsigned int level, void *opaque, const char *str)
40 {
41         (void)opaque;
42         (void)level;
43
44         return printf("%s", str);
45 }
46
47 int ec_log_register(ec_log_t usr_log, void *opaque)
48 {
49         if (usr_log == NULL)
50                 return -1;
51
52         ec_log_fct = usr_log;
53         ec_log_opaque = opaque;
54
55         return 0;
56 }
57
58 void ec_log_unregister(void)
59 {
60         ec_log_fct = NULL;
61 }
62
63 int ec_vlog(unsigned int level, const char *format, va_list ap)
64 {
65         char *s;
66         int ret;
67
68         if (ec_log_fct == NULL) {
69                 errno = ENODEV;
70                 return -1;
71         }
72
73         ret = vasprintf(&s, format, ap);
74         if (ret < 0)
75                 return ret;
76
77         ret = ec_log_fct(level, ec_log_opaque, s);
78         free(s);
79
80         return ret;
81 }
82
83 int ec_log(unsigned int level, const char *format, ...)
84 {
85         va_list ap;
86         int ret;
87
88         va_start(ap, format);
89         ret = ec_vlog(level, format, ap);
90         va_end(ap);
91
92         return ret;
93 }