Skip to content

Commit

Permalink
Add additional layer of #[track_caller] to test, avoid const prop.
Browse files Browse the repository at this point in the history
  • Loading branch information
anp committed Dec 7, 2019
1 parent 1c2483e commit 15d1f7c
Showing 1 changed file with 10 additions and 4 deletions.
14 changes: 10 additions & 4 deletions src/test/ui/rfc-2091-track-caller/caller-location-intrinsic.rs
Original file line number Diff line number Diff line change
Expand Up @@ -2,20 +2,26 @@

#![feature(track_caller)]

#[inline(never)]
#[track_caller]
fn defeat_const_prop() -> &'static core::panic::Location<'static> {
core::panic::Location::caller()
}

macro_rules! caller_location_from_macro {
() => (core::panic::Location::caller());
() => (defeat_const_prop());
}

fn main() {
let loc = core::panic::Location::caller();
let loc = defeat_const_prop();
assert_eq!(loc.file(), file!());
assert_eq!(loc.line(), 10);
assert_eq!(loc.line(), 16);
assert_eq!(loc.column(), 15);

// `Location::caller()` in a macro should behave similarly to `file!` and `line!`,
// i.e. point to where the macro was invoked, instead of the macro itself.
let loc2 = caller_location_from_macro!();
assert_eq!(loc2.file(), file!());
assert_eq!(loc2.line(), 17);
assert_eq!(loc2.line(), 23);
assert_eq!(loc2.column(), 16);
}

0 comments on commit 15d1f7c

Please sign in to comment.