Hafr 2.1.1

dotnet add package Hafr --version 2.1.1                
NuGet\Install-Package Hafr -Version 2.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="Hafr" Version="2.1.1" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add Hafr --version 2.1.1                
#r "nuget: Hafr, 2.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 Hafr as a Cake Addin
#addin nuget:?package=Hafr&version=2.1.1

// Install Hafr as a Cake Tool
#tool nuget:?package=Hafr&version=2.1.1                

<div align="center"> <img src="logo.png" width="320" height="320"> <p> <b>A tiny templating language for writing email generation conventions.</b>
</p> </div>

Writing a Template

The Template Structure

A Hafr template consists of two different parts: text and holes. Text is just literal text that will be output verbatim when evaluating the template against a model. A hole will be filled in based on its contents and the model during evaluation. Here's an example:

Hello {name}!

The first and last parts, Hello and ! are literal text, while {name} is a hole. Inside holes, you can access public properties of the model you're evaluating against. If you have the following class:

public record Person(string Name);

And evaluate the template against the following instance:

var person = new Person("John Doe");

The template above will yield:

Hello John Doe!

Any public property of the model will be exposed to the template.

Calling Functions

Hafr has a few built-in methods that you can call to transform properties inside holes:

Method Description
split Takes a separator argument to split its input into separate parts.
join Takes a separator argument to join several parts into one.
substr Takes a count argument to extract a specified number of characters for each part.
skip Takes a count argument to skip a specified number of parts.
take Takes a count argument to pick a specified number of parts.
replace Takes a string to replace and its replacement value.
reverse Reverses a string or a list of strings.
upper Converts a string to uppercase.
lower Converts a string to lowercase.
trim Trims whitespace from the start and end of a string.
truncate Truncates a string to the specified max length.

These methods can be called in one of two ways; using C-style function calls:

Hello {join(split(name, ' '), '.')}!

...or using piping:

Hello {name | split(' ') | join('.')}!

Parsing a Template

To parse a template, use the Parser.TryParse method:

var template = "{firstName | split(' ') | join('.')}.{lastName}@company.com";

if (Parser.TryParse(template, out var expression, out var errorMessage, out var errorPosition))
{
    // Parsing succeeded, it's safe to access the expression in here...
}
else
{
    // Parsing failed. You can use errorMessage and errorPosition in here...
}

Evaluating a Template

After the template has been successfully parsed, you can use it to evaluate against an input model:

public record Person(string FirstName, string LastName);

var model = new Person("John Michael", "Doe");

var result = expression.Evaluate(model).ToLower(); // john.michael.doe@company.com 
Product Compatible and additional computed target framework versions.
.NET net5.0 was computed.  net5.0-windows was computed.  net6.0 is compatible.  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. 
.NET Core netcoreapp2.0 was computed.  netcoreapp2.1 was computed.  netcoreapp2.2 was computed.  netcoreapp3.0 was computed.  netcoreapp3.1 was computed. 
.NET Standard netstandard2.0 is compatible.  netstandard2.1 was computed. 
.NET Framework net461 was computed.  net462 was computed.  net463 was computed.  net47 was computed.  net471 was computed.  net472 was computed.  net48 was computed.  net481 was computed. 
MonoAndroid monoandroid was computed. 
MonoMac monomac was computed. 
MonoTouch monotouch was computed. 
Tizen tizen40 was computed.  tizen60 was computed. 
Xamarin.iOS xamarinios was computed. 
Xamarin.Mac xamarinmac was computed. 
Xamarin.TVOS xamarintvos was computed. 
Xamarin.WatchOS xamarinwatchos was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

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
2.1.1 217 8/7/2023
2.1.0 372 12/6/2022
2.0.0 469 5/24/2022
1.5.1 462 5/24/2022
1.5.0 418 5/24/2022
1.4.0 443 5/10/2022
1.3.0 367 10/21/2021
1.2.1 2,139 5/31/2021
1.2.0 345 5/31/2021
1.1.0 359 4/30/2021
1.0.1 323 4/29/2021
1.0.0 312 4/29/2021
1.0.0-beta.2 153 4/28/2021
1.0.0-beta.1 170 4/27/2021