HexagonSoftware.ExpressionTransforms 2021.6.15.2

There is a newer version of this package available.
See the version list below for details.
dotnet add package HexagonSoftware.ExpressionTransforms --version 2021.6.15.2                
NuGet\Install-Package HexagonSoftware.ExpressionTransforms -Version 2021.6.15.2                
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="HexagonSoftware.ExpressionTransforms" Version="2021.6.15.2" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add HexagonSoftware.ExpressionTransforms --version 2021.6.15.2                
#r "nuget: HexagonSoftware.ExpressionTransforms, 2021.6.15.2"                
#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 HexagonSoftware.ExpressionTransforms as a Cake Addin
#addin nuget:?package=HexagonSoftware.ExpressionTransforms&version=2021.6.15.2

// Install HexagonSoftware.ExpressionTransforms as a Cake Tool
#tool nuget:?package=HexagonSoftware.ExpressionTransforms&version=2021.6.15.2                

Expression Transformations is a utility library that relies of manipulation of System.Linq.Expressions.Expression instances to simplify basic tasks.

Examples

Following are examples of how and why you might want to use this library.

Converting Read Expressions to Setters

Sometimes, you want clients to be able to tell an API how to store a datum. Often, developers using such an API want to copy a value into a field or property of an object.

The norm in such cases, is to allow developers to pass an Action<T> into an API. The API will then call that action with appropriate values at the appropriate time.

However, it often feels kludgy to a developer. They have to write expressions that capture values and do the assignment, themselves. For example.

var API = new MyCoolApi();
API.OnVersionNumberChanged += NewVersionNumber => this.VersionNumber = NewVersionNumber;

While it's a small nuisance, it is emblematic of the fact that client-developers are required to tell an API how to store a value, when what they really want to say is where the data should go.

Sometimes that's fine but sometimes it is not.

In the cases where you really want to allow for property mappings, you can define them using the ToSetter extension method in this library.

class MyCoolApi
{
  ...
  public void MapVersionNumberTo(Expression<Func<int>> Selector)
  {
    OnVersionNumberChanged += SetterFactory.Parameterless.ToSetter(Selector);
  }
  ...
}

This allows for a more semantically-meaningful call from the client's perspective.

var API = new MyCoolApi();
API.MapVersionNumberTo(() => this.VersionNumber);

Converting Abstract Read Expressions to Abstract Setters

You can also create a setter expression from a getter expression without knowing the object to be read/written in advance.

For instance, SetterFactory.ForParameter<MyObject>().ToSetter(O => O.Value) will produce a setter Action that accepts both an instance of MyObject and a paramter suitable to be assigned to Value.

Whenver invoked, that action will assign the Value property on the object passed in as the first parameter.

Binding Targets for IObservables

Another example of the kind of problem you might want to solve with this is binding outgoing values from observables to the setters of properties as in the following code snippet.

var Observable = new Observable();
var Target = new Target();
Observable.BindTo(() => Target.Value);
Product Compatible and additional computed target framework versions.
.NET net5.0 is compatible.  net5.0-windows was computed.  net6.0 was computed.  net6.0-android was computed.  net6.0-ios was computed.  net6.0-maccatalyst was computed.  net6.0-macos was computed.  net6.0-tvos was computed.  net6.0-windows was computed.  net7.0 was computed.  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.
  • net5.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
2021.6.15.3 421 6/15/2021
2021.6.15.2 359 6/15/2021
2021.6.15.1 335 6/15/2021
2021.6.9.7 302 6/9/2021
2021.6.9.6 326 6/9/2021
2021.6.9.5 360 6/9/2021
2021.6.9.4 352 6/9/2021
2021.6.9.3 355 6/9/2021
2021.6.9.2 329 6/9/2021
2021.6.9.1 357 6/9/2021
2021.6.8.1 367 6/9/2021