syslogd,logger: code shrink for musl
[oweals/busybox.git] / sysklogd / syslogd_and_logger.c
1 /* vi: set sw=4 ts=4: */
2 /*
3  * prioritynames[] and facilitynames[]
4  *
5  * Copyright (C) 2008 by Denys Vlasenko <vda.linux@gmail.com>
6  *
7  * Licensed under GPLv2, see file LICENSE in this source tree.
8  */
9
10 #include "libbb.h"
11 #include "common_bufsiz.h"
12 #define SYSLOG_NAMES
13 #define SYSLOG_NAMES_CONST
14 #include <syslog.h>
15
16 #if 0
17 /* For the record: with SYSLOG_NAMES <syslog.h> defines
18  * (not declares) the following:
19  */
20 typedef struct _code {
21         /*const*/ char *c_name;
22         int c_val;
23 } CODE;
24 /*const*/ CODE prioritynames[] = {
25     { "alert", LOG_ALERT },
26 ...
27     { NULL, -1 }
28 };
29 /* same for facilitynames[] */
30
31 /* This MUST occur only once per entire executable,
32  * therefore we can't just do it in syslogd.c and logger.c -
33  * there will be two copies of it.
34  *
35  * We cannot even do it in separate file and then just reference
36  * prioritynames[] from syslogd.c and logger.c - bare <syslog.h>
37  * will not emit extern decls for prioritynames[]! Attempts to
38  * emit "matching" struct _code declaration defeat the whole purpose
39  * of <syslog.h>.
40  *
41  * For now, syslogd.c and logger.c are simply compiled into
42  * one object file.
43  */
44 #endif
45
46 /* musl decided to be funny and it implements these as giant defines
47  * of the form: ((CODE *)(const CODE []){ ... })
48  * Which works, but causes _every_ function using them
49  * to have a copy on stack (at least with gcc-6.3.0).
50  * If we reference them just once, this saves 150 bytes.
51  * The pointers themselves are optimized out
52  * (no size change on uclibc).
53  */
54 static const CODE *const bb_prioritynames = prioritynames;
55 static const CODE *const bb_facilitynames = facilitynames;
56
57 #if ENABLE_SYSLOGD
58 #include "syslogd.c"
59 #endif
60
61 #if ENABLE_LOGGER
62 #include "logger.c"
63 #endif