Skip to content

3.0.0

Compare
Choose a tag to compare
@TylerBrinkley TylerBrinkley released this 02 Nov 02:16
· 14 commits to master since this release

New Features

  • Added C# 8 nullable reference annotations throughout.
  • Reduced default memory usage by over 83% by minimizing generic code over the enum type, due to value type generic argument code explosion.
  • Improved performance throughout.
  • Added ReadOnlySpan<char> parsing support when targeting .NET Core 3.0+.

Breaking Changes

  • GetNames, GetValues, GetMembers, GetFlags, and GetFlagMembers now all return an IReadOnlyList<T> instead of IEnumerable<T>.
  • Since IReadOnlyList<T> was added in .NET Framework 4.5, support for prior .NET Framework versions has been removed.
  • .NET Standard builds now depend on the System.Runtime.CompilerServices.Unsafe package for efficient conversions between the enum and its underlying type instead of relying on Fody to implement that.
  • NonGenericEnums, NonGenericFlagEnums, UnsafeEnums, and UnsafeFlagEnums are now deprecated and will be removed in v4.0. The equivalent methods have been added to the Enums and FlagEnums classes with the unsafe versions having the suffix of Unsafe to avoid a naming conflict with the type-safe versions. This was done to better match System.Enum and provide better discoverability being more centralized. I've created the C# roslyn analyzer Enums.NET.Analyzer which provides a code fix to migrate your usages of the non-generic and unsafe methods to the new methods.
  • Nullable enum types are not supported in the new non-generic methods but are still supported when using NonGenericEnums and NonGenericFlagEnums.
  • Deprecated many convenience method overloads as there were getting to be too many and will be removed in v4.0.
  • NonGenericEnumComparer and UnsafeEnumComparer were removed, use EnumComparer.GetInstance and EnumComparer<TEnum>.Instance instead. EnumComparer<TEnum>'s TEnum type argument is no longer constrained to struct, Enum to support this.
  • A few TryToObject overloads were removed due to there being too many convenience method overloads.