rust/tests/ui/non_zero_suggestions.rs

66 lines
2.1 KiB
Rust
Raw Normal View History

2024-07-26 00:51:30 +05:30
#![warn(clippy::non_zero_suggestions)]
2024-09-22 20:42:10 +02:00
use std::num::{NonZeroI8, NonZeroI16, NonZeroU8, NonZeroU16, NonZeroU32, NonZeroU64, NonZeroUsize};
2024-07-26 00:51:30 +05:30
fn main() {
2024-07-27 03:15:40 +05:30
/// Positive test cases (lint should trigger)
// U32 -> U64
let x: u64 = 100;
let y = NonZeroU32::new(10).unwrap();
let r1 = x / u64::from(y.get());
2024-07-27 03:15:40 +05:30
//~^ ERROR: consider using `NonZeroU64::from()` for more efficient and type-safe conversion
let r2 = x % u64::from(y.get());
2024-07-27 03:15:40 +05:30
//~^ ERROR: consider using `NonZeroU64::from()` for more efficient and type-safe conversion
2024-07-26 00:51:30 +05:30
// U16 -> U32
let a: u32 = 50;
let b = NonZeroU16::new(5).unwrap();
let r3 = a / u32::from(b.get());
2024-07-27 03:15:40 +05:30
//~^ ERROR: consider using `NonZeroU32::from()` for more efficient and type-safe conversion
2024-07-26 00:51:30 +05:30
let x = u64::from(NonZeroU32::new(5).unwrap().get());
2024-07-27 03:15:40 +05:30
//~^ ERROR: consider using `NonZeroU64::from()` for more efficient and type-safe conversion
2024-07-26 00:51:30 +05:30
/// Negative test cases (lint should not trigger)
// Left hand side expressions should not be triggered
let c: u32 = 50;
let d = NonZeroU16::new(5).unwrap();
let r4 = u32::from(b.get()) / a;
2024-07-26 00:51:30 +05:30
// Should not trigger for any other operand other than `/` and `%`
let r5 = a + u32::from(b.get());
let r6 = a - u32::from(b.get());
2024-07-26 00:51:30 +05:30
// Same size types
let e: u32 = 200;
let f = NonZeroU32::new(20).unwrap();
let r7 = e / f.get();
2024-07-26 00:51:30 +05:30
// Smaller to larger, but not NonZero
let g: u64 = 1000;
let h: u32 = 50;
let r8 = g / u64::from(h);
2024-07-26 00:51:30 +05:30
// Using From correctly
let k: u64 = 300;
let l = NonZeroU32::new(15).unwrap();
let r9 = k / NonZeroU64::from(l);
}
2024-07-26 00:51:30 +05:30
// Additional function to test the lint in a different context
fn divide_numbers(x: u64, y: NonZeroU32) -> u64 {
x / u64::from(y.get())
2024-07-27 03:15:40 +05:30
//~^ ERROR: consider using `NonZeroU64::from()` for more efficient and type-safe conversion
}
2024-07-26 00:51:30 +05:30
struct Calculator {
value: u64,
}
2024-07-26 00:51:30 +05:30
impl Calculator {
fn divide(&self, divisor: NonZeroU32) -> u64 {
self.value / u64::from(divisor.get())
//~^ ERROR: consider using `NonZeroU64::from()` for more efficient and type-safe conversion
}
2024-07-26 00:51:30 +05:30
}