Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Redesign From derive macro #241

Merged
merged 45 commits into from
Jul 5, 2023
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
45 commits
Select commit Hold shift + click to select a range
518c1b1
WIP
ilslv Feb 9, 2023
99cb368
Add tests
ilslv Feb 10, 2023
a062ce1
Add tests
ilslv Feb 10, 2023
7f24761
Docs and clippy
ilslv Feb 10, 2023
845558e
Fix unit tests
ilslv Feb 10, 2023
6211b1a
Docs
ilslv Feb 10, 2023
e5ef86e
Port compile_fail tests from `Display` derive macro
ilslv Feb 10, 2023
8c8f9ca
More compile_fail tests
ilslv Feb 10, 2023
6e82741
CHANGELOG
ilslv Feb 10, 2023
7080be8
Reimplement `core::fmt::DebugTuple` to add support for `finish_non_ex…
ilslv Feb 13, 2023
20a0cb0
Docs fmt corrections
ilslv Feb 13, 2023
8c58553
Minor correction
ilslv Feb 13, 2023
5a8cf3a
Minor correction
ilslv Feb 13, 2023
558c2f0
Minor corrections [skip ci]
tyranron Feb 14, 2023
819454e
Restructure the modules and guard `Debug` under a separate `debug` fe…
ilslv Feb 16, 2023
aa2d332
Implement `syn::Type` parsing
ilslv Feb 17, 2023
20d107e
Simplify `syn::Type` parsing with assumptions
ilslv Feb 17, 2023
ea8e31c
Attributes parsing
ilslv Feb 20, 2023
50135d4
Merge branch 'master' into from-attribute
ilslv Mar 7, 2023
0b6ca7b
WIP
ilslv Mar 7, 2023
ce2cd00
WIP
ilslv Mar 7, 2023
61f1a16
WIP
ilslv Mar 8, 2023
0d489d6
Implementation that covers all existing test cases
ilslv Mar 9, 2023
382f185
Exhaustively cover struct with unit tests
ilslv Mar 9, 2023
eac8e27
Exhaustively cover enum and generics with unit tests
ilslv Mar 9, 2023
1ee8c09
More unit tests for generic structs
ilslv Mar 9, 2023
ef8fa47
More unit tests for generic enums
ilslv Mar 10, 2023
f4f874b
More unit tests for generics
ilslv Mar 10, 2023
7df415e
More unit tests for generics
ilslv Mar 10, 2023
87e1058
More unit tests for generics
ilslv Mar 10, 2023
eaa3596
Add compile fail tests
ilslv Mar 10, 2023
ff47628
Skip variants without attributes if another variant has `#[from]` or …
ilslv Mar 10, 2023
9680277
Docs
ilslv Mar 10, 2023
e5f6540
Docs
ilslv Mar 10, 2023
295eb0d
Docs and corrections
ilslv Mar 10, 2023
60430f7
Merge branch 'master' into from-attribute
ilslv Mar 10, 2023
c5b1f77
Clippy
ilslv Mar 10, 2023
14e8361
Corrections
ilslv Mar 10, 2023
1d74fdf
Corrections and changelog
ilslv Mar 10, 2023
249a92c
Corrections
ilslv Mar 10, 2023
4006a78
Merge branch 'master' into from-attribute
ilslv Jul 5, 2023
ebf41ed
Corrections
ilslv Jul 5, 2023
ea0cd04
Merge branch 'master' into from-attribute
ilslv Jul 5, 2023
a78f124
Merge branch 'master' into from-attribute
tyranron Jul 5, 2023
ec48a37
Minor corrections
tyranron Jul 5, 2023
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 2 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -31,6 +31,8 @@ and this project adheres to [Semantic Versioning](http://semver.org/).
- The `From` derive doesn't derive `From<()>` for enum variants without any
fields anymore. This feature was removed because it was considered useless in
practice.
- The `From` derive now uses `#[from(<types>)]` instead of `#[from(types(<types>))]`
and ignores field type itself.
Comment on lines +34 to +35
Copy link
Owner

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Hmm, I didn't realize this changed until I read this changelog entry. Sorry for not noticing earlier, because it's indeed in the PR description. But I don't think we should remove the types wrapper itself. This will make it hard for us to add new sub-attributes to the from attribute in a backwards compatible manner in the future, because although unlikely they might conflict with type names.

Copy link
Owner

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

To be clear this comment was about removing the types wrapper. "Ignoring the field type itself" I'm also not a huge fan of, but I think that's fine.


### Added

Expand Down
3 changes: 2 additions & 1 deletion Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -33,6 +33,7 @@ rustc_version = { version = "0.4", optional = true }

[dev-dependencies]
rustversion = "1.0"
static_assertions = "1.1"
trybuild = "1.0.56"

[badges]
Expand Down Expand Up @@ -229,7 +230,7 @@ required-features = ["try_unwrap"]
[[test]]
name = "compile_fail"
path = "tests/compile_fail/mod.rs"
required-features = ["debug", "display"]
required-features = ["debug", "display", "from"]

[[test]]
name = "no_std"
Expand Down
Loading