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

fix(deps): update rust crate thiserror to v2 #384

Open
wants to merge 1 commit into
base: main
Choose a base branch
from

Conversation

renovate[bot]
Copy link
Contributor

@renovate renovate bot commented Nov 7, 2024

This PR contains the following updates:

Package Type Update Change
thiserror dependencies major 1.0.59 -> 2.0.0

Release Notes

dtolnay/thiserror (thiserror)

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.

    #[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)

    // 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)

    #[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, #​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's Error::source() (#​350)

    #[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)

    #[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)

    #[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)

    #[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),
    }

Configuration

📅 Schedule: Branch creation - At any time (no schedule defined), Automerge - At any time (no schedule defined).

🚦 Automerge: Disabled by config. Please merge this manually once you are satisfied.

Rebasing: Whenever PR is behind base branch, or you tick the rebase/retry checkbox.

🔕 Ignore: Close this PR and you won't be reminded about this update again.


  • If you want to rebase/retry this PR, check this box

This PR was generated by Mend Renovate. View the repository job log.

Copy link
Contributor Author

renovate bot commented Nov 7, 2024

⚠️ Artifact update problem

Renovate failed to update an artifact related to this branch. You probably do not want to merge this PR as-is.

♻ Renovate will retry this branch, including artifacts, only when one of the following happens:

  • any of the package files in this branch needs updating, or
  • the branch becomes conflicted, or
  • you click the rebase/retry checkbox if found above, or
  • you rename this PR's title to start with "rebase!" to trigger it manually

The artifact failure details are included below:

File name: Cargo.lock
Command failed: cargo update --config net.git-fetch-with-cli=true --manifest-path Cargo.toml --package [email protected] --precise 2.0.11
    Updating crates.io index
error: failed to select a version for the requirement `thiserror = "^1.0"`
candidate versions found which didn't match: 2.0.11
location searched: crates.io index
required by package `redox_users v0.4.6`
    ... which satisfies dependency `redox_users = "^0.4"` (locked to 0.4.6) of package `dirs-sys v0.4.1`
    ... which satisfies dependency `dirs-sys = "^0.4.1"` (locked to 0.4.1) of package `dirs v5.0.1`
    ... which satisfies dependency `dirs = "^5.0.1"` (locked to 5.0.1) of package `vpm-repos-gen v1.6.2 (/tmp/renovate/repos/github/koyashiro/vpm-repos-gen)`

@renovate renovate bot requested a review from koyashiro November 7, 2024 21:45
@renovate renovate bot force-pushed the renovate/thiserror-2.x branch 5 times, most recently from f0f8d5a to 9194188 Compare November 17, 2024 07:06
@renovate renovate bot force-pushed the renovate/thiserror-2.x branch 3 times, most recently from 7ac68c6 to fb78038 Compare November 24, 2024 13:39
@renovate renovate bot force-pushed the renovate/thiserror-2.x branch 2 times, most recently from b9c9e87 to 45ca8b7 Compare November 27, 2024 08:14
@renovate renovate bot force-pushed the renovate/thiserror-2.x branch 6 times, most recently from 60bbbca to 465d710 Compare December 9, 2024 03:44
@renovate renovate bot force-pushed the renovate/thiserror-2.x branch 3 times, most recently from 33d3e20 to 0d32387 Compare December 16, 2024 04:17
@renovate renovate bot force-pushed the renovate/thiserror-2.x branch 4 times, most recently from 3892ea5 to 700d4dd Compare December 28, 2024 02:09
@renovate renovate bot force-pushed the renovate/thiserror-2.x branch from 700d4dd to 78e77c6 Compare December 30, 2024 04:58
@renovate renovate bot force-pushed the renovate/thiserror-2.x branch 4 times, most recently from 7d64597 to 1b353f4 Compare January 9, 2025 21:26
@renovate renovate bot force-pushed the renovate/thiserror-2.x branch 2 times, most recently from 5b8a6a1 to 8dfd48b Compare January 19, 2025 09:51
@renovate renovate bot force-pushed the renovate/thiserror-2.x branch from 8dfd48b to 3433fcd Compare January 20, 2025 04:28
@renovate renovate bot force-pushed the renovate/thiserror-2.x branch from 3433fcd to b3dd024 Compare January 21, 2025 01:03
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

0 participants