Facepunch.ActionJigs 0.1.1

Suggested Alternatives

Facepunch.ActionGraphs

There is a newer version of this package available.
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                
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="Facepunch.ActionJigs" Version="0.1.1" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add Facepunch.ActionJigs --version 0.1.1                
#r "nuget: Facepunch.ActionJigs, 0.1.1"                
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// 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.

Nodes

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.

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 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. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.
  • 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.40 is deprecated because it is no longer maintained.
0.1.39 137 10/21/2023 0.1.39 is deprecated because it is no longer maintained.
0.1.38 154 10/20/2023 0.1.38 is deprecated because it is no longer maintained.
0.1.37 162 10/20/2023 0.1.37 is deprecated because it is no longer maintained.
0.1.36 151 10/20/2023 0.1.36 is deprecated because it is no longer maintained.
0.1.35 174 10/20/2023 0.1.35 is deprecated because it is no longer maintained.
0.1.34 161 10/20/2023 0.1.34 is deprecated because it is no longer maintained.
0.1.33 144 10/20/2023 0.1.33 is deprecated because it is no longer maintained.
0.1.32 157 10/20/2023 0.1.32 is deprecated because it is no longer maintained.
0.1.31 166 10/20/2023 0.1.31 is deprecated because it is no longer maintained.
0.1.30 155 10/20/2023 0.1.30 is deprecated because it is no longer maintained.
0.1.29 172 10/20/2023 0.1.29 is deprecated because it is no longer maintained.
0.1.28 156 10/19/2023 0.1.28 is deprecated because it is no longer maintained.
0.1.27 150 10/19/2023 0.1.27 is deprecated because it is no longer maintained.
0.1.26 153 10/19/2023 0.1.26 is deprecated because it is no longer maintained.
0.1.25 163 10/18/2023 0.1.25 is deprecated because it is no longer maintained.
0.1.24 154 10/18/2023 0.1.24 is deprecated because it is no longer maintained.
0.1.23 162 10/18/2023 0.1.23 is deprecated because it is no longer maintained.
0.1.22 157 10/18/2023 0.1.22 is deprecated because it is no longer maintained.
0.1.21 165 10/18/2023 0.1.21 is deprecated because it is no longer maintained.
0.1.20 164 10/12/2023 0.1.20 is deprecated because it is no longer maintained.
0.1.19 155 10/12/2023 0.1.19 is deprecated because it is no longer maintained.
0.1.18 140 10/12/2023 0.1.18 is deprecated because it is no longer maintained.
0.1.17 152 10/12/2023 0.1.17 is deprecated because it is no longer maintained.
0.1.16 165 10/12/2023 0.1.16 is deprecated because it is no longer maintained.
0.1.15 160 10/12/2023 0.1.15 is deprecated because it is no longer maintained.
0.1.14 166 10/9/2023 0.1.14 is deprecated because it is no longer maintained.
0.1.13 174 10/9/2023 0.1.13 is deprecated because it is no longer maintained.
0.1.12 161 10/6/2023 0.1.12 is deprecated because it is no longer maintained.
0.1.11 167 10/6/2023 0.1.11 is deprecated because it is no longer maintained.
0.1.10 172 10/6/2023 0.1.10 is deprecated because it is no longer maintained.
0.1.9 172 10/6/2023 0.1.9 is deprecated because it is no longer maintained.
0.1.8 169 10/6/2023 0.1.8 is deprecated because it is no longer maintained.
0.1.7 175 10/5/2023 0.1.7 is deprecated because it is no longer maintained.
0.1.6 166 10/2/2023 0.1.6 is deprecated because it is no longer maintained.
0.1.5 168 10/2/2023 0.1.5 is deprecated because it is no longer maintained.
0.1.4 173 9/30/2023 0.1.4 is deprecated because it is no longer maintained.
0.1.3 172 9/29/2023 0.1.3 is deprecated because it is no longer maintained.
0.1.2 150 9/29/2023 0.1.2 is deprecated because it is no longer maintained.
0.1.1 148 9/26/2023 0.1.1 is deprecated because it is no longer maintained.
0.1.0 176 9/25/2023 0.1.0 is deprecated because it is no longer maintained.
0.0.2 150 9/19/2023 0.0.2 is deprecated because it is no longer maintained.