about summary refs log tree commit diff
path: root/tests/ui-fulldeps/internal-lints/query_stability.rs
blob: 92c1d6bf7f8e9e00d37437730046fe9f1f1f5dfa (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
//@ compile-flags: -Z unstable-options
//@ ignore-stage1

#![feature(rustc_private)]
#![deny(rustc::potential_query_instability)]

extern crate rustc_data_structures;

use rustc_data_structures::fx::{FxHashMap, FxHashSet};

fn main() {
    let mut x = FxHashMap::<u32, i32>::default();

    for _ in x.drain() {}
    //~^ ERROR using `drain` can result in unstable

    for _ in x.iter() {}
    //~^ ERROR using `iter`

    for _ in Some(&mut x).unwrap().iter_mut() {}
    //~^ ERROR using `iter_mut`

    for _ in x {}
    //~^ ERROR using `into_iter`

    let x = FxHashMap::<u32, i32>::default();
    let _ = x.keys();
    //~^ ERROR using `keys` can result in unstable query results

    let _ = x.values();
    //~^ ERROR using `values` can result in unstable query results

    let mut x = FxHashMap::<u32, i32>::default();
    for val in x.values_mut() {
        //~^ ERROR using `values_mut` can result in unstable query results
        *val = *val + 10;
    }

    FxHashMap::<u32, i32>::default().extend(x);
    //~^ ERROR using `into_iter` can result in unstable query results
}

fn hide_into_iter<T>(x: impl IntoIterator<Item = T>) -> impl Iterator<Item = T> {
    x.into_iter()
}

fn take(map: std::collections::HashMap<i32, i32>) {
    _ = hide_into_iter(map);
    //~^ ERROR using `into_iter` can result in unstable query results
}