forked from model-checking/verify-rust-std
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Rollup merge of rust-lang#128954 - zachs18:fromresidual-no-default, r…
…=scottmcm Explicitly specify type parameter on FromResidual for Option and ControlFlow. ~~Remove type parameter default `R = <Self as Try>::Residual` from `FromResidual`~~ _Specify default type parameter on `FromResidual` impls in the stdlib_ to work around rust-lang#99940 / rust-lang#87350 ~~as mentioned in rust-lang#84277 (comment). This does not completely fix the issue, but works around it for `Option` and `ControlFlow` specifically (`Result` does not have the issue since it already did not use the default parameter of `FromResidual`). ~~(Does this need an ACP or similar?)~~ ~~This probably needs at least an FCP since it changes the API described in [the RFC](rust-lang/rfcs#3058). Not sure if T-lang, T-libs-api, T-libs, or some combination (The tracking issue is tagged T-lang, T-libs-api).~~ This probably doesn't need T-lang input, since it is not changing the API of `FromResidual` from the RFC? Maybe needs T-libs-api FCP?
- Loading branch information
Showing
4 changed files
with
33 additions
and
2 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,26 @@ | ||
//! Regression test that Option and ControlFlow can have downstream FromResidual impls. | ||
//! cc https://github.com/rust-lang/rust/issues/99940, | ||
//! This does NOT test that issue in general; Option and ControlFlow's FromResidual | ||
//! impls in core were changed to not be affected by that issue. | ||
use core::ops::{ControlFlow, FromResidual}; | ||
|
||
struct Local; | ||
|
||
impl<T> FromResidual<Local> for Option<T> { | ||
fn from_residual(_: Local) -> Option<T> { | ||
unimplemented!() | ||
} | ||
} | ||
|
||
impl<B, C> FromResidual<Local> for ControlFlow<B, C> { | ||
fn from_residual(_: Local) -> ControlFlow<B, C> { | ||
unimplemented!() | ||
} | ||
} | ||
|
||
impl<T, E> FromResidual<Local> for Result<T, E> { | ||
fn from_residual(_: Local) -> Result<T, E> { | ||
unimplemented!() | ||
} | ||
} |