diff options
| author | bors <bors@rust-lang.org> | 2019-12-06 15:11:35 +0000 |
|---|---|---|
| committer | bors <bors@rust-lang.org> | 2019-12-06 15:11:35 +0000 |
| commit | 9630dbbc3caca60f2482e6eae8904aa6bda54f93 (patch) | |
| tree | 5deec471683d621f91208385425acc4a6b04713c /src/test/codegen | |
| parent | d0126e8ed3cc0d6fcb9dd44c36a46f9ce65010a0 (diff) | |
| parent | 931be6c3bccc38be9052433c321f11da033c57c5 (diff) | |
| download | rust-9630dbbc3caca60f2482e6eae8904aa6bda54f93.tar.gz rust-9630dbbc3caca60f2482e6eae8904aa6bda54f93.zip | |
Auto merge of #67091 - JohnTitor:rollup-kitphze, r=JohnTitor
Rollup of 11 pull requests
Successful merges:
- #66846 (Make try_mark_previous_green aware of cycles.)
- #66959 (Remove potential cfgs duplicates)
- #66988 (Fix angle bracket formatting when dumping MIR debug vars)
- #66998 (Modified the testcases for VxWorks)
- #67008 (rustdoc: Add test for fixed issue)
- #67023 (SGX: Fix target linker used by bootstrap)
- #67033 (Migrate to LLVM{Get,Set}ValueName2)
- #67049 (Simplify {IoSlice, IoSliceMut}::advance examples and tests)
- #67054 (codegen "unreachable" for invalid SetDiscriminant)
- #67081 (Fix Query type docs)
- #67085 (Remove boxed closures in address parser.)
Failed merges:
r? @ghost
Diffstat (limited to 'src/test/codegen')
| -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..d9614f062b7 --- /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: llvm.trap() + // Also check the next two instructions to make sure we do not match against `trap` + // elsewhere in the code. + // 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; +} |
