Skip to content

Latest commit

 

History

History
119 lines (98 loc) · 3.08 KB

SDL_error.c

File metadata and controls

119 lines (98 loc) · 3.08 KB
 
1
2
/*
Simple DirectMedia Layer
Jan 17, 2020
Jan 17, 2020
3
Copyright (C) 1997-2020 Sam Lantinga <slouken@libsdl.org>
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
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"
#define SDL_ERRBUFIZE 1024
int
SDL_SetError(SDL_PRINTF_FORMAT_STRING const char *fmt, ...)
{
/* Ignore call if invalid format pointer was passed */
Apr 21, 2020
Apr 21, 2020
34
35
36
if (fmt != NULL) {
va_list ap;
SDL_error *error = SDL_GetErrBuf();
Apr 21, 2020
Apr 21, 2020
38
error->error = 1; /* mark error as valid */
Apr 21, 2020
Apr 21, 2020
40
41
42
43
44
45
46
va_start(ap, fmt);
SDL_vsnprintf(error->str, ERR_MAX_STRLEN, fmt, ap);
va_end(ap);
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);
47
48
49
50
51
52
}
}
return -1;
}
Nov 23, 2016
Nov 23, 2016
53
54
55
56
/* Available for backwards compatibility */
const char *
SDL_GetError(void)
{
Apr 21, 2020
Apr 21, 2020
57
58
const SDL_error *error = SDL_GetErrBuf();
return error->error ? error->str : "";
Nov 23, 2016
Nov 23, 2016
59
60
61
62
63
}
void
SDL_ClearError(void)
{
Apr 21, 2020
Apr 21, 2020
64
SDL_GetErrBuf()->error = 0;
Nov 23, 2016
Nov 23, 2016
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
}
/* 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
Mar 14, 2020
Mar 14, 2020
105
char *
106
107
SDL_GetErrorMsg(char *errstr, int maxlen)
{
Apr 21, 2020
Apr 21, 2020
108
const SDL_error *error = SDL_GetErrBuf();
109
110
if (error->error) {
Apr 21, 2020
Apr 21, 2020
111
112
113
SDL_strlcpy(errstr, error->str, maxlen);
} else {
*errstr = '\0';
Apr 21, 2020
Apr 21, 2020
115
116
return errstr;
117
118
119
}
/* vi: set ts=4 sw=4 expandtab: */