// 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/ #include #include "Common.h" #include "StringUtil.h" #include namespace { static PanicAlertHandler panic_handler = 0; } void RegisterPanicAlertHandler(PanicAlertHandler handler) { panic_handler = handler; } void PanicAlert(const char* format, ...) { va_list args; va_start(args, format); if (panic_handler) { char buffer[2048]; CharArrayFromFormatV(buffer, 2048, format, args); LOG(MASTER_LOG, "PANIC: %s", buffer); panic_handler(buffer, false); } else { char buffer[2048]; CharArrayFromFormatV(buffer, 2048, format, args); LOG(MASTER_LOG, "PANIC: %s", buffer); wxMessageBox(buffer, "PANIC!", wxICON_EXCLAMATION); } va_end(args); } bool PanicYesNo(const char* format, ...) { va_list args; va_start(args, format); bool retval; char buffer[2048]; CharArrayFromFormatV(buffer, 2048, format, args); LOG(MASTER_LOG, "PANIC: %s", buffer); retval = wxYES == wxMessageBox(buffer, "PANIC! Continue?", wxICON_QUESTION | wxYES_NO); va_end(args); return(retval); } bool AskYesNo(const char* format, ...) { va_list args; va_start(args, format); bool retval; char buffer[2048]; CharArrayFromFormatV(buffer, 2048, format, args); LOG(MASTER_LOG, "ASK: %s", buffer); retval = wxYES == wxMessageBox(buffer, "Dolphin", wxICON_QUESTION | wxYES_NO); va_end(args); return(retval); } // Standard implementation of logging - simply print to standard output. // Programs are welcome to override this. /* void __Log(int logNumber, const char *text, ...) { va_list args; va_start(args, text); vprintf(text, args); va_end(args); }*/