| 
									
										
										
										
											2013-09-04 20:17:46 -04:00
										 |  |  | // Copyright 2013 Dolphin Emulator Project
 | 
					
						
							|  |  |  | // Licensed under GPLv2
 | 
					
						
							|  |  |  | // Refer to the license.txt file included.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifndef _LOG_H_
 | 
					
						
							|  |  |  | #define _LOG_H_
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-04-01 18:20:08 -04:00
										 |  |  | #define    NOTICE_LEVEL  1  // VERY important information that is NOT errors. Like startup and OSReports.
 | 
					
						
							|  |  |  | #define    ERROR_LEVEL   2  // Critical errors 
 | 
					
						
							|  |  |  | #define    WARNING_LEVEL 3  // Something is suspicious.
 | 
					
						
							|  |  |  | #define    INFO_LEVEL    4  // General information.
 | 
					
						
							|  |  |  | #define    DEBUG_LEVEL   5  // Detailed debugging - might make things slow.
 | 
					
						
							| 
									
										
										
										
											2013-09-04 20:17:46 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | namespace LogTypes | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | enum LOG_TYPE { | 
					
						
							| 
									
										
										
										
											2014-04-01 18:20:08 -04:00
										 |  |  |     ACTIONREPLAY, | 
					
						
							|  |  |  |     AUDIO, | 
					
						
							|  |  |  |     AUDIO_INTERFACE, | 
					
						
							|  |  |  |     BOOT, | 
					
						
							|  |  |  |     COMMANDPROCESSOR, | 
					
						
							|  |  |  |     COMMON, | 
					
						
							|  |  |  |     CONSOLE, | 
					
						
							|  |  |  |     DISCIO, | 
					
						
							|  |  |  |     FILEMON, | 
					
						
							|  |  |  |     DSPHLE, | 
					
						
							|  |  |  |     DSPLLE, | 
					
						
							|  |  |  |     DSP_MAIL, | 
					
						
							|  |  |  |     DSPINTERFACE, | 
					
						
							|  |  |  |     DVDINTERFACE, | 
					
						
							|  |  |  |     DYNA_REC, | 
					
						
							|  |  |  |     EXPANSIONINTERFACE, | 
					
						
							|  |  |  |     GDB_STUB, | 
					
						
							|  |  |  |     ARM11, | 
					
						
							| 
									
										
										
										
											2014-05-07 20:59:21 -04:00
										 |  |  |     GSP, | 
					
						
							| 
									
										
										
										
											2014-04-01 18:20:08 -04:00
										 |  |  |     OSHLE, | 
					
						
							|  |  |  |     MASTER_LOG, | 
					
						
							|  |  |  |     MEMMAP, | 
					
						
							|  |  |  |     MEMCARD_MANAGER, | 
					
						
							|  |  |  |     OSREPORT, | 
					
						
							|  |  |  |     PAD,  | 
					
						
							|  |  |  |     PROCESSORINTERFACE, | 
					
						
							|  |  |  |     PIXELENGINE, | 
					
						
							|  |  |  |     SERIALINTERFACE, | 
					
						
							|  |  |  |     SP1, | 
					
						
							|  |  |  |     STREAMINGINTERFACE, | 
					
						
							|  |  |  |     VIDEO, | 
					
						
							|  |  |  |     VIDEOINTERFACE, | 
					
						
							|  |  |  |     LOADER, | 
					
						
							|  |  |  |     FILESYS, | 
					
						
							|  |  |  |     WII_IPC_DVD, | 
					
						
							|  |  |  |     WII_IPC_ES, | 
					
						
							|  |  |  |     WII_IPC_FILEIO, | 
					
						
							|  |  |  |     WII_IPC_HID, | 
					
						
							|  |  |  |     WII_IPC_HLE, | 
					
						
							| 
									
										
										
										
											2014-05-06 17:18:20 -04:00
										 |  |  |     SVC, | 
					
						
							| 
									
										
										
										
											2014-04-17 23:43:55 -04:00
										 |  |  |     NDMA, | 
					
						
							| 
									
										
										
										
											2014-04-10 22:43:48 -04:00
										 |  |  |     HLE, | 
					
						
							| 
									
										
										
										
											2014-04-06 16:56:42 -04:00
										 |  |  |     RENDER, | 
					
						
							| 
									
										
										
										
											2014-04-05 01:25:13 -04:00
										 |  |  |     LCD, | 
					
						
							| 
									
										
										
										
											2014-04-04 22:53:34 -04:00
										 |  |  |     HW, | 
					
						
							| 
									
										
										
										
											2014-04-01 18:20:08 -04:00
										 |  |  |     TIME, | 
					
						
							|  |  |  |     NETPLAY, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     NUMBER_OF_LOGS // Must be last
 | 
					
						
							| 
									
										
										
										
											2013-09-04 20:17:46 -04:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // FIXME: should this be removed?
 | 
					
						
							|  |  |  | enum LOG_LEVELS { | 
					
						
							| 
									
										
										
										
											2014-04-01 18:20:08 -04:00
										 |  |  |     LNOTICE = NOTICE_LEVEL, | 
					
						
							|  |  |  |     LERROR = ERROR_LEVEL, | 
					
						
							|  |  |  |     LWARNING = WARNING_LEVEL, | 
					
						
							|  |  |  |     LINFO = INFO_LEVEL, | 
					
						
							|  |  |  |     LDEBUG = DEBUG_LEVEL, | 
					
						
							| 
									
										
										
										
											2013-09-04 20:17:46 -04:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define LOGTYPES_LEVELS LogTypes::LOG_LEVELS
 | 
					
						
							|  |  |  | #define LOGTYPES_TYPE LogTypes::LOG_TYPE
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | }  // namespace
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void GenericLog(LOGTYPES_LEVELS level, LOGTYPES_TYPE type, | 
					
						
							| 
									
										
										
										
											2014-04-01 18:20:08 -04:00
										 |  |  |         const char *file, int line, const char *fmt, ...) | 
					
						
							| 
									
										
										
										
											2013-09-04 20:17:46 -04:00
										 |  |  | #ifdef __GNUC__
 | 
					
						
							| 
									
										
										
										
											2014-04-01 18:20:08 -04:00
										 |  |  |         __attribute__((format(printf, 5, 6))) | 
					
						
							| 
									
										
										
										
											2013-09-04 20:17:46 -04:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2014-04-01 18:20:08 -04:00
										 |  |  |         ; | 
					
						
							| 
									
										
										
										
											2013-09-04 20:17:46 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | #if defined LOGGING || defined _DEBUG || defined DEBUGFAST
 | 
					
						
							| 
									
										
										
										
											2014-05-06 17:18:20 -04:00
										 |  |  | #define MAX_LOGLEVEL LogTypes::LDEBUG
 | 
					
						
							| 
									
										
										
										
											2013-09-04 20:17:46 -04:00
										 |  |  | #else
 | 
					
						
							|  |  |  | #ifndef MAX_LOGLEVEL
 | 
					
						
							| 
									
										
										
										
											2014-05-06 17:18:20 -04:00
										 |  |  | #define MAX_LOGLEVEL LogTypes::LWARNING
 | 
					
						
							| 
									
										
										
										
											2013-09-04 20:17:46 -04:00
										 |  |  | #endif // loglevel
 | 
					
						
							|  |  |  | #endif // logging
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef GEKKO
 | 
					
						
							|  |  |  | #define GENERIC_LOG(t, v, ...)
 | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | // Let the compiler optimize this out
 | 
					
						
							|  |  |  | #define GENERIC_LOG(t, v, ...) { \
 | 
					
						
							| 
									
										
										
										
											2014-04-01 18:20:08 -04:00
										 |  |  |     if (v <= MAX_LOGLEVEL) \ | 
					
						
							|  |  |  |         GenericLog(v, t, __FILE__, __LINE__, __VA_ARGS__); \ | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2013-09-04 20:17:46 -04:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define ERROR_LOG(t,...) do { GENERIC_LOG(LogTypes::t, LogTypes::LERROR, __VA_ARGS__) } while (0)
 | 
					
						
							|  |  |  | #define WARN_LOG(t,...) do { GENERIC_LOG(LogTypes::t, LogTypes::LWARNING, __VA_ARGS__) } while (0)
 | 
					
						
							|  |  |  | #define NOTICE_LOG(t,...) do { GENERIC_LOG(LogTypes::t, LogTypes::LNOTICE, __VA_ARGS__) } while (0)
 | 
					
						
							|  |  |  | #define INFO_LOG(t,...) do { GENERIC_LOG(LogTypes::t, LogTypes::LINFO, __VA_ARGS__) } while (0)
 | 
					
						
							|  |  |  | #define DEBUG_LOG(t,...) do { GENERIC_LOG(LogTypes::t, LogTypes::LDEBUG, __VA_ARGS__) } while (0)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #if MAX_LOGLEVEL >= DEBUG_LEVEL
 | 
					
						
							|  |  |  | #define _dbg_assert_(_t_, _a_) \
 | 
					
						
							| 
									
										
										
										
											2014-04-01 18:20:08 -04:00
										 |  |  |     if (!(_a_)) {\ | 
					
						
							|  |  |  |         ERROR_LOG(_t_, "Error...\n\n  Line: %d\n  File: %s\n  Time: %s\n\nIgnore and continue?", \ | 
					
						
							|  |  |  |                        __LINE__, __FILE__, __TIME__); \ | 
					
						
							|  |  |  |         if (!PanicYesNo("*** Assertion (see log)***\n")) {Crash();} \ | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2013-09-04 20:17:46 -04:00
										 |  |  | #define _dbg_assert_msg_(_t_, _a_, ...)\
 | 
					
						
							| 
									
										
										
										
											2014-04-01 18:20:08 -04:00
										 |  |  |     if (!(_a_)) {\ | 
					
						
							|  |  |  |         ERROR_LOG(_t_, __VA_ARGS__); \ | 
					
						
							|  |  |  |         if (!PanicYesNo(__VA_ARGS__)) {Crash();} \ | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2013-09-04 20:17:46 -04:00
										 |  |  | #define _dbg_update_() Host_UpdateLogDisplay();
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #else // not debug
 | 
					
						
							|  |  |  | #define _dbg_update_() ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifndef _dbg_assert_
 | 
					
						
							|  |  |  | #define _dbg_assert_(_t_, _a_) {}
 | 
					
						
							|  |  |  | #define _dbg_assert_msg_(_t_, _a_, _desc_, ...) {}
 | 
					
						
							|  |  |  | #endif // dbg_assert
 | 
					
						
							|  |  |  | #endif // MAX_LOGLEVEL DEBUG
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define _assert_(_a_) _dbg_assert_(MASTER_LOG, _a_)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifndef GEKKO
 | 
					
						
							|  |  |  | #ifdef _WIN32
 | 
					
						
							| 
									
										
										
										
											2014-04-01 18:20:08 -04:00
										 |  |  | #define _assert_msg_(_t_, _a_, _fmt_, ...)        \
 | 
					
						
							|  |  |  |     if (!(_a_)) {\ | 
					
						
							|  |  |  |         if (!PanicYesNo(_fmt_, __VA_ARGS__)) {Crash();} \ | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2013-09-04 20:17:46 -04:00
										 |  |  | #else // not win32
 | 
					
						
							| 
									
										
										
										
											2014-04-01 18:20:08 -04:00
										 |  |  | #define _assert_msg_(_t_, _a_, _fmt_, ...)        \
 | 
					
						
							|  |  |  |     if (!(_a_)) {\ | 
					
						
							|  |  |  |         if (!PanicYesNo(_fmt_, ##__VA_ARGS__)) {Crash();} \ | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2013-09-04 20:17:46 -04:00
										 |  |  | #endif // WIN32
 | 
					
						
							|  |  |  | #else // GEKKO
 | 
					
						
							|  |  |  | #define _assert_msg_(_t_, _a_, _fmt_, ...)
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif // _LOG_H_
 |