Rollup merge of #33683 - sanxiyn:paren-span, r=nikomatsakis
Preserve span when lowering ExprKind::Paren Fix #33681.
This commit is contained in:
commit
5dc8dfa86f
@ -86,7 +86,7 @@ macro_rules! assert {
|
||||
#[stable(feature = "rust1", since = "1.0.0")]
|
||||
macro_rules! assert_eq {
|
||||
($left:expr , $right:expr) => ({
|
||||
match (&($left), &($right)) {
|
||||
match (&$left, &$right) {
|
||||
(left_val, right_val) => {
|
||||
if !(*left_val == *right_val) {
|
||||
panic!("assertion failed: `(left == right)` \
|
||||
|
@ -1286,8 +1286,12 @@ impl<'a> LoweringContext<'a> {
|
||||
maybe_expr.as_ref().map(|x| self.lower_expr(x)))
|
||||
}
|
||||
ExprKind::Paren(ref ex) => {
|
||||
// merge attributes into the inner expression.
|
||||
return self.lower_expr(ex).map(|mut ex| {
|
||||
// include parens in span, but only if it is a super-span.
|
||||
if e.span.contains(ex.span) {
|
||||
ex.span = e.span;
|
||||
}
|
||||
// merge attributes into the inner expression.
|
||||
ex.attrs.update(|attrs| {
|
||||
attrs.prepend(e.attrs.clone())
|
||||
});
|
||||
|
@ -81,11 +81,11 @@ impl FuncContainerOuter {
|
||||
fn run(&self) {
|
||||
unsafe {
|
||||
(*self.container).f1(1); //~ ERROR no method named `f1` found
|
||||
//~^ NOTE use `(*self.container.f1)(...)`
|
||||
//~^ NOTE use `((*self.container).f1)(...)`
|
||||
(*self.container).f2(1); //~ ERROR no method named `f2` found
|
||||
//~^ NOTE use `(*self.container.f2)(...)`
|
||||
//~^ NOTE use `((*self.container).f2)(...)`
|
||||
(*self.container).f3(1); //~ ERROR no method named `f3` found
|
||||
//~^ NOTE use `(*self.container.f3)(...)`
|
||||
//~^ NOTE use `((*self.container).f3)(...)`
|
||||
}
|
||||
}
|
||||
}
|
||||
|
31
src/test/compile-fail/paren-span.rs
Normal file
31
src/test/compile-fail/paren-span.rs
Normal file
@ -0,0 +1,31 @@
|
||||
// Copyright 2016 The Rust Project Developers. See the COPYRIGHT
|
||||
// file at the top-level directory of this distribution and at
|
||||
// http://rust-lang.org/COPYRIGHT.
|
||||
//
|
||||
// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
|
||||
// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
|
||||
// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
|
||||
// option. This file may not be copied, modified, or distributed
|
||||
// except according to those terms.
|
||||
|
||||
// Be smart about span of parenthesized expression in macro.
|
||||
|
||||
macro_rules! paren {
|
||||
($e:expr) => (($e))
|
||||
// ^^^^ do not highlight here
|
||||
}
|
||||
|
||||
mod m {
|
||||
pub struct S {
|
||||
x: i32
|
||||
}
|
||||
pub fn make() -> S {
|
||||
S { x: 0 }
|
||||
}
|
||||
}
|
||||
|
||||
fn main() {
|
||||
let s = m::make();
|
||||
paren!(s.x); //~ ERROR field `x` of struct `m::S` is private
|
||||
// ^^^ highlight here
|
||||
}
|
Loading…
x
Reference in New Issue
Block a user