2015-05-24 06:55:12 +02:00
|
|
|
// Copyright 2008 Dolphin Emulator Project
|
2015-05-18 01:08:10 +02:00
|
|
|
// Licensed under GPLv2+
|
2013-04-17 23:09:55 -04:00
|
|
|
// Refer to the license.txt file included.
|
2009-02-23 06:15:48 +00:00
|
|
|
|
2014-02-20 04:11:52 +01:00
|
|
|
#include <cstdarg>
|
2014-02-17 05:18:15 -05:00
|
|
|
#include <cstdio>
|
2014-02-20 04:11:52 +01:00
|
|
|
#include <string>
|
2009-02-23 06:15:48 +00:00
|
|
|
|
2015-09-28 10:57:16 -05:00
|
|
|
#include "Common/Common.h"
|
2014-09-07 20:06:58 -05:00
|
|
|
#include "Common/CommonTypes.h"
|
2015-09-26 17:13:07 -04:00
|
|
|
#include "Common/MsgHandler.h"
|
2014-02-17 05:18:15 -05:00
|
|
|
#include "Common/StringUtil.h"
|
2015-09-26 17:13:07 -04:00
|
|
|
#include "Common/Logging/Log.h"
|
2009-02-23 06:15:48 +00:00
|
|
|
|
|
|
|
bool DefaultMsgHandler(const char* caption, const char* text, bool yes_no, int Style);
|
|
|
|
static MsgAlertHandler msg_handler = DefaultMsgHandler;
|
2009-03-18 22:05:31 +00:00
|
|
|
static bool AlertEnabled = true;
|
2009-02-23 06:15:48 +00:00
|
|
|
|
2011-01-14 00:15:08 +00:00
|
|
|
std::string DefaultStringTranslator(const char* text);
|
2011-01-13 02:05:58 +00:00
|
|
|
static StringTranslator str_translator = DefaultStringTranslator;
|
|
|
|
|
2011-02-24 05:05:25 +00:00
|
|
|
// Select which of these functions that are used for message boxes. If
|
|
|
|
// wxWidgets is enabled we will use wxMsgAlert() that is defined in Main.cpp
|
2009-02-23 06:15:48 +00:00
|
|
|
void RegisterMsgAlertHandler(MsgAlertHandler handler)
|
|
|
|
{
|
|
|
|
msg_handler = handler;
|
|
|
|
}
|
|
|
|
|
2011-01-13 02:05:58 +00:00
|
|
|
// Select translation function. For wxWidgets use wxStringTranslator in Main.cpp
|
|
|
|
void RegisterStringTranslator(StringTranslator translator)
|
|
|
|
{
|
|
|
|
str_translator = translator;
|
|
|
|
}
|
|
|
|
|
2009-03-18 22:05:31 +00:00
|
|
|
// enable/disable the alert handler
|
2011-01-13 02:05:58 +00:00
|
|
|
void SetEnableAlert(bool enable)
|
|
|
|
{
|
2009-03-18 22:05:31 +00:00
|
|
|
AlertEnabled = enable;
|
|
|
|
}
|
|
|
|
|
2011-02-24 05:05:25 +00:00
|
|
|
// This is the first stop for gui alerts where the log is updated and the
|
|
|
|
// correct window is shown
|
2011-01-13 20:53:37 +00:00
|
|
|
bool MsgAlert(bool yes_no, int Style, const char* format, ...)
|
2009-02-23 06:15:48 +00:00
|
|
|
{
|
|
|
|
// Read message and write it to the log
|
2011-01-13 20:53:37 +00:00
|
|
|
std::string caption;
|
2011-09-09 00:32:04 +02:00
|
|
|
char buffer[2048];
|
2009-02-23 06:15:48 +00:00
|
|
|
|
2011-01-13 20:53:37 +00:00
|
|
|
static std::string info_caption;
|
|
|
|
static std::string warn_caption;
|
|
|
|
static std::string ques_caption;
|
2011-07-15 14:49:34 +00:00
|
|
|
static std::string crit_caption;
|
2011-01-13 20:53:37 +00:00
|
|
|
|
|
|
|
if (!info_caption.length())
|
|
|
|
{
|
2011-01-14 00:15:08 +00:00
|
|
|
info_caption = str_translator(_trans("Information"));
|
|
|
|
ques_caption = str_translator(_trans("Question"));
|
|
|
|
warn_caption = str_translator(_trans("Warning"));
|
2011-07-15 14:49:34 +00:00
|
|
|
crit_caption = str_translator(_trans("Critical"));
|
2011-01-13 20:53:37 +00:00
|
|
|
}
|
|
|
|
|
2014-03-11 00:30:55 +13:00
|
|
|
switch (Style)
|
2011-01-13 20:53:37 +00:00
|
|
|
{
|
|
|
|
case INFORMATION:
|
|
|
|
caption = info_caption;
|
|
|
|
break;
|
|
|
|
case QUESTION:
|
|
|
|
caption = ques_caption;
|
|
|
|
break;
|
|
|
|
case WARNING:
|
|
|
|
caption = warn_caption;
|
|
|
|
break;
|
2011-07-15 14:49:34 +00:00
|
|
|
case CRITICAL:
|
|
|
|
caption = crit_caption;
|
|
|
|
break;
|
2011-01-13 20:53:37 +00:00
|
|
|
}
|
|
|
|
|
2009-02-23 06:15:48 +00:00
|
|
|
va_list args;
|
|
|
|
va_start(args, format);
|
2015-02-15 14:43:31 -05:00
|
|
|
CharArrayFromFormatV(buffer, sizeof(buffer) - 1, str_translator(format).c_str(), args);
|
2009-02-23 06:15:48 +00:00
|
|
|
va_end(args);
|
|
|
|
|
2011-01-13 20:53:37 +00:00
|
|
|
ERROR_LOG(MASTER_LOG, "%s: %s", caption.c_str(), buffer);
|
2009-02-23 06:15:48 +00:00
|
|
|
|
2009-06-08 10:16:08 +00:00
|
|
|
// Don't ignore questions, especially AskYesNo, PanicYesNo could be ignored
|
2011-07-15 14:49:34 +00:00
|
|
|
if (msg_handler && (AlertEnabled || Style == QUESTION || Style == CRITICAL))
|
2011-02-23 16:00:01 +00:00
|
|
|
return msg_handler(caption.c_str(), buffer, yes_no, Style);
|
|
|
|
|
|
|
|
return true;
|
2009-02-23 06:15:48 +00:00
|
|
|
}
|
|
|
|
|
2011-02-24 05:05:25 +00:00
|
|
|
// Default non library dependent panic alert
|
2009-02-23 06:15:48 +00:00
|
|
|
bool DefaultMsgHandler(const char* caption, const char* text, bool yes_no, int Style)
|
|
|
|
{
|
|
|
|
#ifdef _WIN32
|
2013-03-19 21:51:12 -04:00
|
|
|
int STYLE = MB_ICONINFORMATION;
|
|
|
|
if (Style == QUESTION) STYLE = MB_ICONQUESTION;
|
|
|
|
if (Style == WARNING) STYLE = MB_ICONWARNING;
|
|
|
|
|
|
|
|
return IDYES == MessageBox(0, UTF8ToTStr(text).c_str(), UTF8ToTStr(caption).c_str(), STYLE | (yes_no ? MB_YESNO : MB_OK));
|
2009-02-23 06:15:48 +00:00
|
|
|
#else
|
2015-11-08 13:58:25 +13:00
|
|
|
fprintf(stderr, "%s\n", text);
|
|
|
|
|
|
|
|
// Return no to any question (which will in general crash the emulator)
|
|
|
|
return false;
|
2009-02-23 06:15:48 +00:00
|
|
|
#endif
|
|
|
|
}
|
2011-01-13 02:05:58 +00:00
|
|
|
|
|
|
|
// Default (non) translator
|
2011-01-14 00:15:08 +00:00
|
|
|
std::string DefaultStringTranslator(const char* text)
|
2011-01-13 02:05:58 +00:00
|
|
|
{
|
|
|
|
return text;
|
|
|
|
}
|
|
|
|
|