summaryrefslogtreecommitdiff
path: root/config.c
diff options
context:
space:
mode:
authorpommicket <pommicket@gmail.com>2023-01-03 12:25:58 -0500
committerpommicket <pommicket@gmail.com>2023-01-03 12:26:09 -0500
commit1c74c64c6429ebc3720e519cfb155b0a914e1c24 (patch)
tree75a4ccb9cfdb7e023ed19aa45b3f791d9a1dc9be /config.c
parent7428d8a59298d6a7e45cfdbfa937a770393aaa1c (diff)
different types of messages
Diffstat (limited to 'config.c')
-rw-r--r--config.c25
1 files changed, 14 insertions, 11 deletions
diff --git a/config.c b/config.c
index 4582f3b..25915cc 100644
--- a/config.c
+++ b/config.c
@@ -147,16 +147,6 @@ static void setting_string_set(Settings *settings, const SettingString *set, con
}
-
-
-
-// all worth it for the -Wformat warnings
-#define config_err(cfg, ...) do {\
- if ((cfg)->error) break;\
- snprintf((cfg)->ted->error, sizeof (cfg)->ted->error - 1, "%s:%u: ", (cfg)->filename, (cfg)->line_number), \
- snprintf((cfg)->ted->error + strlen((cfg)->ted->error), sizeof (cfg)->ted->error - 1 - strlen((cfg)->ted->error), __VA_ARGS__), \
- (cfg)->error = true; } while (0)
-
typedef struct {
Ted *ted;
const char *filename;
@@ -164,6 +154,16 @@ typedef struct {
bool error;
} ConfigReader;
+static void config_err(ConfigReader *cfg, PRINTF_FORMAT_STRING const char *fmt, ...) ATTRIBUTE_PRINTF(2, 3);
+static void config_err(ConfigReader *cfg, const char *fmt, ...) {
+ char error[1024] = {0};
+ strbuf_printf(error, "%s:%u: ", cfg->filename, cfg->line_number);
+ va_list args;
+ va_start(args, fmt);
+ vsnprintf(error + strlen(error), sizeof error - strlen(error) - 1, fmt, args);
+ va_end(args);
+}
+
static void context_copy(SettingsContext *dest, const SettingsContext *src) {
*dest = *src;
if (src->path)
@@ -647,7 +647,10 @@ uniform sampler2D t_texture;\n\
gl_rc_sab_decref(&s->bg_shader);
- GLuint shader = gl_compile_and_link_shaders(ted->error, vshader, fshader);
+ char error[512] = {0};
+ GLuint shader = gl_compile_and_link_shaders(error, vshader, fshader);
+ if (*error)
+ ted_seterr(ted, "%s", error);
if (shader) {
GLuint buffer = 0, array = 0;
glGenBuffers(1, &buffer);