Wed, 02 Jul 2025 23:21:17 +0200
resolve TODOs regarding input.h
a) mouse position must be integer, because it can be negative (though rarely)
b) we should not trade "access complexity" for space in the scancodes array
95
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
1 | /* |
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
2 | * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER. |
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
3 | * Copyright 2023 Mike Becker. All rights reserved. |
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
4 | * |
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
5 | * Redistribution and use in source and binary forms, with or without |
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
6 | * modification, are permitted provided that the following conditions are met: |
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
7 | * |
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
8 | * 1. Redistributions of source code must retain the above copyright |
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
9 | * notice, this list of conditions and the following disclaimer. |
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
10 | * |
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
11 | * 2. Redistributions in binary form must reproduce the above copyright |
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
12 | * notice, this list of conditions and the following disclaimer in the |
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
13 | * documentation and/or other materials provided with the distribution. |
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
14 | * |
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
15 | * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" |
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
16 | * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE |
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
17 | * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE |
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
18 | * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE |
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
19 | * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR |
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
20 | * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF |
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
21 | * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS |
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
22 | * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN |
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
23 | * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) |
622887f7e954
in preparation of more scenes, bring back AscScene struct
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 |
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
25 | * POSSIBILITY OF SUCH DAMAGE. |
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
26 | */ |
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
27 | |
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
28 | #include "ascension/scene_node.h" |
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
29 | #include "ascension/context.h" |
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
30 | |
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
31 | #include <cx/tree.h> |
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
32 | #include <cx/linked_list.h> |
114 | 33 | #include <cx/printf.h> |
34 | ||
35 | #include "ascension/error.h" | |
95
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
36 | |
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
37 | static CxTreeIterator asc_scene_node_iterator( |
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
38 | AscSceneNode *node, |
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
39 | bool visit_on_exit |
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
40 | ) { |
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
41 | return cx_tree_iterator( |
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
42 | node, visit_on_exit, |
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
43 | offsetof(AscSceneNode, children), |
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
44 | offsetof(AscSceneNode, next) |
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
45 | ); |
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
46 | } |
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
47 | |
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
48 | AscSceneNode *asc_scene_node_empty(void) { |
122
1b118cd3e369
replace all stdlib malloc/free with UCX allocator
Mike Becker <universe@uap-core.de>
parents:
116
diff
changeset
|
49 | AscSceneNode *node = cxZallocDefault(sizeof(AscSceneNode)); |
95
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
50 | node->render_group = ASC_RENDER_GROUP_NONE; |
116
bfb2a7d62047
replace scaling with correct mesh sizes
Mike Becker <universe@uap-core.de>
parents:
114
diff
changeset
|
51 | node->scale = asc_vec3f_one; |
95
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
52 | asc_transform_identity(node->transform); |
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
53 | asc_transform_identity(node->world_transform); |
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
54 | return node; |
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
55 | } |
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
56 | |
113
71ba88258ea0
change node's free function to a destroy function
Mike Becker <universe@uap-core.de>
parents:
108
diff
changeset
|
57 | static void asc_scene_node_destroy(AscSceneNode *node) { |
71ba88258ea0
change node's free function to a destroy function
Mike Becker <universe@uap-core.de>
parents:
108
diff
changeset
|
58 | cxListFree(node->behaviors); |
71ba88258ea0
change node's free function to a destroy function
Mike Becker <universe@uap-core.de>
parents:
108
diff
changeset
|
59 | if (node->destroy_func != NULL) { |
71ba88258ea0
change node's free function to a destroy function
Mike Becker <universe@uap-core.de>
parents:
108
diff
changeset
|
60 | node->destroy_func(node); |
71ba88258ea0
change node's free function to a destroy function
Mike Becker <universe@uap-core.de>
parents:
108
diff
changeset
|
61 | } |
114 | 62 | if (node->name.ptr != NULL) { |
63 | asc_dprintf("Destroy node: %"CX_PRIstr, CX_SFMT(node->name)); | |
64 | cx_strfree(&node->name); | |
65 | } | |
113
71ba88258ea0
change node's free function to a destroy function
Mike Becker <universe@uap-core.de>
parents:
108
diff
changeset
|
66 | } |
71ba88258ea0
change node's free function to a destroy function
Mike Becker <universe@uap-core.de>
parents:
108
diff
changeset
|
67 | |
95
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
68 | void asc_scene_node_free(AscSceneNode *node) { |
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
69 | if (node == NULL) return; |
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
70 | |
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
71 | // remove this node from its parent |
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
72 | asc_scene_node_unlink(node); |
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
73 | |
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
74 | // free the entire subtree |
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
75 | CxTreeIterator iter = asc_scene_node_iterator(node, true); |
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
76 | cx_foreach(AscSceneNode*, child, iter) { |
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
77 | if (!iter.exiting) continue; |
113
71ba88258ea0
change node's free function to a destroy function
Mike Becker <universe@uap-core.de>
parents:
108
diff
changeset
|
78 | asc_scene_node_destroy(child); |
122
1b118cd3e369
replace all stdlib malloc/free with UCX allocator
Mike Becker <universe@uap-core.de>
parents:
116
diff
changeset
|
79 | cxFreeDefault(child); |
95
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
80 | } |
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
81 | } |
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
82 | |
114 | 83 | void asc_scene_node_name(AscSceneNode *node, const char *name) { |
122
1b118cd3e369
replace all stdlib malloc/free with UCX allocator
Mike Becker <universe@uap-core.de>
parents:
116
diff
changeset
|
84 | cx_strfree(&node->name); |
114 | 85 | if (name == NULL) { |
86 | node->name.ptr = NULL; | |
87 | node->name.length = 0; | |
88 | } else { | |
89 | node->name.ptr = strdup(name); | |
90 | node->name.length = strlen(name); | |
91 | } | |
92 | } | |
93 | ||
94 | cxstring asc_scene_node_get_name(AscSceneNode *node) { | |
95 | if (node->name.ptr != NULL) return cx_strcast(node->name); | |
96 | ||
97 | AscSceneNode *parent = node->parent; | |
98 | while (parent != NULL && parent->name.ptr == NULL) { | |
99 | parent = parent->parent; | |
100 | } | |
101 | if (parent == NULL) { | |
102 | cx_sprintf(&node->name.ptr, &node->name.length, | |
103 | "%"PRIuPTR " - w/o named parent", (uintptr_t)node); | |
104 | } else { | |
105 | cx_sprintf(&node->name.ptr, &node->name.length, | |
106 | "%"PRIuPTR " - child of %"CX_PRIstr, (uintptr_t)node, CX_SFMT(parent->name)); | |
107 | } | |
108 | ||
109 | return cx_strcast(node->name); | |
110 | } | |
111 | ||
95
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
112 | void asc_scene_node_link(AscSceneNode * restrict parent, AscSceneNode * restrict node) { |
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
113 | cx_tree_link( |
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
114 | parent, node, |
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
115 | offsetof(AscSceneNode, parent), |
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
116 | offsetof(AscSceneNode, children), |
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
117 | offsetof(AscSceneNode, last_child), |
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
118 | offsetof(AscSceneNode, prev), |
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
119 | offsetof(AscSceneNode, next) |
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
120 | ); |
102
0d94fd280c6e
remove separate depth attribute and use the z-coordinate instead
Mike Becker <universe@uap-core.de>
parents:
101
diff
changeset
|
121 | asc_node_update_transform(node); |
95
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
122 | } |
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
123 | |
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
124 | void asc_scene_node_unlink(AscSceneNode *node) { |
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
125 | cx_tree_unlink( |
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
126 | node, |
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
127 | offsetof(AscSceneNode, parent), |
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
128 | offsetof(AscSceneNode, children), |
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
129 | offsetof(AscSceneNode, last_child), |
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
130 | offsetof(AscSceneNode, prev), |
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
131 | offsetof(AscSceneNode, next) |
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
132 | ); |
102
0d94fd280c6e
remove separate depth attribute and use the z-coordinate instead
Mike Becker <universe@uap-core.de>
parents:
101
diff
changeset
|
133 | asc_node_update_transform(node); |
95
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
134 | } |
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
135 | |
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
136 | void asc_node_update(AscSceneNode *node) { |
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
137 | asc_set_flag(node->flags, ASC_SCENE_NODE_UPDATE_GRAPHICS); |
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
138 | } |
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
139 | |
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
140 | void asc_node_update_transform(AscSceneNode *node) { |
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
141 | // fast skip if node is already marked |
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
142 | if (asc_test_flag(node->flags, ASC_SCENE_NODE_UPDATE_TRANSFORM)) { |
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
143 | return; |
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
144 | } |
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
145 | |
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
146 | CxTreeIterator iter = asc_scene_node_iterator(node, false); |
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
147 | cx_foreach(AscSceneNode*, n, iter) { |
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
148 | if (asc_test_flag(n->flags, ASC_SCENE_NODE_UPDATE_TRANSFORM)) { |
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
149 | cxTreeIteratorContinue(iter); |
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
150 | } |
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
151 | asc_set_flag(n->flags, ASC_SCENE_NODE_UPDATE_TRANSFORM); |
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
152 | } |
622887f7e954
in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents:
diff
changeset
|
153 | } |