summaryrefslogtreecommitdiffstats
path: root/src/test/ui/cleanup-shortcircuit.rs
blob: fe867ce1fbd57980ffbbb2d3132669c5e3a78a64 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
// run-pass
// Test that cleanups for the RHS of shortcircuiting operators work.

// pretty-expanded FIXME #23616

#![allow(deref_nullptr)]


use std::env;

pub fn main() {
    let args: Vec<String> = env::args().collect();

    // Here, the rvalue `"signal".to_string()` requires cleanup. Older versions
    // of the code had a problem that the cleanup scope for this
    // expression was the end of the `if`, and as the `"signal".to_string()`
    // expression was never evaluated, we wound up trying to clean
    // uninitialized memory.

    if args.len() >= 2 && args[1] == "signal" {
        // Raise a segfault.
        unsafe { *std::ptr::null_mut::<isize>() = 0; }
    }
}