Skip to content

Commit dcd8c23

Browse files
committed
rollup merge of #18518 : bkoropoff/issue-18514
2 parents 6784051 + 09cc2f1 commit dcd8c23

File tree

3 files changed

+56
-1
lines changed

3 files changed

+56
-1
lines changed

src/librustc/middle/trans/common.rs

Lines changed: 5 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -502,7 +502,11 @@ impl<'blk, 'tcx> mc::Typer<'tcx> for BlockS<'blk, 'tcx> {
502502
}
503503

504504
fn node_method_ty(&self, method_call: typeck::MethodCall) -> Option<ty::t> {
505-
self.tcx().method_map.borrow().find(&method_call).map(|method| method.ty)
505+
self.tcx()
506+
.method_map
507+
.borrow()
508+
.find(&method_call)
509+
.map(|method| monomorphize_type(self, method.ty))
506510
}
507511

508512
fn adjustments<'a>(&'a self) -> &'a RefCell<NodeMap<ty::AutoAdjustment>> {

src/test/auxiliary/issue-18514.rs

Lines changed: 27 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,27 @@
1+
// Copyright 2014 The Rust Project Developers. See the COPYRIGHT
2+
// file at the top-level directory of this distribution and at
3+
// http://rust-lang.org/COPYRIGHT.
4+
//
5+
// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
6+
// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
7+
// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
8+
// option. This file may not be copied, modified, or distributed
9+
// except according to those terms.
10+
11+
#![crate_type = "rlib"]
12+
13+
pub trait Tr {
14+
fn tr(&self);
15+
}
16+
17+
pub struct St<V>(pub Vec<V>);
18+
19+
impl<V> Tr for St<V> {
20+
fn tr(&self) {
21+
match self {
22+
&St(ref v) => {
23+
v.iter();
24+
}
25+
}
26+
}
27+
}

src/test/run-pass/issue-18514.rs

Lines changed: 24 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,24 @@
1+
// Copyright 2012 The Rust Project Developers. See the COPYRIGHT
2+
// file at the top-level directory of this distribution and at
3+
// http://rust-lang.org/COPYRIGHT.
4+
//
5+
// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
6+
// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
7+
// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
8+
// option. This file may not be copied, modified, or distributed
9+
// except according to those terms.
10+
11+
// Test that we don't ICE when translating a generic impl method from
12+
// an extern crate that contains a match expression on a local
13+
// variable lvalue where one of the match case bodies contains an
14+
// expression that autoderefs through an overloaded generic deref
15+
// impl.
16+
17+
// aux-build:issue-18514.rs
18+
extern crate "issue-18514" as ice;
19+
use ice::{Tr, St};
20+
21+
fn main() {
22+
let st: St<()> = St(vec![]);
23+
st.tr();
24+
}

0 commit comments

Comments
 (0)