2015-06-21 15:33:46 +00:00
|
|
|
/*
|
|
|
|
Simple DirectMedia Layer
|
2022-01-03 17:40:00 +00:00
|
|
|
Copyright (C) 1997-2022 Sam Lantinga <slouken@libsdl.org>
|
2015-06-21 15:33:46 +00:00
|
|
|
|
|
|
|
This software is provided 'as-is', without any express or implied
|
|
|
|
warranty. In no event will the authors be held liable for any damages
|
|
|
|
arising from the use of this software.
|
|
|
|
|
|
|
|
Permission is granted to anyone to use this software for any purpose,
|
|
|
|
including commercial applications, and to alter it and redistribute it
|
|
|
|
freely, subject to the following restrictions:
|
|
|
|
|
|
|
|
1. The origin of this software must not be misrepresented; you must not
|
|
|
|
claim that you wrote the original software. If you use this software
|
|
|
|
in a product, an acknowledgment in the product documentation would be
|
|
|
|
appreciated but is not required.
|
|
|
|
2. Altered source versions must be plainly marked as such, and must not be
|
|
|
|
misrepresented as being the original software.
|
|
|
|
3. This notice may not be removed or altered from any source distribution.
|
|
|
|
*/
|
|
|
|
#include "./SDL_internal.h"
|
|
|
|
|
|
|
|
/* Simple error handling in SDL */
|
|
|
|
|
|
|
|
#include "SDL_error.h"
|
|
|
|
#include "SDL_error_c.h"
|
|
|
|
|
|
|
|
int
|
|
|
|
SDL_SetError(SDL_PRINTF_FORMAT_STRING const char *fmt, ...)
|
|
|
|
{
|
|
|
|
/* Ignore call if invalid format pointer was passed */
|
2020-04-21 05:30:36 +00:00
|
|
|
if (fmt != NULL) {
|
|
|
|
va_list ap;
|
2022-06-27 23:59:50 +00:00
|
|
|
int result;
|
2020-04-21 05:30:36 +00:00
|
|
|
SDL_error *error = SDL_GetErrBuf();
|
2015-06-21 15:33:46 +00:00
|
|
|
|
2020-04-21 05:30:36 +00:00
|
|
|
error->error = 1; /* mark error as valid */
|
2015-06-21 15:33:46 +00:00
|
|
|
|
2020-04-21 05:30:36 +00:00
|
|
|
va_start(ap, fmt);
|
2022-06-27 23:59:50 +00:00
|
|
|
result = SDL_vsnprintf(error->str, error->len, fmt, ap);
|
2022-06-28 07:46:12 +00:00
|
|
|
va_end(ap);
|
|
|
|
|
2022-06-27 23:59:50 +00:00
|
|
|
if (result >= 0 && (size_t)result >= error->len && error->realloc_func) {
|
|
|
|
size_t len = (size_t)result + 1;
|
|
|
|
char *str = (char *)error->realloc_func(error->str, len);
|
|
|
|
if (str) {
|
|
|
|
error->str = str;
|
|
|
|
error->len = len;
|
2022-06-28 07:46:12 +00:00
|
|
|
va_start(ap, fmt);
|
2022-06-27 23:59:50 +00:00
|
|
|
SDL_vsnprintf(error->str, error->len, fmt, ap);
|
2022-06-28 07:46:12 +00:00
|
|
|
va_end(ap);
|
2022-06-27 23:59:50 +00:00
|
|
|
}
|
|
|
|
}
|
2022-06-28 07:46:12 +00:00
|
|
|
|
2020-04-21 05:30:36 +00:00
|
|
|
|
|
|
|
if (SDL_LogGetPriority(SDL_LOG_CATEGORY_ERROR) <= SDL_LOG_PRIORITY_DEBUG) {
|
|
|
|
/* If we are in debug mode, print out the error message */
|
|
|
|
SDL_LogDebug(SDL_LOG_CATEGORY_ERROR, "%s", error->str);
|
2015-06-21 15:33:46 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
|
2016-11-23 16:49:26 +00:00
|
|
|
/* Available for backwards compatibility */
|
|
|
|
const char *
|
|
|
|
SDL_GetError(void)
|
|
|
|
{
|
2020-04-21 05:30:36 +00:00
|
|
|
const SDL_error *error = SDL_GetErrBuf();
|
|
|
|
return error->error ? error->str : "";
|
2016-11-23 16:49:26 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
SDL_ClearError(void)
|
|
|
|
{
|
2020-04-21 05:30:36 +00:00
|
|
|
SDL_GetErrBuf()->error = 0;
|
2016-11-23 16:49:26 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/* Very common errors go here */
|
|
|
|
int
|
|
|
|
SDL_Error(SDL_errorcode code)
|
|
|
|
{
|
|
|
|
switch (code) {
|
|
|
|
case SDL_ENOMEM:
|
|
|
|
return SDL_SetError("Out of memory");
|
|
|
|
case SDL_EFREAD:
|
|
|
|
return SDL_SetError("Error reading from datastream");
|
|
|
|
case SDL_EFWRITE:
|
|
|
|
return SDL_SetError("Error writing to datastream");
|
|
|
|
case SDL_EFSEEK:
|
|
|
|
return SDL_SetError("Error seeking in datastream");
|
|
|
|
case SDL_UNSUPPORTED:
|
|
|
|
return SDL_SetError("That operation is not supported");
|
|
|
|
default:
|
|
|
|
return SDL_SetError("Unknown SDL error");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
#ifdef TEST_ERROR
|
|
|
|
int
|
|
|
|
main(int argc, char *argv[])
|
|
|
|
{
|
|
|
|
char buffer[BUFSIZ + 1];
|
|
|
|
|
|
|
|
SDL_SetError("Hi there!");
|
|
|
|
printf("Error 1: %s\n", SDL_GetError());
|
|
|
|
SDL_ClearError();
|
|
|
|
SDL_memset(buffer, '1', BUFSIZ);
|
|
|
|
buffer[BUFSIZ] = 0;
|
|
|
|
SDL_SetError("This is the error: %s (%f)", buffer, 1.0);
|
|
|
|
printf("Error 2: %s\n", SDL_GetError());
|
|
|
|
exit(0);
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
2020-03-14 04:28:09 +00:00
|
|
|
char *
|
2015-06-21 15:33:46 +00:00
|
|
|
SDL_GetErrorMsg(char *errstr, int maxlen)
|
|
|
|
{
|
2020-04-21 05:30:36 +00:00
|
|
|
const SDL_error *error = SDL_GetErrBuf();
|
2015-06-21 15:33:46 +00:00
|
|
|
|
|
|
|
if (error->error) {
|
2020-04-21 05:30:36 +00:00
|
|
|
SDL_strlcpy(errstr, error->str, maxlen);
|
|
|
|
} else {
|
|
|
|
*errstr = '\0';
|
2015-06-21 15:33:46 +00:00
|
|
|
}
|
2020-04-21 05:30:36 +00:00
|
|
|
|
|
|
|
return errstr;
|
2015-06-21 15:33:46 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/* vi: set ts=4 sw=4 expandtab: */
|