summaryrefslogtreecommitdiffstats
path: root/src/test/incremental/string_constant.rs
blob: cae7b4aab7565ed60455eec442a1a4de705760e2 (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
// revisions: cfail1 cfail2 cfail3 cfail4
// compile-flags: -Z query-dep-graph
// [cfail3]compile-flags: -Zincremental-relative-spans
// [cfail4]compile-flags: -Zincremental-relative-spans
// build-pass (FIXME(62277): could be check-pass?)

#![allow(warnings)]
#![feature(rustc_attrs)]
#![crate_type = "rlib"]

// Here the only thing which changes is the string constant in `x`.
// Therefore, the compiler deduces (correctly) that typeck is not
// needed even for callers of `x`.

pub mod x {
    #[cfg(any(cfail1, cfail3))]
    pub fn x() {
        println!("{}", "1");
    }

    #[cfg(any(cfail2, cfail4))]
    #[rustc_clean(except = "hir_owner,hir_owner_nodes,optimized_mir,promoted_mir", cfg = "cfail2")]
    #[rustc_clean(except = "hir_owner_nodes,promoted_mir", cfg = "cfail4")]
    pub fn x() {
        println!("{}", "2");
    }
}

pub mod y {
    use x;

    #[rustc_clean(cfg = "cfail2")]
    #[rustc_clean(cfg = "cfail4")]
    pub fn y() {
        x::x();
    }
}

pub mod z {
    use y;

    #[rustc_clean(cfg = "cfail2")]
    #[rustc_clean(cfg = "cfail4")]
    pub fn z() {
        y::y();
    }
}