Skip to content

Commit

Permalink
Auto merge of #114841 - bvanjoi:fix-114814, r=cuviper
Browse files Browse the repository at this point in the history
add track_caller for arith ops

Fixes #114814

`#[track_caller]` is works, r? `@scottmcm`
  • Loading branch information
bors committed Nov 29, 2023
2 parents bbefc98 + fc87d6e commit b1e56de
Show file tree
Hide file tree
Showing 16 changed files with 95 additions and 4 deletions.
4 changes: 4 additions & 0 deletions library/core/src/internal_macros.rs
Original file line number Diff line number Diff line change
Expand Up @@ -31,6 +31,7 @@ macro_rules! forward_ref_binop {
type Output = <$t as $imp<$u>>::Output;

#[inline]
#[track_caller]
fn $method(self, other: $u) -> <$t as $imp<$u>>::Output {
$imp::$method(*self, other)
}
Expand All @@ -41,6 +42,7 @@ macro_rules! forward_ref_binop {
type Output = <$t as $imp<$u>>::Output;

#[inline]
#[track_caller]
fn $method(self, other: &$u) -> <$t as $imp<$u>>::Output {
$imp::$method(self, *other)
}
Expand All @@ -51,6 +53,7 @@ macro_rules! forward_ref_binop {
type Output = <$t as $imp<$u>>::Output;

#[inline]
#[track_caller]
fn $method(self, other: &$u) -> <$t as $imp<$u>>::Output {
$imp::$method(*self, *other)
}
Expand All @@ -69,6 +72,7 @@ macro_rules! forward_ref_op_assign {
#[$attr]
impl $imp<&$u> for $t {
#[inline]
#[track_caller]
fn $method(&mut self, other: &$u) {
$imp::$method(self, *other);
}
Expand Down
10 changes: 10 additions & 0 deletions library/core/src/ops/arith.rs
Original file line number Diff line number Diff line change
Expand Up @@ -98,6 +98,7 @@ macro_rules! add_impl {
type Output = $t;

#[inline]
#[track_caller]
#[rustc_inherit_overflow_checks]
fn add(self, other: $t) -> $t { self + other }
}
Expand Down Expand Up @@ -206,6 +207,7 @@ macro_rules! sub_impl {
type Output = $t;

#[inline]
#[track_caller]
#[rustc_inherit_overflow_checks]
fn sub(self, other: $t) -> $t { self - other }
}
Expand Down Expand Up @@ -335,6 +337,7 @@ macro_rules! mul_impl {
type Output = $t;

#[inline]
#[track_caller]
#[rustc_inherit_overflow_checks]
fn mul(self, other: $t) -> $t { self * other }
}
Expand Down Expand Up @@ -474,6 +477,7 @@ macro_rules! div_impl_integer {
type Output = $t;

#[inline]
#[track_caller]
fn div(self, other: $t) -> $t { self / other }
}

Expand Down Expand Up @@ -575,6 +579,7 @@ macro_rules! rem_impl_integer {
type Output = $t;

#[inline]
#[track_caller]
fn rem(self, other: $t) -> $t { self % other }
}

Expand Down Expand Up @@ -749,6 +754,7 @@ macro_rules! add_assign_impl {
#[stable(feature = "op_assign_traits", since = "1.8.0")]
impl AddAssign for $t {
#[inline]
#[track_caller]
#[rustc_inherit_overflow_checks]
fn add_assign(&mut self, other: $t) { *self += other }
}
Expand Down Expand Up @@ -815,6 +821,7 @@ macro_rules! sub_assign_impl {
#[stable(feature = "op_assign_traits", since = "1.8.0")]
impl SubAssign for $t {
#[inline]
#[track_caller]
#[rustc_inherit_overflow_checks]
fn sub_assign(&mut self, other: $t) { *self -= other }
}
Expand Down Expand Up @@ -872,6 +879,7 @@ macro_rules! mul_assign_impl {
#[stable(feature = "op_assign_traits", since = "1.8.0")]
impl MulAssign for $t {
#[inline]
#[track_caller]
#[rustc_inherit_overflow_checks]
fn mul_assign(&mut self, other: $t) { *self *= other }
}
Expand Down Expand Up @@ -929,6 +937,7 @@ macro_rules! div_assign_impl {
#[stable(feature = "op_assign_traits", since = "1.8.0")]
impl DivAssign for $t {
#[inline]
#[track_caller]
fn div_assign(&mut self, other: $t) { *self /= other }
}

Expand Down Expand Up @@ -989,6 +998,7 @@ macro_rules! rem_assign_impl {
#[stable(feature = "op_assign_traits", since = "1.8.0")]
impl RemAssign for $t {
#[inline]
#[track_caller]
fn rem_assign(&mut self, other: $t) { *self %= other }
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@
let mut _3: u8;
scope 1 {
}
scope 2 (inlined <u8 as Add>::add) {
scope 2 (inlined #[track_caller] <u8 as Add>::add) {
debug self => _2;
debug other => _3;
let mut _4: (u8, bool);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@
let mut _3: u8;
scope 1 {
}
scope 2 (inlined <u8 as Add>::add) {
scope 2 (inlined #[track_caller] <u8 as Add>::add) {
debug self => _2;
debug other => _3;
let mut _4: (u8, bool);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@
let mut _3: u8;
scope 1 {
}
scope 2 (inlined <u8 as Add>::add) {
scope 2 (inlined #[track_caller] <u8 as Add>::add) {
debug self => _2;
debug other => _3;
let mut _4: (u8, bool);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@
let mut _3: u8;
scope 1 {
}
scope 2 (inlined <u8 as Add>::add) {
scope 2 (inlined #[track_caller] <u8 as Add>::add) {
debug self => _2;
debug other => _3;
let mut _4: (u8, bool);
Expand Down
8 changes: 8 additions & 0 deletions tests/ui/numbers-arithmetic/location-add-assign-overflow.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
// run-fail
// ignore-wasm32
// error-pattern:location-add-assign-overflow.rs

fn main() {
let mut a: u8 = 255;
a += &1;
}
7 changes: 7 additions & 0 deletions tests/ui/numbers-arithmetic/location-add-overflow.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
// run-fail
// ignore-wasm32
// error-pattern:location-add-overflow.rs

fn main() {
let _: u8 = 255 + &1;
}
8 changes: 8 additions & 0 deletions tests/ui/numbers-arithmetic/location-divide-assign-by-zero.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
// run-fail
// ignore-wasm32
// error-pattern:location-divide-assign-by-zero.rs

fn main() {
let mut a = 1;
a /= &0;
}
9 changes: 9 additions & 0 deletions tests/ui/numbers-arithmetic/location-divide-by-zero.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
// run-fail
// ignore-wasm32
// error-pattern:location-divide-by-zero.rs

// https://github.com/rust-lang/rust/issues/114814

fn main() {
let _ = 1 / &0;
}
8 changes: 8 additions & 0 deletions tests/ui/numbers-arithmetic/location-mod-assign-by-zero.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
// run-fail
// ignore-wasm32
// error-pattern:location-mod-assign-by-zero.rs

fn main() {
let mut a = 1;
a %= &0;
}
7 changes: 7 additions & 0 deletions tests/ui/numbers-arithmetic/location-mod-by-zero.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
// run-fail
// ignore-wasm32
// error-pattern:location-mod-by-zero.rs

fn main() {
let _ = 1 % &0;
}
8 changes: 8 additions & 0 deletions tests/ui/numbers-arithmetic/location-mul-assign-overflow.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
// run-fail
// ignore-wasm32
// error-pattern:location-mul-assign-overflow.rs

fn main() {
let mut a: u8 = 255;
a *= &2;
}
7 changes: 7 additions & 0 deletions tests/ui/numbers-arithmetic/location-mul-overflow.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
// run-fail
// ignore-wasm32
// error-pattern:location-mul-overflow.rs

fn main() {
let _: u8 = 255 * &2;
}
8 changes: 8 additions & 0 deletions tests/ui/numbers-arithmetic/location-sub-assign-overflow.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
// run-fail
// ignore-wasm32
// error-pattern:location-sub-assign-overflow.rs

fn main() {
let mut a: u8 = 0;
a -= &1;
}
7 changes: 7 additions & 0 deletions tests/ui/numbers-arithmetic/location-sub-overflow.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
// run-fail
// ignore-wasm32
// error-pattern:location-sub-overflow.rs

fn main() {
let _: u8 = 0 - &1;
}

0 comments on commit b1e56de

Please sign in to comment.