Expressif 1.10.21

There is a newer version of this package available.
See the version list below for details.
dotnet add package Expressif --version 1.10.21
                    
NuGet\Install-Package Expressif -Version 1.10.21
                    
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="Expressif" Version="1.10.21" />
                    
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="Expressif" Version="1.10.21" />
                    
Directory.Packages.props
<PackageReference Include="Expressif" />
                    
Project file
For projects that support Central Package Management (CPM), copy this XML node into the solution Directory.Packages.props file to version the package.
paket add Expressif --version 1.10.21
                    
#r "nuget: Expressif, 1.10.21"
                    
#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.
#:package Expressif@1.10.21
                    
#:package directive can be used in C# file-based apps starting in .NET 10 preview 4. Copy this into a .cs file before any lines of code to reference the package.
#addin nuget:?package=Expressif&version=1.10.21
                    
Install as a Cake Addin
#tool nuget:?package=Expressif&version=1.10.21
                    
Install as a Cake Tool

Expressif

Expressif is the variable substitution syntax, initially designed for NBi.io.

Expressif allows you to define variables and transformation of these variables (functions), in plain text, which can then be interpreted by the engine. The syntax for the definition of the expression transforming the variable is similar to:

@myVariable | text-to-lower | text-to-pad-right(@myCount, *)

Logo

About | Quickstart | Installing | Functions and predicates

About

Social media: website twitter badge

Releases: nuget licence badge

Dev. activity: GitHub last commit Still maintained GitHub commit activity

Continuous integration builds: Build status Tests CodeFactor codecov FOSSA Status

Status: stars badge Bugs badge Features badge Top language

Quickstart

Expression

Expressif provides a class named Expression to define a chain of functions applied to a value. The class is expecting the textual representation of the chained functions in its constructor.

var expression = new Expression("lower");
var result = expression.Evaluate("Nikola Tesla");
Assert.That(result, Is.EqualTo("nikola tesla"));

Some functions require parameters, you can specify them between the parenthesis following the function name. Note that literal textual values don't required quotes surronding them.

var expression = new Expression("remove-chars(a)");
var result = expression.Evaluate("Nikola Tesla");
Assert.That(result, Is.EqualTo("Nikol Tesl"));

You can chain the functions with the operator pipe (|). The functions are executed from left to right.

var expression = new Expression("lower | remove-chars(a)");
var result = expression.Evaluate("Nikola Tesla");
Assert.That(result, Is.EqualTo("nikol tesl"));

It's possible to use variables as function parameters. The name of the variables must always start by an arobas (@)

var context = new Context();
context.Variables.Add<char>("myChar", 'k');

var expression = new Expression("lower | remove-chars(@myChar)", context);
var result = expression.Evaluate("Nikola Tesla");
Assert.That(result, Is.EqualTo("niola tesla"));

In addition to the variables that must be scalar values (text, numeric, dateTime ...), you can also add a property-object to the context. A property-object must be a pure C# object, an IDictionnary, an IList, or a DataRow. You can access the properties of the property-object based on the property's name with the syntax [property-name].

var context = new Context();
context.CurrentObject.Set(new { CharToBeRemoved = 't' });

var expression = new Expression("lower | remove-chars([CharToBeRemoved])", context);
var result = expression.Evaluate("Nikola Tesla");
Assert.That(result, Is.EqualTo("nikola esla"));

or based on its position with the syntax #index (where index is positive number).

var context = new Context();
context.CurrentObject.Set(new List<char>() { 'e', 's' });

var expression = new Expression("lower | remove-chars(#1)", context);
var result = expression.Evaluate("Nikola Tesla");
Assert.That(result, Is.EqualTo("nikola tela"));

It's also possible to use the result of function as the value of a parameter for another function. To achieve this the function as a parameter must be surrounded by curly braces {...}.

var context = new Context();
context.Variables.Add<int>("myVar", 6);
context.CurrentObject.Set(new List<int>() { 15, 8, 3 });

