47 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			C
		
	
	
	
		
		
			
		
	
	
			47 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			C
		
	
	
	
|  | // Copyright(c) 2015-present, Gabi Melman & spdlog contributors.
 | ||
|  | // Distributed under the MIT License (http://opensource.org/licenses/MIT)
 | ||
|  | 
 | ||
|  | #pragma once
 | ||
|  | 
 | ||
|  | #include <map>
 | ||
|  | #include <string>
 | ||
|  | 
 | ||
|  | #include <spdlog/common.h>
 | ||
|  | 
 | ||
|  | // MDC is a simple map of key->string values stored in thread local storage whose content will be printed by the loggers.
 | ||
|  | // Note: Not supported in async mode (thread local storage - so the async thread pool have different copy).
 | ||
|  | //
 | ||
|  | // Usage example:
 | ||
|  | // spdlog::mdc::put("mdc_key_1", "mdc_value_1");
 | ||
|  | // spdlog::info("Hello, {}", "World!");  // => [2024-04-26 02:08:05.040] [info] [mdc_key_1:mdc_value_1] Hello, World!
 | ||
|  | 
 | ||
|  | namespace spdlog { | ||
|  | class SPDLOG_API mdc { | ||
|  | public: | ||
|  |     using mdc_map_t = std::map<std::string, std::string>; | ||
|  | 
 | ||
|  |     static void put(const std::string &key, const std::string &value) { | ||
|  |         get_context()[key] = value; | ||
|  |     } | ||
|  | 
 | ||
|  |     static std::string get(const std::string &key) { | ||
|  |         auto &context = get_context(); | ||
|  |         auto it = context.find(key); | ||
|  |         if (it != context.end()) { | ||
|  |             return it->second; | ||
|  |         } | ||
|  |         return ""; | ||
|  |     } | ||
|  | 
 | ||
|  |     static void remove(const std::string &key) { get_context().erase(key); } | ||
|  | 
 | ||
|  |     static void clear() { get_context().clear(); } | ||
|  | 
 | ||
|  |     static mdc_map_t &get_context() { | ||
|  |         static thread_local mdc_map_t context; | ||
|  |         return context; | ||
|  |     } | ||
|  | }; | ||
|  | 
 | ||
|  | }  // namespace spdlog
 |