Facepunch.ActionJigs
0.1.1
See the version list below for details.
dotnet add package Facepunch.ActionJigs --version 0.1.1
NuGet\Install-Package Facepunch.ActionJigs -Version 0.1.1
<PackageReference Include="Facepunch.ActionJigs" Version="0.1.1" />
paket add Facepunch.ActionJigs --version 0.1.1
#r "nuget: Facepunch.ActionJigs, 0.1.1"
// Install Facepunch.ActionJigs as a Cake Addin #addin nuget:?package=Facepunch.ActionJigs&version=0.1.1 // Install Facepunch.ActionJigs as a Cake Tool #tool nuget:?package=Facepunch.ActionJigs&version=0.1.1
Facepunch.ActionJigs
Runtime-composable async methods that can be converted to and from JSON.
Overview
An ActionJig is made out of nodes, links and variables. Nodes either perform actions or evaluate expressions, and links connect them together to shuttle values or signals around. Variables provide storage local to each invocation of the jig, and are used to capture values at specific points during invocation.
Node
Nodes have a definition and a binding. Bindings specify which properties, inputs, and outputs a node has. Inputs and outputs may transmit values or signals. A node with signal inputs / outputs is an Action node, which is invoked when an input signal fires. Nodes without any signal inputs / outputs are Expression nodes, which are lazily evaluated when any of their output values are requested by an Action node.
Definition
A node definition describes what the node will do, and controls which properties, inputs, and outputs a node will have.
A NodeLibrary is a collection of node definitions, and each ActionJig
will reference exactly one such library. Each definition in a library has
a unique internal name like op.add
or math.max
.
Binding
Definitions provide bindings, which are specifically typed sets of properties,
inputs, and outputs. Depending on the definition, the binding of a node may
change as you connect inputs or assign properties. For example, the type of the
result
output of an op.add
addition node depends on the types of the
provided inputs.
Property
Properties are constant named values stored in a node, which control its
binding. For example: a var.set
node, which would set a variable when
invoked, has a property specifying which variable it will assign. Changing
that property will change the input value type of the node, to match the
variable type.
Input
A node input will either receive a signal or a value.
Input values can be provided by another node's output through a Link, or a constant value stored inside the input. Input signals can only be provided by an output signal from another node, and control when the receiving node executes.
If an input value accepts an array type, it may be linked to multiple outputs in a specific order to provide the individual items of an array. Otherwise, inputs link to at most one output.
Output
A node output will emit either a signal or a value.
Output signals may fire mutliple times per invocation of the node, for example
the body
output of the loop node control.foreach
will fire once per element
in the items
input value. If multiple input signals are connected to the same
output signal, the receiving nodes will act as independent concurrent tasks.
Output values of Action nodes may be provided by a specific output signal, and can only be used downstream of that output signal.
Output values of expression nodes are always available, and will be evaluated lazily when requested by an Action node.
Link
Links are the connections between an output and an input. An output signal can only connect to input signals, and an output value can only connect to input values. See Input and Output for more details.
Variable
Variables are provided as a way to capture values at specific points to be read later on.
Each variable has a specific name and type. They are referenced in var.set
and var.get
nodes, and must be set before they can be read. They are local
to each invocation of an ActionJig, so if multiple instances of the same jig
are running simultaneously they won't share variables.
User Data
Each main element of an ActionJig has a UserData
property, which can store
arbitary named values serialized as JSON nodes. This could be used to record
each node's position in a visual editor, for example.
Validation
Each time an ActionJig is modified, elements will be marked as needing
validation. This validation is performed either when attempting to invoke the
ActionJig, or when accessing the Messages
property. This property will be
populated with a list of information, warnings and errors, each describing
the context and cause. Any error messages will mean the ActionJig can't be
invoked.
You can also access the messages specific to a particular node / link /
property / input / output / variable by using the element.GetMessages()
extension method. Accessing this will also cause validation to occur, if any
elements have changed since the last validation.
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net7.0 is compatible. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 was computed. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. net9.0 was computed. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. |
-
net7.0
- No dependencies.
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.
Version | Downloads | Last updated | |
---|---|---|---|
0.1.40 | 212 | 10/21/2023 | |
0.1.39 | 137 | 10/21/2023 | |
0.1.38 | 154 | 10/20/2023 | |
0.1.37 | 162 | 10/20/2023 | |
0.1.36 | 151 | 10/20/2023 | |
0.1.35 | 174 | 10/20/2023 | |
0.1.34 | 161 | 10/20/2023 | |
0.1.33 | 144 | 10/20/2023 | |
0.1.32 | 157 | 10/20/2023 | |
0.1.31 | 166 | 10/20/2023 | |
0.1.30 | 155 | 10/20/2023 | |
0.1.29 | 172 | 10/20/2023 | |
0.1.28 | 156 | 10/19/2023 | |
0.1.27 | 150 | 10/19/2023 | |
0.1.26 | 153 | 10/19/2023 | |
0.1.25 | 163 | 10/18/2023 | |
0.1.24 | 154 | 10/18/2023 | |
0.1.23 | 162 | 10/18/2023 | |
0.1.22 | 157 | 10/18/2023 | |
0.1.21 | 165 | 10/18/2023 | |
0.1.20 | 164 | 10/12/2023 | |
0.1.19 | 155 | 10/12/2023 | |
0.1.18 | 140 | 10/12/2023 | |
0.1.17 | 152 | 10/12/2023 | |
0.1.16 | 165 | 10/12/2023 | |
0.1.15 | 160 | 10/12/2023 | |
0.1.14 | 166 | 10/9/2023 | |
0.1.13 | 174 | 10/9/2023 | |
0.1.12 | 161 | 10/6/2023 | |
0.1.11 | 167 | 10/6/2023 | |
0.1.10 | 172 | 10/6/2023 | |
0.1.9 | 172 | 10/6/2023 | |
0.1.8 | 169 | 10/6/2023 | |
0.1.7 | 175 | 10/5/2023 | |
0.1.6 | 166 | 10/2/2023 | |
0.1.5 | 168 | 10/2/2023 | |
0.1.4 | 173 | 9/30/2023 | |
0.1.3 | 172 | 9/29/2023 | |
0.1.2 | 150 | 9/29/2023 | |
0.1.1 | 148 | 9/26/2023 | |
0.1.0 | 176 | 9/25/2023 | |
0.0.2 | 150 | 9/19/2023 |