summaryrefslogtreecommitdiffstats
path: root/tests/ui/borrowck/slice-index-bounds-check-invalidation.rs
blob: 0e0e3cda6e2edbf6580ac7fc3a3a8a71a187660f (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
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
// Test that we error if a slice is modified after it has been bounds checked
// and before we actually index it.

fn modify_before_assert_slice_slice(x: &[&[i32]]) -> i32 {
    let mut x = x;
    let z: &[i32] = &[1, 2, 3];
    let y: &[&[i32]] = &[z];
    x[{ x = y; 0 }][2]              // OK we haven't checked any bounds before we index `x`.
}

fn modify_before_assert_array_slice(x: &[&[i32]; 3]) -> i32 {
    let mut x = x;
    let z: &[i32] = &[1, 2, 3];
    let y: &[&[i32]; 3] = &[z, z, z];
    x[{ x = y; 0 }][2]              // OK we haven't checked any bounds before we index `x`.
}

fn modify_before_assert_slice_array(x: &[&[i32; 3]]) -> i32 {
    let mut x = x;
    let z: &[i32; 3] = &[1, 2, 3];
    let y: &[&[i32; 3]] = &[z];
    x[{ x = y; 0 }][2]              // OK we haven't checked any bounds before we index `x`.
}

fn modify_before_assert_array_array(x: &[&[i32; 3]; 3]) -> i32 {
    let mut x = x;
    let z: &[i32; 3] = &[1, 2, 3];
    let y: &[&[i32; 3]; 3] = &[z, z, z];
    x[{ x = y; 0 }][2]              // OK we haven't checked any bounds before we index `x`.
}

fn modify_after_assert_slice_slice(x: &[&[i32]]) -> i32 {
    let mut x = x;
    let z: &[i32] = &[1, 2, 3];
    let y: &[&[i32]] = &[&z];
    x[1][{ x = y; 2}]               //~ ERROR cannot assign `x` in indexing expression
}

fn modify_after_assert_array_slice(x: &[&[i32]; 1]) -> i32 {
    let mut x = x;
    let z: &[i32] = &[1, 2, 3];
    let y: &[&[i32]; 1] = &[&z];
    x[0][{ x = y; 2}]               // OK cannot invalidate a fixed-size array bounds check
}

fn modify_after_assert_slice_array(x: &[&[i32; 3]]) -> i32 {
    let mut x = x;
    let z: &[i32; 3] = &[1, 2, 3];
    let y: &[&[i32; 3]] = &[&z];
    x[1][{ x = y; 2}]               //~ ERROR cannot assign `x` in indexing expression
}

fn modify_after_assert_array_array(x: &[&[i32; 3]; 1]) -> i32 {
    let mut x = x;
    let z: &[i32; 3] = &[1, 2, 3];
    let y: &[&[i32; 3]; 1] = &[&z];
    x[0][{ x = y; 2}]               // OK cannot invalidate a fixed-size array bounds check
}

fn modify_after_assert_slice_slice_array(x: &[&[[i32; 1]]]) -> i32 {
    let mut x = x;
    let z: &[[i32; 1]] = &[[1], [2], [3]];
    let y: &[&[[i32; 1]]] = &[&z];
    x[1][{ x = y; 2}][0]            //~ ERROR cannot assign `x` in indexing expression
}

fn modify_after_assert_slice_slice_slice(x: &[&[&[i32]]]) -> i32 {
    let mut x = x;
    let z: &[&[i32]] = &[&[1], &[2], &[3]];
    let y: &[&[&[i32]]] = &[z];
    x[1][{ x = y; 2}][0]            //~ ERROR cannot assign `x` in indexing expression
}


fn main() {
    println!("{}", modify_after_assert_slice_array(&[&[4, 5, 6], &[9, 10, 11]]));
    println!("{}", modify_after_assert_slice_slice(&[&[4, 5, 6], &[9, 10, 11]]));
    println!("{}", modify_after_assert_slice_slice_array(&[&[[4], [5], [6]], &[[9], [10], [11]]]));
    println!("{}", modify_after_assert_slice_slice_slice(
        &[&[&[4], &[5], &[6]], &[&[9], &[10], &[11]]]),
    );
}