Light.GuardClauses
                             
                            
                                11.0.0-preview1
                            
                        
                    See the version list below for details.
dotnet add package Light.GuardClauses --version 11.0.0-preview1
NuGet\Install-Package Light.GuardClauses -Version 11.0.0-preview1
<PackageReference Include="Light.GuardClauses" Version="11.0.0-preview1" />
<PackageVersion Include="Light.GuardClauses" Version="11.0.0-preview1" />
<PackageReference Include="Light.GuardClauses" />
paket add Light.GuardClauses --version 11.0.0-preview1
#r "nuget: Light.GuardClauses, 11.0.0-preview1"
#:package Light.GuardClauses@11.0.0-preview1
#addin nuget:?package=Light.GuardClauses&version=11.0.0-preview1&prerelease
#tool nuget:?package=Light.GuardClauses&version=11.0.0-preview1&prerelease
Light.GuardClauses
A lightweight .NET library for expressive Guard Clauses.
Light.GuardClauses - easy precondition checks in C# / .NET
Read the full docs in the Wiki
As a software developer, you're used to writing if statements at the beginning of your methods which validate the parameters that are passed in. Most often you'll probably check for null:
public class Foo
{
    private readonly IBar _bar;
    
    public Foo(IBar? bar)
    {
        if (bar == null)
            throw new ArgumentNullException(nameof(bar));
        
        _bar = bar;
    }
}
Light.GuardClauses simplifies these precondition checks for you by providing extension methods that you can directly call on your parameters:
public class Foo
{
    private readonly IBar _bar;
    
    public Foo(IBar? bar)
    {
        _bar = bar.MustNotBeNull();
    }
}
As of version 10, Light.GuardClauses supports the CallerArgumentExpressionAttribute of C# 10. If your C# compiler is on a lower version, then the
CallerArgumentExpressionAttributemight not be respected - you should then call all assertions with an explicit parameter name, e.g.bar.MustNotBeNull(nameof(bar)). You can use the C# 10 compiler by e.g. installing .NET 6 and/or Visual Studio 2022. TheCallerArgumentExpressionAttributeis backwards-compatible, so it can be used with projects targeting .NET Standard 2, .NET Framework, or .NET Core.
By using Light.GuardClauses, you'll gain access to assertions for a vast amount of scenarios like checking strings, collections, enums, URIs, DateTime, Type, IComparable<T>, IEnumerable, IEnumerable<T>, and Span<T>. Just have a look at these examples:
public class ConsoleWriter
{
    private readonly ConsoleColor _foregroundColor;
    public ConsoleWriter(ConsoleColor foregroundColor = ConsoleColor.Black) =>
        _foregroundColor = foregroundColor.MustBeValidEnumValue();
}
public void SetMovieRating(Guid movieId, int numberOfStars)
{
    movieId.MustNotBeEmpty();
    numberOfStars.MustBeIn(Range.FromInclusive(0).ToInclusive(5));
    
    var movie = _movieRepo.GetById(movieId);
    movie.AddRating(numberOfStars);
}
public class WebGateway
{
    private readonly HttpClient _httpClient;
    private readonly Uri _targetUrl;
    public WebGateway(HttpClient? httpClient, Uri? targetUrl)
    {
        _httpClient = httpClient.MustNotBeNull();
        _targetUrl = targetUrl.MustBeHttpOrHttpsUrl();
    }
}
In addition to assertions that throw exceptions (all these start with Must), Light.GuardClauses provides assertions that return a Boolean. Some examples are:
- string.IsNullOrWhitespace()
- collection.IsNullOrEmpty()
- enum.IsValidEnumValue()
You can use these in your branching logic to easily check if an assertion is true or false.
Every assertion is well-documented - explore them using IntelliSense or check out this overview.
Light.GuardClauses is optimized
Since version 4.x, Light.GuardClauses is optimized for performance (measured in .NET 4.8 and .NET 6). With the incredible help of @redknightlois and the awesome tool Benchmark.NET, most assertions are as fast as your imperative code would be.
Light.GuardClauses has support for .NET analyzers / FxCopAnalyzers with the ValidatedNotNullAttribute. Analyzers will know when an assertion validated that a parameters is not null and consequently, CA1062 will not be raised.
Furthermore, Light.GuardClauses has support for ReSharper since version 4.x. Via Contract Annotations, R# knows when assertions do not return a null value and thus removes squiggly lines indicating a possible NullReferenceException. Since version 10.1.0, Light.GuardClauses also annotates assertions that do not iterate over an IEnumerable<T> with ReSharper's NoEnumerationAttribute - ReSharper will then not indicate a "Possible multiple enumeration" (thanks to cdonnellytx for this contribution).
Light.GuardClauses supports C#8 Nullable Reference Types since version 8.0.
And, of course, the functional correctness of Light.GuardClauses is covered by a vast suite of automated tests.
Supported Platforms
Light.GuardClauses is built against .NET Standard 2.0 and 2.1, thus it can be used in frameworks like .NET 6, .NET 7, .NET Framework 4.6.1 or newer, Unity, Mono, or UWP.
How to Install
Light.GuardClauses is available as a NuGet package.
- dotnet CLI: dotnet add package Light.GuardClauses
- Visual Studio Package Manager Console: Install-Package Light.GuardClauses
- Package Reference in csproj: <PackageReference Include="Light.GuardClauses" Version="11.0.0-preview1" />
Also, you can incorporate Light.GuardClauses as a single source file where the API is changed to internal. This is especially interesting for framework / library developers that do not want to have a dependency on the Light.GuardClauses DLL. You can grab the default .NET Standard 2.0 version in Light.GuardClauses.SingleFile.cs or you can use the Light.GuardClauses.SourceCodeTransformation project to create your custom file. You can learn more about it here.
Let there be... Light

| 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 is compatible. 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 is compatible. | 
| .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- System.Memory (>= 4.5.5)
- System.Runtime.CompilerServices.Unsafe (>= 6.0.0)
 
- 
                                                    .NETStandard 2.1- System.Runtime.CompilerServices.Unsafe (>= 6.0.0)
 
- 
                                                    net8.0- No dependencies.
 
NuGet packages (28)
Showing the top 5 NuGet packages that depend on Light.GuardClauses:
| Package | Downloads | 
|---|---|
| Updatedge.net C# wrapper for the updatedge API | |
| Light.ViewModels Simplify your XAML applications with Light.ViewModels! | |
| Synnotech.Migrations.Core Core implementation of a generic migration engine that can be adapted to any target system. | |
| Synnotech.Linq2Db Package Description | |
| Light.DependencyInjection The DI Container you always wanted. | 
GitHub repositories (1)
Showing the top 1 popular GitHub repositories that depend on Light.GuardClauses:
| Repository | Stars | 
|---|---|
| ExtendedXmlSerializer/home 
                                                            A configurable and eXtensible Xml serializer for .NET.
                                                         | 
| Version | Downloads | Last Updated | 
|---|---|---|
| 13.1.0 | 10,668 | 7/21/2025 | 
| 13.0.0 | 45,597 | 3/9/2025 | 
| 12.0.0 | 140,515 | 10/27/2024 | 
| 11.0.0 | 304,483 | 11/16/2023 | 
| 11.0.0-preview1 | 188 | 9/24/2023 | 
| 10.3.0 | 10,587 | 10/9/2023 | 
| 10.2.0 | 3,328 | 9/22/2023 | 
| 10.1.0 | 14,312 | 8/6/2023 | 
| 10.0.0 | 524,444 | 12/6/2021 | 
| 9.0.0 | 140,085 | 12/6/2020 | 
| 8.1.0 | 60,943 | 5/27/2020 | 
| 8.0.1 | 23,093 | 3/26/2020 | 
| 8.0.0 | 780 | 3/25/2020 | 
| 7.0.0 | 47,106 | 7/13/2019 | 
| 6.2.0 | 17,975 | 2/12/2019 | 
| 6.1.0 | 21,822 | 11/18/2018 | 
| 6.0.0 | 1,069 | 11/10/2018 | 
| 5.0.1 | 60,570 | 8/3/2018 | 
| 5.0.0 | 1,606 | 7/29/2018 | 
| 4.0.0 | 1,800 | 7/10/2018 | 
| 3.5.0 | 3,188 | 9/3/2017 | 
| 3.4.0 | 1,353 | 8/27/2017 | 
| 3.3.0 | 1,555 | 8/15/2017 | 
| 3.2.0 | 1,344 | 8/13/2017 | 
| 3.1.0 | 1,329 | 8/6/2017 | 
| 3.0.0 | 1,812 | 7/23/2017 | 
| 2.0.0 | 1,700 | 5/29/2017 | 
| 1.3.0 | 1,434 | 4/12/2017 | 
| 1.2.1 | 2,191 | 11/16/2016 | 
| 1.2.0 | 3,676 | 7/25/2016 | 
| 1.1.0 | 1,883 | 6/2/2016 | 
| 1.0.0 | 1,453 | 6/1/2016 | 
| 0.2.0 | 1,441 | 3/29/2016 | 
| 0.1.0 | 1,796 | 3/23/2016 | 
Light.GuardClauses 11.0.0-preview1
--------------------------------
- Light.GuardClauses now targets .NET 8 and is AOT-compatible
- breaking: EnumInfo<T> no longer has the UnderlyingType property
- In AOT scenarios, avoid the Type-related assertions, they are marked with the DynamicallyAccessedMembersAttribute