From cbaf4880adbf78515a4347225472deb45c42c4c9 Mon Sep 17 00:00:00 2001 From: Gabi Melman Date: Mon, 15 Nov 2021 14:42:36 +0200 Subject: [PATCH 1/4] Update README.md --- README.md | 28 ++++++++++++++++++++++++++++ 1 file changed, 28 insertions(+) diff --git a/README.md b/README.md index 00e0ac29..6c3c4c28 100644 --- a/README.md +++ b/README.md @@ -373,6 +373,34 @@ $ export SPDLOG_LEVEL=info,mylogger=trace $ ./example ``` + +--- +#### Log file open/close event handlers +```c++ +// You can get subscribe to get callbacks from spdlog before/after log file has been opened or closed. +// This is useful for cleanup procedures or for adding someting the start/end of the log files. +void file_events_example(){ + spdlog::file_event_handlers_t handlers; + handlers.before_open = [](spdlog::filename_t filename) { + spdlog::info("Before opening {}", filename); + }; + handlers.after_open = [](spdlog::filename_t filename, std::FILE *fstream) { + fputs("After opening\n", fstream); + }; + handlers.before_close = [](spdlog::filename_t filename, std::FILE *fstream) { + fputs("Before closing\n", fstream); + }; + handlers.after_close = [](spdlog::filename_t filename) { + spdlog::info("After closing {}", filename); + }; + auto file_sink = std::make_shared("logs/events-sample.txt", true, handlers); + spdlog::logger my_logger("some_logger", file_sink); + // or + // auto my_logger = spdlog::basic_logger_st("some_logger", "logs/events-sample.txt", true, handlers); + my_logger.info("Some log line"); +} +``` + --- ## Benchmarks From a5fa6eb356a0b408211458b1da0d2f7aadd5ad1c Mon Sep 17 00:00:00 2001 From: Gabi Melman Date: Mon, 15 Nov 2021 14:45:07 +0200 Subject: [PATCH 2/4] Update README.md --- README.md | 24 +++++++++--------------- 1 file changed, 9 insertions(+), 15 deletions(-) diff --git a/README.md b/README.md index 6c3c4c28..f964e067 100644 --- a/README.md +++ b/README.md @@ -379,23 +379,17 @@ $ ./example ```c++ // You can get subscribe to get callbacks from spdlog before/after log file has been opened or closed. // This is useful for cleanup procedures or for adding someting the start/end of the log files. -void file_events_example(){ +void file_events_example() +{ + // pass the spdlog::file_event_handlers_t to file sinks for open/close log file notifications spdlog::file_event_handlers_t handlers; - handlers.before_open = [](spdlog::filename_t filename) { - spdlog::info("Before opening {}", filename); - }; - handlers.after_open = [](spdlog::filename_t filename, std::FILE *fstream) { - fputs("After opening\n", fstream); - }; - handlers.before_close = [](spdlog::filename_t filename, std::FILE *fstream) { - fputs("Before closing\n", fstream); - }; - handlers.after_close = [](spdlog::filename_t filename) { - spdlog::info("After closing {}", filename); - }; + handlers.before_open = [](spdlog::filename_t filename) { spdlog::info("Before opening {}", filename); }; + handlers.after_open = [](spdlog::filename_t filename, std::FILE *fstream) { fputs("After opening\n", fstream); }; + handlers.before_close = [](spdlog::filename_t filename, std::FILE *fstream) { fputs("Before closing\n", fstream); }; + handlers.after_close = [](spdlog::filename_t filename) { spdlog::info("After closing {}", filename); }; auto file_sink = std::make_shared("logs/events-sample.txt", true, handlers); - spdlog::logger my_logger("some_logger", file_sink); - // or + spdlog::logger my_logger("some_logger", file_sink); + // or // auto my_logger = spdlog::basic_logger_st("some_logger", "logs/events-sample.txt", true, handlers); my_logger.info("Some log line"); } From ea92864a4d01655befa2f08463085dbd812f865d Mon Sep 17 00:00:00 2001 From: Gabi Melman Date: Mon, 15 Nov 2021 14:46:23 +0200 Subject: [PATCH 3/4] Update README.md --- README.md | 1 + 1 file changed, 1 insertion(+) diff --git a/README.md b/README.md index f964e067..b7d6d034 100644 --- a/README.md +++ b/README.md @@ -388,6 +388,7 @@ void file_events_example() handlers.before_close = [](spdlog::filename_t filename, std::FILE *fstream) { fputs("Before closing\n", fstream); }; handlers.after_close = [](spdlog::filename_t filename) { spdlog::info("After closing {}", filename); }; auto file_sink = std::make_shared("logs/events-sample.txt", true, handlers); + spdlog::logger my_logger("some_logger", file_sink); // or // auto my_logger = spdlog::basic_logger_st("some_logger", "logs/events-sample.txt", true, handlers); From da621e4402f6af5a16068bf3b5ce487e1fec5fcd Mon Sep 17 00:00:00 2001 From: Gabi Melman Date: Mon, 15 Nov 2021 14:48:20 +0200 Subject: [PATCH 4/4] Update README.md --- README.md | 7 +------ 1 file changed, 1 insertion(+), 6 deletions(-) diff --git a/README.md b/README.md index b7d6d034..ed673345 100644 --- a/README.md +++ b/README.md @@ -387,12 +387,7 @@ void file_events_example() handlers.after_open = [](spdlog::filename_t filename, std::FILE *fstream) { fputs("After opening\n", fstream); }; handlers.before_close = [](spdlog::filename_t filename, std::FILE *fstream) { fputs("Before closing\n", fstream); }; handlers.after_close = [](spdlog::filename_t filename) { spdlog::info("After closing {}", filename); }; - auto file_sink = std::make_shared("logs/events-sample.txt", true, handlers); - - spdlog::logger my_logger("some_logger", file_sink); - // or - // auto my_logger = spdlog::basic_logger_st("some_logger", "logs/events-sample.txt", true, handlers); - my_logger.info("Some log line"); + auto my_logger = spdlog::basic_logger_st("some_logger", "logs/events-sample.txt", true, handlers); } ```