blob: 355d334585249bcc28e5c1ceb74250defd7547ae (
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
|
// revisions:rpass1 rpass2
// compile-flags: -Z query-dep-graph
// aux-build:cached_hygiene.rs
// This tests the following scenario
// 1. A foreign crate is compiled with incremental compilation.
// This causes hygiene information to be saved to the incr cache.
// 2. One function is the foreign crate is modified. This causes the
// optimized mir for an unmodified function to be loaded from the
// incremental cache and written out to the crate metadata.
// 3. In the process of loading and writing out this function's MIR,
// we load hygiene information from the incremental cache and
// write it to our metadata.
// 4. This hygiene information is loaded by another crate (this file)
// Previously, this situation would cause hygiene identifiers
// (SyntaxContexts and ExpnIds) to get corrupted when we tried to
// serialize the hygiene information loaded from the incr cache into
// the metadata. Specifically, we were not resetting `orig_id`
// for an `EpxnData` generate in the current crate, which would cause
// us to serialize the `ExpnId` pointing to a garbage location in
// the metadata.
#![feature(rustc_attrs)]
#![rustc_partition_reused(module="load_cached_hygiene-call_unchanged_function", cfg="rpass2")]
#![rustc_partition_codegened(module="load_cached_hygiene-call_changed_function", cfg="rpass2")]
extern crate cached_hygiene;
pub mod call_unchanged_function {
pub fn unchanged() {
cached_hygiene::unchanged_fn();
}
}
pub mod call_changed_function {
pub fn changed() {
cached_hygiene::changed_fn();
}
}
pub fn main() {
call_unchanged_function::unchanged();
call_changed_function::changed();
}
|