diff options
| author | bors <bors@rust-lang.org> | 2019-05-13 10:57:59 +0000 |
|---|---|---|
| committer | bors <bors@rust-lang.org> | 2019-05-13 10:57:59 +0000 |
| commit | a9ec99f4201ec33026a468ef1289f98a95b4d71a (patch) | |
| tree | 5fcc9cf3f251b57c981556394a4ca8180d39b8ed | |
| parent | 69ef8fbe7084f40893252df9fa47298b0a5c5057 (diff) | |
| parent | 0af18eed107f8b5d113e7d8e33f9182e37f0996b (diff) | |
| download | rust-a9ec99f4201ec33026a468ef1289f98a95b4d71a.tar.gz rust-a9ec99f4201ec33026a468ef1289f98a95b4d71a.zip | |
Auto merge of #60649 - Xanewok:save-analysis-assoc-const-ice, r=oli-obk
save-analysis: Fix ICE when processing associated constant Closes #59134 Closes https://github.com/rust-lang/rls/issues/1449 Thanks @swgillespie for helping tracking this down and fixing it! r? @eddyb
| -rw-r--r-- | src/librustc_save_analysis/dump_visitor.rs | 10 | ||||
| -rw-r--r-- | src/test/ui/save-analysis/issue-59134-0.rs | 12 | ||||
| -rw-r--r-- | src/test/ui/save-analysis/issue-59134-0.stderr | 9 | ||||
| -rw-r--r-- | src/test/ui/save-analysis/issue-59134-1.rs | 12 | ||||
| -rw-r--r-- | src/test/ui/save-analysis/issue-59134-1.stderr | 9 |
5 files changed, 48 insertions, 4 deletions
diff --git a/src/librustc_save_analysis/dump_visitor.rs b/src/librustc_save_analysis/dump_visitor.rs index a45e32ddb66..1e65f868eba 100644 --- a/src/librustc_save_analysis/dump_visitor.rs +++ b/src/librustc_save_analysis/dump_visitor.rs @@ -463,10 +463,12 @@ impl<'l, 'tcx: 'l, 'll, O: DumpOutput + 'll> DumpVisitor<'l, 'tcx, 'll, O> { } // walk type and init value - self.visit_ty(typ); - if let Some(expr) = expr { - self.visit_expr(expr); - } + self.nest_tables(id, |v| { + v.visit_ty(typ); + if let Some(expr) = expr { + v.visit_expr(expr); + } + }); } // FIXME tuple structs should generate tuple-specific data. diff --git a/src/test/ui/save-analysis/issue-59134-0.rs b/src/test/ui/save-analysis/issue-59134-0.rs new file mode 100644 index 00000000000..3158328b3ff --- /dev/null +++ b/src/test/ui/save-analysis/issue-59134-0.rs @@ -0,0 +1,12 @@ +// compile-flags: -Zsave-analysis + +// Check that this doesn't ICE when processing associated const (field expr). + +pub fn f() { + trait Trait {} + impl Trait { + const FLAG: u32 = bogus.field; //~ ERROR cannot find value `bogus` + } +} + +fn main() {} diff --git a/src/test/ui/save-analysis/issue-59134-0.stderr b/src/test/ui/save-analysis/issue-59134-0.stderr new file mode 100644 index 00000000000..4e9b2e6fdeb --- /dev/null +++ b/src/test/ui/save-analysis/issue-59134-0.stderr @@ -0,0 +1,9 @@ +error[E0425]: cannot find value `bogus` in this scope + --> $DIR/issue-59134-0.rs:8:27 + | +LL | const FLAG: u32 = bogus.field; + | ^^^^^ not found in this scope + +error: aborting due to previous error + +For more information about this error, try `rustc --explain E0425`. diff --git a/src/test/ui/save-analysis/issue-59134-1.rs b/src/test/ui/save-analysis/issue-59134-1.rs new file mode 100644 index 00000000000..3cb629777a4 --- /dev/null +++ b/src/test/ui/save-analysis/issue-59134-1.rs @@ -0,0 +1,12 @@ +// compile-flags: -Zsave-analysis + +// Check that this doesn't ICE when processing associated const (type). + +fn func() { + trait Trait { + type MyType; + const CONST: Self::MyType = bogus.field; //~ ERROR cannot find value `bogus` + } +} + +fn main() {} diff --git a/src/test/ui/save-analysis/issue-59134-1.stderr b/src/test/ui/save-analysis/issue-59134-1.stderr new file mode 100644 index 00000000000..bdc335eaac0 --- /dev/null +++ b/src/test/ui/save-analysis/issue-59134-1.stderr @@ -0,0 +1,9 @@ +error[E0425]: cannot find value `bogus` in this scope + --> $DIR/issue-59134-1.rs:8:37 + | +LL | const CONST: Self::MyType = bogus.field; + | ^^^^^ not found in this scope + +error: aborting due to previous error + +For more information about this error, try `rustc --explain E0425`. |
