* Support phf crate for faster match on large enums * comment * add changelog entry * add tests, embed phf, and improve lowercase support * fix doc change * Refactor & support case insensitive with case sensitive phf match * more tests, some fixes of new implementation and prep for feature
10 KiB
Changelog
Unreleased
- #220. Add support for PHF in
EnumString
(opt-in runtime performance improvements for large enums as#[strum(use_phf)]
, requiresphf
feature and increases MSRV to1.46
)
0.24.0
-
#212. Fix some clippy lints
-
#209. Use
core
instead ofstd
in a few places. -
#206. Add
get_documentation()
toEnumMessage
. This provides the ability to get the doc comment for a variant. Currently, very little formatting is done. That is subject to change. Please do not abuse this feature. Rust docs are meant for developer documentation, not long messages for users. However, this may be useful in some situations so we've added support for it. -
#202. Add a missing doc comment
-
#201. Upgrade Heck version
0.23.1
-
#193 Fixes an ambiguity introduced by #186 when your enum has a variant called Error.
-
#192 The work done in #189 was lost in other PR's. This re-added the functionality to support no-std.
0.23.0
-
#185 Adds the
FromRepr
derive that adds afrom_repr(x: usize) -> Option<Self>
method to your enum. This lets you convert integer values to your enum. If you specify a #[repr(..)] attribute on your enum, or use an explicit discriminant, this will be incorporated into the derive.from_repr
will beconst
if you use a recent rust version.- This cannot be a trait method currently because only inherent methods support
const
.
-
#186 Automatically implement
TryFrom<str>
for enums that implementEnumString
. This is only enabled for rustc >= 1.34 which is when `TryFrom was stabilized.- This is a small breaking change. If you had manually implemented
TryFrom<str>
for your enum, this will cause a conflict. You can probably remove your manual implementation.
- This is a small breaking change. If you had manually implemented
-
#189 Use
core::result::Result
instead ofstd::result::Result
. This should be more portable in no-std environments.
0.22.0
-
#180: Deprecates
ToString
derive. You should useDisplay
instead. -
#178: Deprecates AsStaticStr. This has been undocumented for a while. The recommended method is to derive
IntoStaticStr
instead. -
#171: Improve
no-std
support. -
#170: enable changing the path to strum traits. This is necessary if you re-export strum as a submodule in another crate.
0.21.1
- #164 Improve compatibility with older versions of
syn
.
0.21.0
-
Replace
std::
withcore::
to support no-std projects. #145 -
Breaking Changes
- MSRV is updated to 1.32 because
heck
does not work in1.31.1
anymore. Rust 1.32 came out Jan 2019 so hopefully teams have moved to an equal or newer version. - #149 Remove the "rename" feature. In Rust 2018, macros should be
imported using a qualified path to avoid collisions.
strum_macros::EnumString
rather than using the "Rename" feature to avoid collisions. - #160 enum messages: Make the returned values all 'static
- It is unlikely this will break anyone, but the new signature for functions generated by EnumMessage
is
fn get_message(&self) -> Option<&'static str>
.
- It is unlikely this will break anyone, but the new signature for functions generated by EnumMessage
is
- MSRV is updated to 1.32 because
-
Added support for ascii_case_insensitive string comparisons. #157 This feature allows
FromString
impls to match strings that differ in case from the expected variant.
0.20.0
-
Refactors to do better error handling. Thanks @jplatte for these changes
-
Adding
vis(scope)
to EnumDiscriminants. #137- This feature works best with versions of rust >= 1.34 due to a rustc parsing error in earlier versions.
- Earlier versions can still use
vis(r#pub)
-
These changes should not be breaking, but the amount of code modified was significant.
-
FYI about #122. The macro renames feature will be removed in early 2021. This feature was only necessary in rust 2015 because macros didn't support qualified imports so macro names could collide between crates.
0.19.4 / 0.19.5
- Updated docs
0.19.3
- Properly error on malformed strum attributes. #119
- These types of inputs have historically been ignore silently. This may break code that is already incorrect.
- Move docs back to rust docs. #121
- Updated the docs a second time to improve discoverability.
0.19.2
0.19.1
- Breaking Change: EnumVariantNames now properly adjusts to the
to_string
andserialize
attributes. - There's a regression in this release that may make strum imcompatible with other plugins if those plugins use non-rust syntax in their attributes. #104
0.19.0
-
Fixed a regression using
nth_back
. #85 -
Added repository to Cargo.toml. #90
-
Correctly handle fill align in
Display
impls. #95 -
Breaking Change: Use Associated Constant for EnumCount instead of const fn and free constant. #99 This behavior is consistent with the other derives.
-
Breaking Change.
default
anddisabled
should now be written as markers instead of key value pairs. Here is the old way of adding these attributes to a variant.// OLD WAY enum Test { #[strum(disabled = "true", default = "true")] Variant(String) }
Here is the new way. There is less ambiguity in the new syntax.
enum Test { #[strum(disabled, default)] Variant(String) }
-
Breaking Change. Most of the strum plugins will now error more aggresively on invalid options being used. Historically, the plugins have ignore invalid options, but most of these should error now. Silent errors are a rust anti-pattern.
0.18.0
- Only copy across
"doc", "cfg", "allow", "deny"
attributes from main enum variants to discriminant variants. #73 - The formatting of generated serialization variants returned by
get_serializations()
from an enum that derivesEnumMessage
is now affected by theserialize_all
property on the enum. #84 - IntoEnumIterator now has the constraint
IntoEnumIterator::Iterator<Item=Self>
andSelf: Sized
. This makes it much easier to be generic overIntoEnumIterator
and enum variants must be sized. [#80]
0.17.1
0.17.0
- Breaking Change. Enum variant names now exports an associated constant
VARIANTS
in thestrum::VariantNames
trait instead of adding avariants
method directly to the enum. The fix is touse strum::VariantNames
in your module and replace occurrances ofvariants()
withVARIANTS
. - 🐛 fix - stop incrementing iterator index after we reach the end. #76
- Strum iterators now implemented DoubleEndedIterator. #60
0.16.0
- Added serialize UPPERCASE
- Added "case-styles" to match the formatting convention they imply such as
kebab-case
andcamelCase
. - Added Enum Variant Names to improve compatibility with
structopt
andclap
. #56 - Added derive re-export to
strum
to allow re-exporting macros from main crate. #57 - Bumped syn and quote to
1.0
. This raises minimal compatible rust version to1.31
. - Did internal refactoring to improve organization of code. Shouldn't change user-facing api though.
- Added license file to subdirectories so they are included in crate distros.
0.15.0
Added
- Added Feature flags to rename macros. This is to improve compatibility with older versions of rust. Wiki
0.14.0
Added
- Allow Missing Docs on EnumCount. PR #43
- Fix serialize_all in
AsRefStr
,AsStaticStr
andIntoStaticStr
. PR #42- This is a bug fix, but it may break code that was relying on the incorrect behavior.
0.13.0
Added
- Added a derive to implement
From<YourEnum>
for&'static str
. This deprecatesAsStaticStr
since the new solution doesn't require astrum
specific trait to use.
0.12.0
Added
- Serialization case can be controlled using
#[strum(serialize_all = "snake_case")]
. (#21) #[derive(EnumDiscriminants)]
generates enum with variants without fields. (#33)
0.10.0
Added
- Implemented
Clone
forEnumIter
s. (#18) - Added
AsStaticRef
derive to allow enums toimpl AsStaticRef<str>
. (#23)
Fixed
#[allow(missing_docs)]
on generatedEnumIter
s. (#19)