simple-lexer
0.0.1
There is a newer version of this package available.
See the version list below for details.
See the version list below for details.
dotnet add package simple-lexer --version 0.0.1
NuGet\Install-Package simple-lexer -Version 0.0.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="simple-lexer" Version="0.0.1" />
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add simple-lexer --version 0.0.1
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
#r "nuget: simple-lexer, 0.0.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 simple-lexer as a Cake Addin #addin nuget:?package=simple-lexer&version=0.0.1 // Install simple-lexer as a Cake Tool #tool nuget:?package=simple-lexer&version=0.0.1
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
C# Lexer
Simple lexer written in C#
Code example:
// Class that extends ILexerNode
var lexer = LexerBuilder.New<BaseNode>()
.Init()
.WithAmbiguityResolverEnum(AmbiguityResolverEnum.FirstMatch)
// Define the nil node
.NilNode(() => new NilNode())
.WithHandler(new Regex("[\\d]+"), opt => {
opt.Yield(opt.Buffer, new NumericNode {Value = decimal.Parse(opt.Buffer)});
})
.WithHandler(new Regex("[+-\\/*]"), opt => {
opt.Yield(opt.Buffer, new OpNode {Operator = opt.Buffer[0]});
})
.WithHandler(new Regex("[\\s]+"), opt => {
opt.Dispose(opt.Buffer);
})
.WithHandler(new Regex("[\\w]+"), opt => opt.SetBuffer(string.Empty))
.WithHandler(new Regex("$"), opt => opt.Stop())
.FinalizeHandlers()
.Build();
var nodes = lexer.Process("12 * 23 + 34 / 45 - 56 Error".ToMemoryStream());
> nodes
// NumericNode, OpNode, and etc.
Notes:
- Order of handlers matter in case of FirstMatch or LastMatch
- Handler can yield more than one time
- Upon invocation of Yield, the string gets removed from the beginning of the buffer
- Handler has option (i.e.
opt
):- Buffer string
- Next character
- Previous token
- Stop Lexer
- Modify Buffer
- Yield result
- Dispose a string from the beginning of the Buffer
- Do nothing
- AmbiguityResolvers:
FirstMatch
: takes the first matching handlerLastMatch
: takes the last matching handlerLongestMatch
: takes the handler yielding handler (defaults back toFirstMatch
in case of failure)
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net5.0 was computed. 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. |
.NET Core | netcoreapp2.0 is compatible. netcoreapp2.1 was computed. netcoreapp2.2 was computed. netcoreapp3.0 was computed. netcoreapp3.1 was computed. |
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.
-
.NETCoreApp 2.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.