src/ascension/behavior.h

Tue, 22 Jul 2025 20:57:13 +0200

author
Mike Becker <universe@uap-core.de>
date
Tue, 22 Jul 2025 20:57:13 +0200
changeset 219
62508d957a22
parent 182
264dfe1928b2
permissions
-rw-r--r--

remove outdated TODO comments

108
d619bf7dd87b add AscBehavior - prepares resolution of issue #646
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1 /*
d619bf7dd87b add AscBehavior - prepares resolution of issue #646
Mike Becker <universe@uap-core.de>
parents:
diff changeset
2 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER.
d619bf7dd87b add AscBehavior - prepares resolution of issue #646
Mike Becker <universe@uap-core.de>
parents:
diff changeset
3 * Copyright 2025 Mike Becker. All rights reserved.
d619bf7dd87b add AscBehavior - prepares resolution of issue #646
Mike Becker <universe@uap-core.de>
parents:
diff changeset
4 *
d619bf7dd87b add AscBehavior - prepares resolution of issue #646
Mike Becker <universe@uap-core.de>
parents:
diff changeset
5 * Redistribution and use in source and binary forms, with or without
d619bf7dd87b add AscBehavior - prepares resolution of issue #646
Mike Becker <universe@uap-core.de>
parents:
diff changeset
6 * modification, are permitted provided that the following conditions are met:
d619bf7dd87b add AscBehavior - prepares resolution of issue #646
Mike Becker <universe@uap-core.de>
parents:
diff changeset
7 *
d619bf7dd87b add AscBehavior - prepares resolution of issue #646
Mike Becker <universe@uap-core.de>
parents:
diff changeset
8 * 1. Redistributions of source code must retain the above copyright
d619bf7dd87b add AscBehavior - prepares resolution of issue #646
Mike Becker <universe@uap-core.de>
parents:
diff changeset
9 * notice, this list of conditions and the following disclaimer.
d619bf7dd87b add AscBehavior - prepares resolution of issue #646
Mike Becker <universe@uap-core.de>
parents:
diff changeset
10 *
d619bf7dd87b add AscBehavior - prepares resolution of issue #646
Mike Becker <universe@uap-core.de>
parents:
diff changeset
11 * 2. Redistributions in binary form must reproduce the above copyright
d619bf7dd87b add AscBehavior - prepares resolution of issue #646
Mike Becker <universe@uap-core.de>
parents:
diff changeset
12 * notice, this list of conditions and the following disclaimer in the
d619bf7dd87b add AscBehavior - prepares resolution of issue #646
Mike Becker <universe@uap-core.de>
parents:
diff changeset
13 * documentation and/or other materials provided with the distribution.
d619bf7dd87b add AscBehavior - prepares resolution of issue #646
Mike Becker <universe@uap-core.de>
parents:
diff changeset
14 *
d619bf7dd87b add AscBehavior - prepares resolution of issue #646
Mike Becker <universe@uap-core.de>
parents:
diff changeset
15 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
d619bf7dd87b add AscBehavior - prepares resolution of issue #646
Mike Becker <universe@uap-core.de>
parents:
diff changeset
16 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
d619bf7dd87b add AscBehavior - prepares resolution of issue #646
Mike Becker <universe@uap-core.de>
parents:
diff changeset
17 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
d619bf7dd87b add AscBehavior - prepares resolution of issue #646
Mike Becker <universe@uap-core.de>
parents:
diff changeset
18 * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
d619bf7dd87b add AscBehavior - prepares resolution of issue #646
Mike Becker <universe@uap-core.de>
parents:
diff changeset
19 * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
d619bf7dd87b add AscBehavior - prepares resolution of issue #646
Mike Becker <universe@uap-core.de>
parents:
diff changeset
20 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
d619bf7dd87b add AscBehavior - prepares resolution of issue #646
Mike Becker <universe@uap-core.de>
parents:
diff changeset
21 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
d619bf7dd87b add AscBehavior - prepares resolution of issue #646
Mike Becker <universe@uap-core.de>
parents:
diff changeset
22 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
d619bf7dd87b add AscBehavior - prepares resolution of issue #646
Mike Becker <universe@uap-core.de>
parents:
diff changeset
23 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
d619bf7dd87b add AscBehavior - prepares resolution of issue #646
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
d619bf7dd87b add AscBehavior - prepares resolution of issue #646
Mike Becker <universe@uap-core.de>
parents:
diff changeset
25 * POSSIBILITY OF SUCH DAMAGE.
d619bf7dd87b add AscBehavior - prepares resolution of issue #646
Mike Becker <universe@uap-core.de>
parents:
diff changeset
26 */
d619bf7dd87b add AscBehavior - prepares resolution of issue #646
Mike Becker <universe@uap-core.de>
parents:
diff changeset
27
d619bf7dd87b add AscBehavior - prepares resolution of issue #646
Mike Becker <universe@uap-core.de>
parents:
diff changeset
28
d619bf7dd87b add AscBehavior - prepares resolution of issue #646
Mike Becker <universe@uap-core.de>
parents:
diff changeset
29 #ifndef ASC_BEHAVIOR_H
d619bf7dd87b add AscBehavior - prepares resolution of issue #646
Mike Becker <universe@uap-core.de>
parents:
diff changeset
30 #define ASC_BEHAVIOR_H
d619bf7dd87b add AscBehavior - prepares resolution of issue #646
Mike Becker <universe@uap-core.de>
parents:
diff changeset
31
d619bf7dd87b add AscBehavior - prepares resolution of issue #646
Mike Becker <universe@uap-core.de>
parents:
diff changeset
32 #include "scene_node.h"
d619bf7dd87b add AscBehavior - prepares resolution of issue #646
Mike Becker <universe@uap-core.de>
parents:
diff changeset
33
d619bf7dd87b add AscBehavior - prepares resolution of issue #646
Mike Becker <universe@uap-core.de>
parents:
diff changeset
34 typedef struct asc_behavior_s AscBehavior;
d619bf7dd87b add AscBehavior - prepares resolution of issue #646
Mike Becker <universe@uap-core.de>
parents:
diff changeset
35
d619bf7dd87b add AscBehavior - prepares resolution of issue #646
Mike Becker <universe@uap-core.de>
parents:
diff changeset
36 typedef void(*asc_behavior_func)(AscBehavior*);
d619bf7dd87b add AscBehavior - prepares resolution of issue #646
Mike Becker <universe@uap-core.de>
parents:
diff changeset
37 typedef void(*asc_behavior_destroy_func)(AscBehavior*);
d619bf7dd87b add AscBehavior - prepares resolution of issue #646
Mike Becker <universe@uap-core.de>
parents:
diff changeset
38
d619bf7dd87b add AscBehavior - prepares resolution of issue #646
Mike Becker <universe@uap-core.de>
parents:
diff changeset
39 struct asc_behavior_s {
148
9f030f402699 implement interval for behaviors - fixes #383
Mike Becker <universe@uap-core.de>
parents: 112
diff changeset
40 AscSceneNode *node;
108
d619bf7dd87b add AscBehavior - prepares resolution of issue #646
Mike Becker <universe@uap-core.de>
parents:
diff changeset
41 asc_behavior_func func;
d619bf7dd87b add AscBehavior - prepares resolution of issue #646
Mike Becker <universe@uap-core.de>
parents:
diff changeset
42 asc_behavior_destroy_func destroy_func;
d619bf7dd87b add AscBehavior - prepares resolution of issue #646
Mike Becker <universe@uap-core.de>
parents:
diff changeset
43 void *data;
148
9f030f402699 implement interval for behaviors - fixes #383
Mike Becker <universe@uap-core.de>
parents: 112
diff changeset
44 uint64_t last_execution;
9f030f402699 implement interval for behaviors - fixes #383
Mike Becker <universe@uap-core.de>
parents: 112
diff changeset
45 uint64_t interval;
180
d942f48dc83a add names to behaviors
Mike Becker <universe@uap-core.de>
parents: 176
diff changeset
46 cxmutstr name;
112
3e956c96dd6c extract execution of behaviors from draw function
Mike Becker <universe@uap-core.de>
parents: 111
diff changeset
47 bool enabled;
176
cb2f60f48337 add asc_behavior_remove()
Mike Becker <universe@uap-core.de>
parents: 156
diff changeset
48 bool killed;
108
d619bf7dd87b add AscBehavior - prepares resolution of issue #646
Mike Becker <universe@uap-core.de>
parents:
diff changeset
49 };
d619bf7dd87b add AscBehavior - prepares resolution of issue #646
Mike Becker <universe@uap-core.de>
parents:
diff changeset
50
d619bf7dd87b add AscBehavior - prepares resolution of issue #646
Mike Becker <universe@uap-core.de>
parents:
diff changeset
51 struct asc_behavior_create_args {
148
9f030f402699 implement interval for behaviors - fixes #383
Mike Becker <universe@uap-core.de>
parents: 112
diff changeset
52 /**
156
bd15eeaa88c0 change order of members in asc_behavior_create_args so that you can just specify the func without designators
Mike Becker <universe@uap-core.de>
parents: 148
diff changeset
53 * The function that is invoked when the behavior is triggered.
bd15eeaa88c0 change order of members in asc_behavior_create_args so that you can just specify the func without designators
Mike Becker <universe@uap-core.de>
parents: 148
diff changeset
54 */
bd15eeaa88c0 change order of members in asc_behavior_create_args so that you can just specify the func without designators
Mike Becker <universe@uap-core.de>
parents: 148
diff changeset
55 asc_behavior_func func;
bd15eeaa88c0 change order of members in asc_behavior_create_args so that you can just specify the func without designators
Mike Becker <universe@uap-core.de>
parents: 148
diff changeset
56 /**
148
9f030f402699 implement interval for behaviors - fixes #383
Mike Becker <universe@uap-core.de>
parents: 112
diff changeset
57 * The function that is invoked when the behavior is destroyed.
9f030f402699 implement interval for behaviors - fixes #383
Mike Becker <universe@uap-core.de>
parents: 112
diff changeset
58 */
108
d619bf7dd87b add AscBehavior - prepares resolution of issue #646
Mike Becker <universe@uap-core.de>
parents:
diff changeset
59 asc_behavior_destroy_func destroy_func;
148
9f030f402699 implement interval for behaviors - fixes #383
Mike Becker <universe@uap-core.de>
parents: 112
diff changeset
60 /**
9f030f402699 implement interval for behaviors - fixes #383
Mike Becker <universe@uap-core.de>
parents: 112
diff changeset
61 * Pointer to additional custom data.
9f030f402699 implement interval for behaviors - fixes #383
Mike Becker <universe@uap-core.de>
parents: 112
diff changeset
62 */
108
d619bf7dd87b add AscBehavior - prepares resolution of issue #646
Mike Becker <universe@uap-core.de>
parents:
diff changeset
63 void *data;
148
9f030f402699 implement interval for behaviors - fixes #383
Mike Becker <universe@uap-core.de>
parents: 112
diff changeset
64 /**
9f030f402699 implement interval for behaviors - fixes #383
Mike Becker <universe@uap-core.de>
parents: 112
diff changeset
65 * Minimum delay between two successive executions in nanoseconds.
9f030f402699 implement interval for behaviors - fixes #383
Mike Becker <universe@uap-core.de>
parents: 112
diff changeset
66 */
9f030f402699 implement interval for behaviors - fixes #383
Mike Becker <universe@uap-core.de>
parents: 112
diff changeset
67 uint64_t interval;
180
d942f48dc83a add names to behaviors
Mike Becker <universe@uap-core.de>
parents: 176
diff changeset
68 /**
d942f48dc83a add names to behaviors
Mike Becker <universe@uap-core.de>
parents: 176
diff changeset
69 * Optional name of the behavior.
d942f48dc83a add names to behaviors
Mike Becker <universe@uap-core.de>
parents: 176
diff changeset
70 */
d942f48dc83a add names to behaviors
Mike Becker <universe@uap-core.de>
parents: 176
diff changeset
71 const char *name;
108
d619bf7dd87b add AscBehavior - prepares resolution of issue #646
Mike Becker <universe@uap-core.de>
parents:
diff changeset
72 };
d619bf7dd87b add AscBehavior - prepares resolution of issue #646
Mike Becker <universe@uap-core.de>
parents:
diff changeset
73
111
ee4b58dfcf7f change naming convention for functions that are hidden behind macros
Mike Becker <universe@uap-core.de>
parents: 108
diff changeset
74 AscBehavior *asc_behavior_add_(AscSceneNode *node, struct asc_behavior_create_args args);
ee4b58dfcf7f change naming convention for functions that are hidden behind macros
Mike Becker <universe@uap-core.de>
parents: 108
diff changeset
75 #define asc_behavior_add(node,...) asc_behavior_add_(node, (struct asc_behavior_create_args){__VA_ARGS__})
108
d619bf7dd87b add AscBehavior - prepares resolution of issue #646
Mike Becker <universe@uap-core.de>
parents:
diff changeset
76
176
cb2f60f48337 add asc_behavior_remove()
Mike Becker <universe@uap-core.de>
parents: 156
diff changeset
77 /**
cb2f60f48337 add asc_behavior_remove()
Mike Becker <universe@uap-core.de>
parents: 156
diff changeset
78 * Removes and destroys a behavior.
cb2f60f48337 add asc_behavior_remove()
Mike Becker <universe@uap-core.de>
parents: 156
diff changeset
79 *
cb2f60f48337 add asc_behavior_remove()
Mike Becker <universe@uap-core.de>
parents: 156
diff changeset
80 * If you just want to temporarily pause a behavior, use asc_behavior_disable().
cb2f60f48337 add asc_behavior_remove()
Mike Becker <universe@uap-core.de>
parents: 156
diff changeset
81 *
cb2f60f48337 add asc_behavior_remove()
Mike Becker <universe@uap-core.de>
parents: 156
diff changeset
82 * @param behavior the behavior to remove
cb2f60f48337 add asc_behavior_remove()
Mike Becker <universe@uap-core.de>
parents: 156
diff changeset
83 * @see asc_behavior_disable()
cb2f60f48337 add asc_behavior_remove()
Mike Becker <universe@uap-core.de>
parents: 156
diff changeset
84 */
cb2f60f48337 add asc_behavior_remove()
Mike Becker <universe@uap-core.de>
parents: 156
diff changeset
85 void asc_behavior_remove(AscBehavior *behavior);
108
d619bf7dd87b add AscBehavior - prepares resolution of issue #646
Mike Becker <universe@uap-core.de>
parents:
diff changeset
86
176
cb2f60f48337 add asc_behavior_remove()
Mike Becker <universe@uap-core.de>
parents: 156
diff changeset
87 /**
cb2f60f48337 add asc_behavior_remove()
Mike Becker <universe@uap-core.de>
parents: 156
diff changeset
88 * Used internally. Do not invoke manually.
cb2f60f48337 add asc_behavior_remove()
Mike Becker <universe@uap-core.de>
parents: 156
diff changeset
89 *
cb2f60f48337 add asc_behavior_remove()
Mike Becker <universe@uap-core.de>
parents: 156
diff changeset
90 * @param behavior the behavior
cb2f60f48337 add asc_behavior_remove()
Mike Becker <universe@uap-core.de>
parents: 156
diff changeset
91 */
148
9f030f402699 implement interval for behaviors - fixes #383
Mike Becker <universe@uap-core.de>
parents: 112
diff changeset
92 void asc_behavior_trigger(AscBehavior *behavior);
9f030f402699 implement interval for behaviors - fixes #383
Mike Becker <universe@uap-core.de>
parents: 112
diff changeset
93
176
cb2f60f48337 add asc_behavior_remove()
Mike Becker <universe@uap-core.de>
parents: 156
diff changeset
94 /**
180
d942f48dc83a add names to behaviors
Mike Becker <universe@uap-core.de>
parents: 176
diff changeset
95 * Assigns a name to a behavior.
d942f48dc83a add names to behaviors
Mike Becker <universe@uap-core.de>
parents: 176
diff changeset
96 *
d942f48dc83a add names to behaviors
Mike Becker <universe@uap-core.de>
parents: 176
diff changeset
97 * @param behavior the behavior
d942f48dc83a add names to behaviors
Mike Becker <universe@uap-core.de>
parents: 176
diff changeset
98 * @param name the new name
d942f48dc83a add names to behaviors
Mike Becker <universe@uap-core.de>
parents: 176
diff changeset
99 */
d942f48dc83a add names to behaviors
Mike Becker <universe@uap-core.de>
parents: 176
diff changeset
100 void asc_behavior_name(AscBehavior *behavior, const char *name);
d942f48dc83a add names to behaviors
Mike Becker <universe@uap-core.de>
parents: 176
diff changeset
101
d942f48dc83a add names to behaviors
Mike Becker <universe@uap-core.de>
parents: 176
diff changeset
102 /**
182
264dfe1928b2 add asc_behavior_get_name()
Mike Becker <universe@uap-core.de>
parents: 180
diff changeset
103 * Returns the name of a behavior.
264dfe1928b2 add asc_behavior_get_name()
Mike Becker <universe@uap-core.de>
parents: 180
diff changeset
104 *
264dfe1928b2 add asc_behavior_get_name()
Mike Becker <universe@uap-core.de>
parents: 180
diff changeset
105 * @param behavior the behavior
264dfe1928b2 add asc_behavior_get_name()
Mike Becker <universe@uap-core.de>
parents: 180
diff changeset
106 * @return the name of the behavior
264dfe1928b2 add asc_behavior_get_name()
Mike Becker <universe@uap-core.de>
parents: 180
diff changeset
107 */
264dfe1928b2 add asc_behavior_get_name()
Mike Becker <universe@uap-core.de>
parents: 180
diff changeset
108 cxstring asc_behavior_get_name(const AscBehavior *behavior);
264dfe1928b2 add asc_behavior_get_name()
Mike Becker <universe@uap-core.de>
parents: 180
diff changeset
109
264dfe1928b2 add asc_behavior_get_name()
Mike Becker <universe@uap-core.de>
parents: 180
diff changeset
110 /**
176
cb2f60f48337 add asc_behavior_remove()
Mike Becker <universe@uap-core.de>
parents: 156
diff changeset
111 * Enables a behavior
cb2f60f48337 add asc_behavior_remove()
Mike Becker <universe@uap-core.de>
parents: 156
diff changeset
112 *
cb2f60f48337 add asc_behavior_remove()
Mike Becker <universe@uap-core.de>
parents: 156
diff changeset
113 * Has no effect on killed behaviors.
cb2f60f48337 add asc_behavior_remove()
Mike Becker <universe@uap-core.de>
parents: 156
diff changeset
114 *
cb2f60f48337 add asc_behavior_remove()
Mike Becker <universe@uap-core.de>
parents: 156
diff changeset
115 * @param behavior the behavior to enable
cb2f60f48337 add asc_behavior_remove()
Mike Becker <universe@uap-core.de>
parents: 156
diff changeset
116 */
148
9f030f402699 implement interval for behaviors - fixes #383
Mike Becker <universe@uap-core.de>
parents: 112
diff changeset
117 static inline void asc_behavior_enable(AscBehavior *behavior) {
176
cb2f60f48337 add asc_behavior_remove()
Mike Becker <universe@uap-core.de>
parents: 156
diff changeset
118 behavior->enabled = !behavior->killed;
148
9f030f402699 implement interval for behaviors - fixes #383
Mike Becker <universe@uap-core.de>
parents: 112
diff changeset
119 }
9f030f402699 implement interval for behaviors - fixes #383
Mike Becker <universe@uap-core.de>
parents: 112
diff changeset
120
176
cb2f60f48337 add asc_behavior_remove()
Mike Becker <universe@uap-core.de>
parents: 156
diff changeset
121 /**
cb2f60f48337 add asc_behavior_remove()
Mike Becker <universe@uap-core.de>
parents: 156
diff changeset
122 * Disables a behavior.
cb2f60f48337 add asc_behavior_remove()
Mike Becker <universe@uap-core.de>
parents: 156
diff changeset
123 *
cb2f60f48337 add asc_behavior_remove()
Mike Becker <universe@uap-core.de>
parents: 156
diff changeset
124 * @param behavior the behavior to disable
cb2f60f48337 add asc_behavior_remove()
Mike Becker <universe@uap-core.de>
parents: 156
diff changeset
125 */
148
9f030f402699 implement interval for behaviors - fixes #383
Mike Becker <universe@uap-core.de>
parents: 112
diff changeset
126 static inline void asc_behavior_disable(AscBehavior *behavior) {
9f030f402699 implement interval for behaviors - fixes #383
Mike Becker <universe@uap-core.de>
parents: 112
diff changeset
127 behavior->enabled = false;
9f030f402699 implement interval for behaviors - fixes #383
Mike Becker <universe@uap-core.de>
parents: 112
diff changeset
128 }
9f030f402699 implement interval for behaviors - fixes #383
Mike Becker <universe@uap-core.de>
parents: 112
diff changeset
129
108
d619bf7dd87b add AscBehavior - prepares resolution of issue #646
Mike Becker <universe@uap-core.de>
parents:
diff changeset
130 #endif

mercurial