diff options
| author | Dylan MacKenzie <ecstaticmorse@gmail.com> | 2020-07-30 12:32:20 -0700 |
|---|---|---|
| committer | Dylan MacKenzie <ecstaticmorse@gmail.com> | 2020-07-30 13:09:45 -0700 |
| commit | 96c84ac3cbc4f2c81580893dacf263d00306649c (patch) | |
| tree | 920ca674695961ea1a2294885481df2c3c63b9fc | |
| parent | fc2c1f8ddc9a460c558741ae44b894faf3967f7c (diff) | |
| download | rust-96c84ac3cbc4f2c81580893dacf263d00306649c.tar.gz rust-96c84ac3cbc4f2c81580893dacf263d00306649c.zip | |
Test `Option::unwrap` in a const context
| -rw-r--r-- | src/test/ui/consts/const-unwrap.rs | 14 | ||||
| -rw-r--r-- | src/test/ui/consts/const-unwrap.stderr | 20 |
2 files changed, 34 insertions, 0 deletions
diff --git a/src/test/ui/consts/const-unwrap.rs b/src/test/ui/consts/const-unwrap.rs new file mode 100644 index 00000000000..6ed60ed87bf --- /dev/null +++ b/src/test/ui/consts/const-unwrap.rs @@ -0,0 +1,14 @@ +// check-fail + +#![feature(const_option)] + +const FOO: i32 = Some(42i32).unwrap(); + +// This causes an error, but it is attributed to the `panic` *inside* `Option::unwrap` (maybe due +// to `track_caller`?). A note points to the originating `const`. +const BAR: i32 = Option::<i32>::None.unwrap(); //~ NOTE + +fn main() { + println!("{}", FOO); + println!("{}", BAR); +} diff --git a/src/test/ui/consts/const-unwrap.stderr b/src/test/ui/consts/const-unwrap.stderr new file mode 100644 index 00000000000..7f2c1f41510 --- /dev/null +++ b/src/test/ui/consts/const-unwrap.stderr @@ -0,0 +1,20 @@ +error: any use of this value will cause an error + --> $SRC_DIR/core/src/option.rs:LL:COL + | +LL | None => panic!("called `Option::unwrap()` on a `None` value"), + | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + | | + | the evaluated program panicked at 'called `Option::unwrap()` on a `None` value', $DIR/const-unwrap.rs:9:38 + | inside `std::option::Option::<i32>::unwrap` at $SRC_DIR/core/src/macros/mod.rs:LL:COL + | inside `BAR` at $DIR/const-unwrap.rs:9:18 + | + ::: $DIR/const-unwrap.rs:9:1 + | +LL | const BAR: i32 = Option::<i32>::None.unwrap(); + | ---------------------------------------------- + | + = note: `#[deny(const_err)]` on by default + = note: this error originates in a macro (in Nightly builds, run with -Z macro-backtrace for more info) + +error: aborting due to previous error + |
