forked from dolphin-emu/dolphin
		
	
		
			
	
	
		
			93 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
		
		
			
		
	
	
			93 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
|   | // Copyright (C) 2003-2008 Dolphin Project.
 | ||
|  | 
 | ||
|  | // This program is free software: you can redistribute it and/or modify
 | ||
|  | // it under the terms of the GNU General Public License as published by
 | ||
|  | // the Free Software Foundation, version 2.0.
 | ||
|  | 
 | ||
|  | // This program is distributed in the hope that it will be useful,
 | ||
|  | // but WITHOUT ANY WARRANTY; without even the implied warranty of
 | ||
|  | // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | ||
|  | // GNU General Public License 2.0 for more details.
 | ||
|  | 
 | ||
|  | // A copy of the GPL 2.0 should have been included with the program.
 | ||
|  | // If not, see http://www.gnu.org/licenses/
 | ||
|  | 
 | ||
|  | // Official SVN repository and contact information can be found at
 | ||
|  | // http://code.google.com/p/dolphin-emu/
 | ||
|  | #if 0
 | ||
|  | 
 | ||
|  | // THESE WILL BE REPLACED WITH A CLEANED UP LOGGING SYSTEM
 | ||
|  | 
 | ||
|  | #ifndef _LOGGING_H
 | ||
|  | #define _LOGGING_H
 | ||
|  | 
 | ||
|  | class IniFile; | ||
|  | 
 | ||
|  | // should be inside the LogManager ...
 | ||
|  | struct CDebugger_Log | ||
|  | { | ||
|  | 	char m_szName[128]; | ||
|  | 	char m_szShortName[10]; | ||
|  | 	char m_szFilename[256]; | ||
|  | 	bool m_bLogToFile; | ||
|  | 	bool m_bShowInLog; | ||
|  | 	bool m_bEnable; | ||
|  | 	FILE* m_pFile; | ||
|  | 
 | ||
|  | 	void Init(void); | ||
|  | 
 | ||
|  | 
 | ||
|  | 	// constructor
 | ||
|  | 	CDebugger_Log(const char* _szShortName, const char* _szName); | ||
|  | 
 | ||
|  | 	// destructor
 | ||
|  | 	~CDebugger_Log(void); | ||
|  | }; | ||
|  | 
 | ||
|  | 
 | ||
|  | #ifdef LOGGING
 | ||
|  | 
 | ||
|  | #define LOG(_t_, ...)                       LogManager::Log(LogManager::_t_, __VA_ARGS__);
 | ||
|  | 
 | ||
|  | #define _dbg_assert_(_t_, _a_)\
 | ||
|  | 	if (!(_a_)){\ | ||
|  | 		char szError[512]; \ | ||
|  | 		sprintf_s(szError, 512, "Error localized at...\n\n  Line: %d\n  File: %s\n  Time: %s\n\nIgnore and continue?", __LINE__, __FILE__, __TIMESTAMP__); \ | ||
|  | 		LOG(_t_, szError); \ | ||
|  | 		if (MessageBox(NULL, szError, "*** Assertion Report ***", MB_YESNO | MB_ICONERROR) == IDNO){Crash();} \ | ||
|  | 	} | ||
|  | #define _dbg_assert_msg_(_t_, _a_, _fmt_, ...)\
 | ||
|  | 	if (!(_a_)){\ | ||
|  | 		char szError[582], szError2[512]; \ | ||
|  | 		sprintf_s(szError2, 512, _fmt_, __VA_ARGS__); \ | ||
|  | 		sprintf_s(szError, 582, "Desc.: %s\n\nIgnore and continue?", szError2);	\ | ||
|  | 		LOG(_t_, szError); \ | ||
|  | 		if (MessageBox(NULL, szError, "*** Fatal Error ***", MB_YESNO | MB_ICONERROR) == IDNO){Crash();} \ | ||
|  | 	} | ||
|  | 
 | ||
|  | #else
 | ||
|  | 
 | ||
|  | #define LOG(_t_, ...)
 | ||
|  | #define _dbg_clear_()
 | ||
|  | #define _dbg_assert_(_t_, _a_) ;
 | ||
|  | #define _dbg_assert_msg_(_t_, _a_, _desc_, ...) ;
 | ||
|  | #define _dbg_update_() ;
 | ||
|  | 
 | ||
|  | #endif
 | ||
|  | 
 | ||
|  | #define _assert_msg_(_t_, _a_, _fmt_, ...)\
 | ||
|  | 	if (!(_a_)){\ | ||
|  | 		char szError[582], szError2[512]; \ | ||
|  | 		sprintf_s(szError2, 512, _fmt_, __VA_ARGS__); \ | ||
|  | 		sprintf_s(szError, 582, "Desc.: %s\n\nIgnore and continue?", szError2);	\ | ||
|  | 		LOG(_t_, szError); \ | ||
|  | 		if (MessageBox(NULL, szError, "*** Fatal Error ***", MB_YESNO | MB_ICONERROR) == IDNO){Crash();} \ | ||
|  | 	} | ||
|  | 
 | ||
|  | #endif
 | ||
|  | 
 | ||
|  | 
 | ||
|  | #endif
 | ||
|  | 
 | ||
|  | #endif
 |