var expression = new Expression("lower | skip-last-chars( {@myVar | subtract(#2) })", context);
var result = expression.Evaluate("Nikola Tesla");
Assert.That(result, Is.EqualTo("nikola te"));

Predication

Expressif provides a class named Predication to define a combination of predicates applied to an argument. The class is expecting the textual representation of the predicates in its constructor.

var predication = new Predication("lower-case");
var result = predication.Evaluate("Nikola Tesla");
Assert.That(result, Is.False);

Same than for expressions, some predicates require parameters, you can specify them between the parenthesis immediately following the predicate name. More specifically, some predicates require an interval as parameter. The parameter can be define with the help of square brackets or parenthesis.

var predication = new Predication("within-interval([0;20[)");
var result = predication.Evaluate(15);
Assert.That(result, Is.True);

Other predicates require a culture as parameter. To specify a culture just use the textual representation of the culture composed of the two letter ISO code of the language then the two letters ISO code of the country separated by a dash i.e. fr-be for Belgian French, nl-be for Belgian Dutch or de-de for German.

var predication = new Predication("matches-date(fr-fr)");
var result = predication.Evaluate("28/12/1978");
Assert.That(result, Is.True);

Any predicate can be negated to return the opposite result. To negate a predicate just put the exclamation mark (!) in front of the predicate name.

var predication = new Predication("!starts-with(Nik)");
var result = predication.Evaluate("Nikola Tesla");
Assert.That(result, Is.False);

You can combine the predicates. Each predicate will accept the same argument and will be evaluated separatly. The results of the combination is dependening on the combinational operator used. To specify the name of the combinational operator use the pipe operator (|) immediately followed by the name of the operator. The following operators are valid |AND, |OR, |XOR.

Take into account that when possible, the operators are implementing a short-circuit. If the two predicates are combined with the operator |AND and the first is returning false, the second will not be evaluated. Following the same reasoning, if the two predicates are combined with the operator |OR and the first is returning true, the second will also be ignored.

var predication = new Predication("starts-with(Nik) |AND ends-with(sla)");
var result = predication.Evaluate("Nikola Tesla");
Assert.That(result, Is.True);

By default, the predicates are combined from left to right. If you've three predicates, the two firsts will be combined and then the result of this combination will be combined with the third predicate. To alter this order, you must group the predicates with the help of curly braces {...}. Each predicate inside a group is evaluated from left to right and then the result of the group is combined with another group or predicate also from left to right.

var predication = new Predication("{starts-with(Nik) |AND ends-with(sla)} |OR {starts-with(ola) |AND ends-with(Tes)}");
var result = predication.Evaluate("Nikola Tesla");
Assert.That(result, Is.True);

var withoutGroupsPredication = new Predication("starts-with(Nik) |AND ends-with(sla) |OR starts-with(ola) |AND ends-with(Tes)");
var secondResult = withoutGroupsPredication.Evaluate("Nikola Tesla");
Assert.That(result, Is.Not.EqualTo(secondResult));

Installing

Install in the usual .NET fashion:

Install-Package Expressif

Supported functions and predicates

Functions

