forked from dolphin-emu/dolphin
		
	
		
			
				
	
	
		
			52 lines
		
	
	
		
			3.0 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			52 lines
		
	
	
		
			3.0 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
// Copyright 2015 Dolphin Emulator Project
 | 
						|
// Licensed under GPLv2+
 | 
						|
// Refer to the license.txt file included.
 | 
						|
 | 
						|
#pragma once
 | 
						|
 | 
						|
#include "Common/Common.h"
 | 
						|
#include "Common/CommonFuncs.h"
 | 
						|
#include "Common/Logging/Log.h"
 | 
						|
#include "Common/MsgHandler.h"
 | 
						|
 | 
						|
#ifdef _WIN32
 | 
						|
#define _assert_msg_(_t_, _a_, _fmt_, ...)                                                         \
 | 
						|
  if (!(_a_))                                                                                      \
 | 
						|
  {                                                                                                \
 | 
						|
    if (!PanicYesNo(_fmt_, __VA_ARGS__))                                                           \
 | 
						|
      Crash();                                                                                     \
 | 
						|
  }
 | 
						|
 | 
						|
#define _dbg_assert_msg_(_t_, _a_, _msg_, ...)                                                     \
 | 
						|
  if (MAX_LOGLEVEL >= LogTypes::LOG_LEVELS::LDEBUG && !(_a_))                                      \
 | 
						|
  {                                                                                                \
 | 
						|
    ERROR_LOG(_t_, _msg_, __VA_ARGS__);                                                            \
 | 
						|
    if (!PanicYesNo(_msg_, __VA_ARGS__))                                                           \
 | 
						|
      Crash();                                                                                     \
 | 
						|
  }
 | 
						|
#else
 | 
						|
#define _assert_msg_(_t_, _a_, _fmt_, ...)                                                         \
 | 
						|
  if (!(_a_))                                                                                      \
 | 
						|
  {                                                                                                \
 | 
						|
    if (!PanicYesNo(_fmt_, ##__VA_ARGS__))                                                         \
 | 
						|
      Crash();                                                                                     \
 | 
						|
  }
 | 
						|
 | 
						|
#define _dbg_assert_msg_(_t_, _a_, _msg_, ...)                                                     \
 | 
						|
  if (MAX_LOGLEVEL >= LogTypes::LOG_LEVELS::LDEBUG && !(_a_))                                      \
 | 
						|
  {                                                                                                \
 | 
						|
    ERROR_LOG(_t_, _msg_, ##__VA_ARGS__);                                                          \
 | 
						|
    if (!PanicYesNo(_msg_, ##__VA_ARGS__))                                                         \
 | 
						|
      Crash();                                                                                     \
 | 
						|
  }
 | 
						|
#endif
 | 
						|
 | 
						|
#define _assert_(_a_)                                                                              \
 | 
						|
  _assert_msg_(MASTER_LOG, _a_,                                                                    \
 | 
						|
               _trans("An error occurred.\n\n  Line: %d\n  File: %s\n\nIgnore and continue?"),     \
 | 
						|
               __LINE__, __FILE__)
 | 
						|
 | 
						|
#define _dbg_assert_(_t_, _a_)                                                                     \
 | 
						|
  if (MAX_LOGLEVEL >= LogTypes::LOG_LEVELS::LDEBUG)                                                \
 | 
						|
  _assert_(_a_)
 |