Umamimolecule.ConditionParser 0.1.1

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

// Install Umamimolecule.ConditionParser as a Cake Tool
#tool nuget:?package=Umamimolecule.ConditionParser&version=0.1.1                

<p align="center"> <img src="https://raw.githubusercontent.com/umamimolecule/ConditionParser/main/.assets/logo-light.png#gh-light-mode-only" /> <img src="https://raw.githubusercontent.com/umamimolecule/ConditionParser/main/.assets/logo-dark.png#gh-dark-mode-only" /> </p>

Condition Parser

A rules engine for .Net to evaluate multiple combinations of conditions.

new ConditionParser().Parse("'Quick brown fox' Contains 'fox'");    // true
new ConditionParser().Parse("123.456 > 200 and 123.456 <= 300");    // false
new ConditionParser().Parse("'Hot coffee' MatchesRegex '^Hot'");    // true

Installation

Install the ConditionParser NuGet package in Visual Studio.

PM> Install-Package Umamimolecule.ConditionParser

Quick start

using System;
using Umamimolecule;

namespace ConditionParserExample
{
    public static class Program
    {
        public static void Main()
        {
            // A simple example to check if a number is > 10.5 and <= 100
            Console.WriteLine("Enter a number: ");
            string number = Console.ReadLine();
            var input = $"{number} > 10.5 and {number} <= 100";
            var result = new ConditionParser().Parse(input);
            Console.WriteLine($"{input} = {result}");
        }
    }
}

Options

The parser behaviour can be controlled by passing in options in the constructor.

using System;
using System.Text.RegularExpressions;

var parser = new ConditionParser(
    new ConditionParserOptions()
    {
        // Behaviour for regex operations
        // Default = RegexOptions.IgnoreCase
        RegexOptions = RegexOptions.IgnoreCase | RegexOptions.RightToLeft,
        
        // Behaviour for string comparison operations
        // Default = StringComparison.OrdinalIgnoreCase
        StringComparison = StringComparison.CurrentCulture
    });

Operators

The following operators are available:

Operator Aliases Description Examples
Contains Checks whether a string contains a substring 'Been' Contains 'bee'
DoesNotContain Checks whether a string does not contain a substring 'Been' DoesNotContain 'fee'
DoesNotEndWith Checks whether a string does not end with a string 'Been' DoesNotEndWith 'ien'
DoesNotEqual !=<br />ne Checks whether a string does not equal another string 'Been' != 'bee'<br />'Been' ne 'bee'<br />'Been' DoesNotEqual 'bee'
DoesNotMatchRegex Checks whether a string does not match a regex pattern 'Been' DoesNotMatchRegex '^Bo*n'
DoesNotStartWith Checks whether a string does not start with a string 'Been' DoesNotStartWith 'Fee'
EndsWith Checks whether a string ends with a string 'Been' EndsWith 'en'
Equals ==<br />eq Checks whether a value equals another 'Been' == 'been'<br />'Been" eq 'been'<br />'Been' Equals 'been'
GreaterThan ><br />gt Checks whether a value is greater than another<sup>1</sup> 123.45 > 200<br />123.45 gt 200<br />123.45 GreaterThan
GreaterThanOrEqual >=<br />ge Checks whether a value is greater than or equal to another<sup>1</sup> 123.45 >= 200<br />123.45 ge 200<br />123.45 GreaterThanOrEqualTo
IsNull Checks whether a value is null 'Been' IsNull
IsNotNull Checks whether a value is not null 'Been' IsNotNull
IsEmpty Checks whether a string is empty 'Been' IsEmpty
IsFalse Checks whether a boolean value is false<sup>2</sup> false IsFalse
IsNotEmpty Checks whether a string is not empty 'Been' IsNotEmpty
IsNotNullOrWhitespace Checks whether a string is not null or whitespace 'Been' IsNotNullOrWhitespace
IsNullOrWhitespace Checks whether a string is null or whitespace 'Been' IsNullOrWhitespace
IsTrue Checks whether a boolean value is true<sup>2</sup> true IsTrue
LessThan <<br />lt Checks whether a value is less than another<sup>1</sup> 123.45 < 200<br />123.45 lt 200<br />123.45 LessThan 200
LessThanOrEqual <=<br />le Checks whether a value is less than or equal to another<sup>1</sup> 123.45 <= 200<br />123.45 le 200<br />123.45 LessThanOrEqualTo 200
MatchesRegex Checks whether a string matches a regex pattern 'Been' MatchesRegex '^B.*n'
StartsWith Checks whether a string starts with a string 'Been' StartsWith 'Be'

<sup>1.</sup>Applies to all data types except for boolean.

<sup>2.</sup>Applies to boolean types only.

Data types

The following data types are supported:

Null

Null values are represented by the keyword null.

Examples:

new ConditionParser().Parse("null == null");    // true
new ConditionParser().Parse("null IsNull");     // true
new ConditionParser().Parse("'abc' == null");   // false

Boolean

Represented by the keywords true and false.

Examples:

new ConditionParser().Parse("true != false");   // true
new ConditionParser().Parse("true IsFalse");    // false

Date and date-time

Date and date-time values are represented by a quoted date value, prefixed with either date or datetime. Single or double-quotes can be used.

Date values are represented in UTC values at midnight. Date and date-time values can be compared against each other.

Examples:

new ConditionParser().Parse("date'2022-12-31' > date'2022-12-01'"); // true
new ConditionParser().Parse("datetime'2022-12-31T01:23:45.678Z' > datetime'2022-12-31T00:00:00.000Z"); // true
new ConditionParser().Parse("date'2022-12-31' == datetime'2022-12-31T00:00:00Z'"); // true

Integer

Integers are represented a sequence of digits, optionally with a leading - to indicate a negative value.

Examples:

new ConditionParser().Parse("1 > 0");       // true
new ConditionParser().Parse("-1 < 0");      // true
new ConditionParser().Parse("1234 == 1");   // false

Double

Doubles are represented by a number with a decimal point, optionally with a leading - to indicate a negative value.

Doubles and integers can be compared against each other.

Examples:

new ConditionParser().Parse("1.23 > 1.1");      // true
new ConditionParser().Parse("-1.23 < 0.0");     // true
new ConditionParser().Parse("1.23 > 1");        // true
new ConditionParser().Parse("1.0 == 1");        // true

String

String values in an expression can be surrounded by either single or double quotes. If the string value contains quotes they need to be escaped as follows:

Quote type Notes Examples
Single (') Escape single quotes within the value as either '' or \'<br />String may contain unescaped double quotes 'o''brien' EndsWith 'rien'<br />'o\'brien' EndsWith 'rien'<br />'These "interesting" times' Contains '"int'
Double (") Escape double quotes within the value as either "" or \"<br />String may contain unescaped single quotes "Bob ""Animal"" Smith" IsNotNull<br />"Bob \"Animal\" Smith" IsNotNull<br />"These 'interesting' times" Contains "'int"

Order of precedence

Like many other languages such as C#, C and Java, and operators are evaluated before or.

Expression Is the same as
A or B and C A or (B and C)
A and B or C (A and B) or C

Expressions can be surrounded by parentheses to control order of evaluation.

new ConditionParser().Parse("('ABC' Contains 'B' or 'ABC' Contains 'C') and (202 >= 200 and 202 < 400)");    // true
Product Compatible and additional computed target framework versions.
.NET 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. 
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
0.1.1 279 6/12/2022
0.1.0 214 6/12/2022