Scope Name Aliases
IO creation-datetime file-to-creation-datetime, file-to-creation-dateTime
IO creation-datetime-utc file-to-creation-datetime-utc, file-to-creation-dateTime-utc
IO directory path-to-directory
IO extension path-to-extension
IO filename path-to-filename
IO filename-without-extension path-to-filename-without-extension
IO root path-to-root
IO size file-to-size
IO update-datetime file-to-update-datetime, file-to-update-dateTime
IO update-datetime-utc file-to-update-datetime-utc, file-to-update-dateTime-utc
Numeric absolute numeric-to-absolute
Numeric add numeric-to-add
Numeric ceiling numeric-to-ceiling
Numeric clip numeric-to-clip
Numeric cube-power numeric-to-cube-power
Numeric cube-root numeric-to-cube-root
Numeric decrement numeric-to-decrement
Numeric divide numeric-to-divide
Numeric floor numeric-to-floor
Numeric increment numeric-to-increment
Numeric integer numeric-to-integer
Numeric invert numeric-to-invert
Numeric multiply numeric-to-multiply
Numeric nth-root numeric-to-nth-root
Numeric null-to-zero
Numeric oppose numeric-to-oppose
Numeric power numeric-to-power
Numeric round numeric-to-round
Numeric sign numeric-to-sign
Numeric square-power numeric-to-square-power
Numeric square-root numeric-to-square-root
Numeric subtract numeric-to-subtract
Special any-to-any
Special neutral Special-to-neutral
Special null-to-value
Special value-to-value
Temporal age date-to-age
Temporal backward dateTime-to-backward, dateTime-to-subtract
Temporal ceiling-hour dateTime-to-ceiling-hour
Temporal ceiling-minute dateTime-to-ceiling-minute
Temporal change-of-hour dateTime-to-change-of-hour
Temporal change-of-minute dateTime-to-change-of-minute
Temporal change-of-month dateTime-to-change-of-month
Temporal change-of-second dateTime-to-change-of-second
Temporal change-of-year dateTime-to-change-of-year
Temporal clamp dateTime-to-clamp, dateTime-to-clip
Temporal datetime-to-date dateTime-to-date
Temporal day-of-month dateTime-to-day-of-month
Temporal day-of-week dateTime-to-day-of-week
Temporal day-of-year dateTime-to-day-of-year
Temporal first-in-month dateTime-to-first-in-month
Temporal first-of-month dateTime-to-first-of-month
Temporal first-of-year dateTime-to-first-of-year
Temporal floor-hour dateTime-to-floor-hour
Temporal floor-minute dateTime-to-floor-minute
Temporal forward dateTime-to-forward, dateTime-to-add
Temporal hour dateTime-to-hour
Temporal hour-minute dateTime-to-hour-minute
Temporal hour-minute-second dateTime-to-hour-minute-second
Temporal hour-of-day dateTime-to-hour-of-day
Temporal invalid-to-date
Temporal iso-day-of-year dateTime-to-iso-day-of-year
Temporal iso-week-of-year dateTime-to-iso-week-of-year
Temporal iso-year-day dateTime-to-iso-year-day
Temporal iso-year-week dateTime-to-iso-year-week
Temporal iso-year-week-day dateTime-to-iso-year-week-day
Temporal last-in-month dateTime-to-last-in-month
Temporal last-of-month dateTime-to-last-of-month
Temporal last-of-year dateTime-to-last-of-year
Temporal length-of-month dateTime-to-length-of-month
Temporal length-of-year dateTime-to-length-of-year
Temporal local-to-utc
Temporal minute-of-day dateTime-to-minute-of-day
Temporal minute-of-hour dateTime-to-minute-of-hour
Temporal month dateTime-to-month
Temporal month-day dateTime-to-month-day
Temporal month-of-year dateTime-to-month-of-year
Temporal next-business-days temporal-to-next-business-days, next-business-day, add-business-days
Temporal next-day dateTime-to-next-day
Temporal next-month dateTime-to-next-month
Temporal next-weekday dateTime-to-next-weekday
Temporal next-weekday-or-same dateTime-to-next-weekday-or-same
Temporal next-year dateTime-to-next-year
Temporal null-to-date
Temporal previous-business-days temporal-to-previous-business-days, previous-business-day, subtract-business-days
Temporal previous-day dateTime-to-previous-day
Temporal previous-month dateTime-to-previous-month
Temporal previous-weekday dateTime-to-previous-weekday
Temporal previous-weekday-or-same dateTime-to-previous-weekday-or-same
Temporal previous-year dateTime-to-previous-year
Temporal second-of-day dateTime-to-second-of-day
Temporal second-of-hour dateTime-to-second-of-hour
Temporal second-of-minute dateTime-to-second-of-minute
Temporal set-time dateTime-to-set-time
Temporal set-to-local
Temporal set-to-utc
Temporal utc-to-local
Temporal year dateTime-to-year
Temporal year-of-era dateTime-to-year-of-era
Text after-substring text-to-after-substring
Text append text-to-append
Text append-new-line text-to-append-new-line
Text append-space text-to-append-space
Text before-substring text-to-before-substring
Text clean-whitespace text-to-clean-whitespace
Text collapse-whitespace text-to-collapse-whitespace
Text count-distinct-chars text-to-count-distinct-chars
Text count-substring text-to-count-substring
Text empty-to-null
Text filter-chars text-to-filter-chars
Text first-chars text-to-first-chars
Text html-to-text
Text last-chars text-to-last-chars
Text length text-to-length, count-chars
Text lower text-to-lower
Text mask-to-text
Text null-to-empty
Text pad-center text-to-pad-center
Text pad-left text-to-pad-left
Text pad-right text-to-pad-right
Text prefix text-to-prefix
Text prefix-new-line text-to-prefix-new-line
Text prefix-space text-to-prefix-space
Text prepend text-to-prepend
Text prepend-new-line text-to-prepend-new-line
Text prepend-space text-to-prepend-space
Text remove-chars text-to-remove-chars
Text replace-chars text-to-replace-chars
Text replace-slice text-to-replace-slice
Text retain-alpha text-to-retain-alpha
Text retain-alpha-numeric text-to-retain-alpha-numeric
Text retain-numeric text-to-retain-numeric
Text retain-numeric-symbol text-to-retain-numeric-symbol
Text skip-first-chars text-to-skip-first-chars
Text skip-last-chars text-to-skip-last-chars
Text suffix text-to-suffix
Text suffix-new-line text-to-suffix-new-line
Text suffix-space text-to-suffix-space
Text text-to-datetime text-to-dateTime
Text text-to-html
Text text-to-mask
Text token text-to-token
Text token-count text-to-token-count
Text trim text-to-trim
Text upper text-to-upper
Text whitespaces-to-empty blank-to-empty
Text whitespaces-to-null blank-to-null
Text without-diacritics text-to-without-diacritics
Text without-whitespaces text-to-without-whitespaces

