-
Notifications
You must be signed in to change notification settings - Fork 2.5k
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
chore(deps): update rust crate thiserror to v2 #14998
Conversation
|
Thanks for the pull request, and welcome! The Rust team is excited to review your changes, and you should hear from @epage (or someone else) some time within the next two weeks. Please see the contribution instructions for more information. Namely, in order to ensure the minimum review times lag, PR authors and assigned reviewers should ensure that the review label (
|
a427ba0
to
13af53a
Compare
This PR contains the following updates: | Package | Type | Update | Change | |---|---|---|---| | [thiserror](https://redirect.github.com/dtolnay/thiserror) | workspace.dependencies | major | `1.0.63` -> `2.0.0` | --- ### Release Notes <details> <summary>dtolnay/thiserror (thiserror)</summary> ### [`v2.0.9`](https://redirect.github.com/dtolnay/thiserror/releases/tag/2.0.9) [Compare Source](https://redirect.github.com/dtolnay/thiserror/compare/2.0.8...2.0.9) - Work around `missing_inline_in_public_items` clippy restriction being triggered in macro-generated code ([#​404](https://redirect.github.com/dtolnay/thiserror/issues/404)) ### [`v2.0.8`](https://redirect.github.com/dtolnay/thiserror/releases/tag/2.0.8) [Compare Source](https://redirect.github.com/dtolnay/thiserror/compare/2.0.7...2.0.8) - Improve support for macro-generated `derive(Error)` call sites ([#​399](https://redirect.github.com/dtolnay/thiserror/issues/399)) ### [`v2.0.7`](https://redirect.github.com/dtolnay/thiserror/releases/tag/2.0.7) [Compare Source](https://redirect.github.com/dtolnay/thiserror/compare/2.0.6...2.0.7) - Work around conflict with #\[deny(clippy::allow_attributes)] ([#​397](https://redirect.github.com/dtolnay/thiserror/issues/397), thanks [@​zertosh](https://redirect.github.com/zertosh)) ### [`v2.0.6`](https://redirect.github.com/dtolnay/thiserror/releases/tag/2.0.6) [Compare Source](https://redirect.github.com/dtolnay/thiserror/compare/2.0.5...2.0.6) - Suppress deprecation warning on generated From impls ([#​396](https://redirect.github.com/dtolnay/thiserror/issues/396)) ### [`v2.0.5`](https://redirect.github.com/dtolnay/thiserror/releases/tag/2.0.5) [Compare Source](https://redirect.github.com/dtolnay/thiserror/compare/2.0.4...2.0.5) - Prevent deprecation warning on generated impl for deprecated type ([#​394](https://redirect.github.com/dtolnay/thiserror/issues/394)) ### [`v2.0.4`](https://redirect.github.com/dtolnay/thiserror/releases/tag/2.0.4) [Compare Source](https://redirect.github.com/dtolnay/thiserror/compare/2.0.3...2.0.4) - Eliminate needless_lifetimes clippy lint in generated `From` impls ([#​391](https://redirect.github.com/dtolnay/thiserror/issues/391), thanks [@​matt-phylum](https://redirect.github.com/matt-phylum)) ### [`v2.0.3`](https://redirect.github.com/dtolnay/thiserror/releases/tag/2.0.3) [Compare Source](https://redirect.github.com/dtolnay/thiserror/compare/2.0.2...2.0.3) - Support the same Path field being repeated in both Debug and Display representation in error message ([#​383](https://redirect.github.com/dtolnay/thiserror/issues/383)) - Improve error message when a format trait used in error message is not implemented by some field ([#​384](https://redirect.github.com/dtolnay/thiserror/issues/384)) ### [`v2.0.2`](https://redirect.github.com/dtolnay/thiserror/releases/tag/2.0.2) [Compare Source](https://redirect.github.com/dtolnay/thiserror/compare/2.0.1...2.0.2) - Fix hang on invalid input inside #\[error(...)] attribute ([#​382](https://redirect.github.com/dtolnay/thiserror/issues/382)) ### [`v2.0.1`](https://redirect.github.com/dtolnay/thiserror/releases/tag/2.0.1) [Compare Source](https://redirect.github.com/dtolnay/thiserror/compare/2.0.0...2.0.1) - Support errors that contain a dynamically sized final field ([#​375](https://redirect.github.com/dtolnay/thiserror/issues/375)) - Improve inference of trait bounds for fields that are interpolated multiple times in an error message ([#​377](https://redirect.github.com/dtolnay/thiserror/issues/377)) ### [`v2.0.0`](https://redirect.github.com/dtolnay/thiserror/releases/tag/2.0.0) [Compare Source](https://redirect.github.com/dtolnay/thiserror/compare/1.0.69...2.0.0) #### Breaking changes - Referencing keyword-named fields by a raw identifier like `{r#type}` inside a format string is no longer accepted; simply use the unraw name like `{type}` ([#​347](https://redirect.github.com/dtolnay/thiserror/issues/347)) This aligns thiserror with the standard library's formatting macros, which gained support for implicit argument capture later than the release of this feature in thiserror 1.x. ```rust #[derive(Error, Debug)] #[error("... {type} ...")] // Before: {r#type} pub struct Error { pub r#type: Type, } ``` - Trait bounds are no longer inferred on fields whose value is shadowed by an explicit named argument in a format message ([#​345](https://redirect.github.com/dtolnay/thiserror/issues/345)) ```rust // Before: impl<T: Octal> Display for Error<T> // After: impl<T> Display for Error<T> #[derive(Error, Debug)] #[error("{thing:o}", thing = "...")] pub struct Error<T> { thing: T, } ``` - Tuple structs and tuple variants can no longer use numerical `{0}` `{1}` access at the same time as supplying extra positional arguments for a format message, as this makes it ambiguous whether the number refers to a tuple field vs a different positional arg ([#​354](https://redirect.github.com/dtolnay/thiserror/issues/354)) ```rust #[derive(Error, Debug)] #[error("ambiguous: {0} {}", $N)] // ^^^ Not allowed, use #[error("... {0} {n}", n = $N)] pub struct TupleError(i32); ``` - Code containing invocations of thiserror's `derive(Error)` must now have a direct dependency on the `thiserror` crate regardless of the error data structure's contents ([#​368](https://redirect.github.com/dtolnay/thiserror/issues/368), [#​369](https://redirect.github.com/dtolnay/thiserror/issues/369), [#​370](https://redirect.github.com/dtolnay/thiserror/issues/370), [#​372](https://redirect.github.com/dtolnay/thiserror/issues/372)) #### Features - Support disabling thiserror's standard library dependency by disabling the default "std" Cargo feature: `thiserror = { version = "2", default-features = false }` ([#​373](https://redirect.github.com/dtolnay/thiserror/issues/373)) - Support using `r#source` as field name to opt out of a field named "source" being treated as an error's `Error::source()` ([#​350](https://redirect.github.com/dtolnay/thiserror/issues/350)) ```rust #[derive(Error, Debug)] #[error("{source} ==> {destination}")] pub struct Error { r#source: char, destination: char, } let error = Error { source: 'S', destination: 'D' }; ``` - Infinite recursion in a generated Display impl now produces an `unconditional_recursion` warning ([#​359](https://redirect.github.com/dtolnay/thiserror/issues/359)) ```rust #[derive(Error, Debug)] #[error("??? {self}")] pub struct Error; ``` - A new attribute `#[error(fmt = path::to::myfmt)]` can be used to write formatting logic for an enum variant out-of-line ([#​367](https://redirect.github.com/dtolnay/thiserror/issues/367)) ```rust #[derive(Error, Debug)] pub enum Error { #[error(fmt = demo_fmt)] Demo { code: u16, message: Option<String> }, } fn demo_fmt(code: &u16, message: &Option<String>, formatter: &mut fmt::Formatter) -> fmt::Result { write!(formatter, "{code}")?; if let Some(msg) = message { write!(formatter, " - {msg}")?; } Ok(()) } ``` - Enums with an enum-level format message are now able to have individual variants that are `transparent` to supersede the enum-level message ([#​366](https://redirect.github.com/dtolnay/thiserror/issues/366)) ```rust #[derive(Error, Debug)] #[error("my error {0}")] pub enum Error { Json(#[from] serde_json::Error), Yaml(#[from] serde_yaml::Error), #[error(transparent)] Other(#[from] anyhow::Error), } ``` ### [`v1.0.69`](https://redirect.github.com/dtolnay/thiserror/releases/tag/1.0.69) [Compare Source](https://redirect.github.com/dtolnay/thiserror/compare/1.0.68...1.0.69) - Backport [2.0.2](https://redirect.github.com/dtolnay/thiserror/releases/tag/2.0.2) fixes ### [`v1.0.68`](https://redirect.github.com/dtolnay/thiserror/releases/tag/1.0.68) [Compare Source](https://redirect.github.com/dtolnay/thiserror/compare/1.0.67...1.0.68) - Handle incomplete expressions more robustly in format arguments, such as while code is being typed ([#​341](https://redirect.github.com/dtolnay/thiserror/issues/341), [#​344](https://redirect.github.com/dtolnay/thiserror/issues/344)) ### [`v1.0.67`](https://redirect.github.com/dtolnay/thiserror/releases/tag/1.0.67) [Compare Source](https://redirect.github.com/dtolnay/thiserror/compare/1.0.66...1.0.67) - Improve expression syntax support inside format arguments ([#​335](https://redirect.github.com/dtolnay/thiserror/issues/335), [#​337](https://redirect.github.com/dtolnay/thiserror/issues/337), [#​339](https://redirect.github.com/dtolnay/thiserror/issues/339), [#​340](https://redirect.github.com/dtolnay/thiserror/issues/340)) ### [`v1.0.66`](https://redirect.github.com/dtolnay/thiserror/releases/tag/1.0.66) [Compare Source](https://redirect.github.com/dtolnay/thiserror/compare/1.0.65...1.0.66) - Improve compile error on malformed format attribute ([#​327](https://redirect.github.com/dtolnay/thiserror/issues/327)) ### [`v1.0.65`](https://redirect.github.com/dtolnay/thiserror/releases/tag/1.0.65) [Compare Source](https://redirect.github.com/dtolnay/thiserror/compare/1.0.64...1.0.65) - Ensure OUT_DIR is left with deterministic contents after build script execution ([#​325](https://redirect.github.com/dtolnay/thiserror/issues/325)) ### [`v1.0.64`](https://redirect.github.com/dtolnay/thiserror/releases/tag/1.0.64) [Compare Source](https://redirect.github.com/dtolnay/thiserror/compare/1.0.63...1.0.64) - Exclude derived impls from coverage instrumentation ([#​322](https://redirect.github.com/dtolnay/thiserror/issues/322), thanks [@​oxalica](https://redirect.github.com/oxalica)) </details> --- ### Configuration 📅 **Schedule**: Branch creation - "before 5am on the first day of the month" (UTC), Automerge - At any time (no schedule defined). 🚦 **Automerge**: Disabled by config. Please merge this manually once you are satisfied. ♻ **Rebasing**: Whenever PR becomes conflicted, or you tick the rebase/retry checkbox. 🔕 **Ignore**: Close this PR and you won't be reminded about this update again. --- - [ ] <!-- rebase-check -->If you want to rebase/retry this PR, check this box --- This PR was generated by [Mend Renovate](https://mend.io/renovate/). View the [repository job log](https://developer.mend.io/github/rust-lang/cargo). <!--renovate-debug:eyJjcmVhdGVkSW5WZXIiOiIzOS44NS4wIiwidXBkYXRlZEluVmVyIjoiMzkuODUuMCIsInRhcmdldEJyYW5jaCI6Im1hc3RlciIsImxhYmVscyI6W119-->
### What does this PR try to resolve? A follow-up of #14998 Other dev tools for cargo development are fine keeping v1. They are not shipped to end users. Before ``` $ cargo tree --workspace -i [email protected] thiserror v1.0.63 ├── cargo_metadata v0.19.0 │ └── capture v0.1.0 (/projects/cargo/benches/capture) ├── gix-lock v15.0.0 │ ├── gix v0.69.1 │ │ └── cargo v0.86.0 (/projects/cargo) │ │ ├── benchsuite v0.0.0 (/projects/cargo/benches/benchsuite) │ │ ├── resolver-tests v0.0.0 (/projects/cargo/crates/resolver-tests) │ │ ├── xtask-bump-check v0.0.0 (/projects/cargo/crates/xtask-bump-check) │ │ └── xtask-lint-docs v0.1.0 (/projects/cargo/crates/xtask-lint-docs) │ │ [dev-dependencies] │ │ └── cargo v0.86.0 (/projects/cargo) (*) │ ├── gix-index v0.37.0 │ │ ├── gix v0.69.1 (*) │ │ ├── gix-dir v0.11.0 │ │ │ └── gix v0.69.1 (*) │ │ └── gix-worktree v0.38.0 │ │ ├── gix v0.69.1 (*) │ │ └── gix-dir v0.11.0 (*) │ ├── gix-protocol v0.47.0 │ │ └── gix v0.69.1 (*) │ ├── gix-ref v0.49.1 │ │ ├── gix v0.69.1 (*) │ │ ├── gix-config v0.42.0 │ │ │ ├── gix v0.69.1 (*) │ │ │ └── gix-submodule v0.16.0 │ │ │ └── gix v0.69.1 (*) │ │ ├── gix-discover v0.37.0 │ │ │ ├── gix v0.69.1 (*) │ │ │ └── gix-dir v0.11.0 (*) │ │ └── gix-protocol v0.47.0 (*) │ └── gix-shallow v0.1.0 │ ├── gix v0.69.1 (*) │ └── gix-protocol v0.47.0 (*) ├── handlebars v6.2.0 │ └── mdman v0.0.0 (/projects/cargo/crates/mdman) ├── pest v2.7.9 │ ├── handlebars v6.2.0 (*) │ ├── pest_derive v2.7.9 (proc-macro) │ │ └── handlebars v6.2.0 (*) │ ├── pest_generator v2.7.9 │ │ └── pest_derive v2.7.9 (proc-macro) (*) │ └── pest_meta v2.7.9 │ └── pest_generator v2.7.9 (*) ├── varisat v0.2.2 │ └── resolver-tests v0.0.0 (/projects/cargo/crates/resolver-tests) ├── varisat-checker v0.2.2 │ └── varisat v0.2.2 (*) └── varisat-dimacs v0.2.2 ├── varisat v0.2.2 (*) └── varisat-checker v0.2.2 (*) ``` After ``` $ cargo tree --workspace -i [email protected] thiserror v1.0.63 ├── cargo_metadata v0.19.0 │ └── capture v0.1.0 (/projects/cargo/benches/capture) ├── handlebars v6.2.0 │ └── mdman v0.0.0 (/projects/cargo/crates/mdman) ├── pest v2.7.9 │ ├── handlebars v6.2.0 (*) │ ├── pest_derive v2.7.9 (proc-macro) │ │ └── handlebars v6.2.0 (*) │ ├── pest_generator v2.7.9 │ │ └── pest_derive v2.7.9 (proc-macro) (*) │ └── pest_meta v2.7.9 │ └── pest_generator v2.7.9 (*) ├── varisat v0.2.2 │ └── resolver-tests v0.0.0 (/projects/cargo/crates/resolver-tests) ├── varisat-checker v0.2.2 │ └── varisat v0.2.2 (*) └── varisat-dimacs v0.2.2 ├── varisat v0.2.2 (*) └── varisat-checker v0.2.2 (*) ``` ### How should we test and review this PR? It has nothing changed but thiserror version. https://diff.rs/gix-lock/15.0.0/gix-lock/15.0.1/Cargo.toml/
Update cargo 9 commits in d73d2caf9e41a39daf2a8d6ce60ec80bf354d2a7..fd784878cfa843e3e29a6654ecf564c62fae6735 2024-12-31 20:51:21 +0000 to 2025-01-03 20:06:26 +0000 - chore: bump gix-lock to remove thiserror@1 from `cargo` (rust-lang/cargo#15012) - refactor(manifest): Clean up field -> env var handling (rust-lang/cargo#15008) - chore(deps): update rust crate thiserror to v2 (rust-lang/cargo#14998) - test(git): Clean up shallow fetch tests (rust-lang/cargo#15002) - fix(schema): Correct and update the JSON Schema (rust-lang/cargo#15000) - chore(deps): update rust crate itertools to 0.14.0 (rust-lang/cargo#14996) - fix: env table config can't trigger rebuild with `rerun-if-env-changed`. (rust-lang/cargo#14756) - chore(deps): update alpine docker tag to v3.21 (rust-lang/cargo#14995) - fix(package): check dirtiness of symlinks source files (rust-lang/cargo#14981)
This PR contains the following updates:
1.0.63
->2.0.0
Release Notes
dtolnay/thiserror (thiserror)
v2.0.9
Compare Source
missing_inline_in_public_items
clippy restriction being triggered in macro-generated code (#404)v2.0.8
Compare Source
derive(Error)
call sites (#399)v2.0.7
Compare Source
v2.0.6
Compare Source
v2.0.5
Compare Source
v2.0.4
Compare Source
From
impls (#391, thanks @matt-phylum)v2.0.3
Compare Source
v2.0.2
Compare Source
v2.0.1
Compare Source
v2.0.0
Compare Source
Breaking changes
Referencing keyword-named fields by a raw identifier like
{r#type}
inside a format string is no longer accepted; simply use the unraw name like{type}
(#347)This aligns thiserror with the standard library's formatting macros, which gained support for implicit argument capture later than the release of this feature in thiserror 1.x.
Trait bounds are no longer inferred on fields whose value is shadowed by an explicit named argument in a format message (#345)
Tuple structs and tuple variants can no longer use numerical
{0}
{1}
access at the same time as supplying extra positional arguments for a format message, as this makes it ambiguous whether the number refers to a tuple field vs a different positional arg (#354)Code containing invocations of thiserror's
derive(Error)
must now have a direct dependency on thethiserror
crate regardless of the error data structure's contents (#368, #369, #370, #372)Features
Support disabling thiserror's standard library dependency by disabling the default "std" Cargo feature:
thiserror = { version = "2", default-features = false }
(#373)Support using
r#source
as field name to opt out of a field named "source" being treated as an error'sError::source()
(#350)Infinite recursion in a generated Display impl now produces an
unconditional_recursion
warning (#359)A new attribute
#[error(fmt = path::to::myfmt)]
can be used to write formatting logic for an enum variant out-of-line (#367)Enums with an enum-level format message are now able to have individual variants that are
transparent
to supersede the enum-level message (#366)v1.0.69
Compare Source
v1.0.68
Compare Source
v1.0.67
Compare Source
v1.0.66
Compare Source
v1.0.65
Compare Source
v1.0.64
Compare Source
Configuration
📅 Schedule: Branch creation - "before 5am on the first day of the month" (UTC), Automerge - At any time (no schedule defined).
🚦 Automerge: Disabled by config. Please merge this manually once you are satisfied.
♻ Rebasing: Whenever PR becomes conflicted, or you tick the rebase/retry checkbox.
🔕 Ignore: Close this PR and you won't be reminded about this update again.
This PR was generated by Mend Renovate. View the repository job log.