summaryrefslogtreecommitdiff
path: root/src/plugins/logger
diff options
context:
space:
mode:
authorSebastien Helleu <flashcode@flashtux.org>2010-07-28 11:20:22 +0200
committerSebastien Helleu <flashcode@flashtux.org>2010-07-28 11:20:22 +0200
commita45048bfbf98f159ecbac4f063a8842744a13e8d (patch)
treea6b59e14241fefecd2b6e2b7eb009d8fcd6910d5 /src/plugins/logger
parent2c16dc8abc133c44e9e80638d1d17d8635d70f89 (diff)
downloadweechat-a45048bfbf98f159ecbac4f063a8842744a13e8d.zip
Use tag "no_log" in logger plugin to prevent a line from being written in log file
Diffstat (limited to 'src/plugins/logger')
-rw-r--r--src/plugins/logger/logger.c46
1 files changed, 27 insertions, 19 deletions
diff --git a/src/plugins/logger/logger.c b/src/plugins/logger/logger.c
index 39a7e246b..ad1eaf13d 100644
--- a/src/plugins/logger/logger.c
+++ b/src/plugins/logger/logger.c
@@ -1125,6 +1125,11 @@ logger_line_log_level (int tags_count, const char **tags)
for (i = 0; i < tags_count; i++)
{
+ /* log disabled on line? return -1 */
+ if (strcmp (tags[i], "no_log") == 0)
+ return -1;
+
+ /* log level for line? return it */
if (strncmp (tags[i], "log", 3) == 0)
{
if (isdigit (tags[i][3]))
@@ -1134,7 +1139,8 @@ logger_line_log_level (int tags_count, const char **tags)
}
}
- return 9;
+ /* return default log level for line */
+ return LOGGER_LEVEL_DEFAULT;
}
/*
@@ -1158,27 +1164,29 @@ logger_print_cb (void *data, struct t_gui_buffer *buffer, time_t date,
(void) highlight;
line_log_level = logger_line_log_level (tags_count, tags);
-
- ptr_logger_buffer = logger_buffer_search_buffer (buffer);
- if (ptr_logger_buffer
- && ptr_logger_buffer->log_enabled
- && (date > 0)
- && (line_log_level <= ptr_logger_buffer->log_level))
+ if (line_log_level >= 0)
{
- date_tmp = localtime (&date);
- buf_time[0] = '\0';
- if (date_tmp)
+ ptr_logger_buffer = logger_buffer_search_buffer (buffer);
+ if (ptr_logger_buffer
+ && ptr_logger_buffer->log_enabled
+ && (date > 0)
+ && (line_log_level <= ptr_logger_buffer->log_level))
{
- strftime (buf_time, sizeof (buf_time) - 1,
- weechat_config_string (logger_config_file_time_format),
- date_tmp);
+ date_tmp = localtime (&date);
+ buf_time[0] = '\0';
+ if (date_tmp)
+ {
+ strftime (buf_time, sizeof (buf_time) - 1,
+ weechat_config_string (logger_config_file_time_format),
+ date_tmp);
+ }
+
+ logger_write_line (ptr_logger_buffer,
+ "%s\t%s\t%s",
+ buf_time,
+ (prefix) ? prefix : "",
+ message);
}
-
- logger_write_line (ptr_logger_buffer,
- "%s\t%s\t%s",
- buf_time,
- (prefix) ? prefix : "",
- message);
}
return WEECHAT_RC_OK;