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
							 |