diff options
| author | bors <bors@rust-lang.org> | 2020-07-27 03:47:17 +0000 |
|---|---|---|
| committer | bors <bors@rust-lang.org> | 2020-07-27 03:47:17 +0000 |
| commit | f721fb5933f130b7a5b72152dbacd298e9ee7f02 (patch) | |
| tree | c5c1c06dcbfc3a32c100edc97df0e9c7c13ddcba | |
| parent | fa36f960687c41caf5b260ab7610ebd83a7860dd (diff) | |
| parent | 4c710e72c42d988b09f7f3d877b1a280fdc46a49 (diff) | |
| download | rust-f721fb5933f130b7a5b72152dbacd298e9ee7f02.tar.gz rust-f721fb5933f130b7a5b72152dbacd298e9ee7f02.zip | |
Auto merge of #74784 - anp:track-vtables, r=eddyb
Fix #[track_caller] shims for trait objects. We were missing an Instance::resolve_for_fn_ptr in resolve_for_vtable. Closes #74764.
| -rw-r--r-- | src/librustc_middle/ty/instance.rs | 2 | ||||
| -rw-r--r-- | src/test/ui/rfc-2091-track-caller/tracked-trait-obj.rs | 23 |
2 files changed, 24 insertions, 1 deletions
diff --git a/src/librustc_middle/ty/instance.rs b/src/librustc_middle/ty/instance.rs index cdb883da32b..289a9db7327 100644 --- a/src/librustc_middle/ty/instance.rs +++ b/src/librustc_middle/ty/instance.rs @@ -389,7 +389,7 @@ impl<'tcx> Instance<'tcx> { debug!(" => associated item with unsizeable self: Self"); Some(Instance { def: InstanceDef::VtableShim(def_id), substs }) } else { - Instance::resolve(tcx, param_env, def_id, substs).ok().flatten() + Instance::resolve_for_fn_ptr(tcx, param_env, def_id, substs) } } diff --git a/src/test/ui/rfc-2091-track-caller/tracked-trait-obj.rs b/src/test/ui/rfc-2091-track-caller/tracked-trait-obj.rs new file mode 100644 index 00000000000..3b2a2238fa8 --- /dev/null +++ b/src/test/ui/rfc-2091-track-caller/tracked-trait-obj.rs @@ -0,0 +1,23 @@ +// run-pass + +trait Tracked { + #[track_caller] + fn handle(&self) { + let location = std::panic::Location::caller(); + assert_eq!(location.file(), file!()); + // we only call this via trait object, so the def site should *always* be returned + assert_eq!(location.line(), line!() - 4); + assert_eq!(location.column(), 5); + } +} + +impl Tracked for () {} +impl Tracked for u8 {} + +fn main() { + let tracked: &dyn Tracked = &5u8; + tracked.handle(); + + const TRACKED: &dyn Tracked = &(); + TRACKED.handle(); +} |
