forked from OpenSIPS/opensips
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathdprint.c
148 lines (121 loc) · 3.2 KB
/
dprint.c
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
/*
* $Id$
*
* debug print
*
* Copyright (C) 2001-2003 FhG Fokus
*
* This file is part of opensips, a free SIP server.
*
* opensips is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version
*
* opensips is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*/
/*!
* \file
* \brief OpenSIPS Debug console print functions
*/
#include "dprint.h"
#include "globals.h"
#include "pt.h"
#include <stdarg.h>
#include <stdio.h>
#include <strings.h>
static int debug_init = L_NOTICE;
/* current logging level for this process */
int *debug = &debug_init;
/* used when resetting the logging level of this process */
static int *default_debug;
static char* str_fac[]={"LOG_AUTH","LOG_CRON","LOG_DAEMON",
"LOG_KERN","LOG_LOCAL0","LOG_LOCAL1",
"LOG_LOCAL2","LOG_LOCAL3","LOG_LOCAL4","LOG_LOCAL5",
"LOG_LOCAL6","LOG_LOCAL7","LOG_LPR","LOG_MAIL",
"LOG_NEWS","LOG_USER","LOG_UUCP",
#ifndef __OS_solaris
"LOG_AUTHPRIV","LOG_FTP","LOG_SYSLOG",
#endif
0};
static int int_fac[]={LOG_AUTH , LOG_CRON , LOG_DAEMON ,
LOG_KERN , LOG_LOCAL0 , LOG_LOCAL1 ,
LOG_LOCAL2 , LOG_LOCAL3 , LOG_LOCAL4 , LOG_LOCAL5 ,
LOG_LOCAL6 , LOG_LOCAL7 , LOG_LPR , LOG_MAIL ,
LOG_NEWS , LOG_USER , LOG_UUCP
#ifndef __OS_solaris
,LOG_AUTHPRIV,LOG_FTP,LOG_SYSLOG
#endif
};
char ctime_buf[256];
int str2facility(char *s)
{
int i;
for( i=0; str_fac[i] ; i++) {
if (!strcasecmp(s,str_fac[i]))
return int_fac[i];
}
return -1;
}
int dp_my_pid(void)
{
return my_pid();
}
void dprint(char * format, ...)
{
va_list ap;
//fprintf(stderr, "%2d(%d) ", process_no, my_pid());
va_start(ap, format);
vfprintf(stderr,format,ap);
fflush(stderr);
va_end(ap);
}
int init_debug(void)
{
debug = &pt[process_no].debug;
*debug = debug_init;
default_debug = &pt[process_no].default_debug;
*default_debug = debug_init;
return 0;
}
/* call before pt is freed */
void cleanup_debug(void)
{
static int debug_level;
debug_level = *debug;
debug = &debug_level;
}
/* change the default log level of a given process */
inline void __set_proc_default_debug(int proc_idx, int level)
{
pt[proc_idx].default_debug = level;
}
/* change the actual log level of the current process */
inline void set_proc_debug_level(int level)
{
__set_proc_debug_level(process_no, level);
}
/* change the actual log level of a given process */
inline void __set_proc_debug_level(int proc_idx, int level)
{
pt[proc_idx].debug = level;
}
inline void set_global_debug_level(int level)
{
int i;
for (i = 0; i < counted_processes; i++) {
__set_proc_default_debug(i, level);
__set_proc_debug_level(i, level);
}
}
inline void reset_proc_debug_level(void)
{
*debug = *default_debug;
}