src/ascension/behavior.h

Sun, 20 Jul 2025 23:31:40 +0200

author
Mike Becker <universe@uap-core.de>
date
Sun, 20 Jul 2025 23:31:40 +0200
changeset 216
943980fa37b5
parent 182
264dfe1928b2
child 219
62508d957a22
permissions
-rw-r--r--

snap the movement to the grid

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;
148
9f030f402699 implement interval for behaviors - fixes #383
Mike Becker <universe@uap-core.de>
parents: 112
diff changeset
49 // TODO: more useful attributes
108
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
d619bf7dd87b add AscBehavior - prepares resolution of issue #646
Mike Becker <universe@uap-core.de>
parents:
diff changeset
52 struct asc_behavior_create_args {
148
9f030f402699 implement interval for behaviors - fixes #383
Mike Becker <universe@uap-core.de>
parents: 112
diff changeset
53 /**
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
54 * 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
55 */
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 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
57 /**
148
9f030f402699 implement interval for behaviors - fixes #383
Mike Becker <universe@uap-core.de>
parents: 112
diff changeset
58 * 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
59 */
108
d619bf7dd87b add AscBehavior - prepares resolution of issue #646
Mike Becker <universe@uap-core.de>
parents:
diff changeset
60 asc_behavior_destroy_func destroy_func;
148
9f030f402699 implement interval for behaviors - fixes #383
Mike Becker <universe@uap-core.de>
parents: 112
diff changeset
61 /**
9f030f402699 implement interval for behaviors - fixes #383
Mike Becker <universe@uap-core.de>
parents: 112
diff changeset
62 * Pointer to additional custom data.
9f030f402699 implement interval for behaviors - fixes #383
Mike Becker <universe@uap-core.de>
parents: 112
diff changeset
63 */
108
d619bf7dd87b add AscBehavior - prepares resolution of issue #646
Mike Becker <universe@uap-core.de>
parents:
diff changeset
64 void *data;
148
9f030f402699 implement interval for behaviors - fixes #383
Mike Becker <universe@uap-core.de>
parents: 112
diff changeset
65 /**
9f030f402699 implement interval for behaviors - fixes #383
Mike Becker <universe@uap-core.de>
parents: 112
diff changeset
66 * 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
67 */
9f030f402699 implement interval for behaviors - fixes #383
Mike Becker <universe@uap-core.de>
parents: 112
diff changeset
68 uint64_t interval;
180
d942f48dc83a add names to behaviors
Mike Becker <universe@uap-core.de>
parents: 176
diff changeset
69 /**
d942f48dc83a add names to behaviors
Mike Becker <universe@uap-core.de>
parents: 176
diff changeset
70 * Optional name of the behavior.
d942f48dc83a add names to behaviors
Mike Becker <universe@uap-core.de>
parents: 176
diff changeset
71 */
d942f48dc83a add names to behaviors
Mike Becker <universe@uap-core.de>
parents: 176
diff changeset
72 const char *name;
108
d619bf7dd87b add AscBehavior - prepares resolution of issue #646
Mike Becker <universe@uap-core.de>
parents:
diff changeset
73 };
d619bf7dd87b add AscBehavior - prepares resolution of issue #646
Mike Becker <universe@uap-core.de>
parents:
diff changeset
74
111
ee4b58dfcf7f change naming convention for functions that are hidden behind macros
Mike Becker <universe@uap-core.de>
parents: 108
diff changeset
75 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
76 #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
77
176
cb2f60f48337 add asc_behavior_remove()
Mike Becker <universe@uap-core.de>
parents: 156
diff changeset
78 /**
cb2f60f48337 add asc_behavior_remove()
Mike Becker <universe@uap-core.de>
parents: 156
diff changeset
79 * Removes and destroys a behavior.
cb2f60f48337 add asc_behavior_remove()
Mike Becker <universe@uap-core.de>
parents: 156
diff changeset
80 *
cb2f60f48337 add asc_behavior_remove()
Mike Becker <universe@uap-core.de>
parents: 156
diff changeset
81 * 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
82 *
cb2f60f48337 add asc_behavior_remove()
Mike Becker <universe@uap-core.de>
parents: 156
diff changeset
83 * @param behavior the behavior to remove
cb2f60f48337 add asc_behavior_remove()
Mike Becker <universe@uap-core.de>
parents: 156
diff changeset
84 * @see asc_behavior_disable()
cb2f60f48337 add asc_behavior_remove()
Mike Becker <universe@uap-core.de>
parents: 156
diff changeset
85 */
cb2f60f48337 add asc_behavior_remove()
Mike Becker <universe@uap-core.de>
parents: 156
diff changeset
86 void asc_behavior_remove(AscBehavior *behavior);
108
d619bf7dd87b add AscBehavior - prepares resolution of issue #646
Mike Becker <universe@uap-core.de>
parents:
diff changeset
87
176
cb2f60f48337 add asc_behavior_remove()
Mike Becker <universe@uap-core.de>
parents: 156
diff changeset
88 /**
cb2f60f48337 add asc_behavior_remove()
Mike Becker <universe@uap-core.de>
parents: 156
diff changeset
89 * Used internally. Do not invoke manually.
cb2f60f48337 add asc_behavior_remove()
Mike Becker <universe@uap-core.de>
parents: 156
diff changeset
90 *
cb2f60f48337 add asc_behavior_remove()
Mike Becker <universe@uap-core.de>
parents: 156
diff changeset
91 * @param behavior the behavior
cb2f60f48337 add asc_behavior_remove()
Mike Becker <universe@uap-core.de>
parents: 156
diff changeset
92 */
148
9f030f402699 implement interval for behaviors - fixes #383
Mike Becker <universe@uap-core.de>
parents: 112
diff changeset
93 void asc_behavior_trigger(AscBehavior *behavior);
9f030f402699 implement interval for behaviors - fixes #383
Mike Becker <universe@uap-core.de>
parents: 112
diff changeset
94
176
cb2f60f48337 add asc_behavior_remove()
Mike Becker <universe@uap-core.de>
parents: 156
diff changeset
95 /**
180
d942f48dc83a add names to behaviors
Mike Becker <universe@uap-core.de>
parents: 176
diff changeset
96 * Assigns a name to a behavior.
d942f48dc83a add names to behaviors
Mike Becker <universe@uap-core.de>
parents: 176
diff changeset
97 *
d942f48dc83a add names to behaviors
Mike Becker <universe@uap-core.de>
parents: 176
diff changeset
98 * @param behavior the behavior
d942f48dc83a add names to behaviors
Mike Becker <universe@uap-core.de>
parents: 176
diff changeset
99 * @param name the new name
d942f48dc83a add names to behaviors
Mike Becker <universe@uap-core.de>
parents: 176
diff changeset
100 */
d942f48dc83a add names to behaviors
Mike Becker <universe@uap-core.de>
parents: 176
diff changeset
101 void asc_behavior_name(AscBehavior *behavior, const char *name);
d942f48dc83a add names to behaviors
Mike Becker <universe@uap-core.de>
parents: 176
diff changeset
102
d942f48dc83a add names to behaviors
Mike Becker <universe@uap-core.de>
parents: 176
diff changeset
103 /**
182
264dfe1928b2 add asc_behavior_get_name()
Mike Becker <universe@uap-core.de>
parents: 180
diff changeset
104 * Returns the name of a behavior.
264dfe1928b2 add asc_behavior_get_name()
Mike Becker <universe@uap-core.de>
parents: 180
diff changeset
105 *
264dfe1928b2 add asc_behavior_get_name()
Mike Becker <universe@uap-core.de>
parents: 180
diff changeset
106 * @param behavior the behavior
264dfe1928b2 add asc_behavior_get_name()
Mike Becker <universe@uap-core.de>
parents: 180
diff changeset
107 * @return the name of the behavior
264dfe1928b2 add asc_behavior_get_name()
Mike Becker <universe@uap-core.de>
parents: 180
diff changeset
108 */
264dfe1928b2 add asc_behavior_get_name()
Mike Becker <universe@uap-core.de>
parents: 180
diff changeset
109 cxstring asc_behavior_get_name(const AscBehavior *behavior);
264dfe1928b2 add asc_behavior_get_name()
Mike Becker <universe@uap-core.de>
parents: 180
diff changeset
110
264dfe1928b2 add asc_behavior_get_name()
Mike Becker <universe@uap-core.de>
parents: 180
diff changeset
111 /**
176
cb2f60f48337 add asc_behavior_remove()
Mike Becker <universe@uap-core.de>
parents: 156
diff changeset
112 * Enables a behavior
cb2f60f48337 add asc_behavior_remove()
Mike Becker <universe@uap-core.de>
parents: 156
diff changeset
113 *
cb2f60f48337 add asc_behavior_remove()
Mike Becker <universe@uap-core.de>
parents: 156
diff changeset
114 * Has no effect on killed behaviors.
cb2f60f48337 add asc_behavior_remove()
Mike Becker <universe@uap-core.de>
parents: 156
diff changeset
115 *
cb2f60f48337 add asc_behavior_remove()
Mike Becker <universe@uap-core.de>
parents: 156
diff changeset
116 * @param behavior the behavior to enable
cb2f60f48337 add asc_behavior_remove()
Mike Becker <universe@uap-core.de>
parents: 156
diff changeset
117 */
148
9f030f402699 implement interval for behaviors - fixes #383
Mike Becker <universe@uap-core.de>
parents: 112
diff changeset
118 static inline void asc_behavior_enable(AscBehavior *behavior) {
176
cb2f60f48337 add asc_behavior_remove()
Mike Becker <universe@uap-core.de>
parents: 156
diff changeset
119 behavior->enabled = !behavior->killed;
148
9f030f402699 implement interval for behaviors - fixes #383
Mike Becker <universe@uap-core.de>
parents: 112
diff changeset
120 }
9f030f402699 implement interval for behaviors - fixes #383
Mike Becker <universe@uap-core.de>
parents: 112
diff changeset
121
176
cb2f60f48337 add asc_behavior_remove()
Mike Becker <universe@uap-core.de>
parents: 156
diff changeset
122 /**
cb2f60f48337 add asc_behavior_remove()
Mike Becker <universe@uap-core.de>
parents: 156
diff changeset
123 * Disables a behavior.
cb2f60f48337 add asc_behavior_remove()
Mike Becker <universe@uap-core.de>
parents: 156
diff changeset
124 *
cb2f60f48337 add asc_behavior_remove()
Mike Becker <universe@uap-core.de>
parents: 156
diff changeset
125 * @param behavior the behavior to disable
cb2f60f48337 add asc_behavior_remove()
Mike Becker <universe@uap-core.de>
parents: 156
diff changeset
126 */
148
9f030f402699 implement interval for behaviors - fixes #383
Mike Becker <universe@uap-core.de>
parents: 112
diff changeset
127 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
128 behavior->enabled = false;
9f030f402699 implement interval for behaviors - fixes #383
Mike Becker <universe@uap-core.de>
parents: 112
diff changeset
129 }
9f030f402699 implement interval for behaviors - fixes #383
Mike Becker <universe@uap-core.de>
parents: 112
diff changeset
130
108
d619bf7dd87b add AscBehavior - prepares resolution of issue #646
Mike Becker <universe@uap-core.de>
parents:
diff changeset
131 #endif

mercurial