Merge pull request #78 from ffontaine/master
[olsrd.git] / src / unix / log.c
1 /*
2  * The olsr.org Optimized Link-State Routing daemon (olsrd)
3  *
4  * (c) by the OLSR project
5  *
6  * See our Git repository to find out who worked on this file
7  * and thus is a copyright holder on it.
8  *
9  * All rights reserved.
10  *
11  * Redistribution and use in source and binary forms, with or without
12  * modification, are permitted provided that the following conditions
13  * are met:
14  *
15  * * Redistributions of source code must retain the above copyright
16  *   notice, this list of conditions and the following disclaimer.
17  * * Redistributions in binary form must reproduce the above copyright
18  *   notice, this list of conditions and the following disclaimer in
19  *   the documentation and/or other materials provided with the
20  *   distribution.
21  * * Neither the name of olsr.org, olsrd nor the names of its
22  *   contributors may be used to endorse or promote products derived
23  *   from this software without specific prior written permission.
24  *
25  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
26  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
27  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
28  * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
29  * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
30  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
31  * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
32  * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
33  * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
34  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
35  * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
36  * POSSIBILITY OF SUCH DAMAGE.
37  *
38  * Visit http://www.olsr.org for more information.
39  *
40  * If you find this software useful feel free to make a donation
41  * to the project. For more information see the website or contact
42  * the copyright holders.
43  *
44  */
45
46 /*
47  * System logging interface for GNU/Linux systems
48  */
49
50 #include "olsr_cfg.h"
51 #include "log.h"
52 #include <syslog.h>
53 #include <stdarg.h>
54
55 #ifdef __ANDROID__
56 #include <android/log.h>
57 #endif /* __ANDROID__ */
58
59 void
60 olsr_openlog(const char *ident __attribute__((unused)))
61 {
62 #ifndef __ANDROID__
63   openlog(ident, LOG_PID | LOG_ODELAY, LOG_DAEMON);
64   setlogmask(LOG_UPTO(LOG_INFO));
65 #endif /* __ANDROID__ */
66
67   return;
68 }
69
70 void olsr_closelog(void) {
71 #ifndef __ANDROID__
72   closelog();
73 #endif /* __ANDROID__ */
74
75   return;
76 }
77
78 #if defined SYSLOG_NUMBERING && SYSLOG_NUMBERING
79
80 unsigned int olsr_syslog_ctr = 0;
81
82 void 
83 olsr_syslog_real(int level, const char *format, ...)
84 {
85
86 #else /* defined SYSLOG_NUMBERING && SYSLOG_NUMBERING */
87
88 void 
89 olsr_syslog(int level, const char *format, ...)
90 {
91
92 #endif /* defined SYSLOG_NUMBERING && SYSLOG_NUMBERING */
93
94   int linux_level;
95   va_list arglist;
96
97   switch (level) {
98   case (OLSR_LOG_INFO):
99 #ifdef __ANDROID__
100     linux_level = ANDROID_LOG_INFO;
101 #else /* __ANDROID__ */
102     linux_level = LOG_INFO;
103 #endif /* __ANDROID__ */
104     break;
105   case (OLSR_LOG_ERR):
106 #ifdef __ANDROID__
107     linux_level = ANDROID_LOG_ERROR;
108 #else /* __ANDROID__ */
109     linux_level = LOG_ERR;
110 #endif /* __ANDROID__ */
111     break;
112   default:
113     return;
114   }
115
116   va_start(arglist, format);
117 #ifdef __ANDROID__
118   __android_log_vprint(linux_level, "olsrd", format, arglist);
119 #else /* __ANDROID__ */
120   vsyslog(linux_level, format, arglist);
121 #endif /* __ANDROID__ */
122   va_end(arglist);
123
124   return;
125 }
126
127 /*
128  * Local Variables:
129  * c-basic-offset: 2
130  * indent-tabs-mode: nil
131  * End:
132  */