libtcod
Loading...
Searching...
No Matches
error.h
Go to the documentation of this file.
1/* BSD 3-Clause License
2 *
3 * Copyright © 2008-2025, Jice and the libtcod contributors.
4 * All rights reserved.
5 *
6 * Redistribution and use in source and binary forms, with or without
7 * modification, are permitted provided that the following conditions are met:
8 *
9 * 1. Redistributions of source code must retain the above copyright notice,
10 * this list of conditions and the following disclaimer.
11 *
12 * 2. Redistributions in binary form must reproduce the above copyright notice,
13 * this list of conditions and the following disclaimer in the documentation
14 * and/or other materials provided with the distribution.
15 *
16 * 3. Neither the name of the copyright holder nor the names of its
17 * contributors may be used to endorse or promote products derived from
18 * this software without specific prior written permission.
19 *
20 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
21 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
22 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
23 * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
24 * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
25 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
26 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
27 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
28 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
29 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
30 * POSSIBILITY OF SUCH DAMAGE.
31 */
34#pragma once
35#ifndef LIBTCOD_ERROR_H_
36#define LIBTCOD_ERROR_H_
37#include "config.h"
38#include "version.h"
84#ifdef __cplusplus
85extern "C" {
86#endif // __cplusplus
87
94TCOD_NODISCARD
95TCODLIB_API const char* TCOD_get_error(void);
96
103TCODLIB_API TCOD_Error TCOD_set_error(const char* msg);
110TCODLIB_FORMAT(1, 2)
111TCODLIB_API TCOD_Error TCOD_set_errorf(const char* fmt, ...);
118TCODLIB_API void TCOD_clear_error(void);
124#define TCOD_set_errorv(msg) TCOD_set_errorf("%s:%i\n%s", TCOD_STRVERSIONNAME " " __FILE__, __LINE__, (msg))
130#define TCOD_set_errorvf(fmt, ...) \
131 TCOD_set_errorf("%s:%i\n" fmt, TCOD_STRVERSIONNAME " " __FILE__, __LINE__, __VA_ARGS__)
132#ifdef __cplusplus
133} // extern "C"
134#endif // __cplusplus
135#endif // LIBTCOD_ERROR_H_
Libtcod config header.
TCOD_Error
An enum of libtcod error codes.
Definition error.h:48
@ TCOD_E_WARN
The function completed, but a minor issue was detected.
Definition error.h:82
@ TCOD_E_REQUIRES_ATTENTION
This function needs additional attention, but is otherwise functioning correctly.
Definition error.h:78
@ TCOD_E_OUT_OF_MEMORY
The function failed because it was unable to allocate enough memory.
Definition error.h:70
@ TCOD_E_INVALID_ARGUMENT
The function failed because a given input argument was invalid.
Definition error.h:66
@ TCOD_E_OK
The function completed successfully without issues.
Definition error.h:55
@ TCOD_E_ERROR
The error code for generic runtime errors.
Definition error.h:62
TCOD_Error TCOD_set_error(const char *msg)
Set an error message and return TCOD_E_ERROR.
TCOD_Error TCOD_set_errorf(const char *fmt,...)
Set an error message and return TCOD_E_ERROR.
const char * TCOD_get_error(void)
Return the last error message.
void TCOD_clear_error(void)
Clear a current existing error message.
Libtcod version informaiton.