(assign-auto-id mo)Given a map object, if it does not have a value for key :id then assign an auto-id value.
Given a map object, if it does not have a value for key :id then assign an auto-id value.
(next-auto-id)Return next sequential id.
Return next sequential id.
(realise-options db [node-type options & children])Given an options map where some options may represent dynamic function values (see replace-fn-options) 'realise' those dynamic values and pass them instead.
Given an options map where some options may represent dynamic function values (see replace-fn-options) 'realise' those dynamic values and pass them instead.
(replace-dynamic-option do-fns opts [opt val])Given an option opt val where val is of the form [:aido/... ...] perform a dynamic replacement.
Given an option opt val where val is of the form [:aido/... ...] perform a dynamic replacement.
(replace-dynamic-options fns opts)Given a map of options replace-fn-options replaces those that are intended to be dynamic. A dynamic option is an option whose value is a vector of the form [:fn/name ...] or [:fn*/name ...]. In this case 'name' should be the name of a function passed to the compile function. Where the name is in the 'fn' namespace the replacement is a function call. Where the name is in the 'fn*' namespace the replacement is the result of calling the function. Hence [:fn*/name ...] does a dymamic replacement at compile time and [:fn/name ...] does a dynamic replacement each time the behaviour tree is walked.
Note that, in order that behaviour trees can be serialised to EDN where a dynamic replacement is created the function is added as metadata to the value. This means that the function will need to be regenerated each time the tree is deserialised. Compile time replacements are replacements by values that can be serialised.
Given a map of options replace-fn-options replaces those that are intended to be dynamic. A dynamic option is an option whose value is a vector of the form [:fn/name ...] or [:fn*/name ...]. In this case 'name' should be the name of a function passed to the compile function. Where the name is in the 'fn' namespace the replacement is a function call. Where the name is in the 'fn*' namespace the replacement is the result of calling the function. Hence [:fn*/name ...] does a dymamic replacement at compile time and [:fn/name ...] does a dynamic replacement each time the behaviour tree is walked. Note that, in order that behaviour trees can be serialised to EDN where a dynamic replacement is created the function is added as metadata to the value. This means that the function will need to be regenerated each time the tree is deserialised. Compile time replacements are replacements by values that can be serialised.
cljdoc builds & hosts documentation for Clojure/Script libraries
| Ctrl+k | Jump to recent docs | 
| ← | Move to previous article | 
| → | Move to next article | 
| Ctrl+/ | Jump to the search field |