summaryrefslogtreecommitdiffstats
path: root/src/test/incremental/issue-92163-missing-sourcefile/issue_92163_main.rs
diff options
context:
space:
mode:
Diffstat (limited to 'src/test/incremental/issue-92163-missing-sourcefile/issue_92163_main.rs')
-rw-r--r--src/test/incremental/issue-92163-missing-sourcefile/issue_92163_main.rs31
1 files changed, 31 insertions, 0 deletions
diff --git a/src/test/incremental/issue-92163-missing-sourcefile/issue_92163_main.rs b/src/test/incremental/issue-92163-missing-sourcefile/issue_92163_main.rs
new file mode 100644
index 000000000..e9219c6f5
--- /dev/null
+++ b/src/test/incremental/issue-92163-missing-sourcefile/issue_92163_main.rs
@@ -0,0 +1,31 @@
+// 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() {}