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
|
/* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You under the Apache License, Version 2.0
* (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
#include <apr_lib.h>
#include <apr_strings.h>
#include <apr_buckets.h>
#include "md_log.h"
#define LOG_BUFFER_LEN 1024
static const char *level_names[] = {
"emergency",
"alert",
"crit",
"err",
"warning",
"notice",
"info",
"debug",
"trace1",
"trace2",
"trace3",
"trace4",
"trace5",
"trace6",
"trace7",
"trace8",
};
const char *md_log_level_name(md_log_level_t level)
{
return level_names[level];
}
static md_log_print_cb *log_printv;
static md_log_level_cb *log_level;
static void *log_baton;
void md_log_set(md_log_level_cb *level_cb, md_log_print_cb *print_cb, void *baton)
{
log_printv = print_cb;
log_level = level_cb;
log_baton = baton;
}
int md_log_is_level(apr_pool_t *p, md_log_level_t level)
{
if (!log_level) {
return 0;
}
return log_level(log_baton, p, level);
}
void md_log_perror(const char *file, int line, md_log_level_t level,
apr_status_t rv, apr_pool_t *p, const char *fmt, ...)
{
va_list ap;
va_start(ap, fmt);
if (log_printv) {
log_printv(file, line, level, rv, log_baton, p, fmt, ap);
}
va_end(ap);
}
|