This namespace contains the API of the nodes framework.
Namespaces | |
details | |
Typedefs | |
using | CoreNodeFactory = Factory< CoreNode(const DataDictionary &)> |
using | Optimizer = Delegate< Result< Opt< OptimizationInfo > >(const CoreNode &node, const Block< const Tuple< TrivialDataPtr, CORENODE_PORT_FLAGS > > &args)> |
template<typename TO , typename FROM > | |
using | ConversionNodeBase = OperatorNode< ConversionNode< TO, FROM >, TO(FROM)> |
using | PortError = Tuple< PortId, Error > |
using | PortAccessDescriptionCallback = void(*)(PortAccessDescription *) |
using | LlvmGlobalsReceiver = Delegate< Result< void >(const CString &name, const CString &decl, void *address)> |
Enumerations | |
enum class | ACCESS_INDEX : Int { UNUSED , INDEX_0 , INDEX_1 , INDEX_2 , INDEX_3 } |
enum class | WIRETYPE : UInt32 { NONE , FLOW , DOMAIN , HIERARCHY , VALUE , LCV_WRITE , REDUCTION_READ_WRITE , DOMAIN_FLOW , DOMAIN_FLOW_VALUE , LIFETIME , LAZY , CONSUMABLE_REQUEST , MODE_MASK , CONTROL_BLOCK , VARLINK , BLOCK_NESTING , SUBTRACTIVE_DOMAIN , ELEMENT_DOMAIN , MATCH_DOMAIN , INDUCED_DOMAIN , FIX_DOMAIN , CONDITIONAL_DOMAIN , INTERSECTION_DOMAIN , INITIALIZE_VALUE , VALUE_FLAG_MASK , FLAG_MASK , INDUCED_MASK , WRITE_MASK , DOMAIN_MASK , ALL , DEFAULT } |
enum class | PORTACCESS_FLAGS : UInt32 { NONE , CONSUMABLE , OFFSET_MASK , FLAG_MASK } |
enum class | PORT_MODE : UInt32 { NONE , INPUT_PORT_FLAG , INPUT_FLAG , OUTPUT_FLAG , LCV_PREV_FLAG , LCV_NEXT_FLAG , REDUCTION_FLAG , FINAL_FLAG , UNINITIALIZED , LAZY , CONSUMABLE_REQUEST , MODIFIERS , INPUT , OUTPUT , LCV_PREV , LCV_NEXT , REDUCTION , FINAL } |
enum class | PORTS_MODE { NONE , ITERATION , BATCH , DIRECT , VARIADIC , MODIFIERS } |
Variables | |
constexpr MAXON_WARNING_PUSH LiteralId | CORENODE_CONVERT_BASEID |
class maxon::corenodes::PortId | MAXON_ENUM_FLAGS |
static constexpr Char | g_coreNodeIdSeparator |
static constexpr Char | g_internalPortPrefix |
static constexpr Char | g_variadicPortIdSeparator |
using CoreNodeFactory = Factory<CoreNode(const DataDictionary&)> |
A CoreNodeFactory creates a CoreNode given a set of arguments in a DataDictionary. The supported arguments are specific for the core node, some common arguments are defined in CoreNodeBaseInterface such as CoreNodeBaseInterface::Type.
using Optimizer = Delegate<Result<Opt<OptimizationInfo> >(const CoreNode& node, const Block<const Tuple<TrivialDataPtr, CORENODE_PORT_FLAGS> >& args)> |
A CoreNode may have an optimizer to provide an optimized handling of the core node given a set of values of its input ports which are known at compile-time.
At compile-time the optimizer is called with the node to optimize and the values of all input ports as arguments, where an empty TrivialDataPtr indicates an unknown (dynamic) value. If an optimization is possible the necessary information is returned in an OptimizationInfo.
To set an optimizer for a core node you have to set the CoreNodeInterface::Optimizer attribute either directly on the core node (CoreNodeBaseInterface::SetValue) or as meta data of the CoreNodeFactory. The latter can be done with the help of MAXON_CORENODE_REGISTER_WITH_METADATA. Also if you use one of the MAXON_CORENODE_REGISTER macros and the core node implementation class has a static Optimize function
this will be used automatically as optimizer.
There is the method CoreNodesLib::CreateOptimizer which returns an optimizer given a number of ShortCircuitRules.
using ConversionNodeBase = OperatorNode<ConversionNode<TO, FROM>, TO(FROM)> |
using PortAccessDescriptionCallback = void(*)(PortAccessDescription*) |
using LlvmGlobalsReceiver = Delegate<Result<void>(const CString& name, const CString& decl, void* address)> |
|
strong |
When a port or micro node is connected to a micro node, the access index tells at which index the MicroNode receives the connection's transported value within the Ports/Batch parameter of the Process method. For indices exceeding INDEX_3 just cast from Int to ACCESS_INDEX. There are also some built-in micro nodes with several parameter connections, they use the access index to identify which connection controls which parameter. Each access index (other than UNUSED) may be used by at most one connection of a micro node.
Core nodes and micro nodes instances and their ports can be connected by wires. The wires are given as a set of WIRETYPE flags.
|
strong |
These flags describe specifics for the access of a micronode to a port. They can be queried for a port within the Process function of a micronode.
|
strong |
maxon::corenodes::MAXON_INTERNED_ID | ( | "Root" | , |
RootNodeId | |||
) |
Identifier of a graph's root group. Not to confuse with scene root node identifier.
Creates a core node from class N. The class N has to contain an Init function where the first parameter is either a MicroNodeGroupRef or a CoreNodeGroupRef and the remaining parameters (if any) have to match the given args. For an example of such a class have a look at MicroNodeGroupInterface.
N | The class which implements the node. It has to contain an Init function with either a MicroNodeGroupRef or a CoreNodeGroupRef as first parameter. |
[in] | nodeId | The identifier to use for the node. This may be left empty. |
[in] | args | Optional arguments for the Init function. |
Result<CoreNode> maxon::corenodes::CreateNode | ( | ) |
Creates a core node from class N. The class N has to contain an Init function which takes a single parameter of type MicroNodeGroupRef or CoreNodeGroupRef. For an example of such a class have a look at MicroNodeGroupInterface. To create a node with additional arguments see the other CreateNode function.
N | The class which implements the node. It has to contain an Init function with either a MicroNodeGroupRef or a CoreNodeGroupRef as parameter. |
maxon::corenodes::MAXON_REGISTRY | ( | CoreNodeFactory | , |
CoreNodes | , | ||
"net.maxon.corenode.registry.corenodes" | |||
) |
The registry for core node factories. You can use one of the MAXON_CORENODE_REGISTER macros to register a core node factory.
Result<CoreNodeFactory> maxon::corenodes::CreateCoreNodeFactory | ( | DataDictionary && | meta = DataDictionary() | ) |
MAXON_WARNING_POP CONVERSION_FLAGS maxon::corenodes::GetScalarConversionFlags | ( | ) |
Call to read the conversion flags that are appropriate for converting a scalar type into another.
DEST | Destination scalar type. |
SRC | Source scalar type. |
enum maxon::corenodes::ACCESS_INDEX Int maxon::corenodes::MAXON_ENUM_LIST | ( | ACCESS_INDEX | ) |
enum maxon::corenodes::WIRETYPE UInt32 maxon::corenodes::MAXON_ENUM_FLAGS | ( | WIRETYPE | ) |
enum maxon::corenodes::PORTACCESS_FLAGS UInt32 maxon::corenodes::MAXON_ENUM_FLAGS | ( | PORTACCESS_FLAGS | ) |
maxon::corenodes::MAXON_DATATYPE | ( | PortId | , |
"net.maxon.corenode.datatype.portid" | |||
) |
enum maxon::corenodes::PORT_MODE UInt32 maxon::corenodes::MAXON_ENUM_FLAGS | ( | PORT_MODE | ) |
enum maxon::corenodes::PORTS_MODE maxon::corenodes::MAXON_ENUM_FLAGS | ( | PORTS_MODE | ) |
String maxon::corenodes::ToString | ( | const NodeHandle * | h, |
const FormatStatement * | fs, | ||
Bool | checkDataType = true |
||
) |
maxon::corenodes::MAXON_DATATYPE | ( | OptimizationInfo | , |
"net.maxon.corenode.datatype.optimizationinfo" | |||
) |
UInt32 maxon::corenodes::ToOffset | ( | PORTACCESS_FLAGS | offsetAndFlags | ) |
|
constexpr |
class maxon::corenodes::MicroNode MAXON_ENUM_FLAGS |
|
staticconstexpr |
Separator character used to delimit the CoreNode instance identifier from the instruction identifier suffix. For instance in an instruction identifier like "cube@RjgMOC8QOpTpIJWyTRxK5m/primitive/generategeometry#!BASIC_1@60", the CoreNode instance identifier is "cube@RjgMOC8QOpTpIJWyTRxK5m/primitive/generategeometry#".
|
staticconstexpr |
Id prefix for internal ports which shall not be visible. Private.
|
staticconstexpr |
Separator for identifiers of variadic port instances, separates between port id and instance id. Private.