Palit.SharpEnums
1.1.0
dotnet add package Palit.SharpEnums --version 1.1.0
NuGet\Install-Package Palit.SharpEnums -Version 1.1.0
<PackageReference Include="Palit.SharpEnums" Version="1.1.0" />
paket add Palit.SharpEnums --version 1.1.0
#r "nuget: Palit.SharpEnums, 1.1.0"
// Install Palit.SharpEnums as a Cake Addin #addin nuget:?package=Palit.SharpEnums&version=1.1.0 // Install Palit.SharpEnums as a Cake Tool #tool nuget:?package=Palit.SharpEnums&version=1.1.0
SharpEnums
Enums have issues. This library provides a base class SharpEnum
to create strongly typed alternatives to enums.
Current Limitations
Keep in mind that there are several limitations to this library right now:
- Enum values must be
int
- The
,
character is reserved as a seperator
Quick Start
SharpEnums are defined by inheriting from the SharpEnum abstract class:
// Allow Flags
[SharpEnumFlags]
public class TestSharpEnum : SharpEnum<TestSharpEnum>
{
public static TestSharpEnum None = new TestSharpEnum(nameof(None), 0);
public static TestSharpEnum Party = new TestSharpEnum(nameof(Party), 1 << 0);
public static TestSharpEnum Time = new TestSharpEnum(nameof(Time), 1 << 1);
public static TestSharpEnum Sleepy = new TestSharpEnum(nameof(Sleepy), 1 << 2);
public static TestSharpEnum Hungry = new TestSharpEnum(nameof(Hungry), 1 << 3);
public static TestSharpEnum PartyTime = new TestSharpEnum(nameof(PartyTime), Party.Value + Time.Value);
public static TestSharpEnum SleepyTime = new TestSharpEnum(nameof(SleepyTime), Sleepy.Value + Time.Value);
public static TestSharpEnum HungryTime = new TestSharpEnum(nameof(HungryTime), Hungry.Value + Time.Value);
public static TestSharpEnum All = new TestSharpEnum(nameof(All), Party.Value + Time.Value + Sleepy.Value + Hungry.Value);
public TestSharpEnum(string name, int val) : base(name, val) { }
}
// No Flags Allowed
public class TypicalEnum : SharpEnum<TypicalEnum>
{
public static TypicalEnum None = new TypicalEnum(nameof(None), 0);
public static TypicalEnum Black = new TypicalEnum(nameof(Black), 1);
public static TypicalEnum Red = new TypicalEnum(nameof(Red), 2);
public static TypicalEnum Orange = new TypicalEnum(nameof(Orange), 3);
public static TypicalEnum Green = new TypicalEnum(nameof(Green), 4);
public TypicalEnum(string name, int value) : base(name, value) { }
}
Serialization
By default SharpEnums will not serialize as expected with JSON.net. SharpEnums includes 3 different JSON.net custom converters to help with this problem:
- IntSharpEnumConverter
- StringSharpEnumConverter
- StringArraySharpEnumConverter
One way to use these converters is with attributes:
// Will serialize to int value i.e. "WhatTimeIsIt": 11
[JsonConverter(typeof(IntSharpEnumConverter<TestSharpEnum>))]
public TestSharpEnum WhatTimeIsIt { get; set; }
// Will serialize to string i.e. "WhatTimeIsIt": "partyTime, hungry"
// Second parameter is optional camel-casing.
[JsonConverter(typeof(StringSharpEnumConverter<TestSharpEnum>), true)]
public TestSharpEnum WhatTimeIsIt { get; set; }
// Will serialize to string array i.e. "WhatTimeIsIt": ["partyTime", "hungry"]
// Second parameter is optional camel-casing.
[JsonConverter(typeof(StringArraySharpEnumConverter<TestSharpEnum>), true)]
public TestSharpEnum WhatTimeIsIt { get; set; }
Safe Deserialization
Each serializer also supports "safe" conversion. By default, invalid values will throw a JsonSerializationException
on deserialization. By enabling safe conversion, invalid values will be deserialized to the default value rather than throw an error.
Safe deserialization is supported by each converter:
// Second parameter is safe conversion boolean.
[JsonConverter(typeof(IntSharpEnumConverter<TestSharpEnum>), true)]
public TestSharpEnum WhatTimeIsIt { get; set; }
// Third parameter is safe conversion boolean.
[JsonConverter(typeof(StringSharpEnumConverter<TestSharpEnum>), true, true)]
public TestSharpEnum WhatTimeIsIt { get; set; }
// Third parameter is safe conversion boolean.
[JsonConverter(typeof(StringArraySharpEnumConverter<TestSharpEnum>), true, true)]
public TestSharpEnum WhatTimeIsIt { get; set; }
Using SharpEnums
Flags Enums
SharpEnums fully supports flag enums. With normal enums, you would use the [Flags]
attribute. With SharpEnums, the same behavior works using the SharpEnumFlags
attribute:
[SharpEnumFlags]
public class TestSharpEnum : SharpEnum<TestSharpEnum>
List all options
var allOptions = TestSmartEnum.AllOptions;
Default value
var defaultValue = TestSmartEnum.DefaultValue;
Has flag
if (enumInstance.HasFlag(TestSmartEnum.Party)) {
}
From value
var enumInstance = TestSmartEnum.FromValue(11);
Try from value
var success = TestSharpEnum.TryFromValue(11, out var enumInstance);
Parse
var enumInstance = TestSmartEnum.Parse("partyTime", caseInsensitive: true);
Try parse
var success = TestSmartEnum.Parse("partyTime", out var enumInstance, caseInsensitive: true);
Operations
All normal enum operations are supported:
var orCombined = TestSharpEnum.Party | TestSharpEnum.Time;
var xorCombined = TestSharpEnum.PartyTime ^ TestSharpEnum.Time;
var andCombined = TestSharpEnum.PartyTime & TestSharpEnum.Time;
License
MIT
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. |
.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
- Newtonsoft.Json (>= 11.0.2)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.