loach.PureSharp
0.1.5
dotnet add package loach.PureSharp --version 0.1.5
NuGet\Install-Package loach.PureSharp -Version 0.1.5
<PackageReference Include="loach.PureSharp" Version="0.1.5" />
<PackageVersion Include="loach.PureSharp" Version="0.1.5" />
<PackageReference Include="loach.PureSharp" />
paket add loach.PureSharp --version 0.1.5
#r "nuget: loach.PureSharp, 0.1.5"
#:package loach.PureSharp@0.1.5
#addin nuget:?package=loach.PureSharp&version=0.1.5
#tool nuget:?package=loach.PureSharp&version=0.1.5
PureSharp
English | 日本語 | 简体中文 | 繁體中文 | Esperanto | Klingon | Español | Français | Deutsch | 한국어
PureSharp is a toolset designed to strongly support "referential transparency" and "immutability" in C#, bringing the safety of functional programming to C#. It leverages Roslyn analyzers to enforce robust, bug-resistant code writing at the compilation level.
Core Concepts
- Purity Enforcement: Explicitly declare logic without side effects and verify it mechanically.
- Immutability Introduction: Achieve "non-reassignable local variables," a feature lacking in the language specification, through intuitive naming conventions.
- Safe Control Flow: Provide pipeline-style conditional branching to prevent runtime exceptions and oversights.
Key Features
1. PureSharp.Core
Provides fundamental attributes and utilities.
[PureMethod]attribute: Declares a method as "pure" (referentially transparent).Fluent.If: A fluent interface that allowsif-elsestatements to be written as expressions.
2. PureSharp.Analyzers (Roslyn Analyzers)
Monitors code writing in real-time and reports rule violations.
Referential Transparency Verification (RTxxxx)
An Error is reported when a method annotated with [PureMethod] performs the following operations:
- Accessing static, mutable (non-readonly) fields.
- Calling non-pure methods (methods without
[PureMethod]). - I/O operations (access to Console, File, Network, etc.).
Local Variable Immutability Enforcement (LVPxxxx)
Achieves immutability using a naming convention that starts with an underscore (_).
- Mandatory Immutability: Prohibits reassignment to local variables starting with
_(Error). - Initialization Enforcement: Variables starting with
_must be initialized at the time of declaration (Error). - Naming Suggestion: Suggests adding an underscore (
_) to variables that have never been reassigned (Warning).
FluentIf Termination Check (FIFxxxx)
- Verifies that chains starting with
Fluent.Ifare correctly terminated with.Else(). Failure to terminate will result in a compile error.
Quick Start
1. Writing Referentially Transparent Methods
using PureSharp.Core;
public class Calculator
{
private static int _globalCache; // Mutable static field
[PureMethod]
public int Add(int a, int b)
{
// OK: Calculation only
return a + b;
// NG: Accessing static field causes RT0001 error
// _globalCache = a + b;
// NG: I/O operations cause RT0003 error
// Console.WriteLine(a);
}
}
2. Utilizing Immutable Local Variables
public void Process()
{
int _result = Calculate(); // Declared as an immutable variable
// NG: Attempting to reassign causes LVP0001 error
// _result = 10;
int count = 0; // Regular variable
// Suggestion: If not reassigned, a warning to change to "_count" (LVP0003)
}
3. Safe Conditional Branching (FluentIf)
int status = Fluent.If(score >= 80, () => 1)
.ElseIf(score >= 60, () => 2)
.Else(0); // Forgetting .Else() causes FIF0001 error
Project Structure
- PureSharp.Core: Provides core attributes and runtime libraries (.NET 10.0 / netstandard2.0).
- PureSharp.Analyzers: The main Roslyn analyzer (netstandard2.0).
- PureSharp.Analyzers.Tests: Unit tests to verify analyzer behavior (xUnit).
Motivation for Development
C# is a very powerful language, but in large-scale development or complex logic, debugging can become difficult due to unintended side effects or variable reuse. PureSharp was born to provide developers with "freedom (from bugs)" in the form of "constraints."
License
This project is released under the MIT License.
| 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
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.