Nemesis.TextParsers
2.6.2
See the version list below for details.
dotnet add package Nemesis.TextParsers --version 2.6.2
NuGet\Install-Package Nemesis.TextParsers -Version 2.6.2
<PackageReference Include="Nemesis.TextParsers" Version="2.6.2" />
paket add Nemesis.TextParsers --version 2.6.2
#r "nuget: Nemesis.TextParsers, 2.6.2"
// Install Nemesis.TextParsers as a Cake Addin #addin nuget:?package=Nemesis.TextParsers&version=2.6.2 // Install Nemesis.TextParsers as a Cake Tool #tool nuget:?package=Nemesis.TextParsers&version=2.6.2
Contains various parser optimized for speed and no allocation
This package was built from the source at https://github.com/nemesissoft/Nemesis.TextParsers/tree/5f10bceacd3d347c29aea8b77393c1b0828bf9a2
Product | Versions 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. |
.NET Core | netcoreapp2.0 was computed. netcoreapp2.1 was computed. netcoreapp2.2 was computed. netcoreapp3.0 was computed. netcoreapp3.1 is compatible. |
.NET Standard | netstandard2.0 is compatible. netstandard2.1 is compatible. |
.NET Framework | net461 is compatible. net462 was computed. net463 was computed. net47 is compatible. 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. |
-
.NETCoreApp 3.1
- No dependencies.
-
.NETFramework 4.6.1
- System.Memory (>= 4.5.4)
- System.ValueTuple (>= 4.5.0)
-
.NETFramework 4.7
- System.Memory (>= 4.5.4)
-
.NETStandard 2.0
- System.Memory (>= 4.5.4)
-
.NETStandard 2.1
- System.Runtime.CompilerServices.Unsafe (>= 4.7.1)
-
net5.0
- No dependencies.
NuGet packages (2)
Showing the top 2 NuGet packages that depend on Nemesis.TextParsers:
Package | Downloads |
---|---|
Nemesis.Demos
Set of utils for showing coding and language/framework features in form of live demos This package was built from the source at https://github.com/nemesissoft/Nemesis.Demos/tree/dcb94c7943b7275519e5994167a812cba983e01d |
|
Nemesis.TextParsers.DependencyInjection
Contains helper methods useful to setup DependencyInjection using Microsoft.Extensions.DependencyInjection This package was built from the source at https://github.com/nemesissoft/Nemesis.TextParsers/tree/b6854dd729d170756762cad27fc9acfa79115931 |
GitHub repositories
This package is not used by any popular GitHub repositories.
Version | Downloads | Last updated |
---|---|---|
2.10.0 | 83 | 1/9/2025 |
2.9.15 | 212 | 8/9/2024 |
2.9.6 | 156 | 8/8/2024 |
2.9.2 | 237 | 1/3/2024 |
2.9.1 | 132 | 1/1/2024 |
2.8.2 | 155 | 12/19/2023 |
2.7.2 | 284 | 7/16/2023 |
2.7.1 | 174 | 7/14/2023 |
2.7.0 | 159 | 7/14/2023 |
2.6.3 | 494 | 5/30/2022 |
2.6.2 | 434 | 3/1/2021 |
2.6.1 | 368 | 2/25/2021 |
2.6.0 | 391 | 2/25/2021 |
2.5.0 | 416 | 12/31/2020 |
2.4.0 | 435 | 11/30/2020 |
2.3.0 | 438 | 11/16/2020 |
2.2.1 | 545 | 5/15/2020 |
2.2.0 | 438 | 5/14/2020 |
2.1.2 | 454 | 5/12/2020 |
2.1.1 | 507 | 5/1/2020 |
2.1.0 | 471 | 4/28/2020 |
2.0.4 | 475 | 4/26/2020 |
2.0.2 | 491 | 4/21/2020 |
2.0.1 | 493 | 4/17/2020 |
2.0.0-alpha | 356 | 4/15/2020 |
1.5.1 | 472 | 3/29/2020 |
1.5.0 | 512 | 3/28/2020 |
1.4.1 | 532 | 3/23/2020 |
1.3.2 | 502 | 3/19/2020 |
1.3.0 | 504 | 3/16/2020 |
1.2.0 | 566 | 3/15/2020 |
1.1.3 | 586 | 3/14/2020 |
1.1.2 | 557 | 2/27/2020 |
1.1.1 | 499 | 2/26/2020 |
1.1.0 | 555 | 2/26/2020 |
1.0.6 | 572 | 2/25/2020 |
1.0.4 | 446 | 2/25/2020 |
1.0.3 | 570 | 2/18/2020 |
1.0.2 | 559 | 11/8/2019 |
1.0.1 | 515 | 11/6/2019 |
1.0.0 | 520 | 9/25/2019 |
0.11.50 | 529 | 9/25/2019 |
0.11.47 | 512 | 9/25/2019 |
0.11.46 | 525 | 9/23/2019 |
0.11.42 | 565 | 9/18/2019 |
0.11.41 | 526 | 9/18/2019 |
0.11.40 | 519 | 9/18/2019 |
0.11.39 | 583 | 9/18/2019 |
0.11.38 | 544 | 9/18/2019 |
0.11.37 | 525 | 9/18/2019 |
0.11.36 | 542 | 9/17/2019 |
0.11.35 | 543 | 9/17/2019 |
0.11.34 | 543 | 9/17/2019 |
0.11.33 | 553 | 9/17/2019 |
0.9.32 | 548 | 9/17/2019 |
0.9.31 | 535 | 9/11/2019 |
0.9.30 | 552 | 9/9/2019 |
0.9.29 | 532 | 9/6/2019 |
0.9.28 | 550 | 8/3/2019 |
0.9.27 | 568 | 8/3/2019 |
0.9.26 | 528 | 8/1/2019 |
0.9.25 | 568 | 7/21/2019 |
0.9.24 | 557 | 7/19/2019 |
0.9.22 | 565 | 6/14/2019 |
0.9.21 | 548 | 6/13/2019 |
0.9.20 | 599 | 6/9/2019 |
0.9.19 | 623 | 6/7/2019 |
0.9.18 | 603 | 6/5/2019 |
0.9.15 | 562 | 5/29/2019 |
0.9.14 | 613 | 5/29/2019 |
0.9.13 | 594 | 5/28/2019 |
0.9.12 | 592 | 5/27/2019 |
0.9.10 | 610 | 5/21/2019 |
0.9.8 | 581 | 5/7/2019 |
0.9.7 | 603 | 5/5/2019 |
0.9.6 | 585 | 5/5/2019 |
0.9.5 | 565 | 5/5/2019 |
0.0.0-alpha.0.335 | 82 | 1/1/2024 |
Release v2.6.2
Add code gen package
Add code generation package that automatically generates necessary transformers
## C# 9.0 Code generation
With introduction of new code-gen engine, you can opt to have your transformer generated automatically without any imperative code.
```csharp
//1. use specially provided (via code-gen) Auto.AutoDeconstructable attribute
[Auto.AutoDeconstructable]
//2. provide deconstructable aspect options or leave this attribute out - default options will be engaged
[DeconstructableSettings('_', '∅', '%', '〈', '〉')]
readonly partial /*3. partial modifier is VERY important - you need this cause generated code is placed in different file*/ struct StructPoint3d
{
public double X { get; }
public double Y { get; }
public double Z { get; }
//4. specify constructor and matching deconstructor
public StructPoint3d(double x, double y, double z) { X = x; Y = y; Z = z; }
public void Deconstruct(out double x, out double y, out double z) { x = X; y = Y; z = Z; }
}
//5. sit back, relax and enjoy - code-gen will do the job for you :-)
```
This in turn might generate the following (parts of code ommited for brevity)
```csharp
using /* ... */;
[Transformer(typeof(StructPoint3dTransformer))]
readonly partial struct StructPoint3d { }
sealed class StructPoint3dTransformer : TransformerBase<StructPoint3d>
{
private readonly ITransformer<double> _transformer_x = TextTransformer.Default.GetTransformer<double>();
/* specify remaining transformers... */
private const int ARITY = 3;
private readonly TupleHelper _helper = new TupleHelper('_', '∅', '%', '〈', '〉');
protected override StructPoint3d ParseCore(in ReadOnlySpan<char> input)
{
var enumerator = _helper.ParseStart(input, ARITY);
var t1 = _helper.ParseElement(ref enumerator, _transformer_x);
/* parse Y and Z... */
_helper.ParseEnd(ref enumerator, ARITY);
return new StructPoint3d(t1, t2, t3);
}
public override string Format(StructPoint3d element)
{
Span<char> initialBuffer = stackalloc char[32];
var accumulator = new ValueSequenceBuilder<char>(initialBuffer);
try
{
_helper.StartFormat(ref accumulator);
var (x, y, z) = element;
_helper.FormatElement(_transformer_x, x, ref accumulator);
/* format Y and Z... */
_helper.EndFormat(ref accumulator);
return accumulator.AsSpan().ToString();
}
finally { accumulator.Dispose(); }
}
}
```
### Code gen diagnositcs
Various diagnositcs exist to guide end user in creation of proper types that can be consumed by automatic generation. They might for example:
1. check if types decorated with Auto* attributes are declared partial (prerequisite for additive code generation)
2. validate settings passed via declarative syntax
3. validate internal structure of type (i.e. check if constructor has matching Deconstruct method)
4. check if external dependencies are included