Predicates

Scope Name Aliases
Boolean false boolean-is-false
Boolean false-or-null boolean-is-false-or-null
Boolean identical-to boolean-is-identical-to
Boolean true boolean-is-true
Boolean true-or-null boolean-is-true-or-null
Numeric equal-to numeric-is-equal-to
Numeric even numeric-is-even
Numeric greater-than numeric-is-greater-than
Numeric greater-than-or-equal numeric-is-greater-than-or-equal
Numeric integer numeric-is-integer
Numeric less-than numeric-is-less-than
Numeric less-than-or-equal numeric-is-less-than-or-equal
Numeric modulo numeric-is-modulo
Numeric negative numeric-is-negative
Numeric negative-or-zero numeric-is-negative-or-zero
Numeric odd numeric-is-odd
Numeric one numeric-is-one
Numeric opposite numeric-is-opposite
Numeric positive numeric-is-positive
Numeric positive-or-zero numeric-is-positive-or-zero
Numeric within-interval numeric-is-within-interval
Numeric zero numeric-is-zero
Numeric zero-or-null numeric-is-zero-or-null
Special null is-null
Temporal after dateTime-is-after
Temporal after-or-same-instant dateTime-is-after-or-same-instant
Temporal before dateTime-is-before
Temporal before-or-same-instant dateTime-is-before-or-same-instant
Temporal business-day dateTime-is-business-day
Temporal contained-in dateTime-is-contained-in
Temporal in-the-future dateTime-is-in-the-future
Temporal in-the-future-or-now dateTime-is-in-the-future-or-now
Temporal in-the-future-or-today dateTime-is-in-the-future-or-today
Temporal in-the-past dateTime-is-in-the-past
Temporal in-the-past-or-now dateTime-is-in-the-past-or-now
Temporal in-the-past-or-today dateTime-is-in-the-past-or-today
Temporal leap-year dateTime-is-leap-year
Temporal on-the-day dateTime-is-on-the-day
Temporal on-the-hour dateTime-is-on-the-hour
Temporal on-the-minute dateTime-is-on-the-minute
Temporal same-instant dateTime-is-same-instant
Temporal today dateTime-is-today
Temporal tomorrow dateTime-is-tomorrow
Temporal weekday dateTime-is-weekday
Temporal weekend dateTime-is-weekend
Temporal within-current-month dateTime-is-within-current-month
Temporal within-current-week dateTime-is-within-current-week
Temporal within-current-year dateTime-is-within-current-year
Temporal within-last-month dateTime-is-within-last-month
Temporal within-last-week dateTime-is-within-last-week
Temporal within-last-year dateTime-is-within-last-year
Temporal within-next-days dateTime-is-within-next-days
Temporal within-previous-days dateTime-is-within-previous-days
Temporal within-upcoming-month dateTime-is-within-upcoming-month
Temporal within-upcoming-week dateTime-is-within-upcoming-week
Temporal within-upcoming-year dateTime-is-within-upcoming-year
Temporal yesterday dateTime-is-yesterday
Text any-of text-is-any-of
Text contains text-contains
Text empty text-is-empty
Text empty-or-null text-is-empty-or-null
Text ends-with text-ends-with
Text equivalent-to text-is-equivalent-to
Text lower-case text-is-lower-case
Text matches-date text-matches-date
Text matches-datetime text-matches-datetime
Text matches-numeric text-matches-numeric
Text matches-regex text-matches-regex
Text matches-time text-matches-time
Text sorted-after text-is-sorted-after
Text sorted-after-or-equivalent-to text-is-sorted-after-or-equivalent-to
Text sorted-before text-is-sorted-before
Text sorted-before-or-equivalent-to text-is-sorted-before-or-equivalent-to
Text starts-with text-starts-with
Text upper-case text-is-upper-case
Product Compatible and additional computed target framework versions.
.NET net8.0 is compatible.  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 is compatible.  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.  net10.0 was computed.  net10.0-android was computed.  net10.0-browser was computed.  net10.0-ios was computed.  net10.0-maccatalyst was computed.  net10.0-macos was computed.  net10.0-tvos was computed.  net10.0-windows was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages (1)

