rust/tests/incremental/issue-92163-missing-sourcefile/issue_92163_main.rs

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

32 lines
1.1 KiB
Rust
Raw Normal View History

//@ aux-build:first_crate.rs
//@ aux-build:second_crate.rs
//@ revisions:rpass1 rpass2
// Regression test for issue #92163
// Under certain circumstances, we may end up trying to
// decode a foreign `Span` from the incremental cache, without previously
// having imported the `SourceFile`s from the owning crate. This can happen
// if the `Span` comes from a transitive dependency (so we never try to resolve
// items from the crate during expansion/resolution).
//
// Previously, this would result in an ICE, since we would not have loaded
// the corresponding `SourceFile` for the `StableSourceFileId` we decoded.
// This test verifies that the decoding of a foreign `Span` will always
// try to import the `SourceFile`s from the foreign crate, instead of
// relying on that having already happened during expansion.
extern crate second_crate;
pub struct Outer;
impl Outer {
pub fn use_it() {
// This returns `first_crate::Foo`, causing
// us to encode the `AdtDef `first_crate::Foo` (along with its `Span`s)
// into the query cache for the `TypeckResults` for this function.
second_crate::make_it();
}
}
fn main() {}