mirror of
https://github.com/cesanta/mongoose.git
synced 2025-01-01 11:07:46 +08:00
Add cs_log_{lock,unlock}
In implementatiosn that have preemptive scheduelrs these can be implemented to ensure logging from different threads is properly serialized.
This commit is contained in:
parent
86f391c701
commit
a4b6d58b24
11
mongoose.c
11
mongoose.c
@ -578,6 +578,15 @@ 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;
|
||||||
|
|
||||||
|
/* In implementations that require locking, these can be overridden. */
|
||||||
|
void cs_log_lock(void) WEAK;
|
||||||
|
void cs_log_lock(void) {
|
||||||
|
}
|
||||||
|
|
||||||
|
void cs_log_unlock(void) WEAK;
|
||||||
|
void cs_log_unlock(void) {
|
||||||
|
}
|
||||||
|
|
||||||
void cs_log_set_file_level(const char *file_level) {
|
void cs_log_set_file_level(const char *file_level) {
|
||||||
char *fl = s_file_level;
|
char *fl = s_file_level;
|
||||||
if (file_level != NULL) {
|
if (file_level != NULL) {
|
||||||
@ -631,6 +640,7 @@ int cs_log_print_prefix(enum cs_log_level level, const char *file, int ln) {
|
|||||||
if (level > pll) return 0;
|
if (level > pll) return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
cs_log_lock();
|
||||||
if (cs_log_file == NULL) cs_log_file = stderr;
|
if (cs_log_file == NULL) cs_log_file = stderr;
|
||||||
cs_log_cur_msg_level = level;
|
cs_log_cur_msg_level = level;
|
||||||
fwrite(prefix, 1, sizeof(prefix), cs_log_file);
|
fwrite(prefix, 1, sizeof(prefix), cs_log_file);
|
||||||
@ -653,6 +663,7 @@ void cs_log_printf(const char *fmt, ...) {
|
|||||||
fputc('\n', cs_log_file);
|
fputc('\n', cs_log_file);
|
||||||
fflush(cs_log_file);
|
fflush(cs_log_file);
|
||||||
cs_log_cur_msg_level = LL_NONE;
|
cs_log_cur_msg_level = LL_NONE;
|
||||||
|
cs_log_unlock();
|
||||||
}
|
}
|
||||||
|
|
||||||
void cs_log_set_file(FILE *file) WEAK;
|
void cs_log_set_file(FILE *file) WEAK;
|
||||||
|
@ -28,6 +28,15 @@ 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;
|
||||||
|
|
||||||
|
/* In implementations that require locking, these can be overridden. */
|
||||||
|
void cs_log_lock(void) WEAK;
|
||||||
|
void cs_log_lock(void) {
|
||||||
|
}
|
||||||
|
|
||||||
|
void cs_log_unlock(void) WEAK;
|
||||||
|
void cs_log_unlock(void) {
|
||||||
|
}
|
||||||
|
|
||||||
void cs_log_set_file_level(const char *file_level) {
|
void cs_log_set_file_level(const char *file_level) {
|
||||||
char *fl = s_file_level;
|
char *fl = s_file_level;
|
||||||
if (file_level != NULL) {
|
if (file_level != NULL) {
|
||||||
@ -81,6 +90,7 @@ int cs_log_print_prefix(enum cs_log_level level, const char *file, int ln) {
|
|||||||
if (level > pll) return 0;
|
if (level > pll) return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
cs_log_lock();
|
||||||
if (cs_log_file == NULL) cs_log_file = stderr;
|
if (cs_log_file == NULL) cs_log_file = stderr;
|
||||||
cs_log_cur_msg_level = level;
|
cs_log_cur_msg_level = level;
|
||||||
fwrite(prefix, 1, sizeof(prefix), cs_log_file);
|
fwrite(prefix, 1, sizeof(prefix), cs_log_file);
|
||||||
@ -103,6 +113,7 @@ void cs_log_printf(const char *fmt, ...) {
|
|||||||
fputc('\n', cs_log_file);
|
fputc('\n', cs_log_file);
|
||||||
fflush(cs_log_file);
|
fflush(cs_log_file);
|
||||||
cs_log_cur_msg_level = LL_NONE;
|
cs_log_cur_msg_level = LL_NONE;
|
||||||
|
cs_log_unlock();
|
||||||
}
|
}
|
||||||
|
|
||||||
void cs_log_set_file(FILE *file) WEAK;
|
void cs_log_set_file(FILE *file) WEAK;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user