mirror of
				https://github.com/OpenMW/openmw.git
				synced 2025-10-26 00:26:42 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			42 lines
		
	
	
	
		
			1,018 B
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			42 lines
		
	
	
	
		
			1,018 B
		
	
	
	
		
			C++
		
	
	
	
	
	
| #ifndef DEBUG_DEBUGGING_H
 | |
| #define DEBUG_DEBUGGING_H
 | |
| 
 | |
| #include <boost/filesystem/fstream.hpp>
 | |
| #include <boost/iostreams/stream.hpp>
 | |
| 
 | |
| #include <components/misc/guarded.hpp>
 | |
| 
 | |
| #include "debuglog.hpp"
 | |
| 
 | |
| namespace Debug
 | |
| {
 | |
|     // ANSI colors for terminal
 | |
|     enum Color
 | |
|     {
 | |
|         Reset = 0,
 | |
|         DarkGray = 90,
 | |
|         Red = 91,
 | |
|         Yellow = 93
 | |
|     };
 | |
| 
 | |
| #ifdef _WIN32
 | |
|     bool attachParentConsole();
 | |
| #endif
 | |
| 
 | |
|     using LogListener = std::function<void(Debug::Level, std::string_view prefix, std::string_view msg)>;
 | |
|     void setLogListener(LogListener);
 | |
| }
 | |
| 
 | |
| // Can be used to print messages without timestamps
 | |
| std::ostream& getRawStdout();
 | |
| 
 | |
| std::ostream& getRawStderr();
 | |
| 
 | |
| Misc::Locked<std::ostream&> getLockedRawStderr();
 | |
| 
 | |
| void setupLogging(const std::string& logDir, const std::string& appName, std::ios_base::openmode = std::ios::out);
 | |
| 
 | |
| int wrapApplication(int (*innerApplication)(int argc, char *argv[]), int argc, char *argv[],
 | |
|                     const std::string& appName, bool autoSetupLogging = true);
 | |
| 
 | |
| #endif
 |