| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778 |
- #include "errors.h"
- #include "log.h"
- #include <stdlib.h>
- #include <string.h>
- static void debug_break(void) {
- #ifndef NDEBUG
- #if defined(_MSC_VER)
- __debugbreak();
- #elif defined(__clang__)
- __builtin_debugtrap();
- #else
- #if defined(__aarch64__)
- __asm__ volatile(".inst 0xd4200000");
- #elif defined(__x86_64__)
- __asm__ volatile("int $0x03");
- #else
- kong_log(LOG_LEVEL_WARNING, "Oh no, debug_break is not implemented for the current compiler and CPU.");
- #endif
- #endif
- #endif
- }
- void error_args(debug_context context, const char *message, va_list args) {
- char buffer[4096];
- if (context.filename != NULL) {
- sprintf(buffer, "In column %i at line %i in %s: ", context.column + 1, context.line + 1, context.filename);
- }
- else {
- sprintf(buffer, "In column %i at line %i: ", context.column + 1, context.line + 1);
- }
- strcat(buffer, message);
- kong_log_args(LOG_LEVEL_ERROR, buffer, args);
- debug_break();
- exit(1);
- }
- void error_args_no_context(const char *message, va_list args) {
- kong_log_args(LOG_LEVEL_ERROR, message, args);
- exit(1);
- }
- void error(debug_context context, const char *message, ...) {
- va_list args;
- va_start(args, message);
- error_args(context, message, args);
- va_end(args);
- }
- void error_no_context(const char *message, ...) {
- va_list args;
- va_start(args, message);
- error_args_no_context(message, args);
- va_end(args);
- }
- void check_args(bool test, debug_context context, const char *message, va_list args) {
- if (!test) {
- error_args(context, message, args);
- }
- }
- void check_function(bool test, debug_context context, const char *message, ...) {
- if (!test) {
- va_list args;
- va_start(args, message);
- error_args(context, message, args);
- va_end(args);
- }
- }
|