Skip to content
Projects
Groups
Snippets
Help
Loading...
Sign in / Register
Toggle navigation
M
mongoose
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Packages
Packages
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
submodule
mongoose
Commits
17703fe3
Commit
17703fe3
authored
Dec 16, 2017
by
Dmitry Frank
Committed by
Cesanta Bot
Dec 16, 2017
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Improve docs for logging
PUBLISHED_FROM=72f0892ecfba5b1c3c2a70f0ecd5715578d7ffce
parent
04aeeba2
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
72 additions
and
8 deletions
+72
-8
mongoose.c
mongoose.c
+72
-8
No files found.
mongoose.c
View file @
17703fe3
...
@@ -428,6 +428,9 @@ int cs_base64_decode(const unsigned char *s, int len, char *dst, int *dec_len) {
...
@@ -428,6 +428,9 @@ int cs_base64_decode(const unsigned char *s, int len, char *dst, int *dec_len) {
extern
"C"
{
extern
"C"
{
#endif
/* __cplusplus */
#endif
/* __cplusplus */
/*
* Log level; `LL_INFO` is the default. Use `cs_log_set_level()` to change it.
*/
enum
cs_log_level
{
enum
cs_log_level
{
LL_NONE
=
-
1
,
LL_NONE
=
-
1
,
LL_ERROR
=
0
,
LL_ERROR
=
0
,
...
@@ -440,12 +443,54 @@ enum cs_log_level {
...
@@ -440,12 +443,54 @@ enum cs_log_level {
_LL_MAX
=
5
,
_LL_MAX
=
5
,
};
};
/* Set log level. */
/*
* Set max log level to print; messages with the level above the given one will
* not be printed.
*/
void
cs_log_set_level
(
enum
cs_log_level
level
);
void
cs_log_set_level
(
enum
cs_log_level
level
);
/* Set log filter. NULL (a default) logs everything. */
/*
void
cs_log_set_filter
(
const
char
*
source_file_name
);
* Set log filter. NULL (a default) logs everything.
* Otherwise, function name and file name will be tested against the given
* pattern, and only matching messages will be printed.
*
* For the pattern syntax, refer to `mg_match_prefix()` in `str_util.h`.
*
* Example:
* ```c
* void foo(void) {
* LOG(LL_INFO, ("hello from foo"));
* }
*
* void bar(void) {
* LOG(LL_INFO, ("hello from bar"));
* }
*
* void test(void) {
* cs_log_set_filter(NULL);
* foo();
* bar();
*
* cs_log_set_filter("f*");
* foo();
* bar(); // Will NOT print anything
*
* cs_log_set_filter("bar");
* foo(); // Will NOT print anything
* bar();
* }
* ```
*/
void
cs_log_set_filter
(
const
char
*
pattern
);
/*
* Helper function which prints message prefix with the given `level`, function
* name `func` and `filename`. If message should be printed (accordingly to the
* current log level and filter), prints the prefix and returns 1, otherwise
* returns 0.
*
* Clients should typically just use `LOG()` macro.
*/
int
cs_log_print_prefix
(
enum
cs_log_level
level
,
const
char
*
func
,
int
cs_log_print_prefix
(
enum
cs_log_level
level
,
const
char
*
func
,
const
char
*
filename
);
const
char
*
filename
);
...
@@ -453,13 +498,29 @@ extern enum cs_log_level cs_log_threshold;
...
@@ -453,13 +498,29 @@ extern enum cs_log_level cs_log_threshold;
#if CS_ENABLE_STDIO
#if CS_ENABLE_STDIO
/*
* Set file to write logs into. If `NULL`, logs go to `stderr`.
*/
void
cs_log_set_file
(
FILE
*
file
);
void
cs_log_set_file
(
FILE
*
file
);
/*
* Prints log to the current log file, appends "\n" in the end and flushes the
* stream.
*/
void
cs_log_printf
(
const
char
*
fmt
,
...)
void
cs_log_printf
(
const
char
*
fmt
,
...)
#ifdef __GNUC__
#ifdef __GNUC__
__attribute__
((
format
(
printf
,
1
,
2
)))
__attribute__
((
format
(
printf
,
1
,
2
)))
#endif
#endif
;
;
/*
* Format and print message `x` with the given level `l`. Example:
*
* ```c
* LOG(LL_INFO, ("my info message: %d", 123));
* LOG(LL_DEBUG, ("my debug message: %d", 123));
* ```
*/
#define LOG(l, x) \
#define LOG(l, x) \
do { \
do { \
if (cs_log_print_prefix(l, __func__, __FILE__)) cs_log_printf x; \
if (cs_log_print_prefix(l, __func__, __FILE__)) cs_log_printf x; \
...
@@ -467,6 +528,9 @@ void cs_log_printf(const char *fmt, ...)
...
@@ -467,6 +528,9 @@ void cs_log_printf(const char *fmt, ...)
#ifndef CS_NDEBUG
#ifndef CS_NDEBUG
/*
* Shortcut for `LOG(LL_VERBOSE_DEBUG, (...))`
*/
#define DBG(x) LOG(LL_VERBOSE_DEBUG, x)
#define DBG(x) LOG(LL_VERBOSE_DEBUG, x)
#else
/* NDEBUG */
#else
/* NDEBUG */
...
@@ -524,12 +588,12 @@ double cs_log_ts WEAK;
...
@@ -524,12 +588,12 @@ double cs_log_ts WEAK;
enum
cs_log_level
cs_log_cur_msg_level
WEAK
=
LL_NONE
;
enum
cs_log_level
cs_log_cur_msg_level
WEAK
=
LL_NONE
;
void
cs_log_set_filter
(
const
char
*
str
)
WEAK
;
void
cs_log_set_filter
(
const
char
*
pattern
)
WEAK
;
void
cs_log_set_filter
(
const
char
*
str
)
{
void
cs_log_set_filter
(
const
char
*
pattern
)
{
free
(
s_filter_pattern
);
free
(
s_filter_pattern
);
if
(
str
!=
NULL
)
{
if
(
pattern
!=
NULL
)
{
s_filter_pattern
=
strdup
(
str
);
s_filter_pattern
=
strdup
(
pattern
);
s_filter_pattern_len
=
strlen
(
str
);
s_filter_pattern_len
=
strlen
(
pattern
);
}
else
{
}
else
{
s_filter_pattern
=
NULL
;
s_filter_pattern
=
NULL
;
s_filter_pattern_len
=
0
;
s_filter_pattern_len
=
0
;
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment