diff options
| author | Ralf Jung <post@ralfj.de> | 2019-12-05 14:33:37 +0100 |
|---|---|---|
| committer | Ralf Jung <post@ralfj.de> | 2019-12-05 14:33:37 +0100 |
| commit | e822235323ba4f732bf2bb930d1a430b70ba5501 (patch) | |
| tree | fb3f63f4537273cecd3b0f00d2bdaa414596ec1c | |
| parent | 8655ad5936dda66a9123251c4c3fa43b7e5b80a4 (diff) | |
| download | rust-e822235323ba4f732bf2bb930d1a430b70ba5501.tar.gz rust-e822235323ba4f732bf2bb930d1a430b70ba5501.zip | |
add a test
| -rw-r--r-- | src/test/codegen/set-discriminant-invalid.rs | 43 |
1 files changed, 43 insertions, 0 deletions
diff --git a/src/test/codegen/set-discriminant-invalid.rs b/src/test/codegen/set-discriminant-invalid.rs new file mode 100644 index 00000000000..65e07fff1e4 --- /dev/null +++ b/src/test/codegen/set-discriminant-invalid.rs @@ -0,0 +1,43 @@ +// compile-flags: -C opt-level=0 +#![crate_type = "lib"] + +pub enum ApiError {} +#[allow(dead_code)] +pub struct TokioError { + b: bool, +} +pub enum Error { + Api { + source: ApiError, + }, + Ethereum, + Tokio { + source: TokioError, + }, +} +struct Api; +impl IntoError<Error> for Api +{ + type Source = ApiError; + // CHECK-LABEL: @into_error + // CHECK: unreachable + // Also check the next two instructions to make sure we do not match against `unreachable` + // elsewhere in the code (e.g., in the closure bode). + // CHECK-NEXT: load + // CHECK-NEXT: ret + #[no_mangle] + fn into_error(self, error: Self::Source) -> Error { + Error::Api { + source: (|v| v)(error), + } + } +} + +pub trait IntoError<E> +{ + /// The underlying error + type Source; + + /// Combine the information to produce the error + fn into_error(self, source: Self::Source) -> E; +} |
