2012-11-01 15:19:01 +00:00
|
|
|
// Copyright (C) 2003 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
|
2012-11-04 22:01:49 +00:00
|
|
|
// the Free Software Foundation, version 2.0 or later versions.
|
2012-11-01 15:19:01 +00:00
|
|
|
|
|
|
|
// 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/
|
|
|
|
|
2017-11-20 10:57:54 +00:00
|
|
|
#include <string>
|
|
|
|
|
2017-03-05 01:21:25 +00:00
|
|
|
#include "ppsspp_config.h"
|
|
|
|
|
2017-11-20 10:57:54 +00:00
|
|
|
#include "Common.h"
|
2020-08-15 10:25:39 +00:00
|
|
|
#include "Common/Log.h"
|
2013-05-03 06:22:15 +00:00
|
|
|
#include "StringUtils.h"
|
2013-08-26 17:00:16 +00:00
|
|
|
#include "util/text/utf8.h"
|
2012-11-01 15:19:01 +00:00
|
|
|
|
2020-08-16 11:41:16 +00:00
|
|
|
#if PPSSPP_PLATFORM(ANDROID)
|
|
|
|
#include <android/log.h>
|
|
|
|
#elif PPSSPP_PLATFORM(WINDOWS)
|
2020-08-16 11:27:28 +00:00
|
|
|
#include "CommonWindows.h"
|
|
|
|
#endif
|
2012-11-01 15:19:01 +00:00
|
|
|
|
2020-08-16 11:48:31 +00:00
|
|
|
#if defined(__ANDROID__)
|
|
|
|
|
|
|
|
#define LOG_BUF_SIZE 1024
|
|
|
|
|
|
|
|
void AndroidAssert(const char *func, const char *file, int line, const char *condition, const char *fmt, ...) {
|
|
|
|
char buf[LOG_BUF_SIZE];
|
|
|
|
va_list args;
|
|
|
|
va_start(args, fmt);
|
|
|
|
vsnprintf(buf, sizeof(buf), fmt, args);
|
|
|
|
__android_log_assert(condition, "PPSSPP", "%s:%d (%s): [%s] %s", file, line, func, condition, buf);
|
|
|
|
va_end(args);
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|
|
|
|
|
2020-08-16 11:41:16 +00:00
|
|
|
bool ShowAssertDialog(const char *function, const char *file, int line, const char *expression, const char* format, ...) {
|
2012-11-01 15:19:01 +00:00
|
|
|
// Read message and write it to the log
|
2020-08-16 11:27:28 +00:00
|
|
|
char text[2048];
|
|
|
|
const char *caption = "Critical";
|
2012-11-01 15:19:01 +00:00
|
|
|
va_list args;
|
|
|
|
va_start(args, format);
|
2020-08-16 11:41:16 +00:00
|
|
|
vsnprintf(text, sizeof(text), format, args);
|
2012-11-01 15:19:01 +00:00
|
|
|
va_end(args);
|
2020-08-16 11:41:16 +00:00
|
|
|
|
2017-11-20 10:57:54 +00:00
|
|
|
// Normal logging (will also log to Android log)
|
2020-08-16 11:27:28 +00:00
|
|
|
ERROR_LOG(SYSTEM, "(%s:%d) %s: %s", file, line, caption, text);
|
2020-08-16 11:41:16 +00:00
|
|
|
// Also do a simple printf for good measure, in case logging of SYSTEM is disabled (should we disallow that?)
|
|
|
|
printf("(%s: %d) %s: %s\n", file, line, caption, text);
|
2012-11-01 15:19:01 +00:00
|
|
|
|
2016-01-03 23:10:50 +00:00
|
|
|
#if defined(USING_WIN_UI)
|
2020-08-16 11:27:28 +00:00
|
|
|
int msgBoxStyle = MB_ICONINFORMATION | MB_YESNO;
|
2017-11-20 10:57:54 +00:00
|
|
|
std::wstring wtext = ConvertUTF8ToWString(text) + L"\n\nTry to continue?";
|
2013-08-26 17:00:16 +00:00
|
|
|
std::wstring wcaption = ConvertUTF8ToWString(caption);
|
2017-11-20 10:57:54 +00:00
|
|
|
OutputDebugString(wtext.c_str());
|
2020-08-16 11:27:28 +00:00
|
|
|
return IDYES == MessageBox(0, wtext.c_str(), wcaption.c_str(), msgBoxStyle);
|
2012-11-01 15:19:01 +00:00
|
|
|
#else
|
2020-08-16 11:27:28 +00:00
|
|
|
OutputDebugStringUTF8(text);
|
2017-11-20 10:57:54 +00:00
|
|
|
return false;
|
2012-11-01 15:19:01 +00:00
|
|
|
#endif
|
|
|
|
}
|