Showing the top 1 NuGet packages that depend on Expressif:

Package Downloads
NBi.Extensibility

Package Description

GitHub repositories (1)

Showing the top 1 popular GitHub repositories that depend on Expressif:

Repository Stars
Seddryck/NBi
NBi is a testing framework (add-on to NUnit) for Business Intelligence and Data Access. The main goal of this framework is to let users create tests with a declarative approach based on an Xml syntax. By the means of NBi, you don't need to develop C# or Java code to specify your tests! Either, you don't need Visual Studio or Eclipse to compile your test suite. Just create an Xml file and let the framework interpret it and play your tests. The framework is designed as an add-on of NUnit but with the possibility to port it easily to other testing frameworks.
Version Downloads Last Updated
1.10.22 160 10/9/2025
1.10.21 160 10/6/2025
1.10.20 120 8/16/2025
1.10.19 207 6/14/2025
1.10.18 218 6/4/2025
1.10.17 152 5/30/2025
1.10.16 167 5/23/2025
1.10.15 193 5/22/2025
1.10.13 257 4/2/2025
1.10.12 229 3/9/2025
1.10.11 458 1/20/2025
1.10.10 183 1/20/2025
1.10.9 180 1/10/2025
1.10.8 175 12/31/2024
1.10.7 165 12/31/2024
1.10.6 173 12/30/2024
1.10.5 171 12/26/2024
1.10.4 161 12/22/2024
1.10.1 180 12/16/2024
1.10.0 172 12/1/2024
1.9.11 174 11/22/2024
1.9.10 164 11/16/2024
1.9.9 223 9/14/2024
1.9.7 179 9/9/2024
1.9.6 176 9/8/2024
1.9.5 198 9/2/2024
1.9.4 173 8/26/2024
1.9.3 194 8/26/2024
1.9.2 203 8/24/2024
1.9.1 201 8/22/2024
1.9.0 272 7/29/2024
1.8.12 142 7/29/2024
1.8.11 158 7/29/2024
1.8.10 178 5/25/2024
1.8.9 170 5/14/2024
1.8.8 215 3/18/2024
1.8.7 181 3/18/2024
1.8.6 197 3/16/2024
1.8.5 182 2/27/2024
1.8.4 200 2/22/2024
1.8.3 173 2/17/2024
1.8.2 205 2/4/2024
1.8.1 172 1/30/2024
1.8.0 216 1/13/2024
1.7.0 181 1/13/2024
1.6.2 192 1/11/2024
1.6.1 179 1/11/2024
1.6.0 214 1/7/2024
1.5.0 220 1/7/2024
1.4.8 195 1/6/2024
1.4.7 198 1/6/2024
1.4.5 208 1/6/2024
1.4.4 205 1/6/2024
1.4.3 244 1/1/2024
1.4.2 186 12/31/2023
1.4.1 201 12/30/2023
1.4.0 211 12/30/2023
1.3.0 192 12/29/2023
1.2.0 193 12/29/2023
1.1.2 199 12/28/2023
1.1.1 178 12/28/2023
1.1.0 191 12/27/2023
1.0.0 199 12/22/2023
0.8.0 186 12/22/2023
0.7.0 176 12/22/2023
0.6.0 199 12/22/2023
0.5.0 220 12/22/2023
0.4.0 204 12/21/2023
0.3.48 198 12/21/2023
0.3.47 231 12/5/2023
0.3.46 196 12/5/2023
0.3.45 160 12/5/2023
0.3.44 172 12/5/2023
0.3.43 195 12/3/2023
0.3.39 199 12/3/2023
0.3.36 202 11/9/2023
0.3.35 191 11/6/2023
0.3.34 237 9/2/2023
0.3.33 214 8/17/2023
0.3.32 285 8/14/2023
0.3.31 256 8/9/2023
0.3.30 266 8/9/2023
0.3.29 255 8/8/2023
0.3.28 275 7/1/2023
0.3.27 253 6/14/2023
0.3.25 304 3/7/2023
0.3.24 351 3/5/2023
0.3.23 336 3/5/2023
0.3.22 350 3/5/2023
0.3.21 332 3/5/2023
0.3.20 331 3/5/2023
0.3.18 406 1/3/2023
0.3.17 402 1/3/2023
0.3.15 404 12/31/2022
0.3.14 398 12/31/2022
0.3.13 395 12/30/2022
0.3.11 442 12/29/2022
0.3.9 388 12/29/2022
0.3.8 387 12/29/2022
0.3.7 415 12/29/2022
0.3.6 395 12/28/2022
0.3.5 401 12/28/2022
0.3.4 418 12/28/2022
0.3.3 421 12/28/2022
0.3.2 392 12/26/2022
0.3.1 411 12/26/2022
0.3.0 409 12/26/2022
0.2.26 408 12/24/2022
0.2.25 414 12/23/2022
0.2.24 432 12/22/2022
0.2.23 395 12/22/2022
0.2.22 407 12/21/2022
0.2.21 420 12/21/2022
0.2.20 436 12/19/2022
0.2.18 429 12/18/2022
0.2.15 439 12/18/2022
0.2.14 424 12/18/2022
0.2.13 416 12/18/2022
0.2.12 436 12/18/2022
0.2.9 403 12/11/2022
0.2.8 422 12/11/2022
0.2.7 402 12/10/2022
0.2.6 408 12/10/2022
0.2.5 404 12/10/2022
0.2.4 427 12/6/2022
0.2.3 401 12/6/2022
0.2.2 467 11/26/2022
0.2.1 456 11/22/2022
0.2.0 439 11/21/2022
0.1.17 457 11/17/2022
0.1.16 468 11/15/2022
0.1.15 496 11/13/2022
0.1.13 459 11/12/2022
0.1.11 437 11/12/2022
0.1.10 448 11/12/2022
0.1.7 485 11/12/2022
0.1.6 457 11/12/2022