Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
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
[PM-13660] implement catchable non generic error types #31
[PM-13660] implement catchable non generic error types #31
Changes from 47 commits
4b7ebf3
2706477
03dbeba
e45a994
97ff4ae
3393de9
9a9c59b
51b23ff
d164501
3f00e38
d868324
d6ee79d
8e91caf
eaf33e0
9d81fd8
e3aa732
fd86a64
e4be0ee
e9087d3
4fedaac
c3647ff
8e8b56b
e013203
eba5023
3224046
33e6bcd
e32f5b6
e8901c6
e4622fb
c2511b3
406c845
5c8f5ef
d144611
6843e4a
cb45b42
9d3999e
9139493
fa8d913
2017aea
60a5091
159f87b
1ef0bfe
1e6b2e7
5cfa4d0
7b627cb
5c74f88
7c051d6
e4ac54c
ebaaeef
a3db63f
e1fdbe4
7f9c7dc
2db85bf
6347bae
File filter
Filter by extension
Conversations
Jump to
There are no files selected for viewing
Large diffs are not rendered by default.
Check warning on line 14 in crates/bitwarden-core/src/client/encryption_settings.rs
Codecov / codecov/patch
crates/bitwarden-core/src/client/encryption_settings.rs#L14
Check warning on line 16 in crates/bitwarden-core/src/error.rs
Codecov / codecov/patch
crates/bitwarden-core/src/error.rs#L16
Check warning on line 3 in crates/bitwarden-error-macro/src/args.rs
Codecov / codecov/patch
crates/bitwarden-error-macro/src/args.rs#L3
Check warning on line 9 in crates/bitwarden-error-macro/src/args.rs
Codecov / codecov/patch
crates/bitwarden-error-macro/src/args.rs#L9
Check warning on line 13 in crates/bitwarden-error-macro/src/attribute.rs
Codecov / codecov/patch
crates/bitwarden-error-macro/src/attribute.rs#L12-L13
Check warning on line 20 in crates/bitwarden-error-macro/src/attribute.rs
Codecov / codecov/patch
crates/bitwarden-error-macro/src/attribute.rs#L19-L20
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
There's a bit of repetition with these lines for all the branches, can they be moved outside the match?
Also small subjective choice, but
variant_ident.to_string()
is the same asformat!("{}", variant_ident)
, but I think it looks nicerThere was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Good catch, I'll fix both!
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
When referring to types in macro generated code, we want to always use the fully qualified names, otherwise we're requiring users to import the correct type. If you're importing
prelude::*
that's not an issue, but nothing keeps the user from directly importing just the macro.Note that we also use
::
in front of the crate name, this is to avoid collisions with user defined modules using the same name.There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I did this for types that we depend on (e.g.
wasm-bindgen
) but never considered our own types, good catch!Check warning on line 62 in crates/bitwarden-error-macro/src/flat/attribute.rs
Codecov / codecov/patch
crates/bitwarden-error-macro/src/flat/attribute.rs#L60-L62
Check warning on line 12 in crates/bitwarden-error-macro/src/full/attribute.rs
Codecov / codecov/patch
crates/bitwarden-error-macro/src/full/attribute.rs#L10-L12