src/error.c

Sun, 11 Aug 2024 16:11:30 +0200

author
Mike Becker <universe@uap-core.de>
date
Sun, 11 Aug 2024 16:11:30 +0200
changeset 68
823c03733e42
parent 58
26ebb2f1e6e6
permissions
-rw-r--r--

add mouse and window focus - resolves #382

plus some minor code improvements

0
593b60458157 initial commit
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1 /*
593b60458157 initial commit
Mike Becker <universe@uap-core.de>
parents:
diff changeset
2 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER.
593b60458157 initial commit
Mike Becker <universe@uap-core.de>
parents:
diff changeset
3 * Copyright 2023 Mike Becker. All rights reserved.
593b60458157 initial commit
Mike Becker <universe@uap-core.de>
parents:
diff changeset
4 *
593b60458157 initial commit
Mike Becker <universe@uap-core.de>
parents:
diff changeset
5 * Redistribution and use in source and binary forms, with or without
593b60458157 initial commit
Mike Becker <universe@uap-core.de>
parents:
diff changeset
6 * modification, are permitted provided that the following conditions are met:
593b60458157 initial commit
Mike Becker <universe@uap-core.de>
parents:
diff changeset
7 *
593b60458157 initial commit
Mike Becker <universe@uap-core.de>
parents:
diff changeset
8 * 1. Redistributions of source code must retain the above copyright
593b60458157 initial commit
Mike Becker <universe@uap-core.de>
parents:
diff changeset
9 * notice, this list of conditions and the following disclaimer.
593b60458157 initial commit
Mike Becker <universe@uap-core.de>
parents:
diff changeset
10 *
593b60458157 initial commit
Mike Becker <universe@uap-core.de>
parents:
diff changeset
11 * 2. Redistributions in binary form must reproduce the above copyright
593b60458157 initial commit
Mike Becker <universe@uap-core.de>
parents:
diff changeset
12 * notice, this list of conditions and the following disclaimer in the
593b60458157 initial commit
Mike Becker <universe@uap-core.de>
parents:
diff changeset
13 * documentation and/or other materials provided with the distribution.
593b60458157 initial commit
Mike Becker <universe@uap-core.de>
parents:
diff changeset
14 *
593b60458157 initial commit
Mike Becker <universe@uap-core.de>
parents:
diff changeset
15 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
593b60458157 initial commit
Mike Becker <universe@uap-core.de>
parents:
diff changeset
16 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
593b60458157 initial commit
Mike Becker <universe@uap-core.de>
parents:
diff changeset
17 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
593b60458157 initial commit
Mike Becker <universe@uap-core.de>
parents:
diff changeset
18 * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
593b60458157 initial commit
Mike Becker <universe@uap-core.de>
parents:
diff changeset
19 * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
593b60458157 initial commit
Mike Becker <universe@uap-core.de>
parents:
diff changeset
20 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
593b60458157 initial commit
Mike Becker <universe@uap-core.de>
parents:
diff changeset
21 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
593b60458157 initial commit
Mike Becker <universe@uap-core.de>
parents:
diff changeset
22 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
593b60458157 initial commit
Mike Becker <universe@uap-core.de>
parents:
diff changeset
23 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
593b60458157 initial commit
Mike Becker <universe@uap-core.de>
parents:
diff changeset
24 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
593b60458157 initial commit
Mike Becker <universe@uap-core.de>
parents:
diff changeset
25 * POSSIBILITY OF SUCH DAMAGE.
593b60458157 initial commit
Mike Becker <universe@uap-core.de>
parents:
diff changeset
26 */
593b60458157 initial commit
Mike Becker <universe@uap-core.de>
parents:
diff changeset
27
7
9dd76cbd6c90 improve code structure
Mike Becker <universe@uap-core.de>
parents: 6
diff changeset
28 #include "ascension/context.h"
9dd76cbd6c90 improve code structure
Mike Becker <universe@uap-core.de>
parents: 6
diff changeset
29 #include "ascension/error.h"
9dd76cbd6c90 improve code structure
Mike Becker <universe@uap-core.de>
parents: 6
diff changeset
30 #include "ascension/utils.h"
0
593b60458157 initial commit
Mike Becker <universe@uap-core.de>
parents:
diff changeset
31
7
9dd76cbd6c90 improve code structure
Mike Becker <universe@uap-core.de>
parents: 6
diff changeset
32 #include <cx/buffer.h>
16
c5dde81b6fb2 add text rendering and demo FPS counter
Mike Becker <universe@uap-core.de>
parents: 15
diff changeset
33 #include <GL/gl.h>
0
593b60458157 initial commit
Mike Becker <universe@uap-core.de>
parents:
diff changeset
34
593b60458157 initial commit
Mike Becker <universe@uap-core.de>
parents:
diff changeset
35 void asc_error_cchar(char const* text) {
593b60458157 initial commit
Mike Becker <universe@uap-core.de>
parents:
diff changeset
36 asc_error_cxstr(cx_str(text));
593b60458157 initial commit
Mike Becker <universe@uap-core.de>
parents:
diff changeset
37 }
593b60458157 initial commit
Mike Becker <universe@uap-core.de>
parents:
diff changeset
38
593b60458157 initial commit
Mike Becker <universe@uap-core.de>
parents:
diff changeset
39 void asc_error_cuchar(unsigned char const* text) {
593b60458157 initial commit
Mike Becker <universe@uap-core.de>
parents:
diff changeset
40 asc_error_cxstr(cx_str((char const*)text));
593b60458157 initial commit
Mike Becker <universe@uap-core.de>
parents:
diff changeset
41 }
593b60458157 initial commit
Mike Becker <universe@uap-core.de>
parents:
diff changeset
42
593b60458157 initial commit
Mike Becker <universe@uap-core.de>
parents:
diff changeset
43 void asc_error_cxstr(cxstring text) {
593b60458157 initial commit
Mike Becker <universe@uap-core.de>
parents:
diff changeset
44 if (text.length == 0) return;
593b60458157 initial commit
Mike Becker <universe@uap-core.de>
parents:
diff changeset
45
593b60458157 initial commit
Mike Becker <universe@uap-core.de>
parents:
diff changeset
46 // write error to debug output
15
362b7659dc76 add shader loading and unloading
Mike Becker <universe@uap-core.de>
parents: 7
diff changeset
47 asc_dprintf("ERROR: %.*s", (int)text.length, text.ptr);
0
593b60458157 initial commit
Mike Becker <universe@uap-core.de>
parents:
diff changeset
48
593b60458157 initial commit
Mike Becker <universe@uap-core.de>
parents:
diff changeset
49 // write error to buffer
593b60458157 initial commit
Mike Becker <universe@uap-core.de>
parents:
diff changeset
50 CxBuffer* buf = &asc_context.error_buffer;
593b60458157 initial commit
Mike Becker <universe@uap-core.de>
parents:
diff changeset
51 cxBufferWrite(text.ptr, 1, text.length, buf);
593b60458157 initial commit
Mike Becker <universe@uap-core.de>
parents:
diff changeset
52 cxBufferPut(buf, '\n');
593b60458157 initial commit
Mike Becker <universe@uap-core.de>
parents:
diff changeset
53
58
26ebb2f1e6e6 improve ui/text.h interface a lot
Mike Becker <universe@uap-core.de>
parents: 16
diff changeset
54 asc_set_flag(asc_context.flags, ASC_FLAG_HAS_ERROR);
0
593b60458157 initial commit
Mike Becker <universe@uap-core.de>
parents:
diff changeset
55 }
593b60458157 initial commit
Mike Becker <universe@uap-core.de>
parents:
diff changeset
56
593b60458157 initial commit
Mike Becker <universe@uap-core.de>
parents:
diff changeset
57 bool asc_has_error(void) {
593b60458157 initial commit
Mike Becker <universe@uap-core.de>
parents:
diff changeset
58 return asc_test_flag(asc_context.flags, ASC_FLAG_HAS_ERROR);
593b60458157 initial commit
Mike Becker <universe@uap-core.de>
parents:
diff changeset
59 }
593b60458157 initial commit
Mike Becker <universe@uap-core.de>
parents:
diff changeset
60
593b60458157 initial commit
Mike Becker <universe@uap-core.de>
parents:
diff changeset
61 char const* asc_get_error(void) {
593b60458157 initial commit
Mike Becker <universe@uap-core.de>
parents:
diff changeset
62 // we zero-terminate the current buffer contents before providing them
593b60458157 initial commit
Mike Becker <universe@uap-core.de>
parents:
diff changeset
63 cxBufferPut(&asc_context.error_buffer, 0);
593b60458157 initial commit
Mike Becker <universe@uap-core.de>
parents:
diff changeset
64 --asc_context.error_buffer.pos;
593b60458157 initial commit
Mike Becker <universe@uap-core.de>
parents:
diff changeset
65 --asc_context.error_buffer.size;
593b60458157 initial commit
Mike Becker <universe@uap-core.de>
parents:
diff changeset
66 return asc_context.error_buffer.space;
593b60458157 initial commit
Mike Becker <universe@uap-core.de>
parents:
diff changeset
67 }
593b60458157 initial commit
Mike Becker <universe@uap-core.de>
parents:
diff changeset
68
593b60458157 initial commit
Mike Becker <universe@uap-core.de>
parents:
diff changeset
69 void asc_clear_error(void) {
593b60458157 initial commit
Mike Becker <universe@uap-core.de>
parents:
diff changeset
70 cxBufferClear(&asc_context.error_buffer);
58
26ebb2f1e6e6 improve ui/text.h interface a lot
Mike Becker <universe@uap-core.de>
parents: 16
diff changeset
71 asc_clear_flag(asc_context.flags, ASC_FLAG_HAS_ERROR);
0
593b60458157 initial commit
Mike Becker <universe@uap-core.de>
parents:
diff changeset
72 }
16
c5dde81b6fb2 add text rendering and demo FPS counter
Mike Becker <universe@uap-core.de>
parents: 15
diff changeset
73
c5dde81b6fb2 add text rendering and demo FPS counter
Mike Becker <universe@uap-core.de>
parents: 15
diff changeset
74 void asc_error_gl(unsigned code, cxstring message) {
c5dde81b6fb2 add text rendering and demo FPS counter
Mike Becker <universe@uap-core.de>
parents: 15
diff changeset
75 const char *glerr;
c5dde81b6fb2 add text rendering and demo FPS counter
Mike Becker <universe@uap-core.de>
parents: 15
diff changeset
76 switch(code) {
c5dde81b6fb2 add text rendering and demo FPS counter
Mike Becker <universe@uap-core.de>
parents: 15
diff changeset
77 case GL_NO_ERROR:
c5dde81b6fb2 add text rendering and demo FPS counter
Mike Becker <universe@uap-core.de>
parents: 15
diff changeset
78 return;
c5dde81b6fb2 add text rendering and demo FPS counter
Mike Becker <universe@uap-core.de>
parents: 15
diff changeset
79 case GL_INVALID_ENUM:
c5dde81b6fb2 add text rendering and demo FPS counter
Mike Becker <universe@uap-core.de>
parents: 15
diff changeset
80 glerr = "invalid enum";
c5dde81b6fb2 add text rendering and demo FPS counter
Mike Becker <universe@uap-core.de>
parents: 15
diff changeset
81 break;
c5dde81b6fb2 add text rendering and demo FPS counter
Mike Becker <universe@uap-core.de>
parents: 15
diff changeset
82 case GL_INVALID_VALUE:
c5dde81b6fb2 add text rendering and demo FPS counter
Mike Becker <universe@uap-core.de>
parents: 15
diff changeset
83 glerr = "invalid value";
c5dde81b6fb2 add text rendering and demo FPS counter
Mike Becker <universe@uap-core.de>
parents: 15
diff changeset
84 break;
c5dde81b6fb2 add text rendering and demo FPS counter
Mike Becker <universe@uap-core.de>
parents: 15
diff changeset
85 case GL_INVALID_OPERATION:
c5dde81b6fb2 add text rendering and demo FPS counter
Mike Becker <universe@uap-core.de>
parents: 15
diff changeset
86 glerr = "invalid operation";
c5dde81b6fb2 add text rendering and demo FPS counter
Mike Becker <universe@uap-core.de>
parents: 15
diff changeset
87 break;
c5dde81b6fb2 add text rendering and demo FPS counter
Mike Becker <universe@uap-core.de>
parents: 15
diff changeset
88 case GL_INVALID_FRAMEBUFFER_OPERATION:
c5dde81b6fb2 add text rendering and demo FPS counter
Mike Becker <universe@uap-core.de>
parents: 15
diff changeset
89 glerr = "invalid framebuffer operation";
c5dde81b6fb2 add text rendering and demo FPS counter
Mike Becker <universe@uap-core.de>
parents: 15
diff changeset
90 break;
c5dde81b6fb2 add text rendering and demo FPS counter
Mike Becker <universe@uap-core.de>
parents: 15
diff changeset
91 case GL_OUT_OF_MEMORY:
c5dde81b6fb2 add text rendering and demo FPS counter
Mike Becker <universe@uap-core.de>
parents: 15
diff changeset
92 glerr = "out of memory";
c5dde81b6fb2 add text rendering and demo FPS counter
Mike Becker <universe@uap-core.de>
parents: 15
diff changeset
93 break;
c5dde81b6fb2 add text rendering and demo FPS counter
Mike Becker <universe@uap-core.de>
parents: 15
diff changeset
94 case GL_STACK_UNDERFLOW:
c5dde81b6fb2 add text rendering and demo FPS counter
Mike Becker <universe@uap-core.de>
parents: 15
diff changeset
95 glerr = "stack underflow";
c5dde81b6fb2 add text rendering and demo FPS counter
Mike Becker <universe@uap-core.de>
parents: 15
diff changeset
96 break;
c5dde81b6fb2 add text rendering and demo FPS counter
Mike Becker <universe@uap-core.de>
parents: 15
diff changeset
97 case GL_STACK_OVERFLOW:
c5dde81b6fb2 add text rendering and demo FPS counter
Mike Becker <universe@uap-core.de>
parents: 15
diff changeset
98 glerr = "stack overflow";
c5dde81b6fb2 add text rendering and demo FPS counter
Mike Becker <universe@uap-core.de>
parents: 15
diff changeset
99 break;
c5dde81b6fb2 add text rendering and demo FPS counter
Mike Becker <universe@uap-core.de>
parents: 15
diff changeset
100 default:
c5dde81b6fb2 add text rendering and demo FPS counter
Mike Becker <universe@uap-core.de>
parents: 15
diff changeset
101 glerr = "unknown GL error";
c5dde81b6fb2 add text rendering and demo FPS counter
Mike Becker <universe@uap-core.de>
parents: 15
diff changeset
102 }
c5dde81b6fb2 add text rendering and demo FPS counter
Mike Becker <universe@uap-core.de>
parents: 15
diff changeset
103 cxmutstr msg = cx_strcat(3, message, CX_STR(" GL Error: "), cx_str(glerr));
c5dde81b6fb2 add text rendering and demo FPS counter
Mike Becker <universe@uap-core.de>
parents: 15
diff changeset
104 asc_error_cxstr(cx_strcast(msg));
c5dde81b6fb2 add text rendering and demo FPS counter
Mike Becker <universe@uap-core.de>
parents: 15
diff changeset
105 cx_strfree(&msg);
c5dde81b6fb2 add text rendering and demo FPS counter
Mike Becker <universe@uap-core.de>
parents: 15
diff changeset
106 }

mercurial