Metalama.Patterns.Contracts
2025.0.5-preview
Prefix Reserved
See the version list below for details.
dotnet add package Metalama.Patterns.Contracts --version 2025.0.5-preview
NuGet\Install-Package Metalama.Patterns.Contracts -Version 2025.0.5-preview
<PackageReference Include="Metalama.Patterns.Contracts" Version="2025.0.5-preview" />
paket add Metalama.Patterns.Contracts --version 2025.0.5-preview
#r "nuget: Metalama.Patterns.Contracts, 2025.0.5-preview"
// Install Metalama.Patterns.Contracts as a Cake Addin #addin nuget:?package=Metalama.Patterns.Contracts&version=2025.0.5-preview&prerelease // Install Metalama.Patterns.Contracts as a Cake Tool #tool nuget:?package=Metalama.Patterns.Contracts&version=2025.0.5-preview&prerelease
About
The Metalama.Patterns.Contracts
package implements the concept of contract-based programming, encompassing preconditions, postconditions, and invariants.
Key Features
- Implementation of preconditions and postconditions through a wide range of numeric or string-based contracts.
- Verification of invariants.
Main Types
Below is a list of available contract attributes for your selection:
Nullability Contracts
[NotNull]
verifies that the assigned value is notnull
.[Required]
contract verifies that the value is notnull
and requires the string to be non-empty.
String Contracts
[NotEmpty]
requires the string to be non-empty. Note that this contract does not validate the string against being null. If you want to prohibit both null and empty strings, use[Required]
.[CreditCard]
validates that the string is a valid credit card number.[Email]
,[Phone]
, and[Url]
validate strings against well-known regular expressions.[Regex]
validates a string against a custom regular expression.[StringLength]
validates that the length of a string falls within a specified range.
Enum Contracts
[EnumDataType]
contract can validate values of typestring
,object
, or of any integer type. It throws an exception if the value is not valid for the givenenum
type.
Numeric Contracts
The following contracts can be used to verify that a value falls within a specified range:
[LessThan]
verifies that the value is less than or equal to the specified maximum.[GreaterThan]
verifies that the value is greater than or equal to the specified minimum.[Negative]
verifies that the value is less than or equal to zero.[Positive]
verifies that the value is greater than or equal to zero.[Range]
verifies that the value is greater than or equal to a specified minimum and less than or equal to a specified maximum.[StrictlyLessThan]
verifies that the value is strictly less than the specified maximum.[StrictlyGreaterThan]
verifies that the value is strictly greater than the specified minimum.[StrictlyNegative]
verifies that the value is strictly less than zero.[StrictlyPositive]
verifies that the value is strictly greater than zero.[StrictRange]
verifies that the value is strictly greater than a specified minimum and strictly less than a specified maximum.
Collections Contracts
[NotEmpty]
contract can be used on any collection, including arrays or immutable arrays. It requires the collection or the array to contain at least one element.
Invariants
[Invariant]
causes the target method (a parameterlessvoid
method) to be invoked after each public method or property setter.[DoNotCheckInvariants]
exempts the target method from enforcing invariants, but does not exempt any method or property setter used by this method.[SuspendInvariant]
exempts the target method from enforcing invariants, including any method or property setter used by this method.
Additional Documentation
- Conceptual documentation:
- API documentation
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net5.0 was computed. net5.0-windows was computed. net6.0 is compatible. 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 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 is compatible. 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. |
-
.NETFramework 4.7.1
- Metalama.Framework (>= 2025.0.5-preview)
-
.NETStandard 2.0
- Metalama.Framework (>= 2025.0.5-preview)
-
net6.0
- Metalama.Framework (>= 2025.0.5-preview)
NuGet packages (6)
Showing the top 5 NuGet packages that depend on Metalama.Patterns.Contracts:
Package | Downloads |
---|---|
Shinya.Core
Shinya.Framework |
|
Metalama.Patterns.Caching.Aspects
A set of aspects that simplify the caching: [Cache] to cache a method result as a function of its parameters, [InvalidateCache] to invalidate the cache, or [CacheKey] to mark a cache key in a class. |
|
Atesh.Metalama
Atesh.Metalama library is a collection of custom made Metalama Aspects (a.k.a Attributes). |
|
JamesConsulting
Package Description |
|
Metalama.Patterns.Xaml
Provides custom |
GitHub repositories
This package is not used by any popular GitHub repositories.
Version | Downloads | Last updated |
---|---|---|
2025.0.8 | 103 | 1/6/2025 |
2025.0.7-rc | 229 | 12/6/2024 |
2025.0.6-rc | 231 | 11/15/2024 |
2025.0.5-preview | 136 | 11/8/2024 |
2025.0.4-preview | 96 | 10/31/2024 |
2025.0.3-preview | 111 | 10/25/2024 |
2025.0.2-preview | 106 | 10/24/2024 |
2025.0.1-preview | 99 | 10/14/2024 |
2024.2.31 | 150 | 12/6/2024 |
2024.2.30 | 160 | 11/15/2024 |
2024.2.29 | 216 | 10/31/2024 |
2024.2.28 | 135 | 10/25/2024 |
2024.2.27 | 117 | 10/24/2024 |
2024.2.26 | 247 | 10/14/2024 |
2024.2.25 | 182 | 10/2/2024 |
2024.2.24 | 5,614 | 9/10/2024 |
2024.2.23 | 830 | 8/30/2024 |
2024.2.22 | 197 | 8/29/2024 |
2024.2.21 | 327 | 8/28/2024 |
2024.2.20 | 1,037 | 8/15/2024 |
2024.2.19 | 796 | 8/1/2024 |
2024.2.18 | 199 | 7/29/2024 |
2024.2.17-rc | 137 | 7/22/2024 |
2024.2.16-rc | 132 | 7/18/2024 |
2024.2.15-rc | 174 | 7/12/2024 |
2024.2.14-rc | 204 | 7/8/2024 |
2024.2.13-rc | 139 | 7/2/2024 |
2024.2.12-preview | 192 | 6/28/2024 |
2024.2.11-preview | 140 | 6/26/2024 |
2024.2.10-preview | 135 | 6/20/2024 |
2024.2.9-preview | 174 | 6/11/2024 |
2024.2.8-preview | 106 | 6/6/2024 |
2024.2.7-preview | 133 | 5/30/2024 |
2024.2.6-preview | 133 | 5/25/2024 |
2024.2.5-preview | 151 | 5/6/2024 |
2024.2.4-preview | 138 | 5/4/2024 |
2024.2.3-preview | 139 | 4/30/2024 |
2024.2.2-preview | 140 | 4/23/2024 |
2024.2.1-preview | 142 | 4/11/2024 |
2024.1.30 | 109 | 10/24/2024 |
2024.1.29 | 128 | 10/11/2024 |
2024.1.28 | 155 | 9/9/2024 |
2024.1.27 | 163 | 8/28/2024 |
2024.1.26 | 320 | 8/15/2024 |
2024.1.25 | 308 | 7/22/2024 |
2024.1.24 | 1,066 | 7/12/2024 |
2024.1.23 | 201 | 6/26/2024 |
2024.1.22 | 183 | 6/15/2024 |
2024.1.21 | 155 | 6/6/2024 |
2024.1.20 | 187 | 5/30/2024 |
2024.1.19 | 179 | 5/24/2024 |
2024.1.18 | 304 | 5/6/2024 |
2024.1.17 | 140 | 5/3/2024 |
2024.1.16 | 207 | 4/30/2024 |
2024.1.15 | 166 | 4/29/2024 |
2024.1.14 | 199 | 4/23/2024 |
2024.1.13 | 153 | 4/23/2024 |
2024.1.12 | 197 | 4/17/2024 |
2024.1.11-rc | 150 | 4/11/2024 |
2024.1.10-rc | 140 | 4/4/2024 |
2024.1.9-rc | 128 | 3/27/2024 |
2024.1.8-preview | 103 | 3/25/2024 |
2024.1.7-preview | 147 | 3/19/2024 |
2024.1.6-preview | 135 | 3/6/2024 |
2024.1.5-preview | 140 | 2/29/2024 |
2024.1.4-preview | 171 | 2/27/2024 |
2024.1.3-preview | 135 | 2/23/2024 |
2024.1.2-preview | 133 | 2/7/2024 |
2024.1.1-preview | 120 | 1/30/2024 |
2024.0.16 | 193 | 6/15/2024 |
2024.0.15 | 147 | 6/6/2024 |
2024.0.14 | 155 | 5/30/2024 |
2024.0.13 | 154 | 5/24/2024 |
2024.0.12 | 180 | 4/17/2024 |
2024.0.11 | 180 | 3/21/2024 |
2024.0.10 | 146 | 3/19/2024 |
2024.0.9 | 185 | 2/29/2024 |
2024.0.8 | 176 | 2/23/2024 |
2024.0.7 | 181 | 2/7/2024 |
2024.0.6 | 231 | 1/3/2024 |
2024.0.5-rc | 195 | 12/21/2023 |
2024.0.4-rc | 159 | 12/12/2023 |
2024.0.3-preview | 177 | 12/6/2023 |
2024.0.2-preview | 180 | 11/14/2023 |
2024.0.1-preview | 147 | 11/6/2023 |
2023.4.9 | 165 | 2/7/2024 |
2023.4.8 | 201 | 12/21/2023 |
2023.4.7 | 200 | 12/12/2023 |
2023.4.6 | 239 | 11/7/2023 |
2023.4.5-rc | 164 | 10/26/2023 |
2023.4.4-preview | 164 | 10/18/2023 |
2023.4.3-preview | 169 | 10/4/2023 |
2023.4.2-preview | 175 | 9/26/2023 |
2023.3.10-preview | 161 | 12/21/2023 |
2023.3.9-preview | 157 | 12/12/2023 |
2023.3.8-preview | 161 | 10/17/2023 |
2023.3.7-preview | 161 | 9/29/2023 |
2023.3.6-preview | 156 | 9/26/2023 |
2023.3.5-preview | 202 | 9/13/2023 |
2023.3.4-preview | 216 | 8/30/2023 |