Toarnbeike.SourceGeneration
0.2.2
dotnet add package Toarnbeike.SourceGeneration --version 0.2.2
NuGet\Install-Package Toarnbeike.SourceGeneration -Version 0.2.2
<PackageReference Include="Toarnbeike.SourceGeneration" Version="0.2.2" />
<PackageVersion Include="Toarnbeike.SourceGeneration" Version="0.2.2" />
<PackageReference Include="Toarnbeike.SourceGeneration" />
paket add Toarnbeike.SourceGeneration --version 0.2.2
#r "nuget: Toarnbeike.SourceGeneration, 0.2.2"
#:package Toarnbeike.SourceGeneration@0.2.2
#addin nuget:?package=Toarnbeike.SourceGeneration&version=0.2.2
#tool nuget:?package=Toarnbeike.SourceGeneration&version=0.2.2
Toarnbeike.SourceGeneration
Toarnbeike.SourceGeneration is a utility library for building incremental source generators.
It provides reusable abstractions for working with Roslyn, focused on improving readability,
correctness, and composability of generator pipelines.
This library is currently intended for internal use and experimentation.
Design philosophy
The library follows the natural stages of an incremental source generator:
Discovery -> Selection -> Semantics -> Modeling -> Rendering
Each namespace in this library maps to one of these concerns.
The goal is to:
- reduce boilerplate
- enforce correct Roslyn usage (symbol-based, incremental-safe)
- improve readability of generator code
Selection
Selection is the entry point of the incremental pipeline.
Instead of manually writing CreateSyntaxProvider logic, the library provides
higher-level abstractions for common patterns.
Example
var types = context.ForAttribute<MyAttribute>();
Available
- ForAttribute<TAttribute>
- Finds all types annotated with TAttribute
- Handles syntax filtering + semantic validation
Planned
- ForInterface<TInterface>
- ForBaseType<TBase>
Semantics
Semantic helpers operate on Roslyn symbols (ISymbol, INamedTypeSymbol, etc.).
These extensions aim to:
- replace string-based matching with symbol-based matching
- simplify attribute and type inspection
- provide consistent formatting
The following extensions are provided:
Attributes
- AttributeDataExtensions - get data supplied by the attribute
- AttributeSymbolExtensions - check if symbol is annotated with attribute, and/or return attribute data
Types
- display helpers
- todo: interface checks
Models
Common models are provided by the library:
ConstructorParameterModel(string TypeName, string Name, string? XmlDescription)with rendering options.
Rendering
Rendering helpers assist in generating source code strings.
These are intentionally simple primitives, not a templating system.
Available
- UsingBuilder - build
usingstatements from provided types - TextRenderingExtensions
- JoinLines
- JoinCommaSeparatedLines
- Indent
Notes
Rendering operates on
- strings
- Roslyn symbols (preferred over raw strings)
Naming
Helpers for consistent naming conventions.
ToCamelCase()
Documentation
Helpers for reading XML documentation from symbols.
- XmlDocumentationExtensions
- extract
<param>documentation from methods
- extract
Utilities
Low-level helpers that are not provided by netstandard2.0.
- HashCodeHelper
| 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. 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. 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. |
| .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. |
-
.NETStandard 2.0
- No dependencies.
NuGet packages (1)
Showing the top 1 NuGet packages that depend on Toarnbeike.SourceGeneration:
| Package | Downloads |
|---|---|
|
Toarnbeike.Unions.Generator
Source generated tagged unions. |
GitHub repositories
This package is not used by any popular GitHub repositories.