| 
									
										
										
										
											2014-10-28 05:36:00 -02:00
										 |  |  | // Copyright 2014 Citra Emulator Project
 | 
					
						
							| 
									
										
										
										
											2014-12-16 21:38:14 -08:00
										 |  |  | // Licensed under GPLv2 or any later version
 | 
					
						
							| 
									
										
										
										
											2014-10-28 05:36:00 -02:00
										 |  |  | // Refer to the license.txt file included.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include <algorithm>
 | 
					
						
							| 
									
										
										
										
											2015-05-12 02:19:44 -03:00
										 |  |  | #include <array>
 | 
					
						
							|  |  |  | #include <cstdio>
 | 
					
						
							| 
									
										
										
										
											2015-08-02 12:55:31 -04:00
										 |  |  | #include "common/assert.h"
 | 
					
						
							| 
									
										
										
										
											2015-05-12 02:19:44 -03:00
										 |  |  | #include "common/common_funcs.h" // snprintf compatibility define
 | 
					
						
							| 
									
										
										
										
											2016-09-20 23:52:38 -07:00
										 |  |  | #include "common/logging/backend.h"
 | 
					
						
							| 
									
										
										
										
											2015-05-12 02:19:44 -03:00
										 |  |  | #include "common/logging/filter.h"
 | 
					
						
							| 
									
										
										
										
											2014-10-28 05:36:00 -02:00
										 |  |  | #include "common/logging/log.h"
 | 
					
						
							|  |  |  | #include "common/logging/text_formatter.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | namespace Log { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /// Macro listing all log classes. Code should define CLS and SUB as desired before invoking this.
 | 
					
						
							| 
									
										
										
										
											2016-09-18 09:38:01 +09:00
										 |  |  | #define ALL_LOG_CLASSES()                                                                          \
 | 
					
						
							|  |  |  |     CLS(Log)                                                                                       \ | 
					
						
							|  |  |  |     CLS(Common)                                                                                    \ | 
					
						
							|  |  |  |     SUB(Common, Filesystem)                                                                        \ | 
					
						
							|  |  |  |     SUB(Common, Memory)                                                                            \ | 
					
						
							|  |  |  |     CLS(Core)                                                                                      \ | 
					
						
							|  |  |  |     SUB(Core, ARM11)                                                                               \ | 
					
						
							|  |  |  |     SUB(Core, Timing)                                                                              \ | 
					
						
							|  |  |  |     CLS(Config)                                                                                    \ | 
					
						
							|  |  |  |     CLS(Debug)                                                                                     \ | 
					
						
							|  |  |  |     SUB(Debug, Emulated)                                                                           \ | 
					
						
							|  |  |  |     SUB(Debug, GPU)                                                                                \ | 
					
						
							|  |  |  |     SUB(Debug, Breakpoint)                                                                         \ | 
					
						
							|  |  |  |     SUB(Debug, GDBStub)                                                                            \ | 
					
						
							|  |  |  |     CLS(Kernel)                                                                                    \ | 
					
						
							|  |  |  |     SUB(Kernel, SVC)                                                                               \ | 
					
						
							|  |  |  |     CLS(Service)                                                                                   \ | 
					
						
							|  |  |  |     SUB(Service, SRV)                                                                              \ | 
					
						
							|  |  |  |     SUB(Service, FRD)                                                                              \ | 
					
						
							|  |  |  |     SUB(Service, FS)                                                                               \ | 
					
						
							|  |  |  |     SUB(Service, ERR)                                                                              \ | 
					
						
							|  |  |  |     SUB(Service, APT)                                                                              \ | 
					
						
							| 
									
										
										
										
											2016-10-02 15:45:58 +08:00
										 |  |  |     SUB(Service, BOSS)                                                                             \ | 
					
						
							| 
									
										
										
										
											2016-09-18 09:38:01 +09:00
										 |  |  |     SUB(Service, GSP)                                                                              \ | 
					
						
							|  |  |  |     SUB(Service, AC)                                                                               \ | 
					
						
							|  |  |  |     SUB(Service, AM)                                                                               \ | 
					
						
							|  |  |  |     SUB(Service, PTM)                                                                              \ | 
					
						
							|  |  |  |     SUB(Service, LDR)                                                                              \ | 
					
						
							| 
									
										
										
										
											2016-09-23 13:47:34 +03:00
										 |  |  |     SUB(Service, MIC)                                                                              \ | 
					
						
							| 
									
										
										
										
											2016-09-18 09:38:01 +09:00
										 |  |  |     SUB(Service, NDM)                                                                              \ | 
					
						
							| 
									
										
										
										
											2016-12-29 23:38:47 +03:00
										 |  |  |     SUB(Service, NFC)                                                                              \ | 
					
						
							| 
									
										
										
										
											2016-09-18 09:38:01 +09:00
										 |  |  |     SUB(Service, NIM)                                                                              \ | 
					
						
							|  |  |  |     SUB(Service, NWM)                                                                              \ | 
					
						
							|  |  |  |     SUB(Service, CAM)                                                                              \ | 
					
						
							|  |  |  |     SUB(Service, CECD)                                                                             \ | 
					
						
							|  |  |  |     SUB(Service, CFG)                                                                              \ | 
					
						
							| 
									
										
										
										
											2016-12-08 12:11:54 +03:00
										 |  |  |     SUB(Service, CSND)                                                                             \ | 
					
						
							| 
									
										
										
										
											2016-09-18 09:38:01 +09:00
										 |  |  |     SUB(Service, DSP)                                                                              \ | 
					
						
							|  |  |  |     SUB(Service, DLP)                                                                              \ | 
					
						
							|  |  |  |     SUB(Service, HID)                                                                              \ | 
					
						
							|  |  |  |     SUB(Service, SOC)                                                                              \ | 
					
						
							|  |  |  |     SUB(Service, IR)                                                                               \ | 
					
						
							|  |  |  |     SUB(Service, Y2R)                                                                              \ | 
					
						
							|  |  |  |     CLS(HW)                                                                                        \ | 
					
						
							|  |  |  |     SUB(HW, Memory)                                                                                \ | 
					
						
							|  |  |  |     SUB(HW, LCD)                                                                                   \ | 
					
						
							|  |  |  |     SUB(HW, GPU)                                                                                   \ | 
					
						
							|  |  |  |     CLS(Frontend)                                                                                  \ | 
					
						
							|  |  |  |     CLS(Render)                                                                                    \ | 
					
						
							|  |  |  |     SUB(Render, Software)                                                                          \ | 
					
						
							|  |  |  |     SUB(Render, OpenGL)                                                                            \ | 
					
						
							|  |  |  |     CLS(Audio)                                                                                     \ | 
					
						
							|  |  |  |     SUB(Audio, DSP)                                                                                \ | 
					
						
							|  |  |  |     SUB(Audio, Sink)                                                                               \ | 
					
						
							|  |  |  |     CLS(Loader) | 
					
						
							| 
									
										
										
										
											2014-10-28 05:36:00 -02:00
										 |  |  | 
 | 
					
						
							|  |  |  | // GetClassName is a macro defined by Windows.h, grrr...
 | 
					
						
							| 
									
										
										
										
											2015-05-12 02:19:44 -03:00
										 |  |  | const char* GetLogClassName(Class log_class) { | 
					
						
							| 
									
										
										
										
											2014-10-28 05:36:00 -02:00
										 |  |  |     switch (log_class) { | 
					
						
							| 
									
										
										
										
											2016-09-18 09:38:01 +09:00
										 |  |  | #define CLS(x)                                                                                     \
 | 
					
						
							|  |  |  |     case Class::x:                                                                                 \ | 
					
						
							|  |  |  |         return #x; | 
					
						
							|  |  |  | #define SUB(x, y)                                                                                  \
 | 
					
						
							|  |  |  |     case Class::x##_##y:                                                                           \ | 
					
						
							|  |  |  |         return #x "." #y; | 
					
						
							| 
									
										
										
										
											2014-10-28 05:36:00 -02:00
										 |  |  |         ALL_LOG_CLASSES() | 
					
						
							|  |  |  | #undef CLS
 | 
					
						
							|  |  |  | #undef SUB
 | 
					
						
							| 
									
										
										
										
											2016-09-18 09:38:01 +09:00
										 |  |  |     case Class::Count: | 
					
						
							|  |  |  |         UNREACHABLE(); | 
					
						
							| 
									
										
										
										
											2014-10-28 05:36:00 -02:00
										 |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-05-12 02:19:44 -03:00
										 |  |  | const char* GetLevelName(Level log_level) { | 
					
						
							| 
									
										
										
										
											2016-09-18 09:38:01 +09:00
										 |  |  | #define LVL(x)                                                                                     \
 | 
					
						
							|  |  |  |     case Level::x:                                                                                 \ | 
					
						
							|  |  |  |         return #x | 
					
						
							| 
									
										
										
										
											2014-10-28 05:36:00 -02:00
										 |  |  |     switch (log_level) { | 
					
						
							|  |  |  |         LVL(Trace); | 
					
						
							|  |  |  |         LVL(Debug); | 
					
						
							|  |  |  |         LVL(Info); | 
					
						
							|  |  |  |         LVL(Warning); | 
					
						
							|  |  |  |         LVL(Error); | 
					
						
							|  |  |  |         LVL(Critical); | 
					
						
							| 
									
										
										
										
											2016-09-18 09:38:01 +09:00
										 |  |  |     case Level::Count: | 
					
						
							|  |  |  |         UNREACHABLE(); | 
					
						
							| 
									
										
										
										
											2014-10-28 05:36:00 -02:00
										 |  |  |     } | 
					
						
							|  |  |  | #undef LVL
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-18 09:38:01 +09:00
										 |  |  | Entry CreateEntry(Class log_class, Level log_level, const char* filename, unsigned int line_nr, | 
					
						
							|  |  |  |                   const char* function, const char* format, va_list args) { | 
					
						
							| 
									
										
										
										
											2014-10-28 05:36:00 -02:00
										 |  |  |     using std::chrono::steady_clock; | 
					
						
							|  |  |  |     using std::chrono::duration_cast; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     static steady_clock::time_point time_origin = steady_clock::now(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     std::array<char, 4 * 1024> formatting_buffer; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     Entry entry; | 
					
						
							|  |  |  |     entry.timestamp = duration_cast<std::chrono::microseconds>(steady_clock::now() - time_origin); | 
					
						
							|  |  |  |     entry.log_class = log_class; | 
					
						
							|  |  |  |     entry.log_level = log_level; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-18 09:38:01 +09:00
										 |  |  |     snprintf(formatting_buffer.data(), formatting_buffer.size(), "%s:%s:%u", filename, function, | 
					
						
							|  |  |  |              line_nr); | 
					
						
							| 
									
										
										
										
											2014-10-28 05:36:00 -02:00
										 |  |  |     entry.location = std::string(formatting_buffer.data()); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     vsnprintf(formatting_buffer.data(), formatting_buffer.size(), format, args); | 
					
						
							|  |  |  |     entry.message = std::string(formatting_buffer.data()); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-06-25 13:26:21 -05:00
										 |  |  |     return entry; | 
					
						
							| 
									
										
										
										
											2014-10-28 05:36:00 -02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-05-12 02:19:44 -03:00
										 |  |  | static Filter* filter = nullptr; | 
					
						
							| 
									
										
										
										
											2015-03-06 19:15:02 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | void SetFilter(Filter* new_filter) { | 
					
						
							|  |  |  |     filter = new_filter; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-18 09:38:01 +09:00
										 |  |  | void LogMessage(Class log_class, Level log_level, const char* filename, unsigned int line_nr, | 
					
						
							|  |  |  |                 const char* function, const char* format, ...) { | 
					
						
							| 
									
										
										
										
											2015-05-12 02:19:44 -03:00
										 |  |  |     if (filter != nullptr && !filter->CheckMessage(log_class, log_level)) | 
					
						
							| 
									
										
										
										
											2015-03-06 19:15:02 +01:00
										 |  |  |         return; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-10-28 05:36:00 -02:00
										 |  |  |     va_list args; | 
					
						
							|  |  |  |     va_start(args, format); | 
					
						
							| 
									
										
										
										
											2016-09-18 09:38:01 +09:00
										 |  |  |     Entry entry = CreateEntry(log_class, log_level, filename, line_nr, function, format, args); | 
					
						
							| 
									
										
										
										
											2014-10-28 05:36:00 -02:00
										 |  |  |     va_end(args); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-05-12 02:19:44 -03:00
										 |  |  |     PrintColoredMessage(entry); | 
					
						
							| 
									
										
										
										
											2014-10-28 05:36:00 -02:00
										 |  |  | } | 
					
						
							|  |  |  | } |