Auto merge of #28484 - nrc:fix-save, r=alexcrichton
Should be lowering ast expressions to HIR expressions, not cheating via the hir map. That goes wrong now that there is not a 1:1 mapping between ast and hir (in the case of the crash due to ExprParen).
This commit is contained in:
commit
6e5a325474
2 changed files with 5 additions and 5 deletions
|
@ -1097,7 +1097,7 @@ impl<'l, 'tcx, 'v> Visitor<'v> for DumpCsvVisitor<'l, 'tcx> {
|
||||||
|
|
||||||
self.visit_expr(&**sub_ex);
|
self.visit_expr(&**sub_ex);
|
||||||
|
|
||||||
let hir_node = self.tcx.map.expect_expr(sub_ex.id);
|
let hir_node = lower_expr(sub_ex);
|
||||||
let ty = &self.tcx.expr_ty_adjusted(&hir_node).sty;
|
let ty = &self.tcx.expr_ty_adjusted(&hir_node).sty;
|
||||||
match *ty {
|
match *ty {
|
||||||
ty::TyStruct(def, _) => {
|
ty::TyStruct(def, _) => {
|
||||||
|
|
|
@ -18,7 +18,7 @@ use std::path::{Path, PathBuf};
|
||||||
|
|
||||||
use rustc_front;
|
use rustc_front;
|
||||||
use rustc::front::map::NodeItem;
|
use rustc::front::map::NodeItem;
|
||||||
use rustc_front::hir;
|
use rustc_front::{hir, lowering};
|
||||||
|
|
||||||
use syntax::attr;
|
use syntax::attr;
|
||||||
use syntax::ast::{self, NodeId};
|
use syntax::ast::{self, NodeId};
|
||||||
|
@ -442,7 +442,7 @@ impl<'l, 'tcx: 'l> SaveContext<'l, 'tcx> {
|
||||||
pub fn get_expr_data(&self, expr: &ast::Expr) -> Option<Data> {
|
pub fn get_expr_data(&self, expr: &ast::Expr) -> Option<Data> {
|
||||||
match expr.node {
|
match expr.node {
|
||||||
ast::ExprField(ref sub_ex, ident) => {
|
ast::ExprField(ref sub_ex, ident) => {
|
||||||
let hir_node = self.tcx.map.expect_expr(sub_ex.id);
|
let hir_node = lowering::lower_expr(sub_ex);
|
||||||
let ty = &self.tcx.expr_ty_adjusted(&hir_node).sty;
|
let ty = &self.tcx.expr_ty_adjusted(&hir_node).sty;
|
||||||
match *ty {
|
match *ty {
|
||||||
ty::TyStruct(def, _) => {
|
ty::TyStruct(def, _) => {
|
||||||
|
@ -462,8 +462,8 @@ impl<'l, 'tcx: 'l> SaveContext<'l, 'tcx> {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
ast::ExprStruct(ref path, _, _) => {
|
ast::ExprStruct(ref path, _, _) => {
|
||||||
let hir_node = self.tcx.map.expect_expr(expr.id);
|
let hir_node = lowering::lower_expr(expr);
|
||||||
let ty = &self.tcx.expr_ty_adjusted(hir_node).sty;
|
let ty = &self.tcx.expr_ty_adjusted(&hir_node).sty;
|
||||||
match *ty {
|
match *ty {
|
||||||
ty::TyStruct(def, _) => {
|
ty::TyStruct(def, _) => {
|
||||||
let sub_span = self.span_utils.span_for_last_ident(path.span);
|
let sub_span = self.span_utils.span_for_last_ident(path.span);
|
||||||
|
|
Loading…
Reference in a new issue