// 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); #if defined(HAVE_WX) && HAVE_WX wxMessageBox(wxString::FromAscii(buffer), wxT("PANIC!"), wxICON_EXCLAMATION); #else vprintf(format, args); printf("\n"); #endif } va_end(args); } void SuccessAlert(const char* format, ...) { va_list args; va_start(args, format); if (panic_handler) { char buffer[2048]; CharArrayFromFormatV(buffer, 2048, format, args); LOG(MASTER_LOG, "SUCCESS: %s", buffer); panic_handler(buffer, false); } else { char buffer[2048]; CharArrayFromFormatV(buffer, 2048, format, args); LOG(MASTER_LOG, "SUCCESS: %s", buffer); #if defined(HAVE_WX) && HAVE_WX wxMessageBox(wxString::FromAscii(buffer), wxT("SUCCESS!"), wxICON_EXCLAMATION); #else vprintf(format, args); printf("\n"); #endif } 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); #if defined(HAVE_WX) && HAVE_WX retval = wxYES == wxMessageBox(wxString::FromAscii(buffer), wxT("PANIC! Continue?"), wxICON_QUESTION | wxYES_NO); #else vprintf(format, args); printf("\n"); #endif 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); #if defined(HAVE_WX) && HAVE_WX retval = wxYES == wxMessageBox(wxString::FromAscii(buffer), wxT("Dolphin"), wxICON_QUESTION | wxYES_NO); #else vprintf(format, args); printf("\n"); #endif 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); }*/