1use super::{IntErrorKind, ParseIntError};
4use crate::clone::{TrivialClone, UseCloned};
5use crate::cmp::Ordering;
6use crate::hash::{Hash, Hasher};
7use crate::marker::{Destruct, Freeze, StructuralPartialEq};
8use crate::num::imp;
9use crate::ops::{BitOr, BitOrAssign, Div, DivAssign, Neg, Rem, RemAssign};
10use crate::panic::{RefUnwindSafe, UnwindSafe};
11use crate::str::FromStr;
12use crate::{fmt, intrinsics, ptr, ub_checks};
13
14#[unstable(
30 feature = "nonzero_internals",
31 reason = "implementation detail which may disappear or be replaced at any time",
32 issue = "none"
33)]
34pub impl(self) unsafe trait ZeroablePrimitive: Sized + Copy {
35 type NonZeroInner: Sized + Copy;
37}
38
39macro_rules! impl_zeroable_primitive {
40 ($($NonZeroInner:ident ( $primitive:ty )),+ $(,)?) => {
41 $(
42 #[unstable(
43 feature = "nonzero_internals",
44 reason = "implementation detail which may disappear or be replaced at any time",
45 issue = "none"
46 )]
47 unsafe impl ZeroablePrimitive for $primitive {
48 type NonZeroInner = super::niche_types::$NonZeroInner;
49 }
50 )+
51 };
52}
53
54#[unstable(feature = "nonzero_internals", reason =
"implementation detail which may disappear or be replaced at any time", issue
= "none")]
unsafe impl ZeroablePrimitive for char {
type NonZeroInner = super::niche_types::NonZeroCharInner;
}impl_zeroable_primitive!(
55 NonZeroU8Inner(u8),
56 NonZeroU16Inner(u16),
57 NonZeroU32Inner(u32),
58 NonZeroU64Inner(u64),
59 NonZeroU128Inner(u128),
60 NonZeroUsizeInner(usize),
61 NonZeroI8Inner(i8),
62 NonZeroI16Inner(i16),
63 NonZeroI32Inner(i32),
64 NonZeroI64Inner(i64),
65 NonZeroI128Inner(i128),
66 NonZeroIsizeInner(isize),
67 NonZeroCharInner(char),
68);
69
70#[stable(feature = "generic_nonzero", since = "1.79.0")]
109#[repr(transparent)]
110#[rustc_nonnull_optimization_guaranteed]
111#[rustc_diagnostic_item = "NonZero"]
112pub struct NonZero<T: ZeroablePrimitive>(T::NonZeroInner);
113
114macro_rules! impl_nonzero_fmt {
115 ($(#[$Attribute:meta] $Trait:ident)*) => {
116 $(
117 #[$Attribute]
118 impl<T> fmt::$Trait for NonZero<T>
119 where
120 T: ZeroablePrimitive + fmt::$Trait,
121 {
122 #[inline]
123 fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
124 self.get().fmt(f)
125 }
126 }
127 )*
128 };
129}
130
131#[stable(feature = "nonzero_fmt_exp", since = "1.84.0")]
impl<T> fmt::UpperExp for NonZero<T> where T: ZeroablePrimitive +
fmt::UpperExp {
#[inline]
fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
self.get().fmt(f)
}
}impl_nonzero_fmt! {
132 #[stable(feature = "nonzero", since = "1.28.0")]
133 Debug
134 #[stable(feature = "nonzero", since = "1.28.0")]
135 Display
136 #[stable(feature = "nonzero", since = "1.28.0")]
137 Binary
138 #[stable(feature = "nonzero", since = "1.28.0")]
139 Octal
140 #[stable(feature = "nonzero", since = "1.28.0")]
141 LowerHex
142 #[stable(feature = "nonzero", since = "1.28.0")]
143 UpperHex
144 #[stable(feature = "nonzero_fmt_exp", since = "1.84.0")]
145 LowerExp
146 #[stable(feature = "nonzero_fmt_exp", since = "1.84.0")]
147 UpperExp
148}
149
150macro_rules! impl_nonzero_auto_trait {
151 (unsafe $Trait:ident) => {
152 #[stable(feature = "nonzero", since = "1.28.0")]
153 unsafe impl<T> $Trait for NonZero<T> where T: ZeroablePrimitive + $Trait {}
154 };
155 ($Trait:ident) => {
156 #[stable(feature = "nonzero", since = "1.28.0")]
157 impl<T> $Trait for NonZero<T> where T: ZeroablePrimitive + $Trait {}
158 };
159}
160
161#[stable(feature = "nonzero", since = "1.28.0")]
unsafe impl<T> Freeze for NonZero<T> where T: ZeroablePrimitive + Freeze { }impl_nonzero_auto_trait!(unsafe Freeze);
164#[stable(feature = "nonzero", since = "1.28.0")]
impl<T> RefUnwindSafe for NonZero<T> where T: ZeroablePrimitive +
RefUnwindSafe {
}impl_nonzero_auto_trait!(RefUnwindSafe);
165#[stable(feature = "nonzero", since = "1.28.0")]
unsafe impl<T> Send for NonZero<T> where T: ZeroablePrimitive + Send { }impl_nonzero_auto_trait!(unsafe Send);
166#[stable(feature = "nonzero", since = "1.28.0")]
unsafe impl<T> Sync for NonZero<T> where T: ZeroablePrimitive + Sync { }impl_nonzero_auto_trait!(unsafe Sync);
167#[stable(feature = "nonzero", since = "1.28.0")]
impl<T> Unpin for NonZero<T> where T: ZeroablePrimitive + Unpin { }impl_nonzero_auto_trait!(Unpin);
168#[stable(feature = "nonzero", since = "1.28.0")]
impl<T> UnwindSafe for NonZero<T> where T: ZeroablePrimitive + UnwindSafe { }impl_nonzero_auto_trait!(UnwindSafe);
169
170#[stable(feature = "nonzero", since = "1.28.0")]
171#[rustc_const_unstable(feature = "const_clone", issue = "142757")]
172const impl<T> Clone for NonZero<T>
173where
174 T: ZeroablePrimitive,
175{
176 #[inline]
177 fn clone(&self) -> Self {
178 *self
179 }
180}
181
182#[unstable(feature = "ergonomic_clones", issue = "132290")]
183impl<T> UseCloned for NonZero<T> where T: ZeroablePrimitive {}
184
185#[stable(feature = "nonzero", since = "1.28.0")]
186impl<T> Copy for NonZero<T> where T: ZeroablePrimitive {}
187
188#[doc(hidden)]
189#[unstable(feature = "trivial_clone", issue = "none")]
190#[rustc_const_unstable(feature = "const_clone", issue = "142757")]
191const unsafe impl<T> TrivialClone for NonZero<T> where T: ZeroablePrimitive {}
192
193#[stable(feature = "nonzero", since = "1.28.0")]
194#[rustc_const_unstable(feature = "const_cmp", issue = "143800")]
195const impl<T> PartialEq for NonZero<T>
196where
197 T: ZeroablePrimitive + [const] PartialEq,
198{
199 #[inline]
200 fn eq(&self, other: &Self) -> bool {
201 self.get() == other.get()
202 }
203
204 #[inline]
205 fn ne(&self, other: &Self) -> bool {
206 self.get() != other.get()
207 }
208}
209
210#[unstable(feature = "structural_match", issue = "31434")]
211impl<T> StructuralPartialEq for NonZero<T> where T: ZeroablePrimitive + StructuralPartialEq {}
212
213#[stable(feature = "nonzero", since = "1.28.0")]
214#[rustc_const_unstable(feature = "const_cmp", issue = "143800")]
215const impl<T> Eq for NonZero<T> where T: ZeroablePrimitive + [const] Eq {}
216
217#[stable(feature = "nonzero", since = "1.28.0")]
218#[rustc_const_unstable(feature = "const_cmp", issue = "143800")]
219const impl<T> PartialOrd for NonZero<T>
220where
221 T: ZeroablePrimitive + [const] PartialOrd,
222{
223 #[inline]
224 fn partial_cmp(&self, other: &Self) -> Option<Ordering> {
225 self.get().partial_cmp(&other.get())
226 }
227
228 #[inline]
229 fn lt(&self, other: &Self) -> bool {
230 self.get() < other.get()
231 }
232
233 #[inline]
234 fn le(&self, other: &Self) -> bool {
235 self.get() <= other.get()
236 }
237
238 #[inline]
239 fn gt(&self, other: &Self) -> bool {
240 self.get() > other.get()
241 }
242
243 #[inline]
244 fn ge(&self, other: &Self) -> bool {
245 self.get() >= other.get()
246 }
247}
248
249#[stable(feature = "nonzero", since = "1.28.0")]
250#[rustc_const_unstable(feature = "const_cmp", issue = "143800")]
251const impl<T> Ord for NonZero<T>
252where
253 T: ZeroablePrimitive + [const] Ord + [const] Destruct,
256{
257 #[inline]
258 fn cmp(&self, other: &Self) -> Ordering {
259 self.get().cmp(&other.get())
260 }
261
262 #[inline]
263 fn max(self, other: Self) -> Self {
264 unsafe { Self::new_unchecked(self.get().max(other.get())) }
266 }
267
268 #[inline]
269 fn min(self, other: Self) -> Self {
270 unsafe { Self::new_unchecked(self.get().min(other.get())) }
272 }
273
274 #[inline]
275 fn clamp(self, min: Self, max: Self) -> Self {
276 unsafe { Self::new_unchecked(self.get().clamp(min.get(), max.get())) }
278 }
279}
280
281#[stable(feature = "nonzero", since = "1.28.0")]
282impl<T> Hash for NonZero<T>
283where
284 T: ZeroablePrimitive + Hash,
285{
286 #[inline]
287 fn hash<H>(&self, state: &mut H)
288 where
289 H: Hasher,
290 {
291 self.get().hash(state)
292 }
293}
294
295#[stable(feature = "from_nonzero", since = "1.31.0")]
296#[rustc_const_unstable(feature = "const_convert", issue = "143773")]
297const impl<T> From<NonZero<T>> for T
298where
299 T: ZeroablePrimitive,
300{
301 #[inline]
302 fn from(nonzero: NonZero<T>) -> Self {
303 nonzero.get()
305 }
306}
307
308#[stable(feature = "nonzero_bitor", since = "1.45.0")]
309#[rustc_const_unstable(feature = "const_ops", issue = "143802")]
310const impl<T> BitOr for NonZero<T>
311where
312 T: ZeroablePrimitive + [const] BitOr<Output = T>,
313{
314 type Output = Self;
315
316 #[inline]
317 fn bitor(self, rhs: Self) -> Self::Output {
318 unsafe { Self::new_unchecked(self.get() | rhs.get()) }
320 }
321}
322
323#[stable(feature = "nonzero_bitor", since = "1.45.0")]
324#[rustc_const_unstable(feature = "const_ops", issue = "143802")]
325const impl<T> BitOr<T> for NonZero<T>
326where
327 T: ZeroablePrimitive + [const] BitOr<Output = T>,
328{
329 type Output = Self;
330
331 #[inline]
332 fn bitor(self, rhs: T) -> Self::Output {
333 unsafe { Self::new_unchecked(self.get() | rhs) }
335 }
336}
337
338#[stable(feature = "nonzero_bitor", since = "1.45.0")]
339#[rustc_const_unstable(feature = "const_ops", issue = "143802")]
340const impl<T> BitOr<NonZero<T>> for T
341where
342 T: ZeroablePrimitive + [const] BitOr<Output = T>,
343{
344 type Output = NonZero<T>;
345
346 #[inline]
347 fn bitor(self, rhs: NonZero<T>) -> Self::Output {
348 unsafe { NonZero::new_unchecked(self | rhs.get()) }
350 }
351}
352
353#[stable(feature = "nonzero_bitor", since = "1.45.0")]
354#[rustc_const_unstable(feature = "const_ops", issue = "143802")]
355const impl<T> BitOrAssign for NonZero<T>
356where
357 T: ZeroablePrimitive,
358 Self: [const] BitOr<Output = Self>,
359{
360 #[inline]
361 fn bitor_assign(&mut self, rhs: Self) {
362 *self = *self | rhs;
363 }
364}
365
366#[stable(feature = "nonzero_bitor", since = "1.45.0")]
367#[rustc_const_unstable(feature = "const_ops", issue = "143802")]
368const impl<T> BitOrAssign<T> for NonZero<T>
369where
370 T: ZeroablePrimitive,
371 Self: [const] BitOr<T, Output = Self>,
372{
373 #[inline]
374 fn bitor_assign(&mut self, rhs: T) {
375 *self = *self | rhs;
376 }
377}
378
379impl<T> NonZero<T>
380where
381 T: ZeroablePrimitive,
382{
383 #[stable(feature = "nonzero", since = "1.28.0")]
385 #[rustc_const_stable(feature = "const_nonzero_int_methods", since = "1.47.0")]
386 #[must_use]
387 #[inline]
388 pub const fn new(n: T) -> Option<Self> {
389 unsafe { intrinsics::transmute_unchecked(n) }
392 }
393
394 #[stable(feature = "nonzero", since = "1.28.0")]
401 #[rustc_const_stable(feature = "nonzero", since = "1.28.0")]
402 #[must_use]
403 #[inline]
404 #[track_caller]
405 pub const unsafe fn new_unchecked(n: T) -> Self {
406 match Self::new(n) {
407 Some(n) => n,
408 None => {
409 unsafe {
411 {
#[rustc_no_mir_inline]
#[inline]
#[rustc_nounwind]
#[track_caller]
const fn precondition_check() {
if !false {
let msg =
"unsafe precondition(s) violated: NonZero::new_unchecked requires the argument to be non-zero\n\nThis indicates a bug in the program. This Undefined Behavior check is optional, and cannot be relied on for safety.";
::core::panicking::panic_nounwind_fmt(::core::fmt::Arguments::from_str(msg),
false);
}
}
if ::core::ub_checks::check_language_ub() { precondition_check(); }
};ub_checks::assert_unsafe_precondition!(
412 check_language_ub,
413 "NonZero::new_unchecked requires the argument to be non-zero",
414 () => false,
415 );
416 intrinsics::unreachable()
417 }
418 }
419 }
420 }
421
422 #[unstable(feature = "nonzero_from_mut", issue = "106290")]
425 #[must_use]
426 #[inline]
427 pub fn from_mut(n: &mut T) -> Option<&mut Self> {
428 let opt_n = unsafe { &mut *(ptr::from_mut(n).cast::<Option<Self>>()) };
431
432 opt_n.as_mut()
433 }
434
435 #[unstable(feature = "nonzero_from_mut", issue = "106290")]
443 #[must_use]
444 #[inline]
445 #[track_caller]
446 pub unsafe fn from_mut_unchecked(n: &mut T) -> &mut Self {
447 match Self::from_mut(n) {
448 Some(n) => n,
449 None => {
450 unsafe {
452 {
#[rustc_no_mir_inline]
#[inline]
#[rustc_nounwind]
#[track_caller]
const fn precondition_check() {
if !false {
let msg =
"unsafe precondition(s) violated: NonZero::from_mut_unchecked requires the argument to dereference as non-zero\n\nThis indicates a bug in the program. This Undefined Behavior check is optional, and cannot be relied on for safety.";
::core::panicking::panic_nounwind_fmt(::core::fmt::Arguments::from_str(msg),
false);
}
}
if ::core::ub_checks::check_library_ub() { precondition_check(); }
};ub_checks::assert_unsafe_precondition!(
453 check_library_ub,
454 "NonZero::from_mut_unchecked requires the argument to dereference as non-zero",
455 () => false,
456 );
457 intrinsics::unreachable()
458 }
459 }
460 }
461 }
462
463 #[stable(feature = "nonzero", since = "1.28.0")]
465 #[rustc_const_stable(feature = "const_nonzero_get", since = "1.34.0")]
466 #[inline]
467 pub const fn get(self) -> T {
468 unsafe { intrinsics::transmute_unchecked(self) }
487 }
488}
489
490macro_rules! nonzero_integer {
491 (
492 #[$stability:meta]
493 Self = $Ty:ident,
494 Primitive = $signedness:ident $Int:ident,
495 SignedPrimitive = $Sint:ty,
496 UnsignedPrimitive = $Uint:ty,
497
498 rot = $rot:literal,
500 rot_op = $rot_op:literal,
501 rot_result = $rot_result:literal,
502 swap_op = $swap_op:literal,
503 swapped = $swapped:literal,
504 reversed = $reversed:literal,
505 leading_zeros_test = $leading_zeros_test:expr,
506 ) => {
507 #[doc = sign_dependent_expr!{
508 $signedness ?
509 if signed {
510 concat!("An [`", stringify!($Int), "`] that is known not to equal zero.")
511 }
512 if unsigned {
513 concat!("A [`", stringify!($Int), "`] that is known not to equal zero.")
514 }
515 }]
516 #[doc = concat!("For example, `Option<", stringify!($Ty), ">` is the same size as `", stringify!($Int), "`:")]
519 #[doc = concat!("assert_eq!(size_of::<Option<core::num::", stringify!($Ty), ">>(), size_of::<", stringify!($Int), ">());")]
522 #[doc = concat!("`", stringify!($Ty), "` is guaranteed to have the same layout and bit validity as `", stringify!($Int), "`")]
527 #[doc = concat!("`Option<", stringify!($Ty), ">` is guaranteed to be compatible with `", stringify!($Int), "`,")]
529 #[doc = concat!("`", stringify!($Ty), "` and `Option<", stringify!($Ty), ">`")]
533 #[doc = concat!("use std::num::", stringify!($Ty), ";")]
537 #[doc = concat!("assert_eq!(size_of::<", stringify!($Ty), ">(), size_of::<Option<", stringify!($Ty), ">>());")]
539 #[doc = concat!("assert_eq!(align_of::<", stringify!($Ty), ">(), align_of::<Option<", stringify!($Ty), ">>());")]
540 #[doc = concat!("`", stringify!($Ty), "`")]
547 #[doc = concat!("use std::num::", stringify!($Ty), ";")]
550 #[doc = concat!("const TEN: ", stringify!($Ty), " = ", stringify!($Ty) , r#"::new(10).expect("ten is non-zero");"#)]
552 #[$stability]
556 pub type $Ty = NonZero<$Int>;
557
558 impl NonZero<$Int> {
559 #[doc = concat!("This value is equal to [`", stringify!($Int), "::BITS`].")]
562 #[doc = concat!("assert_eq!(NonZero::<", stringify!($Int), ">::BITS, ", stringify!($Int), "::BITS);")]
569 #[stable(feature = "nonzero_bits", since = "1.67.0")]
571 pub const BITS: u32 = <$Int>::BITS;
572
573 #[doc = concat!("let n = NonZero::<", stringify!($Int), ">::new(", $leading_zeros_test, ")?;")]
585 #[stable(feature = "nonzero_leading_trailing_zeros", since = "1.53.0")]
591 #[rustc_const_stable(feature = "nonzero_leading_trailing_zeros", since = "1.53.0")]
592 #[must_use = "this returns the result of the operation, \
593 without modifying the original"]
594 #[inline]
595 pub const fn leading_zeros(self) -> u32 {
596 unsafe {
598 intrinsics::ctlz_nonzero(self.get() as $Uint)
599 }
600 }
601
602 #[doc = concat!("let n = NonZero::<", stringify!($Int), ">::new(0b0101000)?;")]
615 #[stable(feature = "nonzero_leading_trailing_zeros", since = "1.53.0")]
621 #[rustc_const_stable(feature = "nonzero_leading_trailing_zeros", since = "1.53.0")]
622 #[must_use = "this returns the result of the operation, \
623 without modifying the original"]
624 #[inline]
625 pub const fn trailing_zeros(self) -> u32 {
626 unsafe {
628 intrinsics::cttz_nonzero(self.get() as $Uint)
629 }
630 }
631
632 #[doc = concat!("let a = NonZero::<", stringify!($Int), ">::new(0b_01100100)?;")]
641 #[doc = concat!("let b = NonZero::<", stringify!($Int), ">::new(0b_01000000)?;")]
642 #[stable(feature = "isolate_most_least_significant_one", since = "1.97.0")]
648 #[rustc_const_stable(feature = "isolate_most_least_significant_one", since = "1.97.0")]
649 #[must_use = "this returns the result of the operation, \
650 without modifying the original"]
651 #[inline(always)]
652 pub const fn isolate_highest_one(self) -> Self {
653 unsafe {
659 let bit = (((1 as $Uint) << (<$Uint>::BITS - 1)).unchecked_shr(self.leading_zeros()));
660 NonZero::new_unchecked(bit as $Int)
661 }
662 }
663
664 #[doc = concat!("let a = NonZero::<", stringify!($Int), ">::new(0b_01100100)?;")]
673 #[doc = concat!("let b = NonZero::<", stringify!($Int), ">::new(0b_00000100)?;")]
674 #[stable(feature = "isolate_most_least_significant_one", since = "1.97.0")]
680 #[rustc_const_stable(feature = "isolate_most_least_significant_one", since = "1.97.0")]
681 #[must_use = "this returns the result of the operation, \
682 without modifying the original"]
683 #[inline(always)]
684 pub const fn isolate_lowest_one(self) -> Self {
685 let n = self.get();
686 let n = n & n.wrapping_neg();
687
688 unsafe { NonZero::new_unchecked(n) }
691 }
692
693 #[doc = concat!("assert_eq!(NonZero::<", stringify!($Int), ">::new(0b1)?.highest_one(), 0);")]
702 #[doc = concat!("assert_eq!(NonZero::<", stringify!($Int), ">::new(0b1_0000)?.highest_one(), 4);")]
703 #[doc = concat!("assert_eq!(NonZero::<", stringify!($Int), ">::new(0b1_1111)?.highest_one(), 4);")]
704 #[stable(feature = "int_lowest_highest_one", since = "1.97.0")]
708 #[rustc_const_stable(feature = "int_lowest_highest_one", since = "1.97.0")]
709 #[must_use = "this returns the result of the operation, \
710 without modifying the original"]
711 #[inline(always)]
712 pub const fn highest_one(self) -> u32 {
713 Self::BITS - 1 - self.leading_zeros()
714 }
715
716 #[doc = concat!("assert_eq!(NonZero::<", stringify!($Int), ">::new(0b1)?.lowest_one(), 0);")]
725 #[doc = concat!("assert_eq!(NonZero::<", stringify!($Int), ">::new(0b1_0000)?.lowest_one(), 4);")]
726 #[doc = concat!("assert_eq!(NonZero::<", stringify!($Int), ">::new(0b1_1111)?.lowest_one(), 0);")]
727 #[stable(feature = "int_lowest_highest_one", since = "1.97.0")]
731 #[rustc_const_stable(feature = "int_lowest_highest_one", since = "1.97.0")]
732 #[must_use = "this returns the result of the operation, \
733 without modifying the original"]
734 #[inline(always)]
735 pub const fn lowest_one(self) -> u32 {
736 self.trailing_zeros()
737 }
738
739 #[doc = concat!("let a = NonZero::<", stringify!($Int), ">::new(0b100_0000)?;")]
749 #[doc = concat!("let b = NonZero::<", stringify!($Int), ">::new(0b100_0011)?;")]
750 #[stable(feature = "non_zero_count_ones", since = "1.86.0")]
758 #[rustc_const_stable(feature = "non_zero_count_ones", since = "1.86.0")]
759 #[doc(alias = "popcount")]
760 #[doc(alias = "popcnt")]
761 #[must_use = "this returns the result of the operation, \
762 without modifying the original"]
763 #[inline(always)]
764 pub const fn count_ones(self) -> NonZero<u32> {
765 unsafe { NonZero::new_unchecked(self.get().count_ones()) }
769 }
770
771 #[doc = concat!("let n = NonZero::new(", $rot_op, stringify!($Int), ")?;")]
785 #[doc = concat!("let m = NonZero::new(", $rot_result, ")?;")]
786 #[doc = concat!("assert_eq!(n.rotate_left(", $rot, "), m);")]
788 #[unstable(feature = "nonzero_bitwise", issue = "128281")]
792 #[must_use = "this returns the result of the operation, \
793 without modifying the original"]
794 #[inline(always)]
795 pub const fn rotate_left(self, n: u32) -> Self {
796 let result = self.get().rotate_left(n);
797 unsafe { Self::new_unchecked(result) }
799 }
800
801 #[doc = concat!("let n = NonZero::new(", $rot_result, stringify!($Int), ")?;")]
816 #[doc = concat!("let m = NonZero::new(", $rot_op, ")?;")]
817 #[doc = concat!("assert_eq!(n.rotate_right(", $rot, "), m);")]
819 #[unstable(feature = "nonzero_bitwise", issue = "128281")]
823 #[must_use = "this returns the result of the operation, \
824 without modifying the original"]
825 #[inline(always)]
826 pub const fn rotate_right(self, n: u32) -> Self {
827 let result = self.get().rotate_right(n);
828 unsafe { Self::new_unchecked(result) }
830 }
831
832 #[doc = concat!("let n = NonZero::new(", $swap_op, stringify!($Int), ")?;")]
843 #[doc = concat!("assert_eq!(m, NonZero::new(", $swapped, ")?);")]
846 #[unstable(feature = "nonzero_bitwise", issue = "128281")]
850 #[must_use = "this returns the result of the operation, \
851 without modifying the original"]
852 #[inline(always)]
853 pub const fn swap_bytes(self) -> Self {
854 let result = self.get().swap_bytes();
855 unsafe { Self::new_unchecked(result) }
857 }
858
859 #[doc = concat!("let n = NonZero::new(", $swap_op, stringify!($Int), ")?;")]
871 #[doc = concat!("assert_eq!(m, NonZero::new(", $reversed, ")?);")]
874 #[unstable(feature = "nonzero_bitwise", issue = "128281")]
878 #[must_use = "this returns the result of the operation, \
879 without modifying the original"]
880 #[inline(always)]
881 pub const fn reverse_bits(self) -> Self {
882 let result = self.get().reverse_bits();
883 unsafe { Self::new_unchecked(result) }
885 }
886
887 #[doc = concat!("use std::num::", stringify!($Ty), ";")]
898 #[doc = concat!("let n = NonZero::new(0x1A", stringify!($Int), ")?;")]
902 #[doc = concat!(" assert_eq!(", stringify!($Ty), "::from_be(n), n)")]
905 #[doc = concat!(" assert_eq!(", stringify!($Ty), "::from_be(n), n.swap_bytes())")]
907 #[unstable(feature = "nonzero_bitwise", issue = "128281")]
912 #[must_use]
913 #[inline(always)]
914 pub const fn from_be(x: Self) -> Self {
915 let result = $Int::from_be(x.get());
916 unsafe { Self::new_unchecked(result) }
918 }
919
920 #[doc = concat!("use std::num::", stringify!($Ty), ";")]
931 #[doc = concat!("let n = NonZero::new(0x1A", stringify!($Int), ")?;")]
935 #[doc = concat!(" assert_eq!(", stringify!($Ty), "::from_le(n), n)")]
938 #[doc = concat!(" assert_eq!(", stringify!($Ty), "::from_le(n), n.swap_bytes())")]
940 #[unstable(feature = "nonzero_bitwise", issue = "128281")]
945 #[must_use]
946 #[inline(always)]
947 pub const fn from_le(x: Self) -> Self {
948 let result = $Int::from_le(x.get());
949 unsafe { Self::new_unchecked(result) }
951 }
952
953 #[doc = concat!("let n = NonZero::new(0x1A", stringify!($Int), ")?;")]
967 #[unstable(feature = "nonzero_bitwise", issue = "128281")]
977 #[must_use = "this returns the result of the operation, \
978 without modifying the original"]
979 #[inline(always)]
980 pub const fn to_be(self) -> Self {
981 let result = self.get().to_be();
982 unsafe { Self::new_unchecked(result) }
984 }
985
986 #[doc = concat!("let n = NonZero::new(0x1A", stringify!($Int), ")?;")]
1000 #[unstable(feature = "nonzero_bitwise", issue = "128281")]
1010 #[must_use = "this returns the result of the operation, \
1011 without modifying the original"]
1012 #[inline(always)]
1013 pub const fn to_le(self) -> Self {
1014 let result = self.get().to_le();
1015 unsafe { Self::new_unchecked(result) }
1017 }
1018
1019 nonzero_integer_signedness_dependent_methods! {
1020 Primitive = $signedness $Int,
1021 SignedPrimitive = $Sint,
1022 UnsignedPrimitive = $Uint,
1023 }
1024
1025 #[doc = concat!("let two = NonZero::new(2", stringify!($Int), ")?;")]
1037 #[doc = concat!("let four = NonZero::new(4", stringify!($Int), ")?;")]
1038 #[doc = concat!("let max = NonZero::new(", stringify!($Int), "::MAX)?;")]
1039 #[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
1046 #[rustc_const_stable(feature = "const_nonzero_checked_ops", since = "1.64.0")]
1047 #[must_use = "this returns the result of the operation, \
1048 without modifying the original"]
1049 #[inline]
1050 pub const fn checked_mul(self, other: Self) -> Option<Self> {
1051 if let Some(result) = self.get().checked_mul(other.get()) {
1052 Some(unsafe { Self::new_unchecked(result) })
1060 } else {
1061 None
1062 }
1063 }
1064
1065 #[doc = concat!("Return [`NonZero::<", stringify!($Int), ">::MAX`] on overflow.")]
1067 #[doc = concat!("let two = NonZero::new(2", stringify!($Int), ")?;")]
1076 #[doc = concat!("let four = NonZero::new(4", stringify!($Int), ")?;")]
1077 #[doc = concat!("let max = NonZero::new(", stringify!($Int), "::MAX)?;")]
1078 #[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
1085 #[rustc_const_stable(feature = "const_nonzero_checked_ops", since = "1.64.0")]
1086 #[must_use = "this returns the result of the operation, \
1087 without modifying the original"]
1088 #[inline]
1089 pub const fn saturating_mul(self, other: Self) -> Self {
1090 unsafe { Self::new_unchecked(self.get().saturating_mul(other.get())) }
1099 }
1100
1101 #[doc = sign_dependent_expr!{
1110 $signedness ?
1111 if signed {
1112 concat!("`self * rhs > ", stringify!($Int), "::MAX`, ",
1113 "or `self * rhs < ", stringify!($Int), "::MIN`.")
1114 }
1115 if unsigned {
1116 concat!("`self * rhs > ", stringify!($Int), "::MAX`.")
1117 }
1118 }]
1119 #[doc = concat!("let two = NonZero::new(2", stringify!($Int), ")?;")]
1130 #[doc = concat!("let four = NonZero::new(4", stringify!($Int), ")?;")]
1131 #[unstable(feature = "nonzero_ops", issue = "84186")]
1137 #[must_use = "this returns the result of the operation, \
1138 without modifying the original"]
1139 #[inline]
1140 pub const unsafe fn unchecked_mul(self, other: Self) -> Self {
1141 unsafe { Self::new_unchecked(self.get().unchecked_mul(other.get())) }
1143 }
1144
1145 #[doc = concat!("let three = NonZero::new(3", stringify!($Int), ")?;")]
1157 #[doc = concat!("let twenty_seven = NonZero::new(27", stringify!($Int), ")?;")]
1158 #[doc = concat!("let half_max = NonZero::new(", stringify!($Int), "::MAX / 2)?;")]
1159 #[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
1166 #[rustc_const_stable(feature = "const_nonzero_checked_ops", since = "1.64.0")]
1167 #[must_use = "this returns the result of the operation, \
1168 without modifying the original"]
1169 #[inline]
1170 pub const fn checked_pow(self, other: u32) -> Option<Self> {
1171 if let Some(result) = self.get().checked_pow(other) {
1172 Some(unsafe { Self::new_unchecked(result) })
1180 } else {
1181 None
1182 }
1183 }
1184
1185 #[doc = sign_dependent_expr!{
1187 $signedness ?
1188 if signed {
1189 concat!("Return [`NonZero::<", stringify!($Int), ">::MIN`] ",
1190 "or [`NonZero::<", stringify!($Int), ">::MAX`] on overflow.")
1191 }
1192 if unsigned {
1193 concat!("Return [`NonZero::<", stringify!($Int), ">::MAX`] on overflow.")
1194 }
1195 }]
1196 #[doc = concat!("let three = NonZero::new(3", stringify!($Int), ")?;")]
1205 #[doc = concat!("let twenty_seven = NonZero::new(27", stringify!($Int), ")?;")]
1206 #[doc = concat!("let max = NonZero::new(", stringify!($Int), "::MAX)?;")]
1207 #[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
1214 #[rustc_const_stable(feature = "const_nonzero_checked_ops", since = "1.64.0")]
1215 #[must_use = "this returns the result of the operation, \
1216 without modifying the original"]
1217 #[inline]
1218 pub const fn saturating_pow(self, other: u32) -> Self {
1219 unsafe { Self::new_unchecked(self.get().saturating_pow(other)) }
1228 }
1229
1230 #[doc = sign_dependent_expr!{
1234 $signedness ?
1235 if signed {
1236 " `+` or `-` "
1237 }
1238 if unsigned {
1239 " `+` "
1240 }
1241 }]
1242 #[doc = concat!("assert_eq!(NonZero::<", stringify!($Int), ">::from_ascii(b\"+10\"), Ok(NonZero::new(10)?));")]
1256 #[doc = concat!("assert!(NonZero::<", stringify!($Int), ">::from_ascii(b\"1 \").is_err());")]
1268 #[unstable(feature = "int_from_ascii", issue = "134821")]
1270 #[inline]
1271 pub const fn from_ascii(src: &[u8]) -> Result<Self, ParseIntError> {
1272 Self::from_ascii_radix(src, 10)
1273 }
1274
1275 #[doc = sign_dependent_expr!{
1279 $signedness ?
1280 if signed {
1281 " `+` or `-` "
1282 }
1283 if unsigned {
1284 " `+` "
1285 }
1286 }]
1287 #[doc = concat!("assert_eq!(NonZero::<", stringify!($Int), ">::from_ascii_radix(b\"A\", 16), Ok(NonZero::new(10)?));")]
1311 #[doc = concat!("assert!(NonZero::<", stringify!($Int), ">::from_ascii_radix(b\"1 \", 10).is_err());")]
1323 #[unstable(feature = "int_from_ascii", issue = "134821")]
1325 #[inline]
1326 pub const fn from_ascii_radix(src: &[u8], radix: u32) -> Result<Self, ParseIntError> {
1327 let n = match <$Int>::from_ascii_radix(src, radix) {
1328 Ok(n) => n,
1329 Err(err) => return Err(err),
1330 };
1331 if let Some(n) = Self::new(n) {
1332 Ok(n)
1333 } else {
1334 Err(ParseIntError { kind: IntErrorKind::Zero })
1335 }
1336 }
1337
1338 #[doc = sign_dependent_expr!{
1342 $signedness ?
1343 if signed {
1344 " `+` or `-` "
1345 }
1346 if unsigned {
1347 " `+` "
1348 }
1349 }]
1350 #[doc = concat!("assert_eq!(NonZero::<", stringify!($Int), ">::from_str_radix(\"A\", 16), Ok(NonZero::new(10)?));")]
1374 #[doc = concat!("assert!(NonZero::<", stringify!($Int), ">::from_str_radix(\"1 \", 10).is_err());")]
1386 #[unstable(feature = "nonzero_from_str_radix", issue = "152193")]
1388 #[inline]
1389 pub const fn from_str_radix(src: &str, radix: u32) -> Result<Self, ParseIntError> {
1390 Self::from_ascii_radix(src.as_bytes(), radix)
1391 }
1392 }
1393
1394 #[stable(feature = "nonzero_parse", since = "1.35.0")]
1395 impl FromStr for NonZero<$Int> {
1396 type Err = ParseIntError;
1397 fn from_str(src: &str) -> Result<Self, Self::Err> {
1398 Self::from_str_radix(src, 10)
1399 }
1400 }
1401
1402 nonzero_integer_signedness_dependent_impls!($signedness $Int);
1403 };
1404
1405 (
1406 Self = $Ty:ident,
1407 Primitive = unsigned $Int:ident,
1408 SignedPrimitive = $Sint:ident,
1409 rot = $rot:literal,
1410 rot_op = $rot_op:literal,
1411 rot_result = $rot_result:literal,
1412 swap_op = $swap_op:literal,
1413 swapped = $swapped:literal,
1414 reversed = $reversed:literal,
1415 $(,)?
1416 ) => {
1417 nonzero_integer! {
1418 #[stable(feature = "nonzero", since = "1.28.0")]
1419 Self = $Ty,
1420 Primitive = unsigned $Int,
1421 SignedPrimitive = $Sint,
1422 UnsignedPrimitive = $Int,
1423 rot = $rot,
1424 rot_op = $rot_op,
1425 rot_result = $rot_result,
1426 swap_op = $swap_op,
1427 swapped = $swapped,
1428 reversed = $reversed,
1429 leading_zeros_test = concat!(stringify!($Int), "::MAX"),
1430 }
1431 };
1432
1433 (
1434 Self = $Ty:ident,
1435 Primitive = signed $Int:ident,
1436 UnsignedPrimitive = $Uint:ident,
1437 rot = $rot:literal,
1438 rot_op = $rot_op:literal,
1439 rot_result = $rot_result:literal,
1440 swap_op = $swap_op:literal,
1441 swapped = $swapped:literal,
1442 reversed = $reversed:literal,
1443 ) => {
1444 nonzero_integer! {
1445 #[stable(feature = "signed_nonzero", since = "1.34.0")]
1446 Self = $Ty,
1447 Primitive = signed $Int,
1448 SignedPrimitive = $Int,
1449 UnsignedPrimitive = $Uint,
1450 rot = $rot,
1451 rot_op = $rot_op,
1452 rot_result = $rot_result,
1453 swap_op = $swap_op,
1454 swapped = $swapped,
1455 reversed = $reversed,
1456 leading_zeros_test = concat!("-1", stringify!($Int)),
1457 }
1458 };
1459}
1460
1461macro_rules! nonzero_integer_signedness_dependent_impls {
1462 (unsigned $Int:ty) => {
1464 #[stable(feature = "nonzero_div", since = "1.51.0")]
1465 #[rustc_const_unstable(feature = "const_ops", issue = "143802")]
1466 const impl Div<NonZero<$Int>> for $Int {
1467 type Output = $Int;
1468
1469 #[doc(alias = "unchecked_div")]
1475 #[inline]
1476 fn div(self, other: NonZero<$Int>) -> $Int {
1477 unsafe { intrinsics::unchecked_div(self, other.get()) }
1480 }
1481 }
1482
1483 #[stable(feature = "nonzero_div_assign", since = "1.79.0")]
1484 #[rustc_const_unstable(feature = "const_ops", issue = "143802")]
1485 const impl DivAssign<NonZero<$Int>> for $Int {
1486 #[inline]
1492 fn div_assign(&mut self, other: NonZero<$Int>) {
1493 *self = *self / other;
1494 }
1495 }
1496
1497 #[stable(feature = "nonzero_div", since = "1.51.0")]
1498 #[rustc_const_unstable(feature = "const_ops", issue = "143802")]
1499 const impl Rem<NonZero<$Int>> for $Int {
1500 type Output = $Int;
1501
1502 #[inline]
1504 fn rem(self, other: NonZero<$Int>) -> $Int {
1505 unsafe { intrinsics::unchecked_rem(self, other.get()) }
1508 }
1509 }
1510
1511 #[stable(feature = "nonzero_div_assign", since = "1.79.0")]
1512 #[rustc_const_unstable(feature = "const_ops", issue = "143802")]
1513 const impl RemAssign<NonZero<$Int>> for $Int {
1514 #[inline]
1516 fn rem_assign(&mut self, other: NonZero<$Int>) {
1517 *self = *self % other;
1518 }
1519 }
1520
1521 impl NonZero<$Int> {
1522 #[doc = concat!("let one = NonZero::new(1", stringify!($Int), ").unwrap();")]
1531 #[doc = concat!("let max = NonZero::new(", stringify!($Int), "::MAX).unwrap();")]
1532 #[doc = concat!("let two = NonZero::new(2", stringify!($Int), ").unwrap();")]
1535 #[doc = concat!("let three = NonZero::new(3", stringify!($Int), ").unwrap();")]
1536 #[stable(feature = "unsigned_nonzero_div_ceil", since = "1.92.0")]
1539 #[rustc_const_stable(feature = "unsigned_nonzero_div_ceil", since = "1.92.0")]
1540 #[must_use = "this returns the result of the operation, \
1541 without modifying the original"]
1542 #[inline]
1543 pub const fn div_ceil(self, rhs: Self) -> Self {
1544 let v = self.get().div_ceil(rhs.get());
1545 unsafe { Self::new_unchecked(v) }
1547 }
1548 }
1549 };
1550 (signed $Int:ty) => {
1552 #[stable(feature = "signed_nonzero_neg", since = "1.71.0")]
1553 #[rustc_const_unstable(feature = "const_ops", issue = "143802")]
1554 const impl Neg for NonZero<$Int> {
1555 type Output = Self;
1556
1557 #[inline]
1558 fn neg(self) -> Self {
1559 unsafe { Self::new_unchecked(self.get().neg()) }
1561 }
1562 }
1563
1564 forward_ref_unop! { impl Neg, neg for NonZero<$Int>,
1565 #[stable(feature = "signed_nonzero_neg", since = "1.71.0")]
1566 #[rustc_const_unstable(feature = "const_ops", issue = "143802")] }
1567 };
1568}
1569
1570#[rustfmt::skip] macro_rules! nonzero_integer_signedness_dependent_methods {
1572 (
1574 Primitive = unsigned $Int:ident,
1575 SignedPrimitive = $Sint:ty,
1576 UnsignedPrimitive = $Uint:ty,
1577 ) => {
1578 #[doc = concat!("assert_eq!(NonZero::<", stringify!($Int), ">::MIN.get(), 1", stringify!($Int), ");")]
1587 #[stable(feature = "nonzero_min_max", since = "1.70.0")]
1589 pub const MIN: Self = Self::new(1).unwrap();
1590
1591 #[doc = concat!("equal to [`", stringify!($Int), "::MAX`].")]
1594 #[doc = concat!("assert_eq!(NonZero::<", stringify!($Int), ">::MAX.get(), ", stringify!($Int), "::MAX);")]
1601 #[stable(feature = "nonzero_min_max", since = "1.70.0")]
1603 pub const MAX: Self = Self::new(<$Int>::MAX).unwrap();
1604
1605 #[doc = concat!("let one = NonZero::new(1", stringify!($Int), ")?;")]
1618 #[doc = concat!("let two = NonZero::new(2", stringify!($Int), ")?;")]
1619 #[doc = concat!("let max = NonZero::new(", stringify!($Int), "::MAX)?;")]
1620 #[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
1627 #[rustc_const_stable(feature = "const_nonzero_checked_ops", since = "1.64.0")]
1628 #[must_use = "this returns the result of the operation, \
1629 without modifying the original"]
1630 #[inline]
1631 pub const fn checked_add(self, other: $Int) -> Option<Self> {
1632 if let Some(result) = self.get().checked_add(other) {
1633 Some(unsafe { Self::new_unchecked(result) })
1641 } else {
1642 None
1643 }
1644 }
1645
1646 #[doc = concat!("Return [`NonZero::<", stringify!($Int), ">::MAX`] on overflow.")]
1648 #[doc = concat!("let one = NonZero::new(1", stringify!($Int), ")?;")]
1657 #[doc = concat!("let two = NonZero::new(2", stringify!($Int), ")?;")]
1658 #[doc = concat!("let max = NonZero::new(", stringify!($Int), "::MAX)?;")]
1659 #[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
1666 #[rustc_const_stable(feature = "const_nonzero_checked_ops", since = "1.64.0")]
1667 #[must_use = "this returns the result of the operation, \
1668 without modifying the original"]
1669 #[inline]
1670 pub const fn saturating_add(self, other: $Int) -> Self {
1671 unsafe { Self::new_unchecked(self.get().saturating_add(other)) }
1679 }
1680
1681 #[doc = concat!("`self + rhs > ", stringify!($Int), "::MAX`.")]
1690 #[doc = concat!("let one = NonZero::new(1", stringify!($Int), ")?;")]
1701 #[doc = concat!("let two = NonZero::new(2", stringify!($Int), ")?;")]
1702 #[unstable(feature = "nonzero_ops", issue = "84186")]
1708 #[must_use = "this returns the result of the operation, \
1709 without modifying the original"]
1710 #[inline]
1711 pub const unsafe fn unchecked_add(self, other: $Int) -> Self {
1712 unsafe { Self::new_unchecked(self.get().unchecked_add(other)) }
1714 }
1715
1716 #[doc = concat!("let two = NonZero::new(2", stringify!($Int), ")?;")]
1729 #[doc = concat!("let three = NonZero::new(3", stringify!($Int), ")?;")]
1730 #[doc = concat!("let four = NonZero::new(4", stringify!($Int), ")?;")]
1731 #[doc = concat!("let max = NonZero::new(", stringify!($Int), "::MAX)?;")]
1732 #[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
1740 #[rustc_const_stable(feature = "const_nonzero_checked_ops", since = "1.64.0")]
1741 #[must_use = "this returns the result of the operation, \
1742 without modifying the original"]
1743 #[inline]
1744 pub const fn checked_next_power_of_two(self) -> Option<Self> {
1745 if let Some(nz) = self.get().checked_next_power_of_two() {
1746 Some(unsafe { Self::new_unchecked(nz) })
1749 } else {
1750 None
1751 }
1752 }
1753
1754 #[doc = concat!("[`", stringify!($Int), "::ilog2`],")]
1758 #[doc = concat!("assert_eq!(NonZero::new(7", stringify!($Int), ")?.ilog2(), 2);")]
1769 #[doc = concat!("assert_eq!(NonZero::new(8", stringify!($Int), ")?.ilog2(), 3);")]
1770 #[doc = concat!("assert_eq!(NonZero::new(9", stringify!($Int), ")?.ilog2(), 3);")]
1771 #[stable(feature = "int_log", since = "1.67.0")]
1775 #[rustc_const_stable(feature = "int_log", since = "1.67.0")]
1776 #[must_use = "this returns the result of the operation, \
1777 without modifying the original"]
1778 #[inline]
1779 pub const fn ilog2(self) -> u32 {
1780 Self::BITS - 1 - self.leading_zeros()
1781 }
1782
1783 #[doc = concat!("[`", stringify!($Int), "::ilog10`],")]
1787 #[doc = concat!("assert_eq!(NonZero::new(99", stringify!($Int), ")?.ilog10(), 1);")]
1798 #[doc = concat!("assert_eq!(NonZero::new(100", stringify!($Int), ")?.ilog10(), 2);")]
1799 #[doc = concat!("assert_eq!(NonZero::new(101", stringify!($Int), ")?.ilog10(), 2);")]
1800 #[stable(feature = "int_log", since = "1.67.0")]
1804 #[rustc_const_stable(feature = "int_log", since = "1.67.0")]
1805 #[must_use = "this returns the result of the operation, \
1806 without modifying the original"]
1807 #[inline]
1808 pub const fn ilog10(self) -> u32 {
1809 imp::int_log10::$Int(self)
1810 }
1811
1812 #[doc = concat!("let one = NonZero::new(1", stringify!($Int), ")?;")]
1826 #[doc = concat!("let two = NonZero::new(2", stringify!($Int), ")?;")]
1827 #[doc = concat!("let four = NonZero::new(4", stringify!($Int), ")?;")]
1828 #[stable(feature = "num_midpoint", since = "1.85.0")]
1835 #[rustc_const_stable(feature = "num_midpoint", since = "1.85.0")]
1836 #[must_use = "this returns the result of the operation, \
1837 without modifying the original"]
1838 #[doc(alias = "average_floor")]
1839 #[doc(alias = "average")]
1840 #[inline]
1841 pub const fn midpoint(self, rhs: Self) -> Self {
1842 unsafe { Self::new_unchecked(self.get().midpoint(rhs.get())) }
1847 }
1848
1849 #[doc = concat!("let eight = NonZero::new(8", stringify!($Int), ")?;")]
1862 #[doc = concat!("let ten = NonZero::new(10", stringify!($Int), ")?;")]
1864 #[must_use]
1869 #[stable(feature = "nonzero_is_power_of_two", since = "1.59.0")]
1870 #[rustc_const_stable(feature = "nonzero_is_power_of_two", since = "1.59.0")]
1871 #[inline]
1872 pub const fn is_power_of_two(self) -> bool {
1873 intrinsics::ctpop(self.get()) < 2
1879 }
1880
1881 #[doc = concat!("let ten = NonZero::new(10", stringify!($Int), ")?;")]
1891 #[doc = concat!("let three = NonZero::new(3", stringify!($Int), ")?;")]
1892 #[stable(feature = "isqrt", since = "1.84.0")]
1898 #[rustc_const_stable(feature = "isqrt", since = "1.84.0")]
1899 #[must_use = "this returns the result of the operation, \
1900 without modifying the original"]
1901 #[inline]
1902 pub const fn isqrt(self) -> Self {
1903 let result = self.get().isqrt();
1904
1905 unsafe { Self::new_unchecked(result) }
1911 }
1912
1913 #[doc = concat!("let n = NonZero::<", stringify!($Int), ">::MAX;")]
1921 #[doc = concat!("assert_eq!(n.cast_signed(), NonZero::new(-1", stringify!($Sint), ").unwrap());")]
1923 #[stable(feature = "integer_sign_cast", since = "1.87.0")]
1925 #[rustc_const_stable(feature = "integer_sign_cast", since = "1.87.0")]
1926 #[must_use = "this returns the result of the operation, \
1927 without modifying the original"]
1928 #[inline(always)]
1929 pub const fn cast_signed(self) -> NonZero<$Sint> {
1930 unsafe { NonZero::new_unchecked(self.get().cast_signed()) }
1932 }
1933
1934 #[doc = concat!("assert_eq!(NonZero::<", stringify!($Int), ">::new(0b1)?.bit_width(), NonZero::new(1)?);")]
1944 #[doc = concat!("assert_eq!(NonZero::<", stringify!($Int), ">::new(0b111)?.bit_width(), NonZero::new(3)?);")]
1945 #[doc = concat!("assert_eq!(NonZero::<", stringify!($Int), ">::new(0b1110)?.bit_width(), NonZero::new(4)?);")]
1946 #[stable(feature = "uint_bit_width", since = "1.97.0")]
1950 #[rustc_const_stable(feature = "uint_bit_width", since = "1.97.0")]
1951 #[must_use = "this returns the result of the operation, \
1952 without modifying the original"]
1953 #[inline(always)]
1954 pub const fn bit_width(self) -> NonZero<u32> {
1955 unsafe { NonZero::new_unchecked(Self::BITS - self.leading_zeros()) }
1958 }
1959 };
1960
1961 (
1963 Primitive = signed $Int:ident,
1964 SignedPrimitive = $Sint:ty,
1965 UnsignedPrimitive = $Uint:ty,
1966 ) => {
1967 #[doc = concat!("equal to [`", stringify!($Int), "::MIN`].")]
1970 #[doc = concat!("assert_eq!(NonZero::<", stringify!($Int), ">::MIN.get(), ", stringify!($Int), "::MIN);")]
1981 #[stable(feature = "nonzero_min_max", since = "1.70.0")]
1983 pub const MIN: Self = Self::new(<$Int>::MIN).unwrap();
1984
1985 #[doc = concat!("equal to [`", stringify!($Int), "::MAX`].")]
1988 #[doc = concat!("assert_eq!(NonZero::<", stringify!($Int), ">::MAX.get(), ", stringify!($Int), "::MAX);")]
1999 #[stable(feature = "nonzero_min_max", since = "1.70.0")]
2001 pub const MAX: Self = Self::new(<$Int>::MAX).unwrap();
2002
2003 #[doc = concat!("See [`", stringify!($Int), "::abs`]")]
2005 #[doc = concat!("let pos = NonZero::new(1", stringify!($Int), ")?;")]
2015 #[doc = concat!("let neg = NonZero::new(-1", stringify!($Int), ")?;")]
2016 #[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
2023 #[rustc_const_stable(feature = "const_nonzero_checked_ops", since = "1.64.0")]
2024 #[must_use = "this returns the result of the operation, \
2025 without modifying the original"]
2026 #[inline]
2027 pub const fn abs(self) -> Self {
2028 unsafe { Self::new_unchecked(self.get().abs()) }
2030 }
2031
2032 #[doc = concat!("`self == NonZero::<", stringify!($Int), ">::MIN`.")]
2035 #[doc = concat!("let pos = NonZero::new(1", stringify!($Int), ")?;")]
2045 #[doc = concat!("let neg = NonZero::new(-1", stringify!($Int), ")?;")]
2046 #[doc = concat!("let min = NonZero::new(", stringify!($Int), "::MIN)?;")]
2047 #[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
2054 #[rustc_const_stable(feature = "const_nonzero_checked_ops", since = "1.64.0")]
2055 #[must_use = "this returns the result of the operation, \
2056 without modifying the original"]
2057 #[inline]
2058 pub const fn checked_abs(self) -> Option<Self> {
2059 if let Some(nz) = self.get().checked_abs() {
2060 Some(unsafe { Self::new_unchecked(nz) })
2062 } else {
2063 None
2064 }
2065 }
2066
2067 #[doc = concat!("[`", stringify!($Int), "::overflowing_abs`].")]
2070 #[doc = concat!("let pos = NonZero::new(1", stringify!($Int), ")?;")]
2079 #[doc = concat!("let neg = NonZero::new(-1", stringify!($Int), ")?;")]
2080 #[doc = concat!("let min = NonZero::new(", stringify!($Int), "::MIN)?;")]
2081 #[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
2089 #[rustc_const_stable(feature = "const_nonzero_checked_ops", since = "1.64.0")]
2090 #[must_use = "this returns the result of the operation, \
2091 without modifying the original"]
2092 #[inline]
2093 pub const fn overflowing_abs(self) -> (Self, bool) {
2094 let (nz, flag) = self.get().overflowing_abs();
2095 (
2096 unsafe { Self::new_unchecked(nz) },
2098 flag,
2099 )
2100 }
2101
2102 #[doc = concat!("[`", stringify!($Int), "::saturating_abs`].")]
2104 #[doc = concat!("let pos = NonZero::new(1", stringify!($Int), ")?;")]
2113 #[doc = concat!("let neg = NonZero::new(-1", stringify!($Int), ")?;")]
2114 #[doc = concat!("let min = NonZero::new(", stringify!($Int), "::MIN)?;")]
2115 #[doc = concat!("let min_plus = NonZero::new(", stringify!($Int), "::MIN + 1)?;")]
2116 #[doc = concat!("let max = NonZero::new(", stringify!($Int), "::MAX)?;")]
2117 #[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
2126 #[rustc_const_stable(feature = "const_nonzero_checked_ops", since = "1.64.0")]
2127 #[must_use = "this returns the result of the operation, \
2128 without modifying the original"]
2129 #[inline]
2130 pub const fn saturating_abs(self) -> Self {
2131 unsafe { Self::new_unchecked(self.get().saturating_abs()) }
2133 }
2134
2135 #[doc = concat!("[`", stringify!($Int), "::wrapping_abs`].")]
2137 #[doc = concat!("let pos = NonZero::new(1", stringify!($Int), ")?;")]
2146 #[doc = concat!("let neg = NonZero::new(-1", stringify!($Int), ")?;")]
2147 #[doc = concat!("let min = NonZero::new(", stringify!($Int), "::MIN)?;")]
2148 #[doc = concat!("# let max = NonZero::new(", stringify!($Int), "::MAX)?;")]
2149 #[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
2158 #[rustc_const_stable(feature = "const_nonzero_checked_ops", since = "1.64.0")]
2159 #[must_use = "this returns the result of the operation, \
2160 without modifying the original"]
2161 #[inline]
2162 pub const fn wrapping_abs(self) -> Self {
2163 unsafe { Self::new_unchecked(self.get().wrapping_abs()) }
2165 }
2166
2167 #[doc = concat!("let u_pos = NonZero::new(1", stringify!($Uint), ")?;")]
2178 #[doc = concat!("let i_pos = NonZero::new(1", stringify!($Int), ")?;")]
2179 #[doc = concat!("let i_neg = NonZero::new(-1", stringify!($Int), ")?;")]
2180 #[doc = concat!("let i_min = NonZero::new(", stringify!($Int), "::MIN)?;")]
2181 #[doc = concat!("let u_max = NonZero::new(", stringify!($Uint), "::MAX / 2 + 1)?;")]
2182 #[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
2190 #[rustc_const_stable(feature = "const_nonzero_checked_ops", since = "1.64.0")]
2191 #[must_use = "this returns the result of the operation, \
2192 without modifying the original"]
2193 #[inline]
2194 pub const fn unsigned_abs(self) -> NonZero<$Uint> {
2195 unsafe { NonZero::new_unchecked(self.get().unsigned_abs()) }
2197 }
2198
2199 #[doc = concat!("let pos_five = NonZero::new(5", stringify!($Int), ")?;")]
2210 #[doc = concat!("let neg_five = NonZero::new(-5", stringify!($Int), ")?;")]
2211 #[must_use]
2218 #[inline]
2219 #[stable(feature = "nonzero_negation_ops", since = "1.71.0")]
2220 #[rustc_const_stable(feature = "nonzero_negation_ops", since = "1.71.0")]
2221 pub const fn is_positive(self) -> bool {
2222 self.get().is_positive()
2223 }
2224
2225 #[doc = concat!("let pos_five = NonZero::new(5", stringify!($Int), ")?;")]
2236 #[doc = concat!("let neg_five = NonZero::new(-5", stringify!($Int), ")?;")]
2237 #[must_use]
2244 #[inline]
2245 #[stable(feature = "nonzero_negation_ops", since = "1.71.0")]
2246 #[rustc_const_stable(feature = "nonzero_negation_ops", since = "1.71.0")]
2247 pub const fn is_negative(self) -> bool {
2248 self.get().is_negative()
2249 }
2250
2251 #[doc = concat!("returning `None` if `self == NonZero::<", stringify!($Int), ">::MIN`.")]
2253 #[doc = concat!("let pos_five = NonZero::new(5", stringify!($Int), ")?;")]
2262 #[doc = concat!("let neg_five = NonZero::new(-5", stringify!($Int), ")?;")]
2263 #[doc = concat!("let min = NonZero::new(", stringify!($Int), "::MIN)?;")]
2264 #[inline]
2271 #[stable(feature = "nonzero_negation_ops", since = "1.71.0")]
2272 #[rustc_const_stable(feature = "nonzero_negation_ops", since = "1.71.0")]
2273 pub const fn checked_neg(self) -> Option<Self> {
2274 if let Some(result) = self.get().checked_neg() {
2275 return Some(unsafe { Self::new_unchecked(result) });
2277 }
2278 None
2279 }
2280
2281 #[doc = concat!("See [`", stringify!($Int), "::overflowing_neg`]")]
2284 #[doc = concat!("let pos_five = NonZero::new(5", stringify!($Int), ")?;")]
2294 #[doc = concat!("let neg_five = NonZero::new(-5", stringify!($Int), ")?;")]
2295 #[doc = concat!("let min = NonZero::new(", stringify!($Int), "::MIN)?;")]
2296 #[inline]
2303 #[stable(feature = "nonzero_negation_ops", since = "1.71.0")]
2304 #[rustc_const_stable(feature = "nonzero_negation_ops", since = "1.71.0")]
2305 pub const fn overflowing_neg(self) -> (Self, bool) {
2306 let (result, overflow) = self.get().overflowing_neg();
2307 ((unsafe { Self::new_unchecked(result) }), overflow)
2309 }
2310
2311 #[doc = concat!("returning [`NonZero::<", stringify!($Int), ">::MAX`]")]
2313 #[doc = concat!("if `self == NonZero::<", stringify!($Int), ">::MIN`")]
2314 #[doc = concat!("let pos_five = NonZero::new(5", stringify!($Int), ")?;")]
2324 #[doc = concat!("let neg_five = NonZero::new(-5", stringify!($Int), ")?;")]
2325 #[doc = concat!("let min = NonZero::new(", stringify!($Int), "::MIN)?;")]
2326 #[doc = concat!("let min_plus_one = NonZero::new(", stringify!($Int), "::MIN + 1)?;")]
2327 #[doc = concat!("let max = NonZero::new(", stringify!($Int), "::MAX)?;")]
2328 #[inline]
2336 #[stable(feature = "nonzero_negation_ops", since = "1.71.0")]
2337 #[rustc_const_stable(feature = "nonzero_negation_ops", since = "1.71.0")]
2338 pub const fn saturating_neg(self) -> Self {
2339 if let Some(result) = self.checked_neg() {
2340 return result;
2341 }
2342 Self::MAX
2343 }
2344
2345 #[doc = concat!("See [`", stringify!($Int), "::wrapping_neg`]")]
2349 #[doc = concat!("let pos_five = NonZero::new(5", stringify!($Int), ")?;")]
2359 #[doc = concat!("let neg_five = NonZero::new(-5", stringify!($Int), ")?;")]
2360 #[doc = concat!("let min = NonZero::new(", stringify!($Int), "::MIN)?;")]
2361 #[inline]
2368 #[stable(feature = "nonzero_negation_ops", since = "1.71.0")]
2369 #[rustc_const_stable(feature = "nonzero_negation_ops", since = "1.71.0")]
2370 pub const fn wrapping_neg(self) -> Self {
2371 let result = self.get().wrapping_neg();
2372 unsafe { Self::new_unchecked(result) }
2374 }
2375
2376 #[doc = concat!("let n = NonZero::new(-1", stringify!($Int), ").unwrap();")]
2384 #[doc = concat!("assert_eq!(n.cast_unsigned(), NonZero::<", stringify!($Uint), ">::MAX);")]
2386 #[stable(feature = "integer_sign_cast", since = "1.87.0")]
2388 #[rustc_const_stable(feature = "integer_sign_cast", since = "1.87.0")]
2389 #[must_use = "this returns the result of the operation, \
2390 without modifying the original"]
2391 #[inline(always)]
2392 pub const fn cast_unsigned(self) -> NonZero<$Uint> {
2393 unsafe { NonZero::new_unchecked(self.get().cast_unsigned()) }
2395 }
2396
2397 };
2398}
2399
2400#[doc = "A [`u8`] that is known not to equal zero."]
#[doc = "For example, `Option<NonZeroU8>` is the same size as `u8`:"]
#[doc =
"assert_eq!(size_of::<Option<core::num::NonZeroU8>>(), size_of::<u8>());"]
#[doc =
"`NonZeroU8` is guaranteed to have the same layout and bit validity as `u8`"]
#[doc = "`Option<NonZeroU8>` is guaranteed to be compatible with `u8`,"]
#[doc = "`NonZeroU8` and `Option<NonZeroU8>`"]
#[doc = "use std::num::NonZeroU8;"]
#[doc = "assert_eq!(size_of::<NonZeroU8>(), size_of::<Option<NonZeroU8>>());"]
#[doc =
"assert_eq!(align_of::<NonZeroU8>(), align_of::<Option<NonZeroU8>>());"]
#[doc = "`NonZeroU8`"]
#[doc = "use std::num::NonZeroU8;"]
#[doc =
"const TEN: NonZeroU8 = NonZeroU8::new(10).expect(\"ten is non-zero\");"]
#[stable(feature = "nonzero", since = "1.28.0")]
pub type NonZeroU8 = NonZero<u8>;
impl NonZero<u8> {
#[doc = "This value is equal to [`u8::BITS`]."]
#[doc = "assert_eq!(NonZero::<u8>::BITS, u8::BITS);"]
#[stable(feature = "nonzero_bits", since = "1.67.0")]
pub const BITS: u32 = <u8>::BITS;
#[doc = "let n = NonZero::<u8>::new(u8::MAX)?;"]
#[stable(feature = "nonzero_leading_trailing_zeros", since = "1.53.0")]
#[rustc_const_stable(feature = "nonzero_leading_trailing_zeros", since =
"1.53.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn leading_zeros(self) -> u32 {
unsafe { intrinsics::ctlz_nonzero(self.get() as u8) }
}
#[doc = "let n = NonZero::<u8>::new(0b0101000)?;"]
#[stable(feature = "nonzero_leading_trailing_zeros", since = "1.53.0")]
#[rustc_const_stable(feature = "nonzero_leading_trailing_zeros", since =
"1.53.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn trailing_zeros(self) -> u32 {
unsafe { intrinsics::cttz_nonzero(self.get() as u8) }
}
#[doc = "let a = NonZero::<u8>::new(0b_01100100)?;"]
#[doc = "let b = NonZero::<u8>::new(0b_01000000)?;"]
#[stable(feature = "isolate_most_least_significant_one", since =
"1.97.0")]
#[rustc_const_stable(feature = "isolate_most_least_significant_one", since
= "1.97.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn isolate_highest_one(self) -> Self {
unsafe {
let bit =
(((1 as u8) <<
(<u8>::BITS - 1)).unchecked_shr(self.leading_zeros()));
NonZero::new_unchecked(bit as u8)
}
}
#[doc = "let a = NonZero::<u8>::new(0b_01100100)?;"]
#[doc = "let b = NonZero::<u8>::new(0b_00000100)?;"]
#[stable(feature = "isolate_most_least_significant_one", since =
"1.97.0")]
#[rustc_const_stable(feature = "isolate_most_least_significant_one", since
= "1.97.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn isolate_lowest_one(self) -> Self {
let n = self.get();
let n = n & n.wrapping_neg();
unsafe { NonZero::new_unchecked(n) }
}
#[doc = "assert_eq!(NonZero::<u8>::new(0b1)?.highest_one(), 0);"]
#[doc = "assert_eq!(NonZero::<u8>::new(0b1_0000)?.highest_one(), 4);"]
#[doc = "assert_eq!(NonZero::<u8>::new(0b1_1111)?.highest_one(), 4);"]
#[stable(feature = "int_lowest_highest_one", since = "1.97.0")]
#[rustc_const_stable(feature = "int_lowest_highest_one", since =
"1.97.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn highest_one(self) -> u32 {
Self::BITS - 1 - self.leading_zeros()
}
#[doc = "assert_eq!(NonZero::<u8>::new(0b1)?.lowest_one(), 0);"]
#[doc = "assert_eq!(NonZero::<u8>::new(0b1_0000)?.lowest_one(), 4);"]
#[doc = "assert_eq!(NonZero::<u8>::new(0b1_1111)?.lowest_one(), 0);"]
#[stable(feature = "int_lowest_highest_one", since = "1.97.0")]
#[rustc_const_stable(feature = "int_lowest_highest_one", since =
"1.97.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn lowest_one(self) -> u32 { self.trailing_zeros() }
#[doc = "let a = NonZero::<u8>::new(0b100_0000)?;"]
#[doc = "let b = NonZero::<u8>::new(0b100_0011)?;"]
#[stable(feature = "non_zero_count_ones", since = "1.86.0")]
#[rustc_const_stable(feature = "non_zero_count_ones", since = "1.86.0")]
#[doc(alias = "popcount")]
#[doc(alias = "popcnt")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn count_ones(self) -> NonZero<u32> {
unsafe { NonZero::new_unchecked(self.get().count_ones()) }
}
#[doc = "let n = NonZero::new(0x82u8)?;"]
#[doc = "let m = NonZero::new(0xa)?;"]
#[doc = "assert_eq!(n.rotate_left(2), m);"]
#[unstable(feature = "nonzero_bitwise", issue = "128281")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn rotate_left(self, n: u32) -> Self {
let result = self.get().rotate_left(n);
unsafe { Self::new_unchecked(result) }
}
#[doc = "let n = NonZero::new(0xau8)?;"]
#[doc = "let m = NonZero::new(0x82)?;"]
#[doc = "assert_eq!(n.rotate_right(2), m);"]
#[unstable(feature = "nonzero_bitwise", issue = "128281")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn rotate_right(self, n: u32) -> Self {
let result = self.get().rotate_right(n);
unsafe { Self::new_unchecked(result) }
}
#[doc = "let n = NonZero::new(0x12u8)?;"]
#[doc = "assert_eq!(m, NonZero::new(0x12)?);"]
#[unstable(feature = "nonzero_bitwise", issue = "128281")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn swap_bytes(self) -> Self {
let result = self.get().swap_bytes();
unsafe { Self::new_unchecked(result) }
}
#[doc = "let n = NonZero::new(0x12u8)?;"]
#[doc = "assert_eq!(m, NonZero::new(0x48)?);"]
#[unstable(feature = "nonzero_bitwise", issue = "128281")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn reverse_bits(self) -> Self {
let result = self.get().reverse_bits();
unsafe { Self::new_unchecked(result) }
}
#[doc = "use std::num::NonZeroU8;"]
#[doc = "let n = NonZero::new(0x1Au8)?;"]
#[doc = " assert_eq!(NonZeroU8::from_be(n), n)"]
#[doc = " assert_eq!(NonZeroU8::from_be(n), n.swap_bytes())"]
#[unstable(feature = "nonzero_bitwise", issue = "128281")]
#[must_use]
#[inline(always)]
pub const fn from_be(x: Self) -> Self {
let result = u8::from_be(x.get());
unsafe { Self::new_unchecked(result) }
}
#[doc = "use std::num::NonZeroU8;"]
#[doc = "let n = NonZero::new(0x1Au8)?;"]
#[doc = " assert_eq!(NonZeroU8::from_le(n), n)"]
#[doc = " assert_eq!(NonZeroU8::from_le(n), n.swap_bytes())"]
#[unstable(feature = "nonzero_bitwise", issue = "128281")]
#[must_use]
#[inline(always)]
pub const fn from_le(x: Self) -> Self {
let result = u8::from_le(x.get());
unsafe { Self::new_unchecked(result) }
}
#[doc = "let n = NonZero::new(0x1Au8)?;"]
#[unstable(feature = "nonzero_bitwise", issue = "128281")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn to_be(self) -> Self {
let result = self.get().to_be();
unsafe { Self::new_unchecked(result) }
}
#[doc = "let n = NonZero::new(0x1Au8)?;"]
#[unstable(feature = "nonzero_bitwise", issue = "128281")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn to_le(self) -> Self {
let result = self.get().to_le();
unsafe { Self::new_unchecked(result) }
}
#[doc = "assert_eq!(NonZero::<u8>::MIN.get(), 1u8);"]
#[stable(feature = "nonzero_min_max", since = "1.70.0")]
pub const MIN: Self = Self::new(1).unwrap();
#[doc = "equal to [`u8::MAX`]."]
#[doc = "assert_eq!(NonZero::<u8>::MAX.get(), u8::MAX);"]
#[stable(feature = "nonzero_min_max", since = "1.70.0")]
pub const MAX: Self = Self::new(<u8>::MAX).unwrap();
#[doc = "let one = NonZero::new(1u8)?;"]
#[doc = "let two = NonZero::new(2u8)?;"]
#[doc = "let max = NonZero::new(u8::MAX)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn checked_add(self, other: u8) -> Option<Self> {
if let Some(result) = self.get().checked_add(other) {
Some(unsafe { Self::new_unchecked(result) })
} else { None }
}
#[doc = "Return [`NonZero::<u8>::MAX`] on overflow."]
#[doc = "let one = NonZero::new(1u8)?;"]
#[doc = "let two = NonZero::new(2u8)?;"]
#[doc = "let max = NonZero::new(u8::MAX)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn saturating_add(self, other: u8) -> Self {
unsafe { Self::new_unchecked(self.get().saturating_add(other)) }
}
#[doc = "`self + rhs > u8::MAX`."]
#[doc = "let one = NonZero::new(1u8)?;"]
#[doc = "let two = NonZero::new(2u8)?;"]
#[unstable(feature = "nonzero_ops", issue = "84186")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const unsafe fn unchecked_add(self, other: u8) -> Self {
unsafe { Self::new_unchecked(self.get().unchecked_add(other)) }
}
#[doc = "let two = NonZero::new(2u8)?;"]
#[doc = "let three = NonZero::new(3u8)?;"]
#[doc = "let four = NonZero::new(4u8)?;"]
#[doc = "let max = NonZero::new(u8::MAX)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn checked_next_power_of_two(self) -> Option<Self> {
if let Some(nz) = self.get().checked_next_power_of_two() {
Some(unsafe { Self::new_unchecked(nz) })
} else { None }
}
#[doc = "[`u8::ilog2`],"]
#[doc = "assert_eq!(NonZero::new(7u8)?.ilog2(), 2);"]
#[doc = "assert_eq!(NonZero::new(8u8)?.ilog2(), 3);"]
#[doc = "assert_eq!(NonZero::new(9u8)?.ilog2(), 3);"]
#[stable(feature = "int_log", since = "1.67.0")]
#[rustc_const_stable(feature = "int_log", since = "1.67.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn ilog2(self) -> u32 { Self::BITS - 1 - self.leading_zeros() }
#[doc = "[`u8::ilog10`],"]
#[doc = "assert_eq!(NonZero::new(99u8)?.ilog10(), 1);"]
#[doc = "assert_eq!(NonZero::new(100u8)?.ilog10(), 2);"]
#[doc = "assert_eq!(NonZero::new(101u8)?.ilog10(), 2);"]
#[stable(feature = "int_log", since = "1.67.0")]
#[rustc_const_stable(feature = "int_log", since = "1.67.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn ilog10(self) -> u32 { imp::int_log10::u8(self) }
#[doc = "let one = NonZero::new(1u8)?;"]
#[doc = "let two = NonZero::new(2u8)?;"]
#[doc = "let four = NonZero::new(4u8)?;"]
#[stable(feature = "num_midpoint", since = "1.85.0")]
#[rustc_const_stable(feature = "num_midpoint", since = "1.85.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[doc(alias = "average_floor")]
#[doc(alias = "average")]
#[inline]
pub const fn midpoint(self, rhs: Self) -> Self {
unsafe { Self::new_unchecked(self.get().midpoint(rhs.get())) }
}
#[doc = "let eight = NonZero::new(8u8)?;"]
#[doc = "let ten = NonZero::new(10u8)?;"]
#[must_use]
#[stable(feature = "nonzero_is_power_of_two", since = "1.59.0")]
#[rustc_const_stable(feature = "nonzero_is_power_of_two", since =
"1.59.0")]
#[inline]
pub const fn is_power_of_two(self) -> bool {
intrinsics::ctpop(self.get()) < 2
}
#[doc = "let ten = NonZero::new(10u8)?;"]
#[doc = "let three = NonZero::new(3u8)?;"]
#[stable(feature = "isqrt", since = "1.84.0")]
#[rustc_const_stable(feature = "isqrt", since = "1.84.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn isqrt(self) -> Self {
let result = self.get().isqrt();
unsafe { Self::new_unchecked(result) }
}
#[doc = "let n = NonZero::<u8>::MAX;"]
#[doc = "assert_eq!(n.cast_signed(), NonZero::new(-1i8).unwrap());"]
#[stable(feature = "integer_sign_cast", since = "1.87.0")]
#[rustc_const_stable(feature = "integer_sign_cast", since = "1.87.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn cast_signed(self) -> NonZero<i8> {
unsafe { NonZero::new_unchecked(self.get().cast_signed()) }
}
#[doc =
"assert_eq!(NonZero::<u8>::new(0b1)?.bit_width(), NonZero::new(1)?);"]
#[doc =
"assert_eq!(NonZero::<u8>::new(0b111)?.bit_width(), NonZero::new(3)?);"]
#[doc =
"assert_eq!(NonZero::<u8>::new(0b1110)?.bit_width(), NonZero::new(4)?);"]
#[stable(feature = "uint_bit_width", since = "1.97.0")]
#[rustc_const_stable(feature = "uint_bit_width", since = "1.97.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn bit_width(self) -> NonZero<u32> {
unsafe { NonZero::new_unchecked(Self::BITS - self.leading_zeros()) }
}
#[doc = "let two = NonZero::new(2u8)?;"]
#[doc = "let four = NonZero::new(4u8)?;"]
#[doc = "let max = NonZero::new(u8::MAX)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn checked_mul(self, other: Self) -> Option<Self> {
if let Some(result) = self.get().checked_mul(other.get()) {
Some(unsafe { Self::new_unchecked(result) })
} else { None }
}
#[doc = "Return [`NonZero::<u8>::MAX`] on overflow."]
#[doc = "let two = NonZero::new(2u8)?;"]
#[doc = "let four = NonZero::new(4u8)?;"]
#[doc = "let max = NonZero::new(u8::MAX)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn saturating_mul(self, other: Self) -> Self {
unsafe { Self::new_unchecked(self.get().saturating_mul(other.get())) }
}
#[doc = "`self * rhs > u8::MAX`."]
#[doc = "let two = NonZero::new(2u8)?;"]
#[doc = "let four = NonZero::new(4u8)?;"]
#[unstable(feature = "nonzero_ops", issue = "84186")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const unsafe fn unchecked_mul(self, other: Self) -> Self {
unsafe { Self::new_unchecked(self.get().unchecked_mul(other.get())) }
}
#[doc = "let three = NonZero::new(3u8)?;"]
#[doc = "let twenty_seven = NonZero::new(27u8)?;"]
#[doc = "let half_max = NonZero::new(u8::MAX / 2)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn checked_pow(self, other: u32) -> Option<Self> {
if let Some(result) = self.get().checked_pow(other) {
Some(unsafe { Self::new_unchecked(result) })
} else { None }
}
#[doc = "Return [`NonZero::<u8>::MAX`] on overflow."]
#[doc = "let three = NonZero::new(3u8)?;"]
#[doc = "let twenty_seven = NonZero::new(27u8)?;"]
#[doc = "let max = NonZero::new(u8::MAX)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn saturating_pow(self, other: u32) -> Self {
unsafe { Self::new_unchecked(self.get().saturating_pow(other)) }
}
#[doc = " `+` "]
#[doc =
"assert_eq!(NonZero::<u8>::from_ascii(b\"+10\"), Ok(NonZero::new(10)?));"]
#[doc = "assert!(NonZero::<u8>::from_ascii(b\"1 \").is_err());"]
#[unstable(feature = "int_from_ascii", issue = "134821")]
#[inline]
pub const fn from_ascii(src: &[u8]) -> Result<Self, ParseIntError> {
Self::from_ascii_radix(src, 10)
}
#[doc = " `+` "]
#[doc =
"assert_eq!(NonZero::<u8>::from_ascii_radix(b\"A\", 16), Ok(NonZero::new(10)?));"]
#[doc = "assert!(NonZero::<u8>::from_ascii_radix(b\"1 \", 10).is_err());"]
#[unstable(feature = "int_from_ascii", issue = "134821")]
#[inline]
pub const fn from_ascii_radix(src: &[u8], radix: u32)
-> Result<Self, ParseIntError> {
let n =
match <u8>::from_ascii_radix(src, radix) {
Ok(n) => n,
Err(err) => return Err(err),
};
if let Some(n) = Self::new(n) {
Ok(n)
} else { Err(ParseIntError { kind: IntErrorKind::Zero }) }
}
#[doc = " `+` "]
#[doc =
"assert_eq!(NonZero::<u8>::from_str_radix(\"A\", 16), Ok(NonZero::new(10)?));"]
#[doc = "assert!(NonZero::<u8>::from_str_radix(\"1 \", 10).is_err());"]
#[unstable(feature = "nonzero_from_str_radix", issue = "152193")]
#[inline]
pub const fn from_str_radix(src: &str, radix: u32)
-> Result<Self, ParseIntError> {
Self::from_ascii_radix(src.as_bytes(), radix)
}
}
#[stable(feature = "nonzero_parse", since = "1.35.0")]
impl FromStr for NonZero<u8> {
type Err = ParseIntError;
fn from_str(src: &str) -> Result<Self, Self::Err> {
Self::from_str_radix(src, 10)
}
}
#[stable(feature = "nonzero_div", since = "1.51.0")]
#[rustc_const_unstable(feature = "const_ops", issue = "143802")]
impl const Div<NonZero<u8>> for u8 {
type Output = u8;
#[doc(alias = "unchecked_div")]
#[inline]
fn div(self, other: NonZero<u8>) -> u8 {
unsafe { intrinsics::unchecked_div(self, other.get()) }
}
}
#[stable(feature = "nonzero_div_assign", since = "1.79.0")]
#[rustc_const_unstable(feature = "const_ops", issue = "143802")]
impl const DivAssign<NonZero<u8>> for u8 {
#[inline]
fn div_assign(&mut self, other: NonZero<u8>) { *self = *self / other; }
}
#[stable(feature = "nonzero_div", since = "1.51.0")]
#[rustc_const_unstable(feature = "const_ops", issue = "143802")]
impl const Rem<NonZero<u8>> for u8 {
type Output = u8;
#[inline]
fn rem(self, other: NonZero<u8>) -> u8 {
unsafe { intrinsics::unchecked_rem(self, other.get()) }
}
}
#[stable(feature = "nonzero_div_assign", since = "1.79.0")]
#[rustc_const_unstable(feature = "const_ops", issue = "143802")]
impl const RemAssign<NonZero<u8>> for u8 {
#[inline]
fn rem_assign(&mut self, other: NonZero<u8>) { *self = *self % other; }
}
impl NonZero<u8> {
#[doc = "let one = NonZero::new(1u8).unwrap();"]
#[doc = "let max = NonZero::new(u8::MAX).unwrap();"]
#[doc = "let two = NonZero::new(2u8).unwrap();"]
#[doc = "let three = NonZero::new(3u8).unwrap();"]
#[stable(feature = "unsigned_nonzero_div_ceil", since = "1.92.0")]
#[rustc_const_stable(feature = "unsigned_nonzero_div_ceil", since =
"1.92.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn div_ceil(self, rhs: Self) -> Self {
let v = self.get().div_ceil(rhs.get());
unsafe { Self::new_unchecked(v) }
}
}nonzero_integer! {
2401 Self = NonZeroU8,
2402 Primitive = unsigned u8,
2403 SignedPrimitive = i8,
2404 rot = 2,
2405 rot_op = "0x82",
2406 rot_result = "0xa",
2407 swap_op = "0x12",
2408 swapped = "0x12",
2409 reversed = "0x48",
2410}
2411
2412#[doc = "A [`u16`] that is known not to equal zero."]
#[doc = "For example, `Option<NonZeroU16>` is the same size as `u16`:"]
#[doc =
"assert_eq!(size_of::<Option<core::num::NonZeroU16>>(), size_of::<u16>());"]
#[doc =
"`NonZeroU16` is guaranteed to have the same layout and bit validity as `u16`"]
#[doc = "`Option<NonZeroU16>` is guaranteed to be compatible with `u16`,"]
#[doc = "`NonZeroU16` and `Option<NonZeroU16>`"]
#[doc = "use std::num::NonZeroU16;"]
#[doc =
"assert_eq!(size_of::<NonZeroU16>(), size_of::<Option<NonZeroU16>>());"]
#[doc =
"assert_eq!(align_of::<NonZeroU16>(), align_of::<Option<NonZeroU16>>());"]
#[doc = "`NonZeroU16`"]
#[doc = "use std::num::NonZeroU16;"]
#[doc =
"const TEN: NonZeroU16 = NonZeroU16::new(10).expect(\"ten is non-zero\");"]
#[stable(feature = "nonzero", since = "1.28.0")]
pub type NonZeroU16 = NonZero<u16>;
impl NonZero<u16> {
#[doc = "This value is equal to [`u16::BITS`]."]
#[doc = "assert_eq!(NonZero::<u16>::BITS, u16::BITS);"]
#[stable(feature = "nonzero_bits", since = "1.67.0")]
pub const BITS: u32 = <u16>::BITS;
#[doc = "let n = NonZero::<u16>::new(u16::MAX)?;"]
#[stable(feature = "nonzero_leading_trailing_zeros", since = "1.53.0")]
#[rustc_const_stable(feature = "nonzero_leading_trailing_zeros", since =
"1.53.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn leading_zeros(self) -> u32 {
unsafe { intrinsics::ctlz_nonzero(self.get() as u16) }
}
#[doc = "let n = NonZero::<u16>::new(0b0101000)?;"]
#[stable(feature = "nonzero_leading_trailing_zeros", since = "1.53.0")]
#[rustc_const_stable(feature = "nonzero_leading_trailing_zeros", since =
"1.53.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn trailing_zeros(self) -> u32 {
unsafe { intrinsics::cttz_nonzero(self.get() as u16) }
}
#[doc = "let a = NonZero::<u16>::new(0b_01100100)?;"]
#[doc = "let b = NonZero::<u16>::new(0b_01000000)?;"]
#[stable(feature = "isolate_most_least_significant_one", since =
"1.97.0")]
#[rustc_const_stable(feature = "isolate_most_least_significant_one", since
= "1.97.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn isolate_highest_one(self) -> Self {
unsafe {
let bit =
(((1 as u16) <<
(<u16>::BITS - 1)).unchecked_shr(self.leading_zeros()));
NonZero::new_unchecked(bit as u16)
}
}
#[doc = "let a = NonZero::<u16>::new(0b_01100100)?;"]
#[doc = "let b = NonZero::<u16>::new(0b_00000100)?;"]
#[stable(feature = "isolate_most_least_significant_one", since =
"1.97.0")]
#[rustc_const_stable(feature = "isolate_most_least_significant_one", since
= "1.97.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn isolate_lowest_one(self) -> Self {
let n = self.get();
let n = n & n.wrapping_neg();
unsafe { NonZero::new_unchecked(n) }
}
#[doc = "assert_eq!(NonZero::<u16>::new(0b1)?.highest_one(), 0);"]
#[doc = "assert_eq!(NonZero::<u16>::new(0b1_0000)?.highest_one(), 4);"]
#[doc = "assert_eq!(NonZero::<u16>::new(0b1_1111)?.highest_one(), 4);"]
#[stable(feature = "int_lowest_highest_one", since = "1.97.0")]
#[rustc_const_stable(feature = "int_lowest_highest_one", since =
"1.97.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn highest_one(self) -> u32 {
Self::BITS - 1 - self.leading_zeros()
}
#[doc = "assert_eq!(NonZero::<u16>::new(0b1)?.lowest_one(), 0);"]
#[doc = "assert_eq!(NonZero::<u16>::new(0b1_0000)?.lowest_one(), 4);"]
#[doc = "assert_eq!(NonZero::<u16>::new(0b1_1111)?.lowest_one(), 0);"]
#[stable(feature = "int_lowest_highest_one", since = "1.97.0")]
#[rustc_const_stable(feature = "int_lowest_highest_one", since =
"1.97.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn lowest_one(self) -> u32 { self.trailing_zeros() }
#[doc = "let a = NonZero::<u16>::new(0b100_0000)?;"]
#[doc = "let b = NonZero::<u16>::new(0b100_0011)?;"]
#[stable(feature = "non_zero_count_ones", since = "1.86.0")]
#[rustc_const_stable(feature = "non_zero_count_ones", since = "1.86.0")]
#[doc(alias = "popcount")]
#[doc(alias = "popcnt")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn count_ones(self) -> NonZero<u32> {
unsafe { NonZero::new_unchecked(self.get().count_ones()) }
}
#[doc = "let n = NonZero::new(0xa003u16)?;"]
#[doc = "let m = NonZero::new(0x3a)?;"]
#[doc = "assert_eq!(n.rotate_left(4), m);"]
#[unstable(feature = "nonzero_bitwise", issue = "128281")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn rotate_left(self, n: u32) -> Self {
let result = self.get().rotate_left(n);
unsafe { Self::new_unchecked(result) }
}
#[doc = "let n = NonZero::new(0x3au16)?;"]
#[doc = "let m = NonZero::new(0xa003)?;"]
#[doc = "assert_eq!(n.rotate_right(4), m);"]
#[unstable(feature = "nonzero_bitwise", issue = "128281")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn rotate_right(self, n: u32) -> Self {
let result = self.get().rotate_right(n);
unsafe { Self::new_unchecked(result) }
}
#[doc = "let n = NonZero::new(0x1234u16)?;"]
#[doc = "assert_eq!(m, NonZero::new(0x3412)?);"]
#[unstable(feature = "nonzero_bitwise", issue = "128281")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn swap_bytes(self) -> Self {
let result = self.get().swap_bytes();
unsafe { Self::new_unchecked(result) }
}
#[doc = "let n = NonZero::new(0x1234u16)?;"]
#[doc = "assert_eq!(m, NonZero::new(0x2c48)?);"]
#[unstable(feature = "nonzero_bitwise", issue = "128281")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn reverse_bits(self) -> Self {
let result = self.get().reverse_bits();
unsafe { Self::new_unchecked(result) }
}
#[doc = "use std::num::NonZeroU16;"]
#[doc = "let n = NonZero::new(0x1Au16)?;"]
#[doc = " assert_eq!(NonZeroU16::from_be(n), n)"]
#[doc = " assert_eq!(NonZeroU16::from_be(n), n.swap_bytes())"]
#[unstable(feature = "nonzero_bitwise", issue = "128281")]
#[must_use]
#[inline(always)]
pub const fn from_be(x: Self) -> Self {
let result = u16::from_be(x.get());
unsafe { Self::new_unchecked(result) }
}
#[doc = "use std::num::NonZeroU16;"]
#[doc = "let n = NonZero::new(0x1Au16)?;"]
#[doc = " assert_eq!(NonZeroU16::from_le(n), n)"]
#[doc = " assert_eq!(NonZeroU16::from_le(n), n.swap_bytes())"]
#[unstable(feature = "nonzero_bitwise", issue = "128281")]
#[must_use]
#[inline(always)]
pub const fn from_le(x: Self) -> Self {
let result = u16::from_le(x.get());
unsafe { Self::new_unchecked(result) }
}
#[doc = "let n = NonZero::new(0x1Au16)?;"]
#[unstable(feature = "nonzero_bitwise", issue = "128281")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn to_be(self) -> Self {
let result = self.get().to_be();
unsafe { Self::new_unchecked(result) }
}
#[doc = "let n = NonZero::new(0x1Au16)?;"]
#[unstable(feature = "nonzero_bitwise", issue = "128281")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn to_le(self) -> Self {
let result = self.get().to_le();
unsafe { Self::new_unchecked(result) }
}
#[doc = "assert_eq!(NonZero::<u16>::MIN.get(), 1u16);"]
#[stable(feature = "nonzero_min_max", since = "1.70.0")]
pub const MIN: Self = Self::new(1).unwrap();
#[doc = "equal to [`u16::MAX`]."]
#[doc = "assert_eq!(NonZero::<u16>::MAX.get(), u16::MAX);"]
#[stable(feature = "nonzero_min_max", since = "1.70.0")]
pub const MAX: Self = Self::new(<u16>::MAX).unwrap();
#[doc = "let one = NonZero::new(1u16)?;"]
#[doc = "let two = NonZero::new(2u16)?;"]
#[doc = "let max = NonZero::new(u16::MAX)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn checked_add(self, other: u16) -> Option<Self> {
if let Some(result) = self.get().checked_add(other) {
Some(unsafe { Self::new_unchecked(result) })
} else { None }
}
#[doc = "Return [`NonZero::<u16>::MAX`] on overflow."]
#[doc = "let one = NonZero::new(1u16)?;"]
#[doc = "let two = NonZero::new(2u16)?;"]
#[doc = "let max = NonZero::new(u16::MAX)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn saturating_add(self, other: u16) -> Self {
unsafe { Self::new_unchecked(self.get().saturating_add(other)) }
}
#[doc = "`self + rhs > u16::MAX`."]
#[doc = "let one = NonZero::new(1u16)?;"]
#[doc = "let two = NonZero::new(2u16)?;"]
#[unstable(feature = "nonzero_ops", issue = "84186")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const unsafe fn unchecked_add(self, other: u16) -> Self {
unsafe { Self::new_unchecked(self.get().unchecked_add(other)) }
}
#[doc = "let two = NonZero::new(2u16)?;"]
#[doc = "let three = NonZero::new(3u16)?;"]
#[doc = "let four = NonZero::new(4u16)?;"]
#[doc = "let max = NonZero::new(u16::MAX)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn checked_next_power_of_two(self) -> Option<Self> {
if let Some(nz) = self.get().checked_next_power_of_two() {
Some(unsafe { Self::new_unchecked(nz) })
} else { None }
}
#[doc = "[`u16::ilog2`],"]
#[doc = "assert_eq!(NonZero::new(7u16)?.ilog2(), 2);"]
#[doc = "assert_eq!(NonZero::new(8u16)?.ilog2(), 3);"]
#[doc = "assert_eq!(NonZero::new(9u16)?.ilog2(), 3);"]
#[stable(feature = "int_log", since = "1.67.0")]
#[rustc_const_stable(feature = "int_log", since = "1.67.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn ilog2(self) -> u32 { Self::BITS - 1 - self.leading_zeros() }
#[doc = "[`u16::ilog10`],"]
#[doc = "assert_eq!(NonZero::new(99u16)?.ilog10(), 1);"]
#[doc = "assert_eq!(NonZero::new(100u16)?.ilog10(), 2);"]
#[doc = "assert_eq!(NonZero::new(101u16)?.ilog10(), 2);"]
#[stable(feature = "int_log", since = "1.67.0")]
#[rustc_const_stable(feature = "int_log", since = "1.67.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn ilog10(self) -> u32 { imp::int_log10::u16(self) }
#[doc = "let one = NonZero::new(1u16)?;"]
#[doc = "let two = NonZero::new(2u16)?;"]
#[doc = "let four = NonZero::new(4u16)?;"]
#[stable(feature = "num_midpoint", since = "1.85.0")]
#[rustc_const_stable(feature = "num_midpoint", since = "1.85.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[doc(alias = "average_floor")]
#[doc(alias = "average")]
#[inline]
pub const fn midpoint(self, rhs: Self) -> Self {
unsafe { Self::new_unchecked(self.get().midpoint(rhs.get())) }
}
#[doc = "let eight = NonZero::new(8u16)?;"]
#[doc = "let ten = NonZero::new(10u16)?;"]
#[must_use]
#[stable(feature = "nonzero_is_power_of_two", since = "1.59.0")]
#[rustc_const_stable(feature = "nonzero_is_power_of_two", since =
"1.59.0")]
#[inline]
pub const fn is_power_of_two(self) -> bool {
intrinsics::ctpop(self.get()) < 2
}
#[doc = "let ten = NonZero::new(10u16)?;"]
#[doc = "let three = NonZero::new(3u16)?;"]
#[stable(feature = "isqrt", since = "1.84.0")]
#[rustc_const_stable(feature = "isqrt", since = "1.84.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn isqrt(self) -> Self {
let result = self.get().isqrt();
unsafe { Self::new_unchecked(result) }
}
#[doc = "let n = NonZero::<u16>::MAX;"]
#[doc = "assert_eq!(n.cast_signed(), NonZero::new(-1i16).unwrap());"]
#[stable(feature = "integer_sign_cast", since = "1.87.0")]
#[rustc_const_stable(feature = "integer_sign_cast", since = "1.87.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn cast_signed(self) -> NonZero<i16> {
unsafe { NonZero::new_unchecked(self.get().cast_signed()) }
}
#[doc =
"assert_eq!(NonZero::<u16>::new(0b1)?.bit_width(), NonZero::new(1)?);"]
#[doc =
"assert_eq!(NonZero::<u16>::new(0b111)?.bit_width(), NonZero::new(3)?);"]
#[doc =
"assert_eq!(NonZero::<u16>::new(0b1110)?.bit_width(), NonZero::new(4)?);"]
#[stable(feature = "uint_bit_width", since = "1.97.0")]
#[rustc_const_stable(feature = "uint_bit_width", since = "1.97.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn bit_width(self) -> NonZero<u32> {
unsafe { NonZero::new_unchecked(Self::BITS - self.leading_zeros()) }
}
#[doc = "let two = NonZero::new(2u16)?;"]
#[doc = "let four = NonZero::new(4u16)?;"]
#[doc = "let max = NonZero::new(u16::MAX)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn checked_mul(self, other: Self) -> Option<Self> {
if let Some(result) = self.get().checked_mul(other.get()) {
Some(unsafe { Self::new_unchecked(result) })
} else { None }
}
#[doc = "Return [`NonZero::<u16>::MAX`] on overflow."]
#[doc = "let two = NonZero::new(2u16)?;"]
#[doc = "let four = NonZero::new(4u16)?;"]
#[doc = "let max = NonZero::new(u16::MAX)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn saturating_mul(self, other: Self) -> Self {
unsafe { Self::new_unchecked(self.get().saturating_mul(other.get())) }
}
#[doc = "`self * rhs > u16::MAX`."]
#[doc = "let two = NonZero::new(2u16)?;"]
#[doc = "let four = NonZero::new(4u16)?;"]
#[unstable(feature = "nonzero_ops", issue = "84186")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const unsafe fn unchecked_mul(self, other: Self) -> Self {
unsafe { Self::new_unchecked(self.get().unchecked_mul(other.get())) }
}
#[doc = "let three = NonZero::new(3u16)?;"]
#[doc = "let twenty_seven = NonZero::new(27u16)?;"]
#[doc = "let half_max = NonZero::new(u16::MAX / 2)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn checked_pow(self, other: u32) -> Option<Self> {
if let Some(result) = self.get().checked_pow(other) {
Some(unsafe { Self::new_unchecked(result) })
} else { None }
}
#[doc = "Return [`NonZero::<u16>::MAX`] on overflow."]
#[doc = "let three = NonZero::new(3u16)?;"]
#[doc = "let twenty_seven = NonZero::new(27u16)?;"]
#[doc = "let max = NonZero::new(u16::MAX)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn saturating_pow(self, other: u32) -> Self {
unsafe { Self::new_unchecked(self.get().saturating_pow(other)) }
}
#[doc = " `+` "]
#[doc =
"assert_eq!(NonZero::<u16>::from_ascii(b\"+10\"), Ok(NonZero::new(10)?));"]
#[doc = "assert!(NonZero::<u16>::from_ascii(b\"1 \").is_err());"]
#[unstable(feature = "int_from_ascii", issue = "134821")]
#[inline]
pub const fn from_ascii(src: &[u8]) -> Result<Self, ParseIntError> {
Self::from_ascii_radix(src, 10)
}
#[doc = " `+` "]
#[doc =
"assert_eq!(NonZero::<u16>::from_ascii_radix(b\"A\", 16), Ok(NonZero::new(10)?));"]
#[doc =
"assert!(NonZero::<u16>::from_ascii_radix(b\"1 \", 10).is_err());"]
#[unstable(feature = "int_from_ascii", issue = "134821")]
#[inline]
pub const fn from_ascii_radix(src: &[u8], radix: u32)
-> Result<Self, ParseIntError> {
let n =
match <u16>::from_ascii_radix(src, radix) {
Ok(n) => n,
Err(err) => return Err(err),
};
if let Some(n) = Self::new(n) {
Ok(n)
} else { Err(ParseIntError { kind: IntErrorKind::Zero }) }
}
#[doc = " `+` "]
#[doc =
"assert_eq!(NonZero::<u16>::from_str_radix(\"A\", 16), Ok(NonZero::new(10)?));"]
#[doc = "assert!(NonZero::<u16>::from_str_radix(\"1 \", 10).is_err());"]
#[unstable(feature = "nonzero_from_str_radix", issue = "152193")]
#[inline]
pub const fn from_str_radix(src: &str, radix: u32)
-> Result<Self, ParseIntError> {
Self::from_ascii_radix(src.as_bytes(), radix)
}
}
#[stable(feature = "nonzero_parse", since = "1.35.0")]
impl FromStr for NonZero<u16> {
type Err = ParseIntError;
fn from_str(src: &str) -> Result<Self, Self::Err> {
Self::from_str_radix(src, 10)
}
}
#[stable(feature = "nonzero_div", since = "1.51.0")]
#[rustc_const_unstable(feature = "const_ops", issue = "143802")]
impl const Div<NonZero<u16>> for u16 {
type Output = u16;
#[doc(alias = "unchecked_div")]
#[inline]
fn div(self, other: NonZero<u16>) -> u16 {
unsafe { intrinsics::unchecked_div(self, other.get()) }
}
}
#[stable(feature = "nonzero_div_assign", since = "1.79.0")]
#[rustc_const_unstable(feature = "const_ops", issue = "143802")]
impl const DivAssign<NonZero<u16>> for u16 {
#[inline]
fn div_assign(&mut self, other: NonZero<u16>) { *self = *self / other; }
}
#[stable(feature = "nonzero_div", since = "1.51.0")]
#[rustc_const_unstable(feature = "const_ops", issue = "143802")]
impl const Rem<NonZero<u16>> for u16 {
type Output = u16;
#[inline]
fn rem(self, other: NonZero<u16>) -> u16 {
unsafe { intrinsics::unchecked_rem(self, other.get()) }
}
}
#[stable(feature = "nonzero_div_assign", since = "1.79.0")]
#[rustc_const_unstable(feature = "const_ops", issue = "143802")]
impl const RemAssign<NonZero<u16>> for u16 {
#[inline]
fn rem_assign(&mut self, other: NonZero<u16>) { *self = *self % other; }
}
impl NonZero<u16> {
#[doc = "let one = NonZero::new(1u16).unwrap();"]
#[doc = "let max = NonZero::new(u16::MAX).unwrap();"]
#[doc = "let two = NonZero::new(2u16).unwrap();"]
#[doc = "let three = NonZero::new(3u16).unwrap();"]
#[stable(feature = "unsigned_nonzero_div_ceil", since = "1.92.0")]
#[rustc_const_stable(feature = "unsigned_nonzero_div_ceil", since =
"1.92.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn div_ceil(self, rhs: Self) -> Self {
let v = self.get().div_ceil(rhs.get());
unsafe { Self::new_unchecked(v) }
}
}nonzero_integer! {
2413 Self = NonZeroU16,
2414 Primitive = unsigned u16,
2415 SignedPrimitive = i16,
2416 rot = 4,
2417 rot_op = "0xa003",
2418 rot_result = "0x3a",
2419 swap_op = "0x1234",
2420 swapped = "0x3412",
2421 reversed = "0x2c48",
2422}
2423
2424#[doc = "A [`u32`] that is known not to equal zero."]
#[doc = "For example, `Option<NonZeroU32>` is the same size as `u32`:"]
#[doc =
"assert_eq!(size_of::<Option<core::num::NonZeroU32>>(), size_of::<u32>());"]
#[doc =
"`NonZeroU32` is guaranteed to have the same layout and bit validity as `u32`"]
#[doc = "`Option<NonZeroU32>` is guaranteed to be compatible with `u32`,"]
#[doc = "`NonZeroU32` and `Option<NonZeroU32>`"]
#[doc = "use std::num::NonZeroU32;"]
#[doc =
"assert_eq!(size_of::<NonZeroU32>(), size_of::<Option<NonZeroU32>>());"]
#[doc =
"assert_eq!(align_of::<NonZeroU32>(), align_of::<Option<NonZeroU32>>());"]
#[doc = "`NonZeroU32`"]
#[doc = "use std::num::NonZeroU32;"]
#[doc =
"const TEN: NonZeroU32 = NonZeroU32::new(10).expect(\"ten is non-zero\");"]
#[stable(feature = "nonzero", since = "1.28.0")]
pub type NonZeroU32 = NonZero<u32>;
impl NonZero<u32> {
#[doc = "This value is equal to [`u32::BITS`]."]
#[doc = "assert_eq!(NonZero::<u32>::BITS, u32::BITS);"]
#[stable(feature = "nonzero_bits", since = "1.67.0")]
pub const BITS: u32 = <u32>::BITS;
#[doc = "let n = NonZero::<u32>::new(u32::MAX)?;"]
#[stable(feature = "nonzero_leading_trailing_zeros", since = "1.53.0")]
#[rustc_const_stable(feature = "nonzero_leading_trailing_zeros", since =
"1.53.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn leading_zeros(self) -> u32 {
unsafe { intrinsics::ctlz_nonzero(self.get() as u32) }
}
#[doc = "let n = NonZero::<u32>::new(0b0101000)?;"]
#[stable(feature = "nonzero_leading_trailing_zeros", since = "1.53.0")]
#[rustc_const_stable(feature = "nonzero_leading_trailing_zeros", since =
"1.53.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn trailing_zeros(self) -> u32 {
unsafe { intrinsics::cttz_nonzero(self.get() as u32) }
}
#[doc = "let a = NonZero::<u32>::new(0b_01100100)?;"]
#[doc = "let b = NonZero::<u32>::new(0b_01000000)?;"]
#[stable(feature = "isolate_most_least_significant_one", since =
"1.97.0")]
#[rustc_const_stable(feature = "isolate_most_least_significant_one", since
= "1.97.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn isolate_highest_one(self) -> Self {
unsafe {
let bit =
(((1 as u32) <<
(<u32>::BITS - 1)).unchecked_shr(self.leading_zeros()));
NonZero::new_unchecked(bit as u32)
}
}
#[doc = "let a = NonZero::<u32>::new(0b_01100100)?;"]
#[doc = "let b = NonZero::<u32>::new(0b_00000100)?;"]
#[stable(feature = "isolate_most_least_significant_one", since =
"1.97.0")]
#[rustc_const_stable(feature = "isolate_most_least_significant_one", since
= "1.97.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn isolate_lowest_one(self) -> Self {
let n = self.get();
let n = n & n.wrapping_neg();
unsafe { NonZero::new_unchecked(n) }
}
#[doc = "assert_eq!(NonZero::<u32>::new(0b1)?.highest_one(), 0);"]
#[doc = "assert_eq!(NonZero::<u32>::new(0b1_0000)?.highest_one(), 4);"]
#[doc = "assert_eq!(NonZero::<u32>::new(0b1_1111)?.highest_one(), 4);"]
#[stable(feature = "int_lowest_highest_one", since = "1.97.0")]
#[rustc_const_stable(feature = "int_lowest_highest_one", since =
"1.97.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn highest_one(self) -> u32 {
Self::BITS - 1 - self.leading_zeros()
}
#[doc = "assert_eq!(NonZero::<u32>::new(0b1)?.lowest_one(), 0);"]
#[doc = "assert_eq!(NonZero::<u32>::new(0b1_0000)?.lowest_one(), 4);"]
#[doc = "assert_eq!(NonZero::<u32>::new(0b1_1111)?.lowest_one(), 0);"]
#[stable(feature = "int_lowest_highest_one", since = "1.97.0")]
#[rustc_const_stable(feature = "int_lowest_highest_one", since =
"1.97.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn lowest_one(self) -> u32 { self.trailing_zeros() }
#[doc = "let a = NonZero::<u32>::new(0b100_0000)?;"]
#[doc = "let b = NonZero::<u32>::new(0b100_0011)?;"]
#[stable(feature = "non_zero_count_ones", since = "1.86.0")]
#[rustc_const_stable(feature = "non_zero_count_ones", since = "1.86.0")]
#[doc(alias = "popcount")]
#[doc(alias = "popcnt")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn count_ones(self) -> NonZero<u32> {
unsafe { NonZero::new_unchecked(self.get().count_ones()) }
}
#[doc = "let n = NonZero::new(0x10000b3u32)?;"]
#[doc = "let m = NonZero::new(0xb301)?;"]
#[doc = "assert_eq!(n.rotate_left(8), m);"]
#[unstable(feature = "nonzero_bitwise", issue = "128281")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn rotate_left(self, n: u32) -> Self {
let result = self.get().rotate_left(n);
unsafe { Self::new_unchecked(result) }
}
#[doc = "let n = NonZero::new(0xb301u32)?;"]
#[doc = "let m = NonZero::new(0x10000b3)?;"]
#[doc = "assert_eq!(n.rotate_right(8), m);"]
#[unstable(feature = "nonzero_bitwise", issue = "128281")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn rotate_right(self, n: u32) -> Self {
let result = self.get().rotate_right(n);
unsafe { Self::new_unchecked(result) }
}
#[doc = "let n = NonZero::new(0x12345678u32)?;"]
#[doc = "assert_eq!(m, NonZero::new(0x78563412)?);"]
#[unstable(feature = "nonzero_bitwise", issue = "128281")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn swap_bytes(self) -> Self {
let result = self.get().swap_bytes();
unsafe { Self::new_unchecked(result) }
}
#[doc = "let n = NonZero::new(0x12345678u32)?;"]
#[doc = "assert_eq!(m, NonZero::new(0x1e6a2c48)?);"]
#[unstable(feature = "nonzero_bitwise", issue = "128281")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn reverse_bits(self) -> Self {
let result = self.get().reverse_bits();
unsafe { Self::new_unchecked(result) }
}
#[doc = "use std::num::NonZeroU32;"]
#[doc = "let n = NonZero::new(0x1Au32)?;"]
#[doc = " assert_eq!(NonZeroU32::from_be(n), n)"]
#[doc = " assert_eq!(NonZeroU32::from_be(n), n.swap_bytes())"]
#[unstable(feature = "nonzero_bitwise", issue = "128281")]
#[must_use]
#[inline(always)]
pub const fn from_be(x: Self) -> Self {
let result = u32::from_be(x.get());
unsafe { Self::new_unchecked(result) }
}
#[doc = "use std::num::NonZeroU32;"]
#[doc = "let n = NonZero::new(0x1Au32)?;"]
#[doc = " assert_eq!(NonZeroU32::from_le(n), n)"]
#[doc = " assert_eq!(NonZeroU32::from_le(n), n.swap_bytes())"]
#[unstable(feature = "nonzero_bitwise", issue = "128281")]
#[must_use]
#[inline(always)]
pub const fn from_le(x: Self) -> Self {
let result = u32::from_le(x.get());
unsafe { Self::new_unchecked(result) }
}
#[doc = "let n = NonZero::new(0x1Au32)?;"]
#[unstable(feature = "nonzero_bitwise", issue = "128281")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn to_be(self) -> Self {
let result = self.get().to_be();
unsafe { Self::new_unchecked(result) }
}
#[doc = "let n = NonZero::new(0x1Au32)?;"]
#[unstable(feature = "nonzero_bitwise", issue = "128281")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn to_le(self) -> Self {
let result = self.get().to_le();
unsafe { Self::new_unchecked(result) }
}
#[doc = "assert_eq!(NonZero::<u32>::MIN.get(), 1u32);"]
#[stable(feature = "nonzero_min_max", since = "1.70.0")]
pub const MIN: Self = Self::new(1).unwrap();
#[doc = "equal to [`u32::MAX`]."]
#[doc = "assert_eq!(NonZero::<u32>::MAX.get(), u32::MAX);"]
#[stable(feature = "nonzero_min_max", since = "1.70.0")]
pub const MAX: Self = Self::new(<u32>::MAX).unwrap();
#[doc = "let one = NonZero::new(1u32)?;"]
#[doc = "let two = NonZero::new(2u32)?;"]
#[doc = "let max = NonZero::new(u32::MAX)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn checked_add(self, other: u32) -> Option<Self> {
if let Some(result) = self.get().checked_add(other) {
Some(unsafe { Self::new_unchecked(result) })
} else { None }
}
#[doc = "Return [`NonZero::<u32>::MAX`] on overflow."]
#[doc = "let one = NonZero::new(1u32)?;"]
#[doc = "let two = NonZero::new(2u32)?;"]
#[doc = "let max = NonZero::new(u32::MAX)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn saturating_add(self, other: u32) -> Self {
unsafe { Self::new_unchecked(self.get().saturating_add(other)) }
}
#[doc = "`self + rhs > u32::MAX`."]
#[doc = "let one = NonZero::new(1u32)?;"]
#[doc = "let two = NonZero::new(2u32)?;"]
#[unstable(feature = "nonzero_ops", issue = "84186")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const unsafe fn unchecked_add(self, other: u32) -> Self {
unsafe { Self::new_unchecked(self.get().unchecked_add(other)) }
}
#[doc = "let two = NonZero::new(2u32)?;"]
#[doc = "let three = NonZero::new(3u32)?;"]
#[doc = "let four = NonZero::new(4u32)?;"]
#[doc = "let max = NonZero::new(u32::MAX)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn checked_next_power_of_two(self) -> Option<Self> {
if let Some(nz) = self.get().checked_next_power_of_two() {
Some(unsafe { Self::new_unchecked(nz) })
} else { None }
}
#[doc = "[`u32::ilog2`],"]
#[doc = "assert_eq!(NonZero::new(7u32)?.ilog2(), 2);"]
#[doc = "assert_eq!(NonZero::new(8u32)?.ilog2(), 3);"]
#[doc = "assert_eq!(NonZero::new(9u32)?.ilog2(), 3);"]
#[stable(feature = "int_log", since = "1.67.0")]
#[rustc_const_stable(feature = "int_log", since = "1.67.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn ilog2(self) -> u32 { Self::BITS - 1 - self.leading_zeros() }
#[doc = "[`u32::ilog10`],"]
#[doc = "assert_eq!(NonZero::new(99u32)?.ilog10(), 1);"]
#[doc = "assert_eq!(NonZero::new(100u32)?.ilog10(), 2);"]
#[doc = "assert_eq!(NonZero::new(101u32)?.ilog10(), 2);"]
#[stable(feature = "int_log", since = "1.67.0")]
#[rustc_const_stable(feature = "int_log", since = "1.67.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn ilog10(self) -> u32 { imp::int_log10::u32(self) }
#[doc = "let one = NonZero::new(1u32)?;"]
#[doc = "let two = NonZero::new(2u32)?;"]
#[doc = "let four = NonZero::new(4u32)?;"]
#[stable(feature = "num_midpoint", since = "1.85.0")]
#[rustc_const_stable(feature = "num_midpoint", since = "1.85.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[doc(alias = "average_floor")]
#[doc(alias = "average")]
#[inline]
pub const fn midpoint(self, rhs: Self) -> Self {
unsafe { Self::new_unchecked(self.get().midpoint(rhs.get())) }
}
#[doc = "let eight = NonZero::new(8u32)?;"]
#[doc = "let ten = NonZero::new(10u32)?;"]
#[must_use]
#[stable(feature = "nonzero_is_power_of_two", since = "1.59.0")]
#[rustc_const_stable(feature = "nonzero_is_power_of_two", since =
"1.59.0")]
#[inline]
pub const fn is_power_of_two(self) -> bool {
intrinsics::ctpop(self.get()) < 2
}
#[doc = "let ten = NonZero::new(10u32)?;"]
#[doc = "let three = NonZero::new(3u32)?;"]
#[stable(feature = "isqrt", since = "1.84.0")]
#[rustc_const_stable(feature = "isqrt", since = "1.84.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn isqrt(self) -> Self {
let result = self.get().isqrt();
unsafe { Self::new_unchecked(result) }
}
#[doc = "let n = NonZero::<u32>::MAX;"]
#[doc = "assert_eq!(n.cast_signed(), NonZero::new(-1i32).unwrap());"]
#[stable(feature = "integer_sign_cast", since = "1.87.0")]
#[rustc_const_stable(feature = "integer_sign_cast", since = "1.87.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn cast_signed(self) -> NonZero<i32> {
unsafe { NonZero::new_unchecked(self.get().cast_signed()) }
}
#[doc =
"assert_eq!(NonZero::<u32>::new(0b1)?.bit_width(), NonZero::new(1)?);"]
#[doc =
"assert_eq!(NonZero::<u32>::new(0b111)?.bit_width(), NonZero::new(3)?);"]
#[doc =
"assert_eq!(NonZero::<u32>::new(0b1110)?.bit_width(), NonZero::new(4)?);"]
#[stable(feature = "uint_bit_width", since = "1.97.0")]
#[rustc_const_stable(feature = "uint_bit_width", since = "1.97.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn bit_width(self) -> NonZero<u32> {
unsafe { NonZero::new_unchecked(Self::BITS - self.leading_zeros()) }
}
#[doc = "let two = NonZero::new(2u32)?;"]
#[doc = "let four = NonZero::new(4u32)?;"]
#[doc = "let max = NonZero::new(u32::MAX)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn checked_mul(self, other: Self) -> Option<Self> {
if let Some(result) = self.get().checked_mul(other.get()) {
Some(unsafe { Self::new_unchecked(result) })
} else { None }
}
#[doc = "Return [`NonZero::<u32>::MAX`] on overflow."]
#[doc = "let two = NonZero::new(2u32)?;"]
#[doc = "let four = NonZero::new(4u32)?;"]
#[doc = "let max = NonZero::new(u32::MAX)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn saturating_mul(self, other: Self) -> Self {
unsafe { Self::new_unchecked(self.get().saturating_mul(other.get())) }
}
#[doc = "`self * rhs > u32::MAX`."]
#[doc = "let two = NonZero::new(2u32)?;"]
#[doc = "let four = NonZero::new(4u32)?;"]
#[unstable(feature = "nonzero_ops", issue = "84186")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const unsafe fn unchecked_mul(self, other: Self) -> Self {
unsafe { Self::new_unchecked(self.get().unchecked_mul(other.get())) }
}
#[doc = "let three = NonZero::new(3u32)?;"]
#[doc = "let twenty_seven = NonZero::new(27u32)?;"]
#[doc = "let half_max = NonZero::new(u32::MAX / 2)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn checked_pow(self, other: u32) -> Option<Self> {
if let Some(result) = self.get().checked_pow(other) {
Some(unsafe { Self::new_unchecked(result) })
} else { None }
}
#[doc = "Return [`NonZero::<u32>::MAX`] on overflow."]
#[doc = "let three = NonZero::new(3u32)?;"]
#[doc = "let twenty_seven = NonZero::new(27u32)?;"]
#[doc = "let max = NonZero::new(u32::MAX)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn saturating_pow(self, other: u32) -> Self {
unsafe { Self::new_unchecked(self.get().saturating_pow(other)) }
}
#[doc = " `+` "]
#[doc =
"assert_eq!(NonZero::<u32>::from_ascii(b\"+10\"), Ok(NonZero::new(10)?));"]
#[doc = "assert!(NonZero::<u32>::from_ascii(b\"1 \").is_err());"]
#[unstable(feature = "int_from_ascii", issue = "134821")]
#[inline]
pub const fn from_ascii(src: &[u8]) -> Result<Self, ParseIntError> {
Self::from_ascii_radix(src, 10)
}
#[doc = " `+` "]
#[doc =
"assert_eq!(NonZero::<u32>::from_ascii_radix(b\"A\", 16), Ok(NonZero::new(10)?));"]
#[doc =
"assert!(NonZero::<u32>::from_ascii_radix(b\"1 \", 10).is_err());"]
#[unstable(feature = "int_from_ascii", issue = "134821")]
#[inline]
pub const fn from_ascii_radix(src: &[u8], radix: u32)
-> Result<Self, ParseIntError> {
let n =
match <u32>::from_ascii_radix(src, radix) {
Ok(n) => n,
Err(err) => return Err(err),
};
if let Some(n) = Self::new(n) {
Ok(n)
} else { Err(ParseIntError { kind: IntErrorKind::Zero }) }
}
#[doc = " `+` "]
#[doc =
"assert_eq!(NonZero::<u32>::from_str_radix(\"A\", 16), Ok(NonZero::new(10)?));"]
#[doc = "assert!(NonZero::<u32>::from_str_radix(\"1 \", 10).is_err());"]
#[unstable(feature = "nonzero_from_str_radix", issue = "152193")]
#[inline]
pub const fn from_str_radix(src: &str, radix: u32)
-> Result<Self, ParseIntError> {
Self::from_ascii_radix(src.as_bytes(), radix)
}
}
#[stable(feature = "nonzero_parse", since = "1.35.0")]
impl FromStr for NonZero<u32> {
type Err = ParseIntError;
fn from_str(src: &str) -> Result<Self, Self::Err> {
Self::from_str_radix(src, 10)
}
}
#[stable(feature = "nonzero_div", since = "1.51.0")]
#[rustc_const_unstable(feature = "const_ops", issue = "143802")]
impl const Div<NonZero<u32>> for u32 {
type Output = u32;
#[doc(alias = "unchecked_div")]
#[inline]
fn div(self, other: NonZero<u32>) -> u32 {
unsafe { intrinsics::unchecked_div(self, other.get()) }
}
}
#[stable(feature = "nonzero_div_assign", since = "1.79.0")]
#[rustc_const_unstable(feature = "const_ops", issue = "143802")]
impl const DivAssign<NonZero<u32>> for u32 {
#[inline]
fn div_assign(&mut self, other: NonZero<u32>) { *self = *self / other; }
}
#[stable(feature = "nonzero_div", since = "1.51.0")]
#[rustc_const_unstable(feature = "const_ops", issue = "143802")]
impl const Rem<NonZero<u32>> for u32 {
type Output = u32;
#[inline]
fn rem(self, other: NonZero<u32>) -> u32 {
unsafe { intrinsics::unchecked_rem(self, other.get()) }
}
}
#[stable(feature = "nonzero_div_assign", since = "1.79.0")]
#[rustc_const_unstable(feature = "const_ops", issue = "143802")]
impl const RemAssign<NonZero<u32>> for u32 {
#[inline]
fn rem_assign(&mut self, other: NonZero<u32>) { *self = *self % other; }
}
impl NonZero<u32> {
#[doc = "let one = NonZero::new(1u32).unwrap();"]
#[doc = "let max = NonZero::new(u32::MAX).unwrap();"]
#[doc = "let two = NonZero::new(2u32).unwrap();"]
#[doc = "let three = NonZero::new(3u32).unwrap();"]
#[stable(feature = "unsigned_nonzero_div_ceil", since = "1.92.0")]
#[rustc_const_stable(feature = "unsigned_nonzero_div_ceil", since =
"1.92.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn div_ceil(self, rhs: Self) -> Self {
let v = self.get().div_ceil(rhs.get());
unsafe { Self::new_unchecked(v) }
}
}nonzero_integer! {
2425 Self = NonZeroU32,
2426 Primitive = unsigned u32,
2427 SignedPrimitive = i32,
2428 rot = 8,
2429 rot_op = "0x10000b3",
2430 rot_result = "0xb301",
2431 swap_op = "0x12345678",
2432 swapped = "0x78563412",
2433 reversed = "0x1e6a2c48",
2434}
2435
2436#[doc = "A [`u64`] that is known not to equal zero."]
#[doc = "For example, `Option<NonZeroU64>` is the same size as `u64`:"]
#[doc =
"assert_eq!(size_of::<Option<core::num::NonZeroU64>>(), size_of::<u64>());"]
#[doc =
"`NonZeroU64` is guaranteed to have the same layout and bit validity as `u64`"]
#[doc = "`Option<NonZeroU64>` is guaranteed to be compatible with `u64`,"]
#[doc = "`NonZeroU64` and `Option<NonZeroU64>`"]
#[doc = "use std::num::NonZeroU64;"]
#[doc =
"assert_eq!(size_of::<NonZeroU64>(), size_of::<Option<NonZeroU64>>());"]
#[doc =
"assert_eq!(align_of::<NonZeroU64>(), align_of::<Option<NonZeroU64>>());"]
#[doc = "`NonZeroU64`"]
#[doc = "use std::num::NonZeroU64;"]
#[doc =
"const TEN: NonZeroU64 = NonZeroU64::new(10).expect(\"ten is non-zero\");"]
#[stable(feature = "nonzero", since = "1.28.0")]
pub type NonZeroU64 = NonZero<u64>;
impl NonZero<u64> {
#[doc = "This value is equal to [`u64::BITS`]."]
#[doc = "assert_eq!(NonZero::<u64>::BITS, u64::BITS);"]
#[stable(feature = "nonzero_bits", since = "1.67.0")]
pub const BITS: u32 = <u64>::BITS;
#[doc = "let n = NonZero::<u64>::new(u64::MAX)?;"]
#[stable(feature = "nonzero_leading_trailing_zeros", since = "1.53.0")]
#[rustc_const_stable(feature = "nonzero_leading_trailing_zeros", since =
"1.53.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn leading_zeros(self) -> u32 {
unsafe { intrinsics::ctlz_nonzero(self.get() as u64) }
}
#[doc = "let n = NonZero::<u64>::new(0b0101000)?;"]
#[stable(feature = "nonzero_leading_trailing_zeros", since = "1.53.0")]
#[rustc_const_stable(feature = "nonzero_leading_trailing_zeros", since =
"1.53.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn trailing_zeros(self) -> u32 {
unsafe { intrinsics::cttz_nonzero(self.get() as u64) }
}
#[doc = "let a = NonZero::<u64>::new(0b_01100100)?;"]
#[doc = "let b = NonZero::<u64>::new(0b_01000000)?;"]
#[stable(feature = "isolate_most_least_significant_one", since =
"1.97.0")]
#[rustc_const_stable(feature = "isolate_most_least_significant_one", since
= "1.97.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn isolate_highest_one(self) -> Self {
unsafe {
let bit =
(((1 as u64) <<
(<u64>::BITS - 1)).unchecked_shr(self.leading_zeros()));
NonZero::new_unchecked(bit as u64)
}
}
#[doc = "let a = NonZero::<u64>::new(0b_01100100)?;"]
#[doc = "let b = NonZero::<u64>::new(0b_00000100)?;"]
#[stable(feature = "isolate_most_least_significant_one", since =
"1.97.0")]
#[rustc_const_stable(feature = "isolate_most_least_significant_one", since
= "1.97.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn isolate_lowest_one(self) -> Self {
let n = self.get();
let n = n & n.wrapping_neg();
unsafe { NonZero::new_unchecked(n) }
}
#[doc = "assert_eq!(NonZero::<u64>::new(0b1)?.highest_one(), 0);"]
#[doc = "assert_eq!(NonZero::<u64>::new(0b1_0000)?.highest_one(), 4);"]
#[doc = "assert_eq!(NonZero::<u64>::new(0b1_1111)?.highest_one(), 4);"]
#[stable(feature = "int_lowest_highest_one", since = "1.97.0")]
#[rustc_const_stable(feature = "int_lowest_highest_one", since =
"1.97.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn highest_one(self) -> u32 {
Self::BITS - 1 - self.leading_zeros()
}
#[doc = "assert_eq!(NonZero::<u64>::new(0b1)?.lowest_one(), 0);"]
#[doc = "assert_eq!(NonZero::<u64>::new(0b1_0000)?.lowest_one(), 4);"]
#[doc = "assert_eq!(NonZero::<u64>::new(0b1_1111)?.lowest_one(), 0);"]
#[stable(feature = "int_lowest_highest_one", since = "1.97.0")]
#[rustc_const_stable(feature = "int_lowest_highest_one", since =
"1.97.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn lowest_one(self) -> u32 { self.trailing_zeros() }
#[doc = "let a = NonZero::<u64>::new(0b100_0000)?;"]
#[doc = "let b = NonZero::<u64>::new(0b100_0011)?;"]
#[stable(feature = "non_zero_count_ones", since = "1.86.0")]
#[rustc_const_stable(feature = "non_zero_count_ones", since = "1.86.0")]
#[doc(alias = "popcount")]
#[doc(alias = "popcnt")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn count_ones(self) -> NonZero<u32> {
unsafe { NonZero::new_unchecked(self.get().count_ones()) }
}
#[doc = "let n = NonZero::new(0xaa00000000006e1u64)?;"]
#[doc = "let m = NonZero::new(0x6e10aa)?;"]
#[doc = "assert_eq!(n.rotate_left(12), m);"]
#[unstable(feature = "nonzero_bitwise", issue = "128281")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn rotate_left(self, n: u32) -> Self {
let result = self.get().rotate_left(n);
unsafe { Self::new_unchecked(result) }
}
#[doc = "let n = NonZero::new(0x6e10aau64)?;"]
#[doc = "let m = NonZero::new(0xaa00000000006e1)?;"]
#[doc = "assert_eq!(n.rotate_right(12), m);"]
#[unstable(feature = "nonzero_bitwise", issue = "128281")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn rotate_right(self, n: u32) -> Self {
let result = self.get().rotate_right(n);
unsafe { Self::new_unchecked(result) }
}
#[doc = "let n = NonZero::new(0x1234567890123456u64)?;"]
#[doc = "assert_eq!(m, NonZero::new(0x5634129078563412)?);"]
#[unstable(feature = "nonzero_bitwise", issue = "128281")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn swap_bytes(self) -> Self {
let result = self.get().swap_bytes();
unsafe { Self::new_unchecked(result) }
}
#[doc = "let n = NonZero::new(0x1234567890123456u64)?;"]
#[doc = "assert_eq!(m, NonZero::new(0x6a2c48091e6a2c48)?);"]
#[unstable(feature = "nonzero_bitwise", issue = "128281")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn reverse_bits(self) -> Self {
let result = self.get().reverse_bits();
unsafe { Self::new_unchecked(result) }
}
#[doc = "use std::num::NonZeroU64;"]
#[doc = "let n = NonZero::new(0x1Au64)?;"]
#[doc = " assert_eq!(NonZeroU64::from_be(n), n)"]
#[doc = " assert_eq!(NonZeroU64::from_be(n), n.swap_bytes())"]
#[unstable(feature = "nonzero_bitwise", issue = "128281")]
#[must_use]
#[inline(always)]
pub const fn from_be(x: Self) -> Self {
let result = u64::from_be(x.get());
unsafe { Self::new_unchecked(result) }
}
#[doc = "use std::num::NonZeroU64;"]
#[doc = "let n = NonZero::new(0x1Au64)?;"]
#[doc = " assert_eq!(NonZeroU64::from_le(n), n)"]
#[doc = " assert_eq!(NonZeroU64::from_le(n), n.swap_bytes())"]
#[unstable(feature = "nonzero_bitwise", issue = "128281")]
#[must_use]
#[inline(always)]
pub const fn from_le(x: Self) -> Self {
let result = u64::from_le(x.get());
unsafe { Self::new_unchecked(result) }
}
#[doc = "let n = NonZero::new(0x1Au64)?;"]
#[unstable(feature = "nonzero_bitwise", issue = "128281")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn to_be(self) -> Self {
let result = self.get().to_be();
unsafe { Self::new_unchecked(result) }
}
#[doc = "let n = NonZero::new(0x1Au64)?;"]
#[unstable(feature = "nonzero_bitwise", issue = "128281")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn to_le(self) -> Self {
let result = self.get().to_le();
unsafe { Self::new_unchecked(result) }
}
#[doc = "assert_eq!(NonZero::<u64>::MIN.get(), 1u64);"]
#[stable(feature = "nonzero_min_max", since = "1.70.0")]
pub const MIN: Self = Self::new(1).unwrap();
#[doc = "equal to [`u64::MAX`]."]
#[doc = "assert_eq!(NonZero::<u64>::MAX.get(), u64::MAX);"]
#[stable(feature = "nonzero_min_max", since = "1.70.0")]
pub const MAX: Self = Self::new(<u64>::MAX).unwrap();
#[doc = "let one = NonZero::new(1u64)?;"]
#[doc = "let two = NonZero::new(2u64)?;"]
#[doc = "let max = NonZero::new(u64::MAX)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn checked_add(self, other: u64) -> Option<Self> {
if let Some(result) = self.get().checked_add(other) {
Some(unsafe { Self::new_unchecked(result) })
} else { None }
}
#[doc = "Return [`NonZero::<u64>::MAX`] on overflow."]
#[doc = "let one = NonZero::new(1u64)?;"]
#[doc = "let two = NonZero::new(2u64)?;"]
#[doc = "let max = NonZero::new(u64::MAX)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn saturating_add(self, other: u64) -> Self {
unsafe { Self::new_unchecked(self.get().saturating_add(other)) }
}
#[doc = "`self + rhs > u64::MAX`."]
#[doc = "let one = NonZero::new(1u64)?;"]
#[doc = "let two = NonZero::new(2u64)?;"]
#[unstable(feature = "nonzero_ops", issue = "84186")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const unsafe fn unchecked_add(self, other: u64) -> Self {
unsafe { Self::new_unchecked(self.get().unchecked_add(other)) }
}
#[doc = "let two = NonZero::new(2u64)?;"]
#[doc = "let three = NonZero::new(3u64)?;"]
#[doc = "let four = NonZero::new(4u64)?;"]
#[doc = "let max = NonZero::new(u64::MAX)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn checked_next_power_of_two(self) -> Option<Self> {
if let Some(nz) = self.get().checked_next_power_of_two() {
Some(unsafe { Self::new_unchecked(nz) })
} else { None }
}
#[doc = "[`u64::ilog2`],"]
#[doc = "assert_eq!(NonZero::new(7u64)?.ilog2(), 2);"]
#[doc = "assert_eq!(NonZero::new(8u64)?.ilog2(), 3);"]
#[doc = "assert_eq!(NonZero::new(9u64)?.ilog2(), 3);"]
#[stable(feature = "int_log", since = "1.67.0")]
#[rustc_const_stable(feature = "int_log", since = "1.67.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn ilog2(self) -> u32 { Self::BITS - 1 - self.leading_zeros() }
#[doc = "[`u64::ilog10`],"]
#[doc = "assert_eq!(NonZero::new(99u64)?.ilog10(), 1);"]
#[doc = "assert_eq!(NonZero::new(100u64)?.ilog10(), 2);"]
#[doc = "assert_eq!(NonZero::new(101u64)?.ilog10(), 2);"]
#[stable(feature = "int_log", since = "1.67.0")]
#[rustc_const_stable(feature = "int_log", since = "1.67.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn ilog10(self) -> u32 { imp::int_log10::u64(self) }
#[doc = "let one = NonZero::new(1u64)?;"]
#[doc = "let two = NonZero::new(2u64)?;"]
#[doc = "let four = NonZero::new(4u64)?;"]
#[stable(feature = "num_midpoint", since = "1.85.0")]
#[rustc_const_stable(feature = "num_midpoint", since = "1.85.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[doc(alias = "average_floor")]
#[doc(alias = "average")]
#[inline]
pub const fn midpoint(self, rhs: Self) -> Self {
unsafe { Self::new_unchecked(self.get().midpoint(rhs.get())) }
}
#[doc = "let eight = NonZero::new(8u64)?;"]
#[doc = "let ten = NonZero::new(10u64)?;"]
#[must_use]
#[stable(feature = "nonzero_is_power_of_two", since = "1.59.0")]
#[rustc_const_stable(feature = "nonzero_is_power_of_two", since =
"1.59.0")]
#[inline]
pub const fn is_power_of_two(self) -> bool {
intrinsics::ctpop(self.get()) < 2
}
#[doc = "let ten = NonZero::new(10u64)?;"]
#[doc = "let three = NonZero::new(3u64)?;"]
#[stable(feature = "isqrt", since = "1.84.0")]
#[rustc_const_stable(feature = "isqrt", since = "1.84.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn isqrt(self) -> Self {
let result = self.get().isqrt();
unsafe { Self::new_unchecked(result) }
}
#[doc = "let n = NonZero::<u64>::MAX;"]
#[doc = "assert_eq!(n.cast_signed(), NonZero::new(-1i64).unwrap());"]
#[stable(feature = "integer_sign_cast", since = "1.87.0")]
#[rustc_const_stable(feature = "integer_sign_cast", since = "1.87.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn cast_signed(self) -> NonZero<i64> {
unsafe { NonZero::new_unchecked(self.get().cast_signed()) }
}
#[doc =
"assert_eq!(NonZero::<u64>::new(0b1)?.bit_width(), NonZero::new(1)?);"]
#[doc =
"assert_eq!(NonZero::<u64>::new(0b111)?.bit_width(), NonZero::new(3)?);"]
#[doc =
"assert_eq!(NonZero::<u64>::new(0b1110)?.bit_width(), NonZero::new(4)?);"]
#[stable(feature = "uint_bit_width", since = "1.97.0")]
#[rustc_const_stable(feature = "uint_bit_width", since = "1.97.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn bit_width(self) -> NonZero<u32> {
unsafe { NonZero::new_unchecked(Self::BITS - self.leading_zeros()) }
}
#[doc = "let two = NonZero::new(2u64)?;"]
#[doc = "let four = NonZero::new(4u64)?;"]
#[doc = "let max = NonZero::new(u64::MAX)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn checked_mul(self, other: Self) -> Option<Self> {
if let Some(result) = self.get().checked_mul(other.get()) {
Some(unsafe { Self::new_unchecked(result) })
} else { None }
}
#[doc = "Return [`NonZero::<u64>::MAX`] on overflow."]
#[doc = "let two = NonZero::new(2u64)?;"]
#[doc = "let four = NonZero::new(4u64)?;"]
#[doc = "let max = NonZero::new(u64::MAX)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn saturating_mul(self, other: Self) -> Self {
unsafe { Self::new_unchecked(self.get().saturating_mul(other.get())) }
}
#[doc = "`self * rhs > u64::MAX`."]
#[doc = "let two = NonZero::new(2u64)?;"]
#[doc = "let four = NonZero::new(4u64)?;"]
#[unstable(feature = "nonzero_ops", issue = "84186")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const unsafe fn unchecked_mul(self, other: Self) -> Self {
unsafe { Self::new_unchecked(self.get().unchecked_mul(other.get())) }
}
#[doc = "let three = NonZero::new(3u64)?;"]
#[doc = "let twenty_seven = NonZero::new(27u64)?;"]
#[doc = "let half_max = NonZero::new(u64::MAX / 2)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn checked_pow(self, other: u32) -> Option<Self> {
if let Some(result) = self.get().checked_pow(other) {
Some(unsafe { Self::new_unchecked(result) })
} else { None }
}
#[doc = "Return [`NonZero::<u64>::MAX`] on overflow."]
#[doc = "let three = NonZero::new(3u64)?;"]
#[doc = "let twenty_seven = NonZero::new(27u64)?;"]
#[doc = "let max = NonZero::new(u64::MAX)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn saturating_pow(self, other: u32) -> Self {
unsafe { Self::new_unchecked(self.get().saturating_pow(other)) }
}
#[doc = " `+` "]
#[doc =
"assert_eq!(NonZero::<u64>::from_ascii(b\"+10\"), Ok(NonZero::new(10)?));"]
#[doc = "assert!(NonZero::<u64>::from_ascii(b\"1 \").is_err());"]
#[unstable(feature = "int_from_ascii", issue = "134821")]
#[inline]
pub const fn from_ascii(src: &[u8]) -> Result<Self, ParseIntError> {
Self::from_ascii_radix(src, 10)
}
#[doc = " `+` "]
#[doc =
"assert_eq!(NonZero::<u64>::from_ascii_radix(b\"A\", 16), Ok(NonZero::new(10)?));"]
#[doc =
"assert!(NonZero::<u64>::from_ascii_radix(b\"1 \", 10).is_err());"]
#[unstable(feature = "int_from_ascii", issue = "134821")]
#[inline]
pub const fn from_ascii_radix(src: &[u8], radix: u32)
-> Result<Self, ParseIntError> {
let n =
match <u64>::from_ascii_radix(src, radix) {
Ok(n) => n,
Err(err) => return Err(err),
};
if let Some(n) = Self::new(n) {
Ok(n)
} else { Err(ParseIntError { kind: IntErrorKind::Zero }) }
}
#[doc = " `+` "]
#[doc =
"assert_eq!(NonZero::<u64>::from_str_radix(\"A\", 16), Ok(NonZero::new(10)?));"]
#[doc = "assert!(NonZero::<u64>::from_str_radix(\"1 \", 10).is_err());"]
#[unstable(feature = "nonzero_from_str_radix", issue = "152193")]
#[inline]
pub const fn from_str_radix(src: &str, radix: u32)
-> Result<Self, ParseIntError> {
Self::from_ascii_radix(src.as_bytes(), radix)
}
}
#[stable(feature = "nonzero_parse", since = "1.35.0")]
impl FromStr for NonZero<u64> {
type Err = ParseIntError;
fn from_str(src: &str) -> Result<Self, Self::Err> {
Self::from_str_radix(src, 10)
}
}
#[stable(feature = "nonzero_div", since = "1.51.0")]
#[rustc_const_unstable(feature = "const_ops", issue = "143802")]
impl const Div<NonZero<u64>> for u64 {
type Output = u64;
#[doc(alias = "unchecked_div")]
#[inline]
fn div(self, other: NonZero<u64>) -> u64 {
unsafe { intrinsics::unchecked_div(self, other.get()) }
}
}
#[stable(feature = "nonzero_div_assign", since = "1.79.0")]
#[rustc_const_unstable(feature = "const_ops", issue = "143802")]
impl const DivAssign<NonZero<u64>> for u64 {
#[inline]
fn div_assign(&mut self, other: NonZero<u64>) { *self = *self / other; }
}
#[stable(feature = "nonzero_div", since = "1.51.0")]
#[rustc_const_unstable(feature = "const_ops", issue = "143802")]
impl const Rem<NonZero<u64>> for u64 {
type Output = u64;
#[inline]
fn rem(self, other: NonZero<u64>) -> u64 {
unsafe { intrinsics::unchecked_rem(self, other.get()) }
}
}
#[stable(feature = "nonzero_div_assign", since = "1.79.0")]
#[rustc_const_unstable(feature = "const_ops", issue = "143802")]
impl const RemAssign<NonZero<u64>> for u64 {
#[inline]
fn rem_assign(&mut self, other: NonZero<u64>) { *self = *self % other; }
}
impl NonZero<u64> {
#[doc = "let one = NonZero::new(1u64).unwrap();"]
#[doc = "let max = NonZero::new(u64::MAX).unwrap();"]
#[doc = "let two = NonZero::new(2u64).unwrap();"]
#[doc = "let three = NonZero::new(3u64).unwrap();"]
#[stable(feature = "unsigned_nonzero_div_ceil", since = "1.92.0")]
#[rustc_const_stable(feature = "unsigned_nonzero_div_ceil", since =
"1.92.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn div_ceil(self, rhs: Self) -> Self {
let v = self.get().div_ceil(rhs.get());
unsafe { Self::new_unchecked(v) }
}
}nonzero_integer! {
2437 Self = NonZeroU64,
2438 Primitive = unsigned u64,
2439 SignedPrimitive = i64,
2440 rot = 12,
2441 rot_op = "0xaa00000000006e1",
2442 rot_result = "0x6e10aa",
2443 swap_op = "0x1234567890123456",
2444 swapped = "0x5634129078563412",
2445 reversed = "0x6a2c48091e6a2c48",
2446}
2447
2448#[doc = "A [`u128`] that is known not to equal zero."]
#[doc = "For example, `Option<NonZeroU128>` is the same size as `u128`:"]
#[doc =
"assert_eq!(size_of::<Option<core::num::NonZeroU128>>(), size_of::<u128>());"]
#[doc =
"`NonZeroU128` is guaranteed to have the same layout and bit validity as `u128`"]
#[doc = "`Option<NonZeroU128>` is guaranteed to be compatible with `u128`,"]
#[doc = "`NonZeroU128` and `Option<NonZeroU128>`"]
#[doc = "use std::num::NonZeroU128;"]
#[doc =
"assert_eq!(size_of::<NonZeroU128>(), size_of::<Option<NonZeroU128>>());"]
#[doc =
"assert_eq!(align_of::<NonZeroU128>(), align_of::<Option<NonZeroU128>>());"]
#[doc = "`NonZeroU128`"]
#[doc = "use std::num::NonZeroU128;"]
#[doc =
"const TEN: NonZeroU128 = NonZeroU128::new(10).expect(\"ten is non-zero\");"]
#[stable(feature = "nonzero", since = "1.28.0")]
pub type NonZeroU128 = NonZero<u128>;
impl NonZero<u128> {
#[doc = "This value is equal to [`u128::BITS`]."]
#[doc = "assert_eq!(NonZero::<u128>::BITS, u128::BITS);"]
#[stable(feature = "nonzero_bits", since = "1.67.0")]
pub const BITS: u32 = <u128>::BITS;
#[doc = "let n = NonZero::<u128>::new(u128::MAX)?;"]
#[stable(feature = "nonzero_leading_trailing_zeros", since = "1.53.0")]
#[rustc_const_stable(feature = "nonzero_leading_trailing_zeros", since =
"1.53.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn leading_zeros(self) -> u32 {
unsafe { intrinsics::ctlz_nonzero(self.get() as u128) }
}
#[doc = "let n = NonZero::<u128>::new(0b0101000)?;"]
#[stable(feature = "nonzero_leading_trailing_zeros", since = "1.53.0")]
#[rustc_const_stable(feature = "nonzero_leading_trailing_zeros", since =
"1.53.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn trailing_zeros(self) -> u32 {
unsafe { intrinsics::cttz_nonzero(self.get() as u128) }
}
#[doc = "let a = NonZero::<u128>::new(0b_01100100)?;"]
#[doc = "let b = NonZero::<u128>::new(0b_01000000)?;"]
#[stable(feature = "isolate_most_least_significant_one", since =
"1.97.0")]
#[rustc_const_stable(feature = "isolate_most_least_significant_one", since
= "1.97.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn isolate_highest_one(self) -> Self {
unsafe {
let bit =
(((1 as u128) <<
(<u128>::BITS - 1)).unchecked_shr(self.leading_zeros()));
NonZero::new_unchecked(bit as u128)
}
}
#[doc = "let a = NonZero::<u128>::new(0b_01100100)?;"]
#[doc = "let b = NonZero::<u128>::new(0b_00000100)?;"]
#[stable(feature = "isolate_most_least_significant_one", since =
"1.97.0")]
#[rustc_const_stable(feature = "isolate_most_least_significant_one", since
= "1.97.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn isolate_lowest_one(self) -> Self {
let n = self.get();
let n = n & n.wrapping_neg();
unsafe { NonZero::new_unchecked(n) }
}
#[doc = "assert_eq!(NonZero::<u128>::new(0b1)?.highest_one(), 0);"]
#[doc = "assert_eq!(NonZero::<u128>::new(0b1_0000)?.highest_one(), 4);"]
#[doc = "assert_eq!(NonZero::<u128>::new(0b1_1111)?.highest_one(), 4);"]
#[stable(feature = "int_lowest_highest_one", since = "1.97.0")]
#[rustc_const_stable(feature = "int_lowest_highest_one", since =
"1.97.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn highest_one(self) -> u32 {
Self::BITS - 1 - self.leading_zeros()
}
#[doc = "assert_eq!(NonZero::<u128>::new(0b1)?.lowest_one(), 0);"]
#[doc = "assert_eq!(NonZero::<u128>::new(0b1_0000)?.lowest_one(), 4);"]
#[doc = "assert_eq!(NonZero::<u128>::new(0b1_1111)?.lowest_one(), 0);"]
#[stable(feature = "int_lowest_highest_one", since = "1.97.0")]
#[rustc_const_stable(feature = "int_lowest_highest_one", since =
"1.97.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn lowest_one(self) -> u32 { self.trailing_zeros() }
#[doc = "let a = NonZero::<u128>::new(0b100_0000)?;"]
#[doc = "let b = NonZero::<u128>::new(0b100_0011)?;"]
#[stable(feature = "non_zero_count_ones", since = "1.86.0")]
#[rustc_const_stable(feature = "non_zero_count_ones", since = "1.86.0")]
#[doc(alias = "popcount")]
#[doc(alias = "popcnt")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn count_ones(self) -> NonZero<u32> {
unsafe { NonZero::new_unchecked(self.get().count_ones()) }
}
#[doc = "let n = NonZero::new(0x13f40000000000000000000000004f76u128)?;"]
#[doc = "let m = NonZero::new(0x4f7613f4)?;"]
#[doc = "assert_eq!(n.rotate_left(16), m);"]
#[unstable(feature = "nonzero_bitwise", issue = "128281")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn rotate_left(self, n: u32) -> Self {
let result = self.get().rotate_left(n);
unsafe { Self::new_unchecked(result) }
}
#[doc = "let n = NonZero::new(0x4f7613f4u128)?;"]
#[doc = "let m = NonZero::new(0x13f40000000000000000000000004f76)?;"]
#[doc = "assert_eq!(n.rotate_right(16), m);"]
#[unstable(feature = "nonzero_bitwise", issue = "128281")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn rotate_right(self, n: u32) -> Self {
let result = self.get().rotate_right(n);
unsafe { Self::new_unchecked(result) }
}
#[doc = "let n = NonZero::new(0x12345678901234567890123456789012u128)?;"]
#[doc =
"assert_eq!(m, NonZero::new(0x12907856341290785634129078563412)?);"]
#[unstable(feature = "nonzero_bitwise", issue = "128281")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn swap_bytes(self) -> Self {
let result = self.get().swap_bytes();
unsafe { Self::new_unchecked(result) }
}
#[doc = "let n = NonZero::new(0x12345678901234567890123456789012u128)?;"]
#[doc =
"assert_eq!(m, NonZero::new(0x48091e6a2c48091e6a2c48091e6a2c48)?);"]
#[unstable(feature = "nonzero_bitwise", issue = "128281")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn reverse_bits(self) -> Self {
let result = self.get().reverse_bits();
unsafe { Self::new_unchecked(result) }
}
#[doc = "use std::num::NonZeroU128;"]
#[doc = "let n = NonZero::new(0x1Au128)?;"]
#[doc = " assert_eq!(NonZeroU128::from_be(n), n)"]
#[doc = " assert_eq!(NonZeroU128::from_be(n), n.swap_bytes())"]
#[unstable(feature = "nonzero_bitwise", issue = "128281")]
#[must_use]
#[inline(always)]
pub const fn from_be(x: Self) -> Self {
let result = u128::from_be(x.get());
unsafe { Self::new_unchecked(result) }
}
#[doc = "use std::num::NonZeroU128;"]
#[doc = "let n = NonZero::new(0x1Au128)?;"]
#[doc = " assert_eq!(NonZeroU128::from_le(n), n)"]
#[doc = " assert_eq!(NonZeroU128::from_le(n), n.swap_bytes())"]
#[unstable(feature = "nonzero_bitwise", issue = "128281")]
#[must_use]
#[inline(always)]
pub const fn from_le(x: Self) -> Self {
let result = u128::from_le(x.get());
unsafe { Self::new_unchecked(result) }
}
#[doc = "let n = NonZero::new(0x1Au128)?;"]
#[unstable(feature = "nonzero_bitwise", issue = "128281")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn to_be(self) -> Self {
let result = self.get().to_be();
unsafe { Self::new_unchecked(result) }
}
#[doc = "let n = NonZero::new(0x1Au128)?;"]
#[unstable(feature = "nonzero_bitwise", issue = "128281")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn to_le(self) -> Self {
let result = self.get().to_le();
unsafe { Self::new_unchecked(result) }
}
#[doc = "assert_eq!(NonZero::<u128>::MIN.get(), 1u128);"]
#[stable(feature = "nonzero_min_max", since = "1.70.0")]
pub const MIN: Self = Self::new(1).unwrap();
#[doc = "equal to [`u128::MAX`]."]
#[doc = "assert_eq!(NonZero::<u128>::MAX.get(), u128::MAX);"]
#[stable(feature = "nonzero_min_max", since = "1.70.0")]
pub const MAX: Self = Self::new(<u128>::MAX).unwrap();
#[doc = "let one = NonZero::new(1u128)?;"]
#[doc = "let two = NonZero::new(2u128)?;"]
#[doc = "let max = NonZero::new(u128::MAX)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn checked_add(self, other: u128) -> Option<Self> {
if let Some(result) = self.get().checked_add(other) {
Some(unsafe { Self::new_unchecked(result) })
} else { None }
}
#[doc = "Return [`NonZero::<u128>::MAX`] on overflow."]
#[doc = "let one = NonZero::new(1u128)?;"]
#[doc = "let two = NonZero::new(2u128)?;"]
#[doc = "let max = NonZero::new(u128::MAX)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn saturating_add(self, other: u128) -> Self {
unsafe { Self::new_unchecked(self.get().saturating_add(other)) }
}
#[doc = "`self + rhs > u128::MAX`."]
#[doc = "let one = NonZero::new(1u128)?;"]
#[doc = "let two = NonZero::new(2u128)?;"]
#[unstable(feature = "nonzero_ops", issue = "84186")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const unsafe fn unchecked_add(self, other: u128) -> Self {
unsafe { Self::new_unchecked(self.get().unchecked_add(other)) }
}
#[doc = "let two = NonZero::new(2u128)?;"]
#[doc = "let three = NonZero::new(3u128)?;"]
#[doc = "let four = NonZero::new(4u128)?;"]
#[doc = "let max = NonZero::new(u128::MAX)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn checked_next_power_of_two(self) -> Option<Self> {
if let Some(nz) = self.get().checked_next_power_of_two() {
Some(unsafe { Self::new_unchecked(nz) })
} else { None }
}
#[doc = "[`u128::ilog2`],"]
#[doc = "assert_eq!(NonZero::new(7u128)?.ilog2(), 2);"]
#[doc = "assert_eq!(NonZero::new(8u128)?.ilog2(), 3);"]
#[doc = "assert_eq!(NonZero::new(9u128)?.ilog2(), 3);"]
#[stable(feature = "int_log", since = "1.67.0")]
#[rustc_const_stable(feature = "int_log", since = "1.67.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn ilog2(self) -> u32 { Self::BITS - 1 - self.leading_zeros() }
#[doc = "[`u128::ilog10`],"]
#[doc = "assert_eq!(NonZero::new(99u128)?.ilog10(), 1);"]
#[doc = "assert_eq!(NonZero::new(100u128)?.ilog10(), 2);"]
#[doc = "assert_eq!(NonZero::new(101u128)?.ilog10(), 2);"]
#[stable(feature = "int_log", since = "1.67.0")]
#[rustc_const_stable(feature = "int_log", since = "1.67.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn ilog10(self) -> u32 { imp::int_log10::u128(self) }
#[doc = "let one = NonZero::new(1u128)?;"]
#[doc = "let two = NonZero::new(2u128)?;"]
#[doc = "let four = NonZero::new(4u128)?;"]
#[stable(feature = "num_midpoint", since = "1.85.0")]
#[rustc_const_stable(feature = "num_midpoint", since = "1.85.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[doc(alias = "average_floor")]
#[doc(alias = "average")]
#[inline]
pub const fn midpoint(self, rhs: Self) -> Self {
unsafe { Self::new_unchecked(self.get().midpoint(rhs.get())) }
}
#[doc = "let eight = NonZero::new(8u128)?;"]
#[doc = "let ten = NonZero::new(10u128)?;"]
#[must_use]
#[stable(feature = "nonzero_is_power_of_two", since = "1.59.0")]
#[rustc_const_stable(feature = "nonzero_is_power_of_two", since =
"1.59.0")]
#[inline]
pub const fn is_power_of_two(self) -> bool {
intrinsics::ctpop(self.get()) < 2
}
#[doc = "let ten = NonZero::new(10u128)?;"]
#[doc = "let three = NonZero::new(3u128)?;"]
#[stable(feature = "isqrt", since = "1.84.0")]
#[rustc_const_stable(feature = "isqrt", since = "1.84.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn isqrt(self) -> Self {
let result = self.get().isqrt();
unsafe { Self::new_unchecked(result) }
}
#[doc = "let n = NonZero::<u128>::MAX;"]
#[doc = "assert_eq!(n.cast_signed(), NonZero::new(-1i128).unwrap());"]
#[stable(feature = "integer_sign_cast", since = "1.87.0")]
#[rustc_const_stable(feature = "integer_sign_cast", since = "1.87.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn cast_signed(self) -> NonZero<i128> {
unsafe { NonZero::new_unchecked(self.get().cast_signed()) }
}
#[doc =
"assert_eq!(NonZero::<u128>::new(0b1)?.bit_width(), NonZero::new(1)?);"]
#[doc =
"assert_eq!(NonZero::<u128>::new(0b111)?.bit_width(), NonZero::new(3)?);"]
#[doc =
"assert_eq!(NonZero::<u128>::new(0b1110)?.bit_width(), NonZero::new(4)?);"]
#[stable(feature = "uint_bit_width", since = "1.97.0")]
#[rustc_const_stable(feature = "uint_bit_width", since = "1.97.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn bit_width(self) -> NonZero<u32> {
unsafe { NonZero::new_unchecked(Self::BITS - self.leading_zeros()) }
}
#[doc = "let two = NonZero::new(2u128)?;"]
#[doc = "let four = NonZero::new(4u128)?;"]
#[doc = "let max = NonZero::new(u128::MAX)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn checked_mul(self, other: Self) -> Option<Self> {
if let Some(result) = self.get().checked_mul(other.get()) {
Some(unsafe { Self::new_unchecked(result) })
} else { None }
}
#[doc = "Return [`NonZero::<u128>::MAX`] on overflow."]
#[doc = "let two = NonZero::new(2u128)?;"]
#[doc = "let four = NonZero::new(4u128)?;"]
#[doc = "let max = NonZero::new(u128::MAX)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn saturating_mul(self, other: Self) -> Self {
unsafe { Self::new_unchecked(self.get().saturating_mul(other.get())) }
}
#[doc = "`self * rhs > u128::MAX`."]
#[doc = "let two = NonZero::new(2u128)?;"]
#[doc = "let four = NonZero::new(4u128)?;"]
#[unstable(feature = "nonzero_ops", issue = "84186")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const unsafe fn unchecked_mul(self, other: Self) -> Self {
unsafe { Self::new_unchecked(self.get().unchecked_mul(other.get())) }
}
#[doc = "let three = NonZero::new(3u128)?;"]
#[doc = "let twenty_seven = NonZero::new(27u128)?;"]
#[doc = "let half_max = NonZero::new(u128::MAX / 2)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn checked_pow(self, other: u32) -> Option<Self> {
if let Some(result) = self.get().checked_pow(other) {
Some(unsafe { Self::new_unchecked(result) })
} else { None }
}
#[doc = "Return [`NonZero::<u128>::MAX`] on overflow."]
#[doc = "let three = NonZero::new(3u128)?;"]
#[doc = "let twenty_seven = NonZero::new(27u128)?;"]
#[doc = "let max = NonZero::new(u128::MAX)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn saturating_pow(self, other: u32) -> Self {
unsafe { Self::new_unchecked(self.get().saturating_pow(other)) }
}
#[doc = " `+` "]
#[doc =
"assert_eq!(NonZero::<u128>::from_ascii(b\"+10\"), Ok(NonZero::new(10)?));"]
#[doc = "assert!(NonZero::<u128>::from_ascii(b\"1 \").is_err());"]
#[unstable(feature = "int_from_ascii", issue = "134821")]
#[inline]
pub const fn from_ascii(src: &[u8]) -> Result<Self, ParseIntError> {
Self::from_ascii_radix(src, 10)
}
#[doc = " `+` "]
#[doc =
"assert_eq!(NonZero::<u128>::from_ascii_radix(b\"A\", 16), Ok(NonZero::new(10)?));"]
#[doc =
"assert!(NonZero::<u128>::from_ascii_radix(b\"1 \", 10).is_err());"]
#[unstable(feature = "int_from_ascii", issue = "134821")]
#[inline]
pub const fn from_ascii_radix(src: &[u8], radix: u32)
-> Result<Self, ParseIntError> {
let n =
match <u128>::from_ascii_radix(src, radix) {
Ok(n) => n,
Err(err) => return Err(err),
};
if let Some(n) = Self::new(n) {
Ok(n)
} else { Err(ParseIntError { kind: IntErrorKind::Zero }) }
}
#[doc = " `+` "]
#[doc =
"assert_eq!(NonZero::<u128>::from_str_radix(\"A\", 16), Ok(NonZero::new(10)?));"]
#[doc = "assert!(NonZero::<u128>::from_str_radix(\"1 \", 10).is_err());"]
#[unstable(feature = "nonzero_from_str_radix", issue = "152193")]
#[inline]
pub const fn from_str_radix(src: &str, radix: u32)
-> Result<Self, ParseIntError> {
Self::from_ascii_radix(src.as_bytes(), radix)
}
}
#[stable(feature = "nonzero_parse", since = "1.35.0")]
impl FromStr for NonZero<u128> {
type Err = ParseIntError;
fn from_str(src: &str) -> Result<Self, Self::Err> {
Self::from_str_radix(src, 10)
}
}
#[stable(feature = "nonzero_div", since = "1.51.0")]
#[rustc_const_unstable(feature = "const_ops", issue = "143802")]
impl const Div<NonZero<u128>> for u128 {
type Output = u128;
#[doc(alias = "unchecked_div")]
#[inline]
fn div(self, other: NonZero<u128>) -> u128 {
unsafe { intrinsics::unchecked_div(self, other.get()) }
}
}
#[stable(feature = "nonzero_div_assign", since = "1.79.0")]
#[rustc_const_unstable(feature = "const_ops", issue = "143802")]
impl const DivAssign<NonZero<u128>> for u128 {
#[inline]
fn div_assign(&mut self, other: NonZero<u128>) { *self = *self / other; }
}
#[stable(feature = "nonzero_div", since = "1.51.0")]
#[rustc_const_unstable(feature = "const_ops", issue = "143802")]
impl const Rem<NonZero<u128>> for u128 {
type Output = u128;
#[inline]
fn rem(self, other: NonZero<u128>) -> u128 {
unsafe { intrinsics::unchecked_rem(self, other.get()) }
}
}
#[stable(feature = "nonzero_div_assign", since = "1.79.0")]
#[rustc_const_unstable(feature = "const_ops", issue = "143802")]
impl const RemAssign<NonZero<u128>> for u128 {
#[inline]
fn rem_assign(&mut self, other: NonZero<u128>) { *self = *self % other; }
}
impl NonZero<u128> {
#[doc = "let one = NonZero::new(1u128).unwrap();"]
#[doc = "let max = NonZero::new(u128::MAX).unwrap();"]
#[doc = "let two = NonZero::new(2u128).unwrap();"]
#[doc = "let three = NonZero::new(3u128).unwrap();"]
#[stable(feature = "unsigned_nonzero_div_ceil", since = "1.92.0")]
#[rustc_const_stable(feature = "unsigned_nonzero_div_ceil", since =
"1.92.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn div_ceil(self, rhs: Self) -> Self {
let v = self.get().div_ceil(rhs.get());
unsafe { Self::new_unchecked(v) }
}
}nonzero_integer! {
2449 Self = NonZeroU128,
2450 Primitive = unsigned u128,
2451 SignedPrimitive = i128,
2452 rot = 16,
2453 rot_op = "0x13f40000000000000000000000004f76",
2454 rot_result = "0x4f7613f4",
2455 swap_op = "0x12345678901234567890123456789012",
2456 swapped = "0x12907856341290785634129078563412",
2457 reversed = "0x48091e6a2c48091e6a2c48091e6a2c48",
2458}
2459
2460#[cfg(target_pointer_width = "16")]
2461nonzero_integer! {
2462 Self = NonZeroUsize,
2463 Primitive = unsigned usize,
2464 SignedPrimitive = isize,
2465 rot = 4,
2466 rot_op = "0xa003",
2467 rot_result = "0x3a",
2468 swap_op = "0x1234",
2469 swapped = "0x3412",
2470 reversed = "0x2c48",
2471}
2472
2473#[cfg(target_pointer_width = "32")]
2474nonzero_integer! {
2475 Self = NonZeroUsize,
2476 Primitive = unsigned usize,
2477 SignedPrimitive = isize,
2478 rot = 8,
2479 rot_op = "0x10000b3",
2480 rot_result = "0xb301",
2481 swap_op = "0x12345678",
2482 swapped = "0x78563412",
2483 reversed = "0x1e6a2c48",
2484}
2485
2486#[cfg(target_pointer_width = "64")]
2487#[doc = "A [`usize`] that is known not to equal zero."]
#[doc = "For example, `Option<NonZeroUsize>` is the same size as `usize`:"]
#[doc =
"assert_eq!(size_of::<Option<core::num::NonZeroUsize>>(), size_of::<usize>());"]
#[doc =
"`NonZeroUsize` is guaranteed to have the same layout and bit validity as `usize`"]
#[doc = "`Option<NonZeroUsize>` is guaranteed to be compatible with `usize`,"]
#[doc = "`NonZeroUsize` and `Option<NonZeroUsize>`"]
#[doc = "use std::num::NonZeroUsize;"]
#[doc =
"assert_eq!(size_of::<NonZeroUsize>(), size_of::<Option<NonZeroUsize>>());"]
#[doc =
"assert_eq!(align_of::<NonZeroUsize>(), align_of::<Option<NonZeroUsize>>());"]
#[doc = "`NonZeroUsize`"]
#[doc = "use std::num::NonZeroUsize;"]
#[doc =
"const TEN: NonZeroUsize = NonZeroUsize::new(10).expect(\"ten is non-zero\");"]
#[stable(feature = "nonzero", since = "1.28.0")]
pub type NonZeroUsize = NonZero<usize>;
impl NonZero<usize> {
#[doc = "This value is equal to [`usize::BITS`]."]
#[doc = "assert_eq!(NonZero::<usize>::BITS, usize::BITS);"]
#[stable(feature = "nonzero_bits", since = "1.67.0")]
pub const BITS: u32 = <usize>::BITS;
#[doc = "let n = NonZero::<usize>::new(usize::MAX)?;"]
#[stable(feature = "nonzero_leading_trailing_zeros", since = "1.53.0")]
#[rustc_const_stable(feature = "nonzero_leading_trailing_zeros", since =
"1.53.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn leading_zeros(self) -> u32 {
unsafe { intrinsics::ctlz_nonzero(self.get() as usize) }
}
#[doc = "let n = NonZero::<usize>::new(0b0101000)?;"]
#[stable(feature = "nonzero_leading_trailing_zeros", since = "1.53.0")]
#[rustc_const_stable(feature = "nonzero_leading_trailing_zeros", since =
"1.53.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn trailing_zeros(self) -> u32 {
unsafe { intrinsics::cttz_nonzero(self.get() as usize) }
}
#[doc = "let a = NonZero::<usize>::new(0b_01100100)?;"]
#[doc = "let b = NonZero::<usize>::new(0b_01000000)?;"]
#[stable(feature = "isolate_most_least_significant_one", since =
"1.97.0")]
#[rustc_const_stable(feature = "isolate_most_least_significant_one", since
= "1.97.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn isolate_highest_one(self) -> Self {
unsafe {
let bit =
(((1 as usize) <<
(<usize>::BITS - 1)).unchecked_shr(self.leading_zeros()));
NonZero::new_unchecked(bit as usize)
}
}
#[doc = "let a = NonZero::<usize>::new(0b_01100100)?;"]
#[doc = "let b = NonZero::<usize>::new(0b_00000100)?;"]
#[stable(feature = "isolate_most_least_significant_one", since =
"1.97.0")]
#[rustc_const_stable(feature = "isolate_most_least_significant_one", since
= "1.97.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn isolate_lowest_one(self) -> Self {
let n = self.get();
let n = n & n.wrapping_neg();
unsafe { NonZero::new_unchecked(n) }
}
#[doc = "assert_eq!(NonZero::<usize>::new(0b1)?.highest_one(), 0);"]
#[doc = "assert_eq!(NonZero::<usize>::new(0b1_0000)?.highest_one(), 4);"]
#[doc = "assert_eq!(NonZero::<usize>::new(0b1_1111)?.highest_one(), 4);"]
#[stable(feature = "int_lowest_highest_one", since = "1.97.0")]
#[rustc_const_stable(feature = "int_lowest_highest_one", since =
"1.97.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn highest_one(self) -> u32 {
Self::BITS - 1 - self.leading_zeros()
}
#[doc = "assert_eq!(NonZero::<usize>::new(0b1)?.lowest_one(), 0);"]
#[doc = "assert_eq!(NonZero::<usize>::new(0b1_0000)?.lowest_one(), 4);"]
#[doc = "assert_eq!(NonZero::<usize>::new(0b1_1111)?.lowest_one(), 0);"]
#[stable(feature = "int_lowest_highest_one", since = "1.97.0")]
#[rustc_const_stable(feature = "int_lowest_highest_one", since =
"1.97.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn lowest_one(self) -> u32 { self.trailing_zeros() }
#[doc = "let a = NonZero::<usize>::new(0b100_0000)?;"]
#[doc = "let b = NonZero::<usize>::new(0b100_0011)?;"]
#[stable(feature = "non_zero_count_ones", since = "1.86.0")]
#[rustc_const_stable(feature = "non_zero_count_ones", since = "1.86.0")]
#[doc(alias = "popcount")]
#[doc(alias = "popcnt")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn count_ones(self) -> NonZero<u32> {
unsafe { NonZero::new_unchecked(self.get().count_ones()) }
}
#[doc = "let n = NonZero::new(0xaa00000000006e1usize)?;"]
#[doc = "let m = NonZero::new(0x6e10aa)?;"]
#[doc = "assert_eq!(n.rotate_left(12), m);"]
#[unstable(feature = "nonzero_bitwise", issue = "128281")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn rotate_left(self, n: u32) -> Self {
let result = self.get().rotate_left(n);
unsafe { Self::new_unchecked(result) }
}
#[doc = "let n = NonZero::new(0x6e10aausize)?;"]
#[doc = "let m = NonZero::new(0xaa00000000006e1)?;"]
#[doc = "assert_eq!(n.rotate_right(12), m);"]
#[unstable(feature = "nonzero_bitwise", issue = "128281")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn rotate_right(self, n: u32) -> Self {
let result = self.get().rotate_right(n);
unsafe { Self::new_unchecked(result) }
}
#[doc = "let n = NonZero::new(0x1234567890123456usize)?;"]
#[doc = "assert_eq!(m, NonZero::new(0x5634129078563412)?);"]
#[unstable(feature = "nonzero_bitwise", issue = "128281")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn swap_bytes(self) -> Self {
let result = self.get().swap_bytes();
unsafe { Self::new_unchecked(result) }
}
#[doc = "let n = NonZero::new(0x1234567890123456usize)?;"]
#[doc = "assert_eq!(m, NonZero::new(0x6a2c48091e6a2c48)?);"]
#[unstable(feature = "nonzero_bitwise", issue = "128281")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn reverse_bits(self) -> Self {
let result = self.get().reverse_bits();
unsafe { Self::new_unchecked(result) }
}
#[doc = "use std::num::NonZeroUsize;"]
#[doc = "let n = NonZero::new(0x1Ausize)?;"]
#[doc = " assert_eq!(NonZeroUsize::from_be(n), n)"]
#[doc = " assert_eq!(NonZeroUsize::from_be(n), n.swap_bytes())"]
#[unstable(feature = "nonzero_bitwise", issue = "128281")]
#[must_use]
#[inline(always)]
pub const fn from_be(x: Self) -> Self {
let result = usize::from_be(x.get());
unsafe { Self::new_unchecked(result) }
}
#[doc = "use std::num::NonZeroUsize;"]
#[doc = "let n = NonZero::new(0x1Ausize)?;"]
#[doc = " assert_eq!(NonZeroUsize::from_le(n), n)"]
#[doc = " assert_eq!(NonZeroUsize::from_le(n), n.swap_bytes())"]
#[unstable(feature = "nonzero_bitwise", issue = "128281")]
#[must_use]
#[inline(always)]
pub const fn from_le(x: Self) -> Self {
let result = usize::from_le(x.get());
unsafe { Self::new_unchecked(result) }
}
#[doc = "let n = NonZero::new(0x1Ausize)?;"]
#[unstable(feature = "nonzero_bitwise", issue = "128281")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn to_be(self) -> Self {
let result = self.get().to_be();
unsafe { Self::new_unchecked(result) }
}
#[doc = "let n = NonZero::new(0x1Ausize)?;"]
#[unstable(feature = "nonzero_bitwise", issue = "128281")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn to_le(self) -> Self {
let result = self.get().to_le();
unsafe { Self::new_unchecked(result) }
}
#[doc = "assert_eq!(NonZero::<usize>::MIN.get(), 1usize);"]
#[stable(feature = "nonzero_min_max", since = "1.70.0")]
pub const MIN: Self = Self::new(1).unwrap();
#[doc = "equal to [`usize::MAX`]."]
#[doc = "assert_eq!(NonZero::<usize>::MAX.get(), usize::MAX);"]
#[stable(feature = "nonzero_min_max", since = "1.70.0")]
pub const MAX: Self = Self::new(<usize>::MAX).unwrap();
#[doc = "let one = NonZero::new(1usize)?;"]
#[doc = "let two = NonZero::new(2usize)?;"]
#[doc = "let max = NonZero::new(usize::MAX)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn checked_add(self, other: usize) -> Option<Self> {
if let Some(result) = self.get().checked_add(other) {
Some(unsafe { Self::new_unchecked(result) })
} else { None }
}
#[doc = "Return [`NonZero::<usize>::MAX`] on overflow."]
#[doc = "let one = NonZero::new(1usize)?;"]
#[doc = "let two = NonZero::new(2usize)?;"]
#[doc = "let max = NonZero::new(usize::MAX)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn saturating_add(self, other: usize) -> Self {
unsafe { Self::new_unchecked(self.get().saturating_add(other)) }
}
#[doc = "`self + rhs > usize::MAX`."]
#[doc = "let one = NonZero::new(1usize)?;"]
#[doc = "let two = NonZero::new(2usize)?;"]
#[unstable(feature = "nonzero_ops", issue = "84186")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const unsafe fn unchecked_add(self, other: usize) -> Self {
unsafe { Self::new_unchecked(self.get().unchecked_add(other)) }
}
#[doc = "let two = NonZero::new(2usize)?;"]
#[doc = "let three = NonZero::new(3usize)?;"]
#[doc = "let four = NonZero::new(4usize)?;"]
#[doc = "let max = NonZero::new(usize::MAX)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn checked_next_power_of_two(self) -> Option<Self> {
if let Some(nz) = self.get().checked_next_power_of_two() {
Some(unsafe { Self::new_unchecked(nz) })
} else { None }
}
#[doc = "[`usize::ilog2`],"]
#[doc = "assert_eq!(NonZero::new(7usize)?.ilog2(), 2);"]
#[doc = "assert_eq!(NonZero::new(8usize)?.ilog2(), 3);"]
#[doc = "assert_eq!(NonZero::new(9usize)?.ilog2(), 3);"]
#[stable(feature = "int_log", since = "1.67.0")]
#[rustc_const_stable(feature = "int_log", since = "1.67.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn ilog2(self) -> u32 { Self::BITS - 1 - self.leading_zeros() }
#[doc = "[`usize::ilog10`],"]
#[doc = "assert_eq!(NonZero::new(99usize)?.ilog10(), 1);"]
#[doc = "assert_eq!(NonZero::new(100usize)?.ilog10(), 2);"]
#[doc = "assert_eq!(NonZero::new(101usize)?.ilog10(), 2);"]
#[stable(feature = "int_log", since = "1.67.0")]
#[rustc_const_stable(feature = "int_log", since = "1.67.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn ilog10(self) -> u32 { imp::int_log10::usize(self) }
#[doc = "let one = NonZero::new(1usize)?;"]
#[doc = "let two = NonZero::new(2usize)?;"]
#[doc = "let four = NonZero::new(4usize)?;"]
#[stable(feature = "num_midpoint", since = "1.85.0")]
#[rustc_const_stable(feature = "num_midpoint", since = "1.85.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[doc(alias = "average_floor")]
#[doc(alias = "average")]
#[inline]
pub const fn midpoint(self, rhs: Self) -> Self {
unsafe { Self::new_unchecked(self.get().midpoint(rhs.get())) }
}
#[doc = "let eight = NonZero::new(8usize)?;"]
#[doc = "let ten = NonZero::new(10usize)?;"]
#[must_use]
#[stable(feature = "nonzero_is_power_of_two", since = "1.59.0")]
#[rustc_const_stable(feature = "nonzero_is_power_of_two", since =
"1.59.0")]
#[inline]
pub const fn is_power_of_two(self) -> bool {
intrinsics::ctpop(self.get()) < 2
}
#[doc = "let ten = NonZero::new(10usize)?;"]
#[doc = "let three = NonZero::new(3usize)?;"]
#[stable(feature = "isqrt", since = "1.84.0")]
#[rustc_const_stable(feature = "isqrt", since = "1.84.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn isqrt(self) -> Self {
let result = self.get().isqrt();
unsafe { Self::new_unchecked(result) }
}
#[doc = "let n = NonZero::<usize>::MAX;"]
#[doc = "assert_eq!(n.cast_signed(), NonZero::new(-1isize).unwrap());"]
#[stable(feature = "integer_sign_cast", since = "1.87.0")]
#[rustc_const_stable(feature = "integer_sign_cast", since = "1.87.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn cast_signed(self) -> NonZero<isize> {
unsafe { NonZero::new_unchecked(self.get().cast_signed()) }
}
#[doc =
"assert_eq!(NonZero::<usize>::new(0b1)?.bit_width(), NonZero::new(1)?);"]
#[doc =
"assert_eq!(NonZero::<usize>::new(0b111)?.bit_width(), NonZero::new(3)?);"]
#[doc =
"assert_eq!(NonZero::<usize>::new(0b1110)?.bit_width(), NonZero::new(4)?);"]
#[stable(feature = "uint_bit_width", since = "1.97.0")]
#[rustc_const_stable(feature = "uint_bit_width", since = "1.97.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn bit_width(self) -> NonZero<u32> {
unsafe { NonZero::new_unchecked(Self::BITS - self.leading_zeros()) }
}
#[doc = "let two = NonZero::new(2usize)?;"]
#[doc = "let four = NonZero::new(4usize)?;"]
#[doc = "let max = NonZero::new(usize::MAX)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn checked_mul(self, other: Self) -> Option<Self> {
if let Some(result) = self.get().checked_mul(other.get()) {
Some(unsafe { Self::new_unchecked(result) })
} else { None }
}
#[doc = "Return [`NonZero::<usize>::MAX`] on overflow."]
#[doc = "let two = NonZero::new(2usize)?;"]
#[doc = "let four = NonZero::new(4usize)?;"]
#[doc = "let max = NonZero::new(usize::MAX)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn saturating_mul(self, other: Self) -> Self {
unsafe { Self::new_unchecked(self.get().saturating_mul(other.get())) }
}
#[doc = "`self * rhs > usize::MAX`."]
#[doc = "let two = NonZero::new(2usize)?;"]
#[doc = "let four = NonZero::new(4usize)?;"]
#[unstable(feature = "nonzero_ops", issue = "84186")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const unsafe fn unchecked_mul(self, other: Self) -> Self {
unsafe { Self::new_unchecked(self.get().unchecked_mul(other.get())) }
}
#[doc = "let three = NonZero::new(3usize)?;"]
#[doc = "let twenty_seven = NonZero::new(27usize)?;"]
#[doc = "let half_max = NonZero::new(usize::MAX / 2)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn checked_pow(self, other: u32) -> Option<Self> {
if let Some(result) = self.get().checked_pow(other) {
Some(unsafe { Self::new_unchecked(result) })
} else { None }
}
#[doc = "Return [`NonZero::<usize>::MAX`] on overflow."]
#[doc = "let three = NonZero::new(3usize)?;"]
#[doc = "let twenty_seven = NonZero::new(27usize)?;"]
#[doc = "let max = NonZero::new(usize::MAX)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn saturating_pow(self, other: u32) -> Self {
unsafe { Self::new_unchecked(self.get().saturating_pow(other)) }
}
#[doc = " `+` "]
#[doc =
"assert_eq!(NonZero::<usize>::from_ascii(b\"+10\"), Ok(NonZero::new(10)?));"]
#[doc = "assert!(NonZero::<usize>::from_ascii(b\"1 \").is_err());"]
#[unstable(feature = "int_from_ascii", issue = "134821")]
#[inline]
pub const fn from_ascii(src: &[u8]) -> Result<Self, ParseIntError> {
Self::from_ascii_radix(src, 10)
}
#[doc = " `+` "]
#[doc =
"assert_eq!(NonZero::<usize>::from_ascii_radix(b\"A\", 16), Ok(NonZero::new(10)?));"]
#[doc =
"assert!(NonZero::<usize>::from_ascii_radix(b\"1 \", 10).is_err());"]
#[unstable(feature = "int_from_ascii", issue = "134821")]
#[inline]
pub const fn from_ascii_radix(src: &[u8], radix: u32)
-> Result<Self, ParseIntError> {
let n =
match <usize>::from_ascii_radix(src, radix) {
Ok(n) => n,
Err(err) => return Err(err),
};
if let Some(n) = Self::new(n) {
Ok(n)
} else { Err(ParseIntError { kind: IntErrorKind::Zero }) }
}
#[doc = " `+` "]
#[doc =
"assert_eq!(NonZero::<usize>::from_str_radix(\"A\", 16), Ok(NonZero::new(10)?));"]
#[doc = "assert!(NonZero::<usize>::from_str_radix(\"1 \", 10).is_err());"]
#[unstable(feature = "nonzero_from_str_radix", issue = "152193")]
#[inline]
pub const fn from_str_radix(src: &str, radix: u32)
-> Result<Self, ParseIntError> {
Self::from_ascii_radix(src.as_bytes(), radix)
}
}
#[stable(feature = "nonzero_parse", since = "1.35.0")]
impl FromStr for NonZero<usize> {
type Err = ParseIntError;
fn from_str(src: &str) -> Result<Self, Self::Err> {
Self::from_str_radix(src, 10)
}
}
#[stable(feature = "nonzero_div", since = "1.51.0")]
#[rustc_const_unstable(feature = "const_ops", issue = "143802")]
impl const Div<NonZero<usize>> for usize {
type Output = usize;
#[doc(alias = "unchecked_div")]
#[inline]
fn div(self, other: NonZero<usize>) -> usize {
unsafe { intrinsics::unchecked_div(self, other.get()) }
}
}
#[stable(feature = "nonzero_div_assign", since = "1.79.0")]
#[rustc_const_unstable(feature = "const_ops", issue = "143802")]
impl const DivAssign<NonZero<usize>> for usize {
#[inline]
fn div_assign(&mut self, other: NonZero<usize>) { *self = *self / other; }
}
#[stable(feature = "nonzero_div", since = "1.51.0")]
#[rustc_const_unstable(feature = "const_ops", issue = "143802")]
impl const Rem<NonZero<usize>> for usize {
type Output = usize;
#[inline]
fn rem(self, other: NonZero<usize>) -> usize {
unsafe { intrinsics::unchecked_rem(self, other.get()) }
}
}
#[stable(feature = "nonzero_div_assign", since = "1.79.0")]
#[rustc_const_unstable(feature = "const_ops", issue = "143802")]
impl const RemAssign<NonZero<usize>> for usize {
#[inline]
fn rem_assign(&mut self, other: NonZero<usize>) { *self = *self % other; }
}
impl NonZero<usize> {
#[doc = "let one = NonZero::new(1usize).unwrap();"]
#[doc = "let max = NonZero::new(usize::MAX).unwrap();"]
#[doc = "let two = NonZero::new(2usize).unwrap();"]
#[doc = "let three = NonZero::new(3usize).unwrap();"]
#[stable(feature = "unsigned_nonzero_div_ceil", since = "1.92.0")]
#[rustc_const_stable(feature = "unsigned_nonzero_div_ceil", since =
"1.92.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn div_ceil(self, rhs: Self) -> Self {
let v = self.get().div_ceil(rhs.get());
unsafe { Self::new_unchecked(v) }
}
}nonzero_integer! {
2488 Self = NonZeroUsize,
2489 Primitive = unsigned usize,
2490 SignedPrimitive = isize,
2491 rot = 12,
2492 rot_op = "0xaa00000000006e1",
2493 rot_result = "0x6e10aa",
2494 swap_op = "0x1234567890123456",
2495 swapped = "0x5634129078563412",
2496 reversed = "0x6a2c48091e6a2c48",
2497}
2498
2499#[doc = "An [`i8`] that is known not to equal zero."]
#[doc = "For example, `Option<NonZeroI8>` is the same size as `i8`:"]
#[doc =
"assert_eq!(size_of::<Option<core::num::NonZeroI8>>(), size_of::<i8>());"]
#[doc =
"`NonZeroI8` is guaranteed to have the same layout and bit validity as `i8`"]
#[doc = "`Option<NonZeroI8>` is guaranteed to be compatible with `i8`,"]
#[doc = "`NonZeroI8` and `Option<NonZeroI8>`"]
#[doc = "use std::num::NonZeroI8;"]
#[doc = "assert_eq!(size_of::<NonZeroI8>(), size_of::<Option<NonZeroI8>>());"]
#[doc =
"assert_eq!(align_of::<NonZeroI8>(), align_of::<Option<NonZeroI8>>());"]
#[doc = "`NonZeroI8`"]
#[doc = "use std::num::NonZeroI8;"]
#[doc =
"const TEN: NonZeroI8 = NonZeroI8::new(10).expect(\"ten is non-zero\");"]
#[stable(feature = "signed_nonzero", since = "1.34.0")]
pub type NonZeroI8 = NonZero<i8>;
impl NonZero<i8> {
#[doc = "This value is equal to [`i8::BITS`]."]
#[doc = "assert_eq!(NonZero::<i8>::BITS, i8::BITS);"]
#[stable(feature = "nonzero_bits", since = "1.67.0")]
pub const BITS: u32 = <i8>::BITS;
#[doc = "let n = NonZero::<i8>::new(-1i8)?;"]
#[stable(feature = "nonzero_leading_trailing_zeros", since = "1.53.0")]
#[rustc_const_stable(feature = "nonzero_leading_trailing_zeros", since =
"1.53.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn leading_zeros(self) -> u32 {
unsafe { intrinsics::ctlz_nonzero(self.get() as u8) }
}
#[doc = "let n = NonZero::<i8>::new(0b0101000)?;"]
#[stable(feature = "nonzero_leading_trailing_zeros", since = "1.53.0")]
#[rustc_const_stable(feature = "nonzero_leading_trailing_zeros", since =
"1.53.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn trailing_zeros(self) -> u32 {
unsafe { intrinsics::cttz_nonzero(self.get() as u8) }
}
#[doc = "let a = NonZero::<i8>::new(0b_01100100)?;"]
#[doc = "let b = NonZero::<i8>::new(0b_01000000)?;"]
#[stable(feature = "isolate_most_least_significant_one", since =
"1.97.0")]
#[rustc_const_stable(feature = "isolate_most_least_significant_one", since
= "1.97.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn isolate_highest_one(self) -> Self {
unsafe {
let bit =
(((1 as u8) <<
(<u8>::BITS - 1)).unchecked_shr(self.leading_zeros()));
NonZero::new_unchecked(bit as i8)
}
}
#[doc = "let a = NonZero::<i8>::new(0b_01100100)?;"]
#[doc = "let b = NonZero::<i8>::new(0b_00000100)?;"]
#[stable(feature = "isolate_most_least_significant_one", since =
"1.97.0")]
#[rustc_const_stable(feature = "isolate_most_least_significant_one", since
= "1.97.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn isolate_lowest_one(self) -> Self {
let n = self.get();
let n = n & n.wrapping_neg();
unsafe { NonZero::new_unchecked(n) }
}
#[doc = "assert_eq!(NonZero::<i8>::new(0b1)?.highest_one(), 0);"]
#[doc = "assert_eq!(NonZero::<i8>::new(0b1_0000)?.highest_one(), 4);"]
#[doc = "assert_eq!(NonZero::<i8>::new(0b1_1111)?.highest_one(), 4);"]
#[stable(feature = "int_lowest_highest_one", since = "1.97.0")]
#[rustc_const_stable(feature = "int_lowest_highest_one", since =
"1.97.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn highest_one(self) -> u32 {
Self::BITS - 1 - self.leading_zeros()
}
#[doc = "assert_eq!(NonZero::<i8>::new(0b1)?.lowest_one(), 0);"]
#[doc = "assert_eq!(NonZero::<i8>::new(0b1_0000)?.lowest_one(), 4);"]
#[doc = "assert_eq!(NonZero::<i8>::new(0b1_1111)?.lowest_one(), 0);"]
#[stable(feature = "int_lowest_highest_one", since = "1.97.0")]
#[rustc_const_stable(feature = "int_lowest_highest_one", since =
"1.97.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn lowest_one(self) -> u32 { self.trailing_zeros() }
#[doc = "let a = NonZero::<i8>::new(0b100_0000)?;"]
#[doc = "let b = NonZero::<i8>::new(0b100_0011)?;"]
#[stable(feature = "non_zero_count_ones", since = "1.86.0")]
#[rustc_const_stable(feature = "non_zero_count_ones", since = "1.86.0")]
#[doc(alias = "popcount")]
#[doc(alias = "popcnt")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn count_ones(self) -> NonZero<u32> {
unsafe { NonZero::new_unchecked(self.get().count_ones()) }
}
#[doc = "let n = NonZero::new(-0x7ei8)?;"]
#[doc = "let m = NonZero::new(0xa)?;"]
#[doc = "assert_eq!(n.rotate_left(2), m);"]
#[unstable(feature = "nonzero_bitwise", issue = "128281")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn rotate_left(self, n: u32) -> Self {
let result = self.get().rotate_left(n);
unsafe { Self::new_unchecked(result) }
}
#[doc = "let n = NonZero::new(0xai8)?;"]
#[doc = "let m = NonZero::new(-0x7e)?;"]
#[doc = "assert_eq!(n.rotate_right(2), m);"]
#[unstable(feature = "nonzero_bitwise", issue = "128281")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn rotate_right(self, n: u32) -> Self {
let result = self.get().rotate_right(n);
unsafe { Self::new_unchecked(result) }
}
#[doc = "let n = NonZero::new(0x12i8)?;"]
#[doc = "assert_eq!(m, NonZero::new(0x12)?);"]
#[unstable(feature = "nonzero_bitwise", issue = "128281")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn swap_bytes(self) -> Self {
let result = self.get().swap_bytes();
unsafe { Self::new_unchecked(result) }
}
#[doc = "let n = NonZero::new(0x12i8)?;"]
#[doc = "assert_eq!(m, NonZero::new(0x48)?);"]
#[unstable(feature = "nonzero_bitwise", issue = "128281")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn reverse_bits(self) -> Self {
let result = self.get().reverse_bits();
unsafe { Self::new_unchecked(result) }
}
#[doc = "use std::num::NonZeroI8;"]
#[doc = "let n = NonZero::new(0x1Ai8)?;"]
#[doc = " assert_eq!(NonZeroI8::from_be(n), n)"]
#[doc = " assert_eq!(NonZeroI8::from_be(n), n.swap_bytes())"]
#[unstable(feature = "nonzero_bitwise", issue = "128281")]
#[must_use]
#[inline(always)]
pub const fn from_be(x: Self) -> Self {
let result = i8::from_be(x.get());
unsafe { Self::new_unchecked(result) }
}
#[doc = "use std::num::NonZeroI8;"]
#[doc = "let n = NonZero::new(0x1Ai8)?;"]
#[doc = " assert_eq!(NonZeroI8::from_le(n), n)"]
#[doc = " assert_eq!(NonZeroI8::from_le(n), n.swap_bytes())"]
#[unstable(feature = "nonzero_bitwise", issue = "128281")]
#[must_use]
#[inline(always)]
pub const fn from_le(x: Self) -> Self {
let result = i8::from_le(x.get());
unsafe { Self::new_unchecked(result) }
}
#[doc = "let n = NonZero::new(0x1Ai8)?;"]
#[unstable(feature = "nonzero_bitwise", issue = "128281")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn to_be(self) -> Self {
let result = self.get().to_be();
unsafe { Self::new_unchecked(result) }
}
#[doc = "let n = NonZero::new(0x1Ai8)?;"]
#[unstable(feature = "nonzero_bitwise", issue = "128281")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn to_le(self) -> Self {
let result = self.get().to_le();
unsafe { Self::new_unchecked(result) }
}
#[doc = "equal to [`i8::MIN`]."]
#[doc = "assert_eq!(NonZero::<i8>::MIN.get(), i8::MIN);"]
#[stable(feature = "nonzero_min_max", since = "1.70.0")]
pub const MIN: Self = Self::new(<i8>::MIN).unwrap();
#[doc = "equal to [`i8::MAX`]."]
#[doc = "assert_eq!(NonZero::<i8>::MAX.get(), i8::MAX);"]
#[stable(feature = "nonzero_min_max", since = "1.70.0")]
pub const MAX: Self = Self::new(<i8>::MAX).unwrap();
#[doc = "See [`i8::abs`]"]
#[doc = "let pos = NonZero::new(1i8)?;"]
#[doc = "let neg = NonZero::new(-1i8)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn abs(self) -> Self {
unsafe { Self::new_unchecked(self.get().abs()) }
}
#[doc = "`self == NonZero::<i8>::MIN`."]
#[doc = "let pos = NonZero::new(1i8)?;"]
#[doc = "let neg = NonZero::new(-1i8)?;"]
#[doc = "let min = NonZero::new(i8::MIN)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn checked_abs(self) -> Option<Self> {
if let Some(nz) = self.get().checked_abs() {
Some(unsafe { Self::new_unchecked(nz) })
} else { None }
}
#[doc = "[`i8::overflowing_abs`]."]
#[doc = "let pos = NonZero::new(1i8)?;"]
#[doc = "let neg = NonZero::new(-1i8)?;"]
#[doc = "let min = NonZero::new(i8::MIN)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn overflowing_abs(self) -> (Self, bool) {
let (nz, flag) = self.get().overflowing_abs();
(unsafe { Self::new_unchecked(nz) }, flag)
}
#[doc = "[`i8::saturating_abs`]."]
#[doc = "let pos = NonZero::new(1i8)?;"]
#[doc = "let neg = NonZero::new(-1i8)?;"]
#[doc = "let min = NonZero::new(i8::MIN)?;"]
#[doc = "let min_plus = NonZero::new(i8::MIN + 1)?;"]
#[doc = "let max = NonZero::new(i8::MAX)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn saturating_abs(self) -> Self {
unsafe { Self::new_unchecked(self.get().saturating_abs()) }
}
#[doc = "[`i8::wrapping_abs`]."]
#[doc = "let pos = NonZero::new(1i8)?;"]
#[doc = "let neg = NonZero::new(-1i8)?;"]
#[doc = "let min = NonZero::new(i8::MIN)?;"]
#[doc = "# let max = NonZero::new(i8::MAX)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn wrapping_abs(self) -> Self {
unsafe { Self::new_unchecked(self.get().wrapping_abs()) }
}
#[doc = "let u_pos = NonZero::new(1u8)?;"]
#[doc = "let i_pos = NonZero::new(1i8)?;"]
#[doc = "let i_neg = NonZero::new(-1i8)?;"]
#[doc = "let i_min = NonZero::new(i8::MIN)?;"]
#[doc = "let u_max = NonZero::new(u8::MAX / 2 + 1)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn unsigned_abs(self) -> NonZero<u8> {
unsafe { NonZero::new_unchecked(self.get().unsigned_abs()) }
}
#[doc = "let pos_five = NonZero::new(5i8)?;"]
#[doc = "let neg_five = NonZero::new(-5i8)?;"]
#[must_use]
#[inline]
#[stable(feature = "nonzero_negation_ops", since = "1.71.0")]
#[rustc_const_stable(feature = "nonzero_negation_ops", since = "1.71.0")]
pub const fn is_positive(self) -> bool { self.get().is_positive() }
#[doc = "let pos_five = NonZero::new(5i8)?;"]
#[doc = "let neg_five = NonZero::new(-5i8)?;"]
#[must_use]
#[inline]
#[stable(feature = "nonzero_negation_ops", since = "1.71.0")]
#[rustc_const_stable(feature = "nonzero_negation_ops", since = "1.71.0")]
pub const fn is_negative(self) -> bool { self.get().is_negative() }
#[doc = "returning `None` if `self == NonZero::<i8>::MIN`."]
#[doc = "let pos_five = NonZero::new(5i8)?;"]
#[doc = "let neg_five = NonZero::new(-5i8)?;"]
#[doc = "let min = NonZero::new(i8::MIN)?;"]
#[inline]
#[stable(feature = "nonzero_negation_ops", since = "1.71.0")]
#[rustc_const_stable(feature = "nonzero_negation_ops", since = "1.71.0")]
pub const fn checked_neg(self) -> Option<Self> {
if let Some(result) = self.get().checked_neg() {
return Some(unsafe { Self::new_unchecked(result) });
}
None
}
#[doc = "See [`i8::overflowing_neg`]"]
#[doc = "let pos_five = NonZero::new(5i8)?;"]
#[doc = "let neg_five = NonZero::new(-5i8)?;"]
#[doc = "let min = NonZero::new(i8::MIN)?;"]
#[inline]
#[stable(feature = "nonzero_negation_ops", since = "1.71.0")]
#[rustc_const_stable(feature = "nonzero_negation_ops", since = "1.71.0")]
pub const fn overflowing_neg(self) -> (Self, bool) {
let (result, overflow) = self.get().overflowing_neg();
((unsafe { Self::new_unchecked(result) }), overflow)
}
#[doc = "returning [`NonZero::<i8>::MAX`]"]
#[doc = "if `self == NonZero::<i8>::MIN`"]
#[doc = "let pos_five = NonZero::new(5i8)?;"]
#[doc = "let neg_five = NonZero::new(-5i8)?;"]
#[doc = "let min = NonZero::new(i8::MIN)?;"]
#[doc = "let min_plus_one = NonZero::new(i8::MIN + 1)?;"]
#[doc = "let max = NonZero::new(i8::MAX)?;"]
#[inline]
#[stable(feature = "nonzero_negation_ops", since = "1.71.0")]
#[rustc_const_stable(feature = "nonzero_negation_ops", since = "1.71.0")]
pub const fn saturating_neg(self) -> Self {
if let Some(result) = self.checked_neg() { return result; }
Self::MAX
}
#[doc = "See [`i8::wrapping_neg`]"]
#[doc = "let pos_five = NonZero::new(5i8)?;"]
#[doc = "let neg_five = NonZero::new(-5i8)?;"]
#[doc = "let min = NonZero::new(i8::MIN)?;"]
#[inline]
#[stable(feature = "nonzero_negation_ops", since = "1.71.0")]
#[rustc_const_stable(feature = "nonzero_negation_ops", since = "1.71.0")]
pub const fn wrapping_neg(self) -> Self {
let result = self.get().wrapping_neg();
unsafe { Self::new_unchecked(result) }
}
#[doc = "let n = NonZero::new(-1i8).unwrap();"]
#[doc = "assert_eq!(n.cast_unsigned(), NonZero::<u8>::MAX);"]
#[stable(feature = "integer_sign_cast", since = "1.87.0")]
#[rustc_const_stable(feature = "integer_sign_cast", since = "1.87.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn cast_unsigned(self) -> NonZero<u8> {
unsafe { NonZero::new_unchecked(self.get().cast_unsigned()) }
}
#[doc = "let two = NonZero::new(2i8)?;"]
#[doc = "let four = NonZero::new(4i8)?;"]
#[doc = "let max = NonZero::new(i8::MAX)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn checked_mul(self, other: Self) -> Option<Self> {
if let Some(result) = self.get().checked_mul(other.get()) {
Some(unsafe { Self::new_unchecked(result) })
} else { None }
}
#[doc = "Return [`NonZero::<i8>::MAX`] on overflow."]
#[doc = "let two = NonZero::new(2i8)?;"]
#[doc = "let four = NonZero::new(4i8)?;"]
#[doc = "let max = NonZero::new(i8::MAX)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn saturating_mul(self, other: Self) -> Self {
unsafe { Self::new_unchecked(self.get().saturating_mul(other.get())) }
}
#[doc = "`self * rhs > i8::MAX`, or `self * rhs < i8::MIN`."]
#[doc = "let two = NonZero::new(2i8)?;"]
#[doc = "let four = NonZero::new(4i8)?;"]
#[unstable(feature = "nonzero_ops", issue = "84186")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const unsafe fn unchecked_mul(self, other: Self) -> Self {
unsafe { Self::new_unchecked(self.get().unchecked_mul(other.get())) }
}
#[doc = "let three = NonZero::new(3i8)?;"]
#[doc = "let twenty_seven = NonZero::new(27i8)?;"]
#[doc = "let half_max = NonZero::new(i8::MAX / 2)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn checked_pow(self, other: u32) -> Option<Self> {
if let Some(result) = self.get().checked_pow(other) {
Some(unsafe { Self::new_unchecked(result) })
} else { None }
}
#[doc =
"Return [`NonZero::<i8>::MIN`] or [`NonZero::<i8>::MAX`] on overflow."]
#[doc = "let three = NonZero::new(3i8)?;"]
#[doc = "let twenty_seven = NonZero::new(27i8)?;"]
#[doc = "let max = NonZero::new(i8::MAX)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn saturating_pow(self, other: u32) -> Self {
unsafe { Self::new_unchecked(self.get().saturating_pow(other)) }
}
#[doc = " `+` or `-` "]
#[doc =
"assert_eq!(NonZero::<i8>::from_ascii(b\"+10\"), Ok(NonZero::new(10)?));"]
#[doc = "assert!(NonZero::<i8>::from_ascii(b\"1 \").is_err());"]
#[unstable(feature = "int_from_ascii", issue = "134821")]
#[inline]
pub const fn from_ascii(src: &[u8]) -> Result<Self, ParseIntError> {
Self::from_ascii_radix(src, 10)
}
#[doc = " `+` or `-` "]
#[doc =
"assert_eq!(NonZero::<i8>::from_ascii_radix(b\"A\", 16), Ok(NonZero::new(10)?));"]
#[doc = "assert!(NonZero::<i8>::from_ascii_radix(b\"1 \", 10).is_err());"]
#[unstable(feature = "int_from_ascii", issue = "134821")]
#[inline]
pub const fn from_ascii_radix(src: &[u8], radix: u32)
-> Result<Self, ParseIntError> {
let n =
match <i8>::from_ascii_radix(src, radix) {
Ok(n) => n,
Err(err) => return Err(err),
};
if let Some(n) = Self::new(n) {
Ok(n)
} else { Err(ParseIntError { kind: IntErrorKind::Zero }) }
}
#[doc = " `+` or `-` "]
#[doc =
"assert_eq!(NonZero::<i8>::from_str_radix(\"A\", 16), Ok(NonZero::new(10)?));"]
#[doc = "assert!(NonZero::<i8>::from_str_radix(\"1 \", 10).is_err());"]
#[unstable(feature = "nonzero_from_str_radix", issue = "152193")]
#[inline]
pub const fn from_str_radix(src: &str, radix: u32)
-> Result<Self, ParseIntError> {
Self::from_ascii_radix(src.as_bytes(), radix)
}
}
#[stable(feature = "nonzero_parse", since = "1.35.0")]
impl FromStr for NonZero<i8> {
type Err = ParseIntError;
fn from_str(src: &str) -> Result<Self, Self::Err> {
Self::from_str_radix(src, 10)
}
}
#[stable(feature = "signed_nonzero_neg", since = "1.71.0")]
#[rustc_const_unstable(feature = "const_ops", issue = "143802")]
impl const Neg for NonZero<i8> {
type Output = Self;
#[inline]
fn neg(self) -> Self { unsafe { Self::new_unchecked(self.get().neg()) } }
}
#[stable(feature = "signed_nonzero_neg", since = "1.71.0")]
#[rustc_const_unstable(feature = "const_ops", issue = "143802")]
impl const Neg for &NonZero<i8> {
type Output = <NonZero<i8> as Neg>::Output;
#[inline]
fn neg(self) -> <NonZero<i8> as Neg>::Output { Neg::neg(*self) }
}nonzero_integer! {
2500 Self = NonZeroI8,
2501 Primitive = signed i8,
2502 UnsignedPrimitive = u8,
2503 rot = 2,
2504 rot_op = "-0x7e",
2505 rot_result = "0xa",
2506 swap_op = "0x12",
2507 swapped = "0x12",
2508 reversed = "0x48",
2509}
2510
2511#[doc = "An [`i16`] that is known not to equal zero."]
#[doc = "For example, `Option<NonZeroI16>` is the same size as `i16`:"]
#[doc =
"assert_eq!(size_of::<Option<core::num::NonZeroI16>>(), size_of::<i16>());"]
#[doc =
"`NonZeroI16` is guaranteed to have the same layout and bit validity as `i16`"]
#[doc = "`Option<NonZeroI16>` is guaranteed to be compatible with `i16`,"]
#[doc = "`NonZeroI16` and `Option<NonZeroI16>`"]
#[doc = "use std::num::NonZeroI16;"]
#[doc =
"assert_eq!(size_of::<NonZeroI16>(), size_of::<Option<NonZeroI16>>());"]
#[doc =
"assert_eq!(align_of::<NonZeroI16>(), align_of::<Option<NonZeroI16>>());"]
#[doc = "`NonZeroI16`"]
#[doc = "use std::num::NonZeroI16;"]
#[doc =
"const TEN: NonZeroI16 = NonZeroI16::new(10).expect(\"ten is non-zero\");"]
#[stable(feature = "signed_nonzero", since = "1.34.0")]
pub type NonZeroI16 = NonZero<i16>;
impl NonZero<i16> {
#[doc = "This value is equal to [`i16::BITS`]."]
#[doc = "assert_eq!(NonZero::<i16>::BITS, i16::BITS);"]
#[stable(feature = "nonzero_bits", since = "1.67.0")]
pub const BITS: u32 = <i16>::BITS;
#[doc = "let n = NonZero::<i16>::new(-1i16)?;"]
#[stable(feature = "nonzero_leading_trailing_zeros", since = "1.53.0")]
#[rustc_const_stable(feature = "nonzero_leading_trailing_zeros", since =
"1.53.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn leading_zeros(self) -> u32 {
unsafe { intrinsics::ctlz_nonzero(self.get() as u16) }
}
#[doc = "let n = NonZero::<i16>::new(0b0101000)?;"]
#[stable(feature = "nonzero_leading_trailing_zeros", since = "1.53.0")]
#[rustc_const_stable(feature = "nonzero_leading_trailing_zeros", since =
"1.53.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn trailing_zeros(self) -> u32 {
unsafe { intrinsics::cttz_nonzero(self.get() as u16) }
}
#[doc = "let a = NonZero::<i16>::new(0b_01100100)?;"]
#[doc = "let b = NonZero::<i16>::new(0b_01000000)?;"]
#[stable(feature = "isolate_most_least_significant_one", since =
"1.97.0")]
#[rustc_const_stable(feature = "isolate_most_least_significant_one", since
= "1.97.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn isolate_highest_one(self) -> Self {
unsafe {
let bit =
(((1 as u16) <<
(<u16>::BITS - 1)).unchecked_shr(self.leading_zeros()));
NonZero::new_unchecked(bit as i16)
}
}
#[doc = "let a = NonZero::<i16>::new(0b_01100100)?;"]
#[doc = "let b = NonZero::<i16>::new(0b_00000100)?;"]
#[stable(feature = "isolate_most_least_significant_one", since =
"1.97.0")]
#[rustc_const_stable(feature = "isolate_most_least_significant_one", since
= "1.97.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn isolate_lowest_one(self) -> Self {
let n = self.get();
let n = n & n.wrapping_neg();
unsafe { NonZero::new_unchecked(n) }
}
#[doc = "assert_eq!(NonZero::<i16>::new(0b1)?.highest_one(), 0);"]
#[doc = "assert_eq!(NonZero::<i16>::new(0b1_0000)?.highest_one(), 4);"]
#[doc = "assert_eq!(NonZero::<i16>::new(0b1_1111)?.highest_one(), 4);"]
#[stable(feature = "int_lowest_highest_one", since = "1.97.0")]
#[rustc_const_stable(feature = "int_lowest_highest_one", since =
"1.97.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn highest_one(self) -> u32 {
Self::BITS - 1 - self.leading_zeros()
}
#[doc = "assert_eq!(NonZero::<i16>::new(0b1)?.lowest_one(), 0);"]
#[doc = "assert_eq!(NonZero::<i16>::new(0b1_0000)?.lowest_one(), 4);"]
#[doc = "assert_eq!(NonZero::<i16>::new(0b1_1111)?.lowest_one(), 0);"]
#[stable(feature = "int_lowest_highest_one", since = "1.97.0")]
#[rustc_const_stable(feature = "int_lowest_highest_one", since =
"1.97.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn lowest_one(self) -> u32 { self.trailing_zeros() }
#[doc = "let a = NonZero::<i16>::new(0b100_0000)?;"]
#[doc = "let b = NonZero::<i16>::new(0b100_0011)?;"]
#[stable(feature = "non_zero_count_ones", since = "1.86.0")]
#[rustc_const_stable(feature = "non_zero_count_ones", since = "1.86.0")]
#[doc(alias = "popcount")]
#[doc(alias = "popcnt")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn count_ones(self) -> NonZero<u32> {
unsafe { NonZero::new_unchecked(self.get().count_ones()) }
}
#[doc = "let n = NonZero::new(-0x5ffdi16)?;"]
#[doc = "let m = NonZero::new(0x3a)?;"]
#[doc = "assert_eq!(n.rotate_left(4), m);"]
#[unstable(feature = "nonzero_bitwise", issue = "128281")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn rotate_left(self, n: u32) -> Self {
let result = self.get().rotate_left(n);
unsafe { Self::new_unchecked(result) }
}
#[doc = "let n = NonZero::new(0x3ai16)?;"]
#[doc = "let m = NonZero::new(-0x5ffd)?;"]
#[doc = "assert_eq!(n.rotate_right(4), m);"]
#[unstable(feature = "nonzero_bitwise", issue = "128281")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn rotate_right(self, n: u32) -> Self {
let result = self.get().rotate_right(n);
unsafe { Self::new_unchecked(result) }
}
#[doc = "let n = NonZero::new(0x1234i16)?;"]
#[doc = "assert_eq!(m, NonZero::new(0x3412)?);"]
#[unstable(feature = "nonzero_bitwise", issue = "128281")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn swap_bytes(self) -> Self {
let result = self.get().swap_bytes();
unsafe { Self::new_unchecked(result) }
}
#[doc = "let n = NonZero::new(0x1234i16)?;"]
#[doc = "assert_eq!(m, NonZero::new(0x2c48)?);"]
#[unstable(feature = "nonzero_bitwise", issue = "128281")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn reverse_bits(self) -> Self {
let result = self.get().reverse_bits();
unsafe { Self::new_unchecked(result) }
}
#[doc = "use std::num::NonZeroI16;"]
#[doc = "let n = NonZero::new(0x1Ai16)?;"]
#[doc = " assert_eq!(NonZeroI16::from_be(n), n)"]
#[doc = " assert_eq!(NonZeroI16::from_be(n), n.swap_bytes())"]
#[unstable(feature = "nonzero_bitwise", issue = "128281")]
#[must_use]
#[inline(always)]
pub const fn from_be(x: Self) -> Self {
let result = i16::from_be(x.get());
unsafe { Self::new_unchecked(result) }
}
#[doc = "use std::num::NonZeroI16;"]
#[doc = "let n = NonZero::new(0x1Ai16)?;"]
#[doc = " assert_eq!(NonZeroI16::from_le(n), n)"]
#[doc = " assert_eq!(NonZeroI16::from_le(n), n.swap_bytes())"]
#[unstable(feature = "nonzero_bitwise", issue = "128281")]
#[must_use]
#[inline(always)]
pub const fn from_le(x: Self) -> Self {
let result = i16::from_le(x.get());
unsafe { Self::new_unchecked(result) }
}
#[doc = "let n = NonZero::new(0x1Ai16)?;"]
#[unstable(feature = "nonzero_bitwise", issue = "128281")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn to_be(self) -> Self {
let result = self.get().to_be();
unsafe { Self::new_unchecked(result) }
}
#[doc = "let n = NonZero::new(0x1Ai16)?;"]
#[unstable(feature = "nonzero_bitwise", issue = "128281")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn to_le(self) -> Self {
let result = self.get().to_le();
unsafe { Self::new_unchecked(result) }
}
#[doc = "equal to [`i16::MIN`]."]
#[doc = "assert_eq!(NonZero::<i16>::MIN.get(), i16::MIN);"]
#[stable(feature = "nonzero_min_max", since = "1.70.0")]
pub const MIN: Self = Self::new(<i16>::MIN).unwrap();
#[doc = "equal to [`i16::MAX`]."]
#[doc = "assert_eq!(NonZero::<i16>::MAX.get(), i16::MAX);"]
#[stable(feature = "nonzero_min_max", since = "1.70.0")]
pub const MAX: Self = Self::new(<i16>::MAX).unwrap();
#[doc = "See [`i16::abs`]"]
#[doc = "let pos = NonZero::new(1i16)?;"]
#[doc = "let neg = NonZero::new(-1i16)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn abs(self) -> Self {
unsafe { Self::new_unchecked(self.get().abs()) }
}
#[doc = "`self == NonZero::<i16>::MIN`."]
#[doc = "let pos = NonZero::new(1i16)?;"]
#[doc = "let neg = NonZero::new(-1i16)?;"]
#[doc = "let min = NonZero::new(i16::MIN)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn checked_abs(self) -> Option<Self> {
if let Some(nz) = self.get().checked_abs() {
Some(unsafe { Self::new_unchecked(nz) })
} else { None }
}
#[doc = "[`i16::overflowing_abs`]."]
#[doc = "let pos = NonZero::new(1i16)?;"]
#[doc = "let neg = NonZero::new(-1i16)?;"]
#[doc = "let min = NonZero::new(i16::MIN)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn overflowing_abs(self) -> (Self, bool) {
let (nz, flag) = self.get().overflowing_abs();
(unsafe { Self::new_unchecked(nz) }, flag)
}
#[doc = "[`i16::saturating_abs`]."]
#[doc = "let pos = NonZero::new(1i16)?;"]
#[doc = "let neg = NonZero::new(-1i16)?;"]
#[doc = "let min = NonZero::new(i16::MIN)?;"]
#[doc = "let min_plus = NonZero::new(i16::MIN + 1)?;"]
#[doc = "let max = NonZero::new(i16::MAX)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn saturating_abs(self) -> Self {
unsafe { Self::new_unchecked(self.get().saturating_abs()) }
}
#[doc = "[`i16::wrapping_abs`]."]
#[doc = "let pos = NonZero::new(1i16)?;"]
#[doc = "let neg = NonZero::new(-1i16)?;"]
#[doc = "let min = NonZero::new(i16::MIN)?;"]
#[doc = "# let max = NonZero::new(i16::MAX)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn wrapping_abs(self) -> Self {
unsafe { Self::new_unchecked(self.get().wrapping_abs()) }
}
#[doc = "let u_pos = NonZero::new(1u16)?;"]
#[doc = "let i_pos = NonZero::new(1i16)?;"]
#[doc = "let i_neg = NonZero::new(-1i16)?;"]
#[doc = "let i_min = NonZero::new(i16::MIN)?;"]
#[doc = "let u_max = NonZero::new(u16::MAX / 2 + 1)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn unsigned_abs(self) -> NonZero<u16> {
unsafe { NonZero::new_unchecked(self.get().unsigned_abs()) }
}
#[doc = "let pos_five = NonZero::new(5i16)?;"]
#[doc = "let neg_five = NonZero::new(-5i16)?;"]
#[must_use]
#[inline]
#[stable(feature = "nonzero_negation_ops", since = "1.71.0")]
#[rustc_const_stable(feature = "nonzero_negation_ops", since = "1.71.0")]
pub const fn is_positive(self) -> bool { self.get().is_positive() }
#[doc = "let pos_five = NonZero::new(5i16)?;"]
#[doc = "let neg_five = NonZero::new(-5i16)?;"]
#[must_use]
#[inline]
#[stable(feature = "nonzero_negation_ops", since = "1.71.0")]
#[rustc_const_stable(feature = "nonzero_negation_ops", since = "1.71.0")]
pub const fn is_negative(self) -> bool { self.get().is_negative() }
#[doc = "returning `None` if `self == NonZero::<i16>::MIN`."]
#[doc = "let pos_five = NonZero::new(5i16)?;"]
#[doc = "let neg_five = NonZero::new(-5i16)?;"]
#[doc = "let min = NonZero::new(i16::MIN)?;"]
#[inline]
#[stable(feature = "nonzero_negation_ops", since = "1.71.0")]
#[rustc_const_stable(feature = "nonzero_negation_ops", since = "1.71.0")]
pub const fn checked_neg(self) -> Option<Self> {
if let Some(result) = self.get().checked_neg() {
return Some(unsafe { Self::new_unchecked(result) });
}
None
}
#[doc = "See [`i16::overflowing_neg`]"]
#[doc = "let pos_five = NonZero::new(5i16)?;"]
#[doc = "let neg_five = NonZero::new(-5i16)?;"]
#[doc = "let min = NonZero::new(i16::MIN)?;"]
#[inline]
#[stable(feature = "nonzero_negation_ops", since = "1.71.0")]
#[rustc_const_stable(feature = "nonzero_negation_ops", since = "1.71.0")]
pub const fn overflowing_neg(self) -> (Self, bool) {
let (result, overflow) = self.get().overflowing_neg();
((unsafe { Self::new_unchecked(result) }), overflow)
}
#[doc = "returning [`NonZero::<i16>::MAX`]"]
#[doc = "if `self == NonZero::<i16>::MIN`"]
#[doc = "let pos_five = NonZero::new(5i16)?;"]
#[doc = "let neg_five = NonZero::new(-5i16)?;"]
#[doc = "let min = NonZero::new(i16::MIN)?;"]
#[doc = "let min_plus_one = NonZero::new(i16::MIN + 1)?;"]
#[doc = "let max = NonZero::new(i16::MAX)?;"]
#[inline]
#[stable(feature = "nonzero_negation_ops", since = "1.71.0")]
#[rustc_const_stable(feature = "nonzero_negation_ops", since = "1.71.0")]
pub const fn saturating_neg(self) -> Self {
if let Some(result) = self.checked_neg() { return result; }
Self::MAX
}
#[doc = "See [`i16::wrapping_neg`]"]
#[doc = "let pos_five = NonZero::new(5i16)?;"]
#[doc = "let neg_five = NonZero::new(-5i16)?;"]
#[doc = "let min = NonZero::new(i16::MIN)?;"]
#[inline]
#[stable(feature = "nonzero_negation_ops", since = "1.71.0")]
#[rustc_const_stable(feature = "nonzero_negation_ops", since = "1.71.0")]
pub const fn wrapping_neg(self) -> Self {
let result = self.get().wrapping_neg();
unsafe { Self::new_unchecked(result) }
}
#[doc = "let n = NonZero::new(-1i16).unwrap();"]
#[doc = "assert_eq!(n.cast_unsigned(), NonZero::<u16>::MAX);"]
#[stable(feature = "integer_sign_cast", since = "1.87.0")]
#[rustc_const_stable(feature = "integer_sign_cast", since = "1.87.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn cast_unsigned(self) -> NonZero<u16> {
unsafe { NonZero::new_unchecked(self.get().cast_unsigned()) }
}
#[doc = "let two = NonZero::new(2i16)?;"]
#[doc = "let four = NonZero::new(4i16)?;"]
#[doc = "let max = NonZero::new(i16::MAX)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn checked_mul(self, other: Self) -> Option<Self> {
if let Some(result) = self.get().checked_mul(other.get()) {
Some(unsafe { Self::new_unchecked(result) })
} else { None }
}
#[doc = "Return [`NonZero::<i16>::MAX`] on overflow."]
#[doc = "let two = NonZero::new(2i16)?;"]
#[doc = "let four = NonZero::new(4i16)?;"]
#[doc = "let max = NonZero::new(i16::MAX)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn saturating_mul(self, other: Self) -> Self {
unsafe { Self::new_unchecked(self.get().saturating_mul(other.get())) }
}
#[doc = "`self * rhs > i16::MAX`, or `self * rhs < i16::MIN`."]
#[doc = "let two = NonZero::new(2i16)?;"]
#[doc = "let four = NonZero::new(4i16)?;"]
#[unstable(feature = "nonzero_ops", issue = "84186")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const unsafe fn unchecked_mul(self, other: Self) -> Self {
unsafe { Self::new_unchecked(self.get().unchecked_mul(other.get())) }
}
#[doc = "let three = NonZero::new(3i16)?;"]
#[doc = "let twenty_seven = NonZero::new(27i16)?;"]
#[doc = "let half_max = NonZero::new(i16::MAX / 2)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn checked_pow(self, other: u32) -> Option<Self> {
if let Some(result) = self.get().checked_pow(other) {
Some(unsafe { Self::new_unchecked(result) })
} else { None }
}
#[doc =
"Return [`NonZero::<i16>::MIN`] or [`NonZero::<i16>::MAX`] on overflow."]
#[doc = "let three = NonZero::new(3i16)?;"]
#[doc = "let twenty_seven = NonZero::new(27i16)?;"]
#[doc = "let max = NonZero::new(i16::MAX)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn saturating_pow(self, other: u32) -> Self {
unsafe { Self::new_unchecked(self.get().saturating_pow(other)) }
}
#[doc = " `+` or `-` "]
#[doc =
"assert_eq!(NonZero::<i16>::from_ascii(b\"+10\"), Ok(NonZero::new(10)?));"]
#[doc = "assert!(NonZero::<i16>::from_ascii(b\"1 \").is_err());"]
#[unstable(feature = "int_from_ascii", issue = "134821")]
#[inline]
pub const fn from_ascii(src: &[u8]) -> Result<Self, ParseIntError> {
Self::from_ascii_radix(src, 10)
}
#[doc = " `+` or `-` "]
#[doc =
"assert_eq!(NonZero::<i16>::from_ascii_radix(b\"A\", 16), Ok(NonZero::new(10)?));"]
#[doc =
"assert!(NonZero::<i16>::from_ascii_radix(b\"1 \", 10).is_err());"]
#[unstable(feature = "int_from_ascii", issue = "134821")]
#[inline]
pub const fn from_ascii_radix(src: &[u8], radix: u32)
-> Result<Self, ParseIntError> {
let n =
match <i16>::from_ascii_radix(src, radix) {
Ok(n) => n,
Err(err) => return Err(err),
};
if let Some(n) = Self::new(n) {
Ok(n)
} else { Err(ParseIntError { kind: IntErrorKind::Zero }) }
}
#[doc = " `+` or `-` "]
#[doc =
"assert_eq!(NonZero::<i16>::from_str_radix(\"A\", 16), Ok(NonZero::new(10)?));"]
#[doc = "assert!(NonZero::<i16>::from_str_radix(\"1 \", 10).is_err());"]
#[unstable(feature = "nonzero_from_str_radix", issue = "152193")]
#[inline]
pub const fn from_str_radix(src: &str, radix: u32)
-> Result<Self, ParseIntError> {
Self::from_ascii_radix(src.as_bytes(), radix)
}
}
#[stable(feature = "nonzero_parse", since = "1.35.0")]
impl FromStr for NonZero<i16> {
type Err = ParseIntError;
fn from_str(src: &str) -> Result<Self, Self::Err> {
Self::from_str_radix(src, 10)
}
}
#[stable(feature = "signed_nonzero_neg", since = "1.71.0")]
#[rustc_const_unstable(feature = "const_ops", issue = "143802")]
impl const Neg for NonZero<i16> {
type Output = Self;
#[inline]
fn neg(self) -> Self { unsafe { Self::new_unchecked(self.get().neg()) } }
}
#[stable(feature = "signed_nonzero_neg", since = "1.71.0")]
#[rustc_const_unstable(feature = "const_ops", issue = "143802")]
impl const Neg for &NonZero<i16> {
type Output = <NonZero<i16> as Neg>::Output;
#[inline]
fn neg(self) -> <NonZero<i16> as Neg>::Output { Neg::neg(*self) }
}nonzero_integer! {
2512 Self = NonZeroI16,
2513 Primitive = signed i16,
2514 UnsignedPrimitive = u16,
2515 rot = 4,
2516 rot_op = "-0x5ffd",
2517 rot_result = "0x3a",
2518 swap_op = "0x1234",
2519 swapped = "0x3412",
2520 reversed = "0x2c48",
2521}
2522
2523#[doc = "An [`i32`] that is known not to equal zero."]
#[doc = "For example, `Option<NonZeroI32>` is the same size as `i32`:"]
#[doc =
"assert_eq!(size_of::<Option<core::num::NonZeroI32>>(), size_of::<i32>());"]
#[doc =
"`NonZeroI32` is guaranteed to have the same layout and bit validity as `i32`"]
#[doc = "`Option<NonZeroI32>` is guaranteed to be compatible with `i32`,"]
#[doc = "`NonZeroI32` and `Option<NonZeroI32>`"]
#[doc = "use std::num::NonZeroI32;"]
#[doc =
"assert_eq!(size_of::<NonZeroI32>(), size_of::<Option<NonZeroI32>>());"]
#[doc =
"assert_eq!(align_of::<NonZeroI32>(), align_of::<Option<NonZeroI32>>());"]
#[doc = "`NonZeroI32`"]
#[doc = "use std::num::NonZeroI32;"]
#[doc =
"const TEN: NonZeroI32 = NonZeroI32::new(10).expect(\"ten is non-zero\");"]
#[stable(feature = "signed_nonzero", since = "1.34.0")]
pub type NonZeroI32 = NonZero<i32>;
impl NonZero<i32> {
#[doc = "This value is equal to [`i32::BITS`]."]
#[doc = "assert_eq!(NonZero::<i32>::BITS, i32::BITS);"]
#[stable(feature = "nonzero_bits", since = "1.67.0")]
pub const BITS: u32 = <i32>::BITS;
#[doc = "let n = NonZero::<i32>::new(-1i32)?;"]
#[stable(feature = "nonzero_leading_trailing_zeros", since = "1.53.0")]
#[rustc_const_stable(feature = "nonzero_leading_trailing_zeros", since =
"1.53.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn leading_zeros(self) -> u32 {
unsafe { intrinsics::ctlz_nonzero(self.get() as u32) }
}
#[doc = "let n = NonZero::<i32>::new(0b0101000)?;"]
#[stable(feature = "nonzero_leading_trailing_zeros", since = "1.53.0")]
#[rustc_const_stable(feature = "nonzero_leading_trailing_zeros", since =
"1.53.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn trailing_zeros(self) -> u32 {
unsafe { intrinsics::cttz_nonzero(self.get() as u32) }
}
#[doc = "let a = NonZero::<i32>::new(0b_01100100)?;"]
#[doc = "let b = NonZero::<i32>::new(0b_01000000)?;"]
#[stable(feature = "isolate_most_least_significant_one", since =
"1.97.0")]
#[rustc_const_stable(feature = "isolate_most_least_significant_one", since
= "1.97.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn isolate_highest_one(self) -> Self {
unsafe {
let bit =
(((1 as u32) <<
(<u32>::BITS - 1)).unchecked_shr(self.leading_zeros()));
NonZero::new_unchecked(bit as i32)
}
}
#[doc = "let a = NonZero::<i32>::new(0b_01100100)?;"]
#[doc = "let b = NonZero::<i32>::new(0b_00000100)?;"]
#[stable(feature = "isolate_most_least_significant_one", since =
"1.97.0")]
#[rustc_const_stable(feature = "isolate_most_least_significant_one", since
= "1.97.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn isolate_lowest_one(self) -> Self {
let n = self.get();
let n = n & n.wrapping_neg();
unsafe { NonZero::new_unchecked(n) }
}
#[doc = "assert_eq!(NonZero::<i32>::new(0b1)?.highest_one(), 0);"]
#[doc = "assert_eq!(NonZero::<i32>::new(0b1_0000)?.highest_one(), 4);"]
#[doc = "assert_eq!(NonZero::<i32>::new(0b1_1111)?.highest_one(), 4);"]
#[stable(feature = "int_lowest_highest_one", since = "1.97.0")]
#[rustc_const_stable(feature = "int_lowest_highest_one", since =
"1.97.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn highest_one(self) -> u32 {
Self::BITS - 1 - self.leading_zeros()
}
#[doc = "assert_eq!(NonZero::<i32>::new(0b1)?.lowest_one(), 0);"]
#[doc = "assert_eq!(NonZero::<i32>::new(0b1_0000)?.lowest_one(), 4);"]
#[doc = "assert_eq!(NonZero::<i32>::new(0b1_1111)?.lowest_one(), 0);"]
#[stable(feature = "int_lowest_highest_one", since = "1.97.0")]
#[rustc_const_stable(feature = "int_lowest_highest_one", since =
"1.97.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn lowest_one(self) -> u32 { self.trailing_zeros() }
#[doc = "let a = NonZero::<i32>::new(0b100_0000)?;"]
#[doc = "let b = NonZero::<i32>::new(0b100_0011)?;"]
#[stable(feature = "non_zero_count_ones", since = "1.86.0")]
#[rustc_const_stable(feature = "non_zero_count_ones", since = "1.86.0")]
#[doc(alias = "popcount")]
#[doc(alias = "popcnt")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn count_ones(self) -> NonZero<u32> {
unsafe { NonZero::new_unchecked(self.get().count_ones()) }
}
#[doc = "let n = NonZero::new(0x10000b3i32)?;"]
#[doc = "let m = NonZero::new(0xb301)?;"]
#[doc = "assert_eq!(n.rotate_left(8), m);"]
#[unstable(feature = "nonzero_bitwise", issue = "128281")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn rotate_left(self, n: u32) -> Self {
let result = self.get().rotate_left(n);
unsafe { Self::new_unchecked(result) }
}
#[doc = "let n = NonZero::new(0xb301i32)?;"]
#[doc = "let m = NonZero::new(0x10000b3)?;"]
#[doc = "assert_eq!(n.rotate_right(8), m);"]
#[unstable(feature = "nonzero_bitwise", issue = "128281")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn rotate_right(self, n: u32) -> Self {
let result = self.get().rotate_right(n);
unsafe { Self::new_unchecked(result) }
}
#[doc = "let n = NonZero::new(0x12345678i32)?;"]
#[doc = "assert_eq!(m, NonZero::new(0x78563412)?);"]
#[unstable(feature = "nonzero_bitwise", issue = "128281")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn swap_bytes(self) -> Self {
let result = self.get().swap_bytes();
unsafe { Self::new_unchecked(result) }
}
#[doc = "let n = NonZero::new(0x12345678i32)?;"]
#[doc = "assert_eq!(m, NonZero::new(0x1e6a2c48)?);"]
#[unstable(feature = "nonzero_bitwise", issue = "128281")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn reverse_bits(self) -> Self {
let result = self.get().reverse_bits();
unsafe { Self::new_unchecked(result) }
}
#[doc = "use std::num::NonZeroI32;"]
#[doc = "let n = NonZero::new(0x1Ai32)?;"]
#[doc = " assert_eq!(NonZeroI32::from_be(n), n)"]
#[doc = " assert_eq!(NonZeroI32::from_be(n), n.swap_bytes())"]
#[unstable(feature = "nonzero_bitwise", issue = "128281")]
#[must_use]
#[inline(always)]
pub const fn from_be(x: Self) -> Self {
let result = i32::from_be(x.get());
unsafe { Self::new_unchecked(result) }
}
#[doc = "use std::num::NonZeroI32;"]
#[doc = "let n = NonZero::new(0x1Ai32)?;"]
#[doc = " assert_eq!(NonZeroI32::from_le(n), n)"]
#[doc = " assert_eq!(NonZeroI32::from_le(n), n.swap_bytes())"]
#[unstable(feature = "nonzero_bitwise", issue = "128281")]
#[must_use]
#[inline(always)]
pub const fn from_le(x: Self) -> Self {
let result = i32::from_le(x.get());
unsafe { Self::new_unchecked(result) }
}
#[doc = "let n = NonZero::new(0x1Ai32)?;"]
#[unstable(feature = "nonzero_bitwise", issue = "128281")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn to_be(self) -> Self {
let result = self.get().to_be();
unsafe { Self::new_unchecked(result) }
}
#[doc = "let n = NonZero::new(0x1Ai32)?;"]
#[unstable(feature = "nonzero_bitwise", issue = "128281")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn to_le(self) -> Self {
let result = self.get().to_le();
unsafe { Self::new_unchecked(result) }
}
#[doc = "equal to [`i32::MIN`]."]
#[doc = "assert_eq!(NonZero::<i32>::MIN.get(), i32::MIN);"]
#[stable(feature = "nonzero_min_max", since = "1.70.0")]
pub const MIN: Self = Self::new(<i32>::MIN).unwrap();
#[doc = "equal to [`i32::MAX`]."]
#[doc = "assert_eq!(NonZero::<i32>::MAX.get(), i32::MAX);"]
#[stable(feature = "nonzero_min_max", since = "1.70.0")]
pub const MAX: Self = Self::new(<i32>::MAX).unwrap();
#[doc = "See [`i32::abs`]"]
#[doc = "let pos = NonZero::new(1i32)?;"]
#[doc = "let neg = NonZero::new(-1i32)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn abs(self) -> Self {
unsafe { Self::new_unchecked(self.get().abs()) }
}
#[doc = "`self == NonZero::<i32>::MIN`."]
#[doc = "let pos = NonZero::new(1i32)?;"]
#[doc = "let neg = NonZero::new(-1i32)?;"]
#[doc = "let min = NonZero::new(i32::MIN)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn checked_abs(self) -> Option<Self> {
if let Some(nz) = self.get().checked_abs() {
Some(unsafe { Self::new_unchecked(nz) })
} else { None }
}
#[doc = "[`i32::overflowing_abs`]."]
#[doc = "let pos = NonZero::new(1i32)?;"]
#[doc = "let neg = NonZero::new(-1i32)?;"]
#[doc = "let min = NonZero::new(i32::MIN)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn overflowing_abs(self) -> (Self, bool) {
let (nz, flag) = self.get().overflowing_abs();
(unsafe { Self::new_unchecked(nz) }, flag)
}
#[doc = "[`i32::saturating_abs`]."]
#[doc = "let pos = NonZero::new(1i32)?;"]
#[doc = "let neg = NonZero::new(-1i32)?;"]
#[doc = "let min = NonZero::new(i32::MIN)?;"]
#[doc = "let min_plus = NonZero::new(i32::MIN + 1)?;"]
#[doc = "let max = NonZero::new(i32::MAX)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn saturating_abs(self) -> Self {
unsafe { Self::new_unchecked(self.get().saturating_abs()) }
}
#[doc = "[`i32::wrapping_abs`]."]
#[doc = "let pos = NonZero::new(1i32)?;"]
#[doc = "let neg = NonZero::new(-1i32)?;"]
#[doc = "let min = NonZero::new(i32::MIN)?;"]
#[doc = "# let max = NonZero::new(i32::MAX)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn wrapping_abs(self) -> Self {
unsafe { Self::new_unchecked(self.get().wrapping_abs()) }
}
#[doc = "let u_pos = NonZero::new(1u32)?;"]
#[doc = "let i_pos = NonZero::new(1i32)?;"]
#[doc = "let i_neg = NonZero::new(-1i32)?;"]
#[doc = "let i_min = NonZero::new(i32::MIN)?;"]
#[doc = "let u_max = NonZero::new(u32::MAX / 2 + 1)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn unsigned_abs(self) -> NonZero<u32> {
unsafe { NonZero::new_unchecked(self.get().unsigned_abs()) }
}
#[doc = "let pos_five = NonZero::new(5i32)?;"]
#[doc = "let neg_five = NonZero::new(-5i32)?;"]
#[must_use]
#[inline]
#[stable(feature = "nonzero_negation_ops", since = "1.71.0")]
#[rustc_const_stable(feature = "nonzero_negation_ops", since = "1.71.0")]
pub const fn is_positive(self) -> bool { self.get().is_positive() }
#[doc = "let pos_five = NonZero::new(5i32)?;"]
#[doc = "let neg_five = NonZero::new(-5i32)?;"]
#[must_use]
#[inline]
#[stable(feature = "nonzero_negation_ops", since = "1.71.0")]
#[rustc_const_stable(feature = "nonzero_negation_ops", since = "1.71.0")]
pub const fn is_negative(self) -> bool { self.get().is_negative() }
#[doc = "returning `None` if `self == NonZero::<i32>::MIN`."]
#[doc = "let pos_five = NonZero::new(5i32)?;"]
#[doc = "let neg_five = NonZero::new(-5i32)?;"]
#[doc = "let min = NonZero::new(i32::MIN)?;"]
#[inline]
#[stable(feature = "nonzero_negation_ops", since = "1.71.0")]
#[rustc_const_stable(feature = "nonzero_negation_ops", since = "1.71.0")]
pub const fn checked_neg(self) -> Option<Self> {
if let Some(result) = self.get().checked_neg() {
return Some(unsafe { Self::new_unchecked(result) });
}
None
}
#[doc = "See [`i32::overflowing_neg`]"]
#[doc = "let pos_five = NonZero::new(5i32)?;"]
#[doc = "let neg_five = NonZero::new(-5i32)?;"]
#[doc = "let min = NonZero::new(i32::MIN)?;"]
#[inline]
#[stable(feature = "nonzero_negation_ops", since = "1.71.0")]
#[rustc_const_stable(feature = "nonzero_negation_ops", since = "1.71.0")]
pub const fn overflowing_neg(self) -> (Self, bool) {
let (result, overflow) = self.get().overflowing_neg();
((unsafe { Self::new_unchecked(result) }), overflow)
}
#[doc = "returning [`NonZero::<i32>::MAX`]"]
#[doc = "if `self == NonZero::<i32>::MIN`"]
#[doc = "let pos_five = NonZero::new(5i32)?;"]
#[doc = "let neg_five = NonZero::new(-5i32)?;"]
#[doc = "let min = NonZero::new(i32::MIN)?;"]
#[doc = "let min_plus_one = NonZero::new(i32::MIN + 1)?;"]
#[doc = "let max = NonZero::new(i32::MAX)?;"]
#[inline]
#[stable(feature = "nonzero_negation_ops", since = "1.71.0")]
#[rustc_const_stable(feature = "nonzero_negation_ops", since = "1.71.0")]
pub const fn saturating_neg(self) -> Self {
if let Some(result) = self.checked_neg() { return result; }
Self::MAX
}
#[doc = "See [`i32::wrapping_neg`]"]
#[doc = "let pos_five = NonZero::new(5i32)?;"]
#[doc = "let neg_five = NonZero::new(-5i32)?;"]
#[doc = "let min = NonZero::new(i32::MIN)?;"]
#[inline]
#[stable(feature = "nonzero_negation_ops", since = "1.71.0")]
#[rustc_const_stable(feature = "nonzero_negation_ops", since = "1.71.0")]
pub const fn wrapping_neg(self) -> Self {
let result = self.get().wrapping_neg();
unsafe { Self::new_unchecked(result) }
}
#[doc = "let n = NonZero::new(-1i32).unwrap();"]
#[doc = "assert_eq!(n.cast_unsigned(), NonZero::<u32>::MAX);"]
#[stable(feature = "integer_sign_cast", since = "1.87.0")]
#[rustc_const_stable(feature = "integer_sign_cast", since = "1.87.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn cast_unsigned(self) -> NonZero<u32> {
unsafe { NonZero::new_unchecked(self.get().cast_unsigned()) }
}
#[doc = "let two = NonZero::new(2i32)?;"]
#[doc = "let four = NonZero::new(4i32)?;"]
#[doc = "let max = NonZero::new(i32::MAX)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn checked_mul(self, other: Self) -> Option<Self> {
if let Some(result) = self.get().checked_mul(other.get()) {
Some(unsafe { Self::new_unchecked(result) })
} else { None }
}
#[doc = "Return [`NonZero::<i32>::MAX`] on overflow."]
#[doc = "let two = NonZero::new(2i32)?;"]
#[doc = "let four = NonZero::new(4i32)?;"]
#[doc = "let max = NonZero::new(i32::MAX)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn saturating_mul(self, other: Self) -> Self {
unsafe { Self::new_unchecked(self.get().saturating_mul(other.get())) }
}
#[doc = "`self * rhs > i32::MAX`, or `self * rhs < i32::MIN`."]
#[doc = "let two = NonZero::new(2i32)?;"]
#[doc = "let four = NonZero::new(4i32)?;"]
#[unstable(feature = "nonzero_ops", issue = "84186")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const unsafe fn unchecked_mul(self, other: Self) -> Self {
unsafe { Self::new_unchecked(self.get().unchecked_mul(other.get())) }
}
#[doc = "let three = NonZero::new(3i32)?;"]
#[doc = "let twenty_seven = NonZero::new(27i32)?;"]
#[doc = "let half_max = NonZero::new(i32::MAX / 2)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn checked_pow(self, other: u32) -> Option<Self> {
if let Some(result) = self.get().checked_pow(other) {
Some(unsafe { Self::new_unchecked(result) })
} else { None }
}
#[doc =
"Return [`NonZero::<i32>::MIN`] or [`NonZero::<i32>::MAX`] on overflow."]
#[doc = "let three = NonZero::new(3i32)?;"]
#[doc = "let twenty_seven = NonZero::new(27i32)?;"]
#[doc = "let max = NonZero::new(i32::MAX)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn saturating_pow(self, other: u32) -> Self {
unsafe { Self::new_unchecked(self.get().saturating_pow(other)) }
}
#[doc = " `+` or `-` "]
#[doc =
"assert_eq!(NonZero::<i32>::from_ascii(b\"+10\"), Ok(NonZero::new(10)?));"]
#[doc = "assert!(NonZero::<i32>::from_ascii(b\"1 \").is_err());"]
#[unstable(feature = "int_from_ascii", issue = "134821")]
#[inline]
pub const fn from_ascii(src: &[u8]) -> Result<Self, ParseIntError> {
Self::from_ascii_radix(src, 10)
}
#[doc = " `+` or `-` "]
#[doc =
"assert_eq!(NonZero::<i32>::from_ascii_radix(b\"A\", 16), Ok(NonZero::new(10)?));"]
#[doc =
"assert!(NonZero::<i32>::from_ascii_radix(b\"1 \", 10).is_err());"]
#[unstable(feature = "int_from_ascii", issue = "134821")]
#[inline]
pub const fn from_ascii_radix(src: &[u8], radix: u32)
-> Result<Self, ParseIntError> {
let n =
match <i32>::from_ascii_radix(src, radix) {
Ok(n) => n,
Err(err) => return Err(err),
};
if let Some(n) = Self::new(n) {
Ok(n)
} else { Err(ParseIntError { kind: IntErrorKind::Zero }) }
}
#[doc = " `+` or `-` "]
#[doc =
"assert_eq!(NonZero::<i32>::from_str_radix(\"A\", 16), Ok(NonZero::new(10)?));"]
#[doc = "assert!(NonZero::<i32>::from_str_radix(\"1 \", 10).is_err());"]
#[unstable(feature = "nonzero_from_str_radix", issue = "152193")]
#[inline]
pub const fn from_str_radix(src: &str, radix: u32)
-> Result<Self, ParseIntError> {
Self::from_ascii_radix(src.as_bytes(), radix)
}
}
#[stable(feature = "nonzero_parse", since = "1.35.0")]
impl FromStr for NonZero<i32> {
type Err = ParseIntError;
fn from_str(src: &str) -> Result<Self, Self::Err> {
Self::from_str_radix(src, 10)
}
}
#[stable(feature = "signed_nonzero_neg", since = "1.71.0")]
#[rustc_const_unstable(feature = "const_ops", issue = "143802")]
impl const Neg for NonZero<i32> {
type Output = Self;
#[inline]
fn neg(self) -> Self { unsafe { Self::new_unchecked(self.get().neg()) } }
}
#[stable(feature = "signed_nonzero_neg", since = "1.71.0")]
#[rustc_const_unstable(feature = "const_ops", issue = "143802")]
impl const Neg for &NonZero<i32> {
type Output = <NonZero<i32> as Neg>::Output;
#[inline]
fn neg(self) -> <NonZero<i32> as Neg>::Output { Neg::neg(*self) }
}nonzero_integer! {
2524 Self = NonZeroI32,
2525 Primitive = signed i32,
2526 UnsignedPrimitive = u32,
2527 rot = 8,
2528 rot_op = "0x10000b3",
2529 rot_result = "0xb301",
2530 swap_op = "0x12345678",
2531 swapped = "0x78563412",
2532 reversed = "0x1e6a2c48",
2533}
2534
2535#[doc = "An [`i64`] that is known not to equal zero."]
#[doc = "For example, `Option<NonZeroI64>` is the same size as `i64`:"]
#[doc =
"assert_eq!(size_of::<Option<core::num::NonZeroI64>>(), size_of::<i64>());"]
#[doc =
"`NonZeroI64` is guaranteed to have the same layout and bit validity as `i64`"]
#[doc = "`Option<NonZeroI64>` is guaranteed to be compatible with `i64`,"]
#[doc = "`NonZeroI64` and `Option<NonZeroI64>`"]
#[doc = "use std::num::NonZeroI64;"]
#[doc =
"assert_eq!(size_of::<NonZeroI64>(), size_of::<Option<NonZeroI64>>());"]
#[doc =
"assert_eq!(align_of::<NonZeroI64>(), align_of::<Option<NonZeroI64>>());"]
#[doc = "`NonZeroI64`"]
#[doc = "use std::num::NonZeroI64;"]
#[doc =
"const TEN: NonZeroI64 = NonZeroI64::new(10).expect(\"ten is non-zero\");"]
#[stable(feature = "signed_nonzero", since = "1.34.0")]
pub type NonZeroI64 = NonZero<i64>;
impl NonZero<i64> {
#[doc = "This value is equal to [`i64::BITS`]."]
#[doc = "assert_eq!(NonZero::<i64>::BITS, i64::BITS);"]
#[stable(feature = "nonzero_bits", since = "1.67.0")]
pub const BITS: u32 = <i64>::BITS;
#[doc = "let n = NonZero::<i64>::new(-1i64)?;"]
#[stable(feature = "nonzero_leading_trailing_zeros", since = "1.53.0")]
#[rustc_const_stable(feature = "nonzero_leading_trailing_zeros", since =
"1.53.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn leading_zeros(self) -> u32 {
unsafe { intrinsics::ctlz_nonzero(self.get() as u64) }
}
#[doc = "let n = NonZero::<i64>::new(0b0101000)?;"]
#[stable(feature = "nonzero_leading_trailing_zeros", since = "1.53.0")]
#[rustc_const_stable(feature = "nonzero_leading_trailing_zeros", since =
"1.53.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn trailing_zeros(self) -> u32 {
unsafe { intrinsics::cttz_nonzero(self.get() as u64) }
}
#[doc = "let a = NonZero::<i64>::new(0b_01100100)?;"]
#[doc = "let b = NonZero::<i64>::new(0b_01000000)?;"]
#[stable(feature = "isolate_most_least_significant_one", since =
"1.97.0")]
#[rustc_const_stable(feature = "isolate_most_least_significant_one", since
= "1.97.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn isolate_highest_one(self) -> Self {
unsafe {
let bit =
(((1 as u64) <<
(<u64>::BITS - 1)).unchecked_shr(self.leading_zeros()));
NonZero::new_unchecked(bit as i64)
}
}
#[doc = "let a = NonZero::<i64>::new(0b_01100100)?;"]
#[doc = "let b = NonZero::<i64>::new(0b_00000100)?;"]
#[stable(feature = "isolate_most_least_significant_one", since =
"1.97.0")]
#[rustc_const_stable(feature = "isolate_most_least_significant_one", since
= "1.97.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn isolate_lowest_one(self) -> Self {
let n = self.get();
let n = n & n.wrapping_neg();
unsafe { NonZero::new_unchecked(n) }
}
#[doc = "assert_eq!(NonZero::<i64>::new(0b1)?.highest_one(), 0);"]
#[doc = "assert_eq!(NonZero::<i64>::new(0b1_0000)?.highest_one(), 4);"]
#[doc = "assert_eq!(NonZero::<i64>::new(0b1_1111)?.highest_one(), 4);"]
#[stable(feature = "int_lowest_highest_one", since = "1.97.0")]
#[rustc_const_stable(feature = "int_lowest_highest_one", since =
"1.97.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn highest_one(self) -> u32 {
Self::BITS - 1 - self.leading_zeros()
}
#[doc = "assert_eq!(NonZero::<i64>::new(0b1)?.lowest_one(), 0);"]
#[doc = "assert_eq!(NonZero::<i64>::new(0b1_0000)?.lowest_one(), 4);"]
#[doc = "assert_eq!(NonZero::<i64>::new(0b1_1111)?.lowest_one(), 0);"]
#[stable(feature = "int_lowest_highest_one", since = "1.97.0")]
#[rustc_const_stable(feature = "int_lowest_highest_one", since =
"1.97.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn lowest_one(self) -> u32 { self.trailing_zeros() }
#[doc = "let a = NonZero::<i64>::new(0b100_0000)?;"]
#[doc = "let b = NonZero::<i64>::new(0b100_0011)?;"]
#[stable(feature = "non_zero_count_ones", since = "1.86.0")]
#[rustc_const_stable(feature = "non_zero_count_ones", since = "1.86.0")]
#[doc(alias = "popcount")]
#[doc(alias = "popcnt")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn count_ones(self) -> NonZero<u32> {
unsafe { NonZero::new_unchecked(self.get().count_ones()) }
}
#[doc = "let n = NonZero::new(0xaa00000000006e1i64)?;"]
#[doc = "let m = NonZero::new(0x6e10aa)?;"]
#[doc = "assert_eq!(n.rotate_left(12), m);"]
#[unstable(feature = "nonzero_bitwise", issue = "128281")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn rotate_left(self, n: u32) -> Self {
let result = self.get().rotate_left(n);
unsafe { Self::new_unchecked(result) }
}
#[doc = "let n = NonZero::new(0x6e10aai64)?;"]
#[doc = "let m = NonZero::new(0xaa00000000006e1)?;"]
#[doc = "assert_eq!(n.rotate_right(12), m);"]
#[unstable(feature = "nonzero_bitwise", issue = "128281")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn rotate_right(self, n: u32) -> Self {
let result = self.get().rotate_right(n);
unsafe { Self::new_unchecked(result) }
}
#[doc = "let n = NonZero::new(0x1234567890123456i64)?;"]
#[doc = "assert_eq!(m, NonZero::new(0x5634129078563412)?);"]
#[unstable(feature = "nonzero_bitwise", issue = "128281")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn swap_bytes(self) -> Self {
let result = self.get().swap_bytes();
unsafe { Self::new_unchecked(result) }
}
#[doc = "let n = NonZero::new(0x1234567890123456i64)?;"]
#[doc = "assert_eq!(m, NonZero::new(0x6a2c48091e6a2c48)?);"]
#[unstable(feature = "nonzero_bitwise", issue = "128281")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn reverse_bits(self) -> Self {
let result = self.get().reverse_bits();
unsafe { Self::new_unchecked(result) }
}
#[doc = "use std::num::NonZeroI64;"]
#[doc = "let n = NonZero::new(0x1Ai64)?;"]
#[doc = " assert_eq!(NonZeroI64::from_be(n), n)"]
#[doc = " assert_eq!(NonZeroI64::from_be(n), n.swap_bytes())"]
#[unstable(feature = "nonzero_bitwise", issue = "128281")]
#[must_use]
#[inline(always)]
pub const fn from_be(x: Self) -> Self {
let result = i64::from_be(x.get());
unsafe { Self::new_unchecked(result) }
}
#[doc = "use std::num::NonZeroI64;"]
#[doc = "let n = NonZero::new(0x1Ai64)?;"]
#[doc = " assert_eq!(NonZeroI64::from_le(n), n)"]
#[doc = " assert_eq!(NonZeroI64::from_le(n), n.swap_bytes())"]
#[unstable(feature = "nonzero_bitwise", issue = "128281")]
#[must_use]
#[inline(always)]
pub const fn from_le(x: Self) -> Self {
let result = i64::from_le(x.get());
unsafe { Self::new_unchecked(result) }
}
#[doc = "let n = NonZero::new(0x1Ai64)?;"]
#[unstable(feature = "nonzero_bitwise", issue = "128281")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn to_be(self) -> Self {
let result = self.get().to_be();
unsafe { Self::new_unchecked(result) }
}
#[doc = "let n = NonZero::new(0x1Ai64)?;"]
#[unstable(feature = "nonzero_bitwise", issue = "128281")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn to_le(self) -> Self {
let result = self.get().to_le();
unsafe { Self::new_unchecked(result) }
}
#[doc = "equal to [`i64::MIN`]."]
#[doc = "assert_eq!(NonZero::<i64>::MIN.get(), i64::MIN);"]
#[stable(feature = "nonzero_min_max", since = "1.70.0")]
pub const MIN: Self = Self::new(<i64>::MIN).unwrap();
#[doc = "equal to [`i64::MAX`]."]
#[doc = "assert_eq!(NonZero::<i64>::MAX.get(), i64::MAX);"]
#[stable(feature = "nonzero_min_max", since = "1.70.0")]
pub const MAX: Self = Self::new(<i64>::MAX).unwrap();
#[doc = "See [`i64::abs`]"]
#[doc = "let pos = NonZero::new(1i64)?;"]
#[doc = "let neg = NonZero::new(-1i64)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn abs(self) -> Self {
unsafe { Self::new_unchecked(self.get().abs()) }
}
#[doc = "`self == NonZero::<i64>::MIN`."]
#[doc = "let pos = NonZero::new(1i64)?;"]
#[doc = "let neg = NonZero::new(-1i64)?;"]
#[doc = "let min = NonZero::new(i64::MIN)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn checked_abs(self) -> Option<Self> {
if let Some(nz) = self.get().checked_abs() {
Some(unsafe { Self::new_unchecked(nz) })
} else { None }
}
#[doc = "[`i64::overflowing_abs`]."]
#[doc = "let pos = NonZero::new(1i64)?;"]
#[doc = "let neg = NonZero::new(-1i64)?;"]
#[doc = "let min = NonZero::new(i64::MIN)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn overflowing_abs(self) -> (Self, bool) {
let (nz, flag) = self.get().overflowing_abs();
(unsafe { Self::new_unchecked(nz) }, flag)
}
#[doc = "[`i64::saturating_abs`]."]
#[doc = "let pos = NonZero::new(1i64)?;"]
#[doc = "let neg = NonZero::new(-1i64)?;"]
#[doc = "let min = NonZero::new(i64::MIN)?;"]
#[doc = "let min_plus = NonZero::new(i64::MIN + 1)?;"]
#[doc = "let max = NonZero::new(i64::MAX)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn saturating_abs(self) -> Self {
unsafe { Self::new_unchecked(self.get().saturating_abs()) }
}
#[doc = "[`i64::wrapping_abs`]."]
#[doc = "let pos = NonZero::new(1i64)?;"]
#[doc = "let neg = NonZero::new(-1i64)?;"]
#[doc = "let min = NonZero::new(i64::MIN)?;"]
#[doc = "# let max = NonZero::new(i64::MAX)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn wrapping_abs(self) -> Self {
unsafe { Self::new_unchecked(self.get().wrapping_abs()) }
}
#[doc = "let u_pos = NonZero::new(1u64)?;"]
#[doc = "let i_pos = NonZero::new(1i64)?;"]
#[doc = "let i_neg = NonZero::new(-1i64)?;"]
#[doc = "let i_min = NonZero::new(i64::MIN)?;"]
#[doc = "let u_max = NonZero::new(u64::MAX / 2 + 1)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn unsigned_abs(self) -> NonZero<u64> {
unsafe { NonZero::new_unchecked(self.get().unsigned_abs()) }
}
#[doc = "let pos_five = NonZero::new(5i64)?;"]
#[doc = "let neg_five = NonZero::new(-5i64)?;"]
#[must_use]
#[inline]
#[stable(feature = "nonzero_negation_ops", since = "1.71.0")]
#[rustc_const_stable(feature = "nonzero_negation_ops", since = "1.71.0")]
pub const fn is_positive(self) -> bool { self.get().is_positive() }
#[doc = "let pos_five = NonZero::new(5i64)?;"]
#[doc = "let neg_five = NonZero::new(-5i64)?;"]
#[must_use]
#[inline]
#[stable(feature = "nonzero_negation_ops", since = "1.71.0")]
#[rustc_const_stable(feature = "nonzero_negation_ops", since = "1.71.0")]
pub const fn is_negative(self) -> bool { self.get().is_negative() }
#[doc = "returning `None` if `self == NonZero::<i64>::MIN`."]
#[doc = "let pos_five = NonZero::new(5i64)?;"]
#[doc = "let neg_five = NonZero::new(-5i64)?;"]
#[doc = "let min = NonZero::new(i64::MIN)?;"]
#[inline]
#[stable(feature = "nonzero_negation_ops", since = "1.71.0")]
#[rustc_const_stable(feature = "nonzero_negation_ops", since = "1.71.0")]
pub const fn checked_neg(self) -> Option<Self> {
if let Some(result) = self.get().checked_neg() {
return Some(unsafe { Self::new_unchecked(result) });
}
None
}
#[doc = "See [`i64::overflowing_neg`]"]
#[doc = "let pos_five = NonZero::new(5i64)?;"]
#[doc = "let neg_five = NonZero::new(-5i64)?;"]
#[doc = "let min = NonZero::new(i64::MIN)?;"]
#[inline]
#[stable(feature = "nonzero_negation_ops", since = "1.71.0")]
#[rustc_const_stable(feature = "nonzero_negation_ops", since = "1.71.0")]
pub const fn overflowing_neg(self) -> (Self, bool) {
let (result, overflow) = self.get().overflowing_neg();
((unsafe { Self::new_unchecked(result) }), overflow)
}
#[doc = "returning [`NonZero::<i64>::MAX`]"]
#[doc = "if `self == NonZero::<i64>::MIN`"]
#[doc = "let pos_five = NonZero::new(5i64)?;"]
#[doc = "let neg_five = NonZero::new(-5i64)?;"]
#[doc = "let min = NonZero::new(i64::MIN)?;"]
#[doc = "let min_plus_one = NonZero::new(i64::MIN + 1)?;"]
#[doc = "let max = NonZero::new(i64::MAX)?;"]
#[inline]
#[stable(feature = "nonzero_negation_ops", since = "1.71.0")]
#[rustc_const_stable(feature = "nonzero_negation_ops", since = "1.71.0")]
pub const fn saturating_neg(self) -> Self {
if let Some(result) = self.checked_neg() { return result; }
Self::MAX
}
#[doc = "See [`i64::wrapping_neg`]"]
#[doc = "let pos_five = NonZero::new(5i64)?;"]
#[doc = "let neg_five = NonZero::new(-5i64)?;"]
#[doc = "let min = NonZero::new(i64::MIN)?;"]
#[inline]
#[stable(feature = "nonzero_negation_ops", since = "1.71.0")]
#[rustc_const_stable(feature = "nonzero_negation_ops", since = "1.71.0")]
pub const fn wrapping_neg(self) -> Self {
let result = self.get().wrapping_neg();
unsafe { Self::new_unchecked(result) }
}
#[doc = "let n = NonZero::new(-1i64).unwrap();"]
#[doc = "assert_eq!(n.cast_unsigned(), NonZero::<u64>::MAX);"]
#[stable(feature = "integer_sign_cast", since = "1.87.0")]
#[rustc_const_stable(feature = "integer_sign_cast", since = "1.87.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn cast_unsigned(self) -> NonZero<u64> {
unsafe { NonZero::new_unchecked(self.get().cast_unsigned()) }
}
#[doc = "let two = NonZero::new(2i64)?;"]
#[doc = "let four = NonZero::new(4i64)?;"]
#[doc = "let max = NonZero::new(i64::MAX)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn checked_mul(self, other: Self) -> Option<Self> {
if let Some(result) = self.get().checked_mul(other.get()) {
Some(unsafe { Self::new_unchecked(result) })
} else { None }
}
#[doc = "Return [`NonZero::<i64>::MAX`] on overflow."]
#[doc = "let two = NonZero::new(2i64)?;"]
#[doc = "let four = NonZero::new(4i64)?;"]
#[doc = "let max = NonZero::new(i64::MAX)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn saturating_mul(self, other: Self) -> Self {
unsafe { Self::new_unchecked(self.get().saturating_mul(other.get())) }
}
#[doc = "`self * rhs > i64::MAX`, or `self * rhs < i64::MIN`."]
#[doc = "let two = NonZero::new(2i64)?;"]
#[doc = "let four = NonZero::new(4i64)?;"]
#[unstable(feature = "nonzero_ops", issue = "84186")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const unsafe fn unchecked_mul(self, other: Self) -> Self {
unsafe { Self::new_unchecked(self.get().unchecked_mul(other.get())) }
}
#[doc = "let three = NonZero::new(3i64)?;"]
#[doc = "let twenty_seven = NonZero::new(27i64)?;"]
#[doc = "let half_max = NonZero::new(i64::MAX / 2)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn checked_pow(self, other: u32) -> Option<Self> {
if let Some(result) = self.get().checked_pow(other) {
Some(unsafe { Self::new_unchecked(result) })
} else { None }
}
#[doc =
"Return [`NonZero::<i64>::MIN`] or [`NonZero::<i64>::MAX`] on overflow."]
#[doc = "let three = NonZero::new(3i64)?;"]
#[doc = "let twenty_seven = NonZero::new(27i64)?;"]
#[doc = "let max = NonZero::new(i64::MAX)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn saturating_pow(self, other: u32) -> Self {
unsafe { Self::new_unchecked(self.get().saturating_pow(other)) }
}
#[doc = " `+` or `-` "]
#[doc =
"assert_eq!(NonZero::<i64>::from_ascii(b\"+10\"), Ok(NonZero::new(10)?));"]
#[doc = "assert!(NonZero::<i64>::from_ascii(b\"1 \").is_err());"]
#[unstable(feature = "int_from_ascii", issue = "134821")]
#[inline]
pub const fn from_ascii(src: &[u8]) -> Result<Self, ParseIntError> {
Self::from_ascii_radix(src, 10)
}
#[doc = " `+` or `-` "]
#[doc =
"assert_eq!(NonZero::<i64>::from_ascii_radix(b\"A\", 16), Ok(NonZero::new(10)?));"]
#[doc =
"assert!(NonZero::<i64>::from_ascii_radix(b\"1 \", 10).is_err());"]
#[unstable(feature = "int_from_ascii", issue = "134821")]
#[inline]
pub const fn from_ascii_radix(src: &[u8], radix: u32)
-> Result<Self, ParseIntError> {
let n =
match <i64>::from_ascii_radix(src, radix) {
Ok(n) => n,
Err(err) => return Err(err),
};
if let Some(n) = Self::new(n) {
Ok(n)
} else { Err(ParseIntError { kind: IntErrorKind::Zero }) }
}
#[doc = " `+` or `-` "]
#[doc =
"assert_eq!(NonZero::<i64>::from_str_radix(\"A\", 16), Ok(NonZero::new(10)?));"]
#[doc = "assert!(NonZero::<i64>::from_str_radix(\"1 \", 10).is_err());"]
#[unstable(feature = "nonzero_from_str_radix", issue = "152193")]
#[inline]
pub const fn from_str_radix(src: &str, radix: u32)
-> Result<Self, ParseIntError> {
Self::from_ascii_radix(src.as_bytes(), radix)
}
}
#[stable(feature = "nonzero_parse", since = "1.35.0")]
impl FromStr for NonZero<i64> {
type Err = ParseIntError;
fn from_str(src: &str) -> Result<Self, Self::Err> {
Self::from_str_radix(src, 10)
}
}
#[stable(feature = "signed_nonzero_neg", since = "1.71.0")]
#[rustc_const_unstable(feature = "const_ops", issue = "143802")]
impl const Neg for NonZero<i64> {
type Output = Self;
#[inline]
fn neg(self) -> Self { unsafe { Self::new_unchecked(self.get().neg()) } }
}
#[stable(feature = "signed_nonzero_neg", since = "1.71.0")]
#[rustc_const_unstable(feature = "const_ops", issue = "143802")]
impl const Neg for &NonZero<i64> {
type Output = <NonZero<i64> as Neg>::Output;
#[inline]
fn neg(self) -> <NonZero<i64> as Neg>::Output { Neg::neg(*self) }
}nonzero_integer! {
2536 Self = NonZeroI64,
2537 Primitive = signed i64,
2538 UnsignedPrimitive = u64,
2539 rot = 12,
2540 rot_op = "0xaa00000000006e1",
2541 rot_result = "0x6e10aa",
2542 swap_op = "0x1234567890123456",
2543 swapped = "0x5634129078563412",
2544 reversed = "0x6a2c48091e6a2c48",
2545}
2546
2547#[doc = "An [`i128`] that is known not to equal zero."]
#[doc = "For example, `Option<NonZeroI128>` is the same size as `i128`:"]
#[doc =
"assert_eq!(size_of::<Option<core::num::NonZeroI128>>(), size_of::<i128>());"]
#[doc =
"`NonZeroI128` is guaranteed to have the same layout and bit validity as `i128`"]
#[doc = "`Option<NonZeroI128>` is guaranteed to be compatible with `i128`,"]
#[doc = "`NonZeroI128` and `Option<NonZeroI128>`"]
#[doc = "use std::num::NonZeroI128;"]
#[doc =
"assert_eq!(size_of::<NonZeroI128>(), size_of::<Option<NonZeroI128>>());"]
#[doc =
"assert_eq!(align_of::<NonZeroI128>(), align_of::<Option<NonZeroI128>>());"]
#[doc = "`NonZeroI128`"]
#[doc = "use std::num::NonZeroI128;"]
#[doc =
"const TEN: NonZeroI128 = NonZeroI128::new(10).expect(\"ten is non-zero\");"]
#[stable(feature = "signed_nonzero", since = "1.34.0")]
pub type NonZeroI128 = NonZero<i128>;
impl NonZero<i128> {
#[doc = "This value is equal to [`i128::BITS`]."]
#[doc = "assert_eq!(NonZero::<i128>::BITS, i128::BITS);"]
#[stable(feature = "nonzero_bits", since = "1.67.0")]
pub const BITS: u32 = <i128>::BITS;
#[doc = "let n = NonZero::<i128>::new(-1i128)?;"]
#[stable(feature = "nonzero_leading_trailing_zeros", since = "1.53.0")]
#[rustc_const_stable(feature = "nonzero_leading_trailing_zeros", since =
"1.53.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn leading_zeros(self) -> u32 {
unsafe { intrinsics::ctlz_nonzero(self.get() as u128) }
}
#[doc = "let n = NonZero::<i128>::new(0b0101000)?;"]
#[stable(feature = "nonzero_leading_trailing_zeros", since = "1.53.0")]
#[rustc_const_stable(feature = "nonzero_leading_trailing_zeros", since =
"1.53.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn trailing_zeros(self) -> u32 {
unsafe { intrinsics::cttz_nonzero(self.get() as u128) }
}
#[doc = "let a = NonZero::<i128>::new(0b_01100100)?;"]
#[doc = "let b = NonZero::<i128>::new(0b_01000000)?;"]
#[stable(feature = "isolate_most_least_significant_one", since =
"1.97.0")]
#[rustc_const_stable(feature = "isolate_most_least_significant_one", since
= "1.97.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn isolate_highest_one(self) -> Self {
unsafe {
let bit =
(((1 as u128) <<
(<u128>::BITS - 1)).unchecked_shr(self.leading_zeros()));
NonZero::new_unchecked(bit as i128)
}
}
#[doc = "let a = NonZero::<i128>::new(0b_01100100)?;"]
#[doc = "let b = NonZero::<i128>::new(0b_00000100)?;"]
#[stable(feature = "isolate_most_least_significant_one", since =
"1.97.0")]
#[rustc_const_stable(feature = "isolate_most_least_significant_one", since
= "1.97.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn isolate_lowest_one(self) -> Self {
let n = self.get();
let n = n & n.wrapping_neg();
unsafe { NonZero::new_unchecked(n) }
}
#[doc = "assert_eq!(NonZero::<i128>::new(0b1)?.highest_one(), 0);"]
#[doc = "assert_eq!(NonZero::<i128>::new(0b1_0000)?.highest_one(), 4);"]
#[doc = "assert_eq!(NonZero::<i128>::new(0b1_1111)?.highest_one(), 4);"]
#[stable(feature = "int_lowest_highest_one", since = "1.97.0")]
#[rustc_const_stable(feature = "int_lowest_highest_one", since =
"1.97.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn highest_one(self) -> u32 {
Self::BITS - 1 - self.leading_zeros()
}
#[doc = "assert_eq!(NonZero::<i128>::new(0b1)?.lowest_one(), 0);"]
#[doc = "assert_eq!(NonZero::<i128>::new(0b1_0000)?.lowest_one(), 4);"]
#[doc = "assert_eq!(NonZero::<i128>::new(0b1_1111)?.lowest_one(), 0);"]
#[stable(feature = "int_lowest_highest_one", since = "1.97.0")]
#[rustc_const_stable(feature = "int_lowest_highest_one", since =
"1.97.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn lowest_one(self) -> u32 { self.trailing_zeros() }
#[doc = "let a = NonZero::<i128>::new(0b100_0000)?;"]
#[doc = "let b = NonZero::<i128>::new(0b100_0011)?;"]
#[stable(feature = "non_zero_count_ones", since = "1.86.0")]
#[rustc_const_stable(feature = "non_zero_count_ones", since = "1.86.0")]
#[doc(alias = "popcount")]
#[doc(alias = "popcnt")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn count_ones(self) -> NonZero<u32> {
unsafe { NonZero::new_unchecked(self.get().count_ones()) }
}
#[doc = "let n = NonZero::new(0x13f40000000000000000000000004f76i128)?;"]
#[doc = "let m = NonZero::new(0x4f7613f4)?;"]
#[doc = "assert_eq!(n.rotate_left(16), m);"]
#[unstable(feature = "nonzero_bitwise", issue = "128281")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn rotate_left(self, n: u32) -> Self {
let result = self.get().rotate_left(n);
unsafe { Self::new_unchecked(result) }
}
#[doc = "let n = NonZero::new(0x4f7613f4i128)?;"]
#[doc = "let m = NonZero::new(0x13f40000000000000000000000004f76)?;"]
#[doc = "assert_eq!(n.rotate_right(16), m);"]
#[unstable(feature = "nonzero_bitwise", issue = "128281")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn rotate_right(self, n: u32) -> Self {
let result = self.get().rotate_right(n);
unsafe { Self::new_unchecked(result) }
}
#[doc = "let n = NonZero::new(0x12345678901234567890123456789012i128)?;"]
#[doc =
"assert_eq!(m, NonZero::new(0x12907856341290785634129078563412)?);"]
#[unstable(feature = "nonzero_bitwise", issue = "128281")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn swap_bytes(self) -> Self {
let result = self.get().swap_bytes();
unsafe { Self::new_unchecked(result) }
}
#[doc = "let n = NonZero::new(0x12345678901234567890123456789012i128)?;"]
#[doc =
"assert_eq!(m, NonZero::new(0x48091e6a2c48091e6a2c48091e6a2c48)?);"]
#[unstable(feature = "nonzero_bitwise", issue = "128281")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn reverse_bits(self) -> Self {
let result = self.get().reverse_bits();
unsafe { Self::new_unchecked(result) }
}
#[doc = "use std::num::NonZeroI128;"]
#[doc = "let n = NonZero::new(0x1Ai128)?;"]
#[doc = " assert_eq!(NonZeroI128::from_be(n), n)"]
#[doc = " assert_eq!(NonZeroI128::from_be(n), n.swap_bytes())"]
#[unstable(feature = "nonzero_bitwise", issue = "128281")]
#[must_use]
#[inline(always)]
pub const fn from_be(x: Self) -> Self {
let result = i128::from_be(x.get());
unsafe { Self::new_unchecked(result) }
}
#[doc = "use std::num::NonZeroI128;"]
#[doc = "let n = NonZero::new(0x1Ai128)?;"]
#[doc = " assert_eq!(NonZeroI128::from_le(n), n)"]
#[doc = " assert_eq!(NonZeroI128::from_le(n), n.swap_bytes())"]
#[unstable(feature = "nonzero_bitwise", issue = "128281")]
#[must_use]
#[inline(always)]
pub const fn from_le(x: Self) -> Self {
let result = i128::from_le(x.get());
unsafe { Self::new_unchecked(result) }
}
#[doc = "let n = NonZero::new(0x1Ai128)?;"]
#[unstable(feature = "nonzero_bitwise", issue = "128281")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn to_be(self) -> Self {
let result = self.get().to_be();
unsafe { Self::new_unchecked(result) }
}
#[doc = "let n = NonZero::new(0x1Ai128)?;"]
#[unstable(feature = "nonzero_bitwise", issue = "128281")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn to_le(self) -> Self {
let result = self.get().to_le();
unsafe { Self::new_unchecked(result) }
}
#[doc = "equal to [`i128::MIN`]."]
#[doc = "assert_eq!(NonZero::<i128>::MIN.get(), i128::MIN);"]
#[stable(feature = "nonzero_min_max", since = "1.70.0")]
pub const MIN: Self = Self::new(<i128>::MIN).unwrap();
#[doc = "equal to [`i128::MAX`]."]
#[doc = "assert_eq!(NonZero::<i128>::MAX.get(), i128::MAX);"]
#[stable(feature = "nonzero_min_max", since = "1.70.0")]
pub const MAX: Self = Self::new(<i128>::MAX).unwrap();
#[doc = "See [`i128::abs`]"]
#[doc = "let pos = NonZero::new(1i128)?;"]
#[doc = "let neg = NonZero::new(-1i128)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn abs(self) -> Self {
unsafe { Self::new_unchecked(self.get().abs()) }
}
#[doc = "`self == NonZero::<i128>::MIN`."]
#[doc = "let pos = NonZero::new(1i128)?;"]
#[doc = "let neg = NonZero::new(-1i128)?;"]
#[doc = "let min = NonZero::new(i128::MIN)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn checked_abs(self) -> Option<Self> {
if let Some(nz) = self.get().checked_abs() {
Some(unsafe { Self::new_unchecked(nz) })
} else { None }
}
#[doc = "[`i128::overflowing_abs`]."]
#[doc = "let pos = NonZero::new(1i128)?;"]
#[doc = "let neg = NonZero::new(-1i128)?;"]
#[doc = "let min = NonZero::new(i128::MIN)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn overflowing_abs(self) -> (Self, bool) {
let (nz, flag) = self.get().overflowing_abs();
(unsafe { Self::new_unchecked(nz) }, flag)
}
#[doc = "[`i128::saturating_abs`]."]
#[doc = "let pos = NonZero::new(1i128)?;"]
#[doc = "let neg = NonZero::new(-1i128)?;"]
#[doc = "let min = NonZero::new(i128::MIN)?;"]
#[doc = "let min_plus = NonZero::new(i128::MIN + 1)?;"]
#[doc = "let max = NonZero::new(i128::MAX)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn saturating_abs(self) -> Self {
unsafe { Self::new_unchecked(self.get().saturating_abs()) }
}
#[doc = "[`i128::wrapping_abs`]."]
#[doc = "let pos = NonZero::new(1i128)?;"]
#[doc = "let neg = NonZero::new(-1i128)?;"]
#[doc = "let min = NonZero::new(i128::MIN)?;"]
#[doc = "# let max = NonZero::new(i128::MAX)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn wrapping_abs(self) -> Self {
unsafe { Self::new_unchecked(self.get().wrapping_abs()) }
}
#[doc = "let u_pos = NonZero::new(1u128)?;"]
#[doc = "let i_pos = NonZero::new(1i128)?;"]
#[doc = "let i_neg = NonZero::new(-1i128)?;"]
#[doc = "let i_min = NonZero::new(i128::MIN)?;"]
#[doc = "let u_max = NonZero::new(u128::MAX / 2 + 1)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn unsigned_abs(self) -> NonZero<u128> {
unsafe { NonZero::new_unchecked(self.get().unsigned_abs()) }
}
#[doc = "let pos_five = NonZero::new(5i128)?;"]
#[doc = "let neg_five = NonZero::new(-5i128)?;"]
#[must_use]
#[inline]
#[stable(feature = "nonzero_negation_ops", since = "1.71.0")]
#[rustc_const_stable(feature = "nonzero_negation_ops", since = "1.71.0")]
pub const fn is_positive(self) -> bool { self.get().is_positive() }
#[doc = "let pos_five = NonZero::new(5i128)?;"]
#[doc = "let neg_five = NonZero::new(-5i128)?;"]
#[must_use]
#[inline]
#[stable(feature = "nonzero_negation_ops", since = "1.71.0")]
#[rustc_const_stable(feature = "nonzero_negation_ops", since = "1.71.0")]
pub const fn is_negative(self) -> bool { self.get().is_negative() }
#[doc = "returning `None` if `self == NonZero::<i128>::MIN`."]
#[doc = "let pos_five = NonZero::new(5i128)?;"]
#[doc = "let neg_five = NonZero::new(-5i128)?;"]
#[doc = "let min = NonZero::new(i128::MIN)?;"]
#[inline]
#[stable(feature = "nonzero_negation_ops", since = "1.71.0")]
#[rustc_const_stable(feature = "nonzero_negation_ops", since = "1.71.0")]
pub const fn checked_neg(self) -> Option<Self> {
if let Some(result) = self.get().checked_neg() {
return Some(unsafe { Self::new_unchecked(result) });
}
None
}
#[doc = "See [`i128::overflowing_neg`]"]
#[doc = "let pos_five = NonZero::new(5i128)?;"]
#[doc = "let neg_five = NonZero::new(-5i128)?;"]
#[doc = "let min = NonZero::new(i128::MIN)?;"]
#[inline]
#[stable(feature = "nonzero_negation_ops", since = "1.71.0")]
#[rustc_const_stable(feature = "nonzero_negation_ops", since = "1.71.0")]
pub const fn overflowing_neg(self) -> (Self, bool) {
let (result, overflow) = self.get().overflowing_neg();
((unsafe { Self::new_unchecked(result) }), overflow)
}
#[doc = "returning [`NonZero::<i128>::MAX`]"]
#[doc = "if `self == NonZero::<i128>::MIN`"]
#[doc = "let pos_five = NonZero::new(5i128)?;"]
#[doc = "let neg_five = NonZero::new(-5i128)?;"]
#[doc = "let min = NonZero::new(i128::MIN)?;"]
#[doc = "let min_plus_one = NonZero::new(i128::MIN + 1)?;"]
#[doc = "let max = NonZero::new(i128::MAX)?;"]
#[inline]
#[stable(feature = "nonzero_negation_ops", since = "1.71.0")]
#[rustc_const_stable(feature = "nonzero_negation_ops", since = "1.71.0")]
pub const fn saturating_neg(self) -> Self {
if let Some(result) = self.checked_neg() { return result; }
Self::MAX
}
#[doc = "See [`i128::wrapping_neg`]"]
#[doc = "let pos_five = NonZero::new(5i128)?;"]
#[doc = "let neg_five = NonZero::new(-5i128)?;"]
#[doc = "let min = NonZero::new(i128::MIN)?;"]
#[inline]
#[stable(feature = "nonzero_negation_ops", since = "1.71.0")]
#[rustc_const_stable(feature = "nonzero_negation_ops", since = "1.71.0")]
pub const fn wrapping_neg(self) -> Self {
let result = self.get().wrapping_neg();
unsafe { Self::new_unchecked(result) }
}
#[doc = "let n = NonZero::new(-1i128).unwrap();"]
#[doc = "assert_eq!(n.cast_unsigned(), NonZero::<u128>::MAX);"]
#[stable(feature = "integer_sign_cast", since = "1.87.0")]
#[rustc_const_stable(feature = "integer_sign_cast", since = "1.87.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn cast_unsigned(self) -> NonZero<u128> {
unsafe { NonZero::new_unchecked(self.get().cast_unsigned()) }
}
#[doc = "let two = NonZero::new(2i128)?;"]
#[doc = "let four = NonZero::new(4i128)?;"]
#[doc = "let max = NonZero::new(i128::MAX)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn checked_mul(self, other: Self) -> Option<Self> {
if let Some(result) = self.get().checked_mul(other.get()) {
Some(unsafe { Self::new_unchecked(result) })
} else { None }
}
#[doc = "Return [`NonZero::<i128>::MAX`] on overflow."]
#[doc = "let two = NonZero::new(2i128)?;"]
#[doc = "let four = NonZero::new(4i128)?;"]
#[doc = "let max = NonZero::new(i128::MAX)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn saturating_mul(self, other: Self) -> Self {
unsafe { Self::new_unchecked(self.get().saturating_mul(other.get())) }
}
#[doc = "`self * rhs > i128::MAX`, or `self * rhs < i128::MIN`."]
#[doc = "let two = NonZero::new(2i128)?;"]
#[doc = "let four = NonZero::new(4i128)?;"]
#[unstable(feature = "nonzero_ops", issue = "84186")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const unsafe fn unchecked_mul(self, other: Self) -> Self {
unsafe { Self::new_unchecked(self.get().unchecked_mul(other.get())) }
}
#[doc = "let three = NonZero::new(3i128)?;"]
#[doc = "let twenty_seven = NonZero::new(27i128)?;"]
#[doc = "let half_max = NonZero::new(i128::MAX / 2)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn checked_pow(self, other: u32) -> Option<Self> {
if let Some(result) = self.get().checked_pow(other) {
Some(unsafe { Self::new_unchecked(result) })
} else { None }
}
#[doc =
"Return [`NonZero::<i128>::MIN`] or [`NonZero::<i128>::MAX`] on overflow."]
#[doc = "let three = NonZero::new(3i128)?;"]
#[doc = "let twenty_seven = NonZero::new(27i128)?;"]
#[doc = "let max = NonZero::new(i128::MAX)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn saturating_pow(self, other: u32) -> Self {
unsafe { Self::new_unchecked(self.get().saturating_pow(other)) }
}
#[doc = " `+` or `-` "]
#[doc =
"assert_eq!(NonZero::<i128>::from_ascii(b\"+10\"), Ok(NonZero::new(10)?));"]
#[doc = "assert!(NonZero::<i128>::from_ascii(b\"1 \").is_err());"]
#[unstable(feature = "int_from_ascii", issue = "134821")]
#[inline]
pub const fn from_ascii(src: &[u8]) -> Result<Self, ParseIntError> {
Self::from_ascii_radix(src, 10)
}
#[doc = " `+` or `-` "]
#[doc =
"assert_eq!(NonZero::<i128>::from_ascii_radix(b\"A\", 16), Ok(NonZero::new(10)?));"]
#[doc =
"assert!(NonZero::<i128>::from_ascii_radix(b\"1 \", 10).is_err());"]
#[unstable(feature = "int_from_ascii", issue = "134821")]
#[inline]
pub const fn from_ascii_radix(src: &[u8], radix: u32)
-> Result<Self, ParseIntError> {
let n =
match <i128>::from_ascii_radix(src, radix) {
Ok(n) => n,
Err(err) => return Err(err),
};
if let Some(n) = Self::new(n) {
Ok(n)
} else { Err(ParseIntError { kind: IntErrorKind::Zero }) }
}
#[doc = " `+` or `-` "]
#[doc =
"assert_eq!(NonZero::<i128>::from_str_radix(\"A\", 16), Ok(NonZero::new(10)?));"]
#[doc = "assert!(NonZero::<i128>::from_str_radix(\"1 \", 10).is_err());"]
#[unstable(feature = "nonzero_from_str_radix", issue = "152193")]
#[inline]
pub const fn from_str_radix(src: &str, radix: u32)
-> Result<Self, ParseIntError> {
Self::from_ascii_radix(src.as_bytes(), radix)
}
}
#[stable(feature = "nonzero_parse", since = "1.35.0")]
impl FromStr for NonZero<i128> {
type Err = ParseIntError;
fn from_str(src: &str) -> Result<Self, Self::Err> {
Self::from_str_radix(src, 10)
}
}
#[stable(feature = "signed_nonzero_neg", since = "1.71.0")]
#[rustc_const_unstable(feature = "const_ops", issue = "143802")]
impl const Neg for NonZero<i128> {
type Output = Self;
#[inline]
fn neg(self) -> Self { unsafe { Self::new_unchecked(self.get().neg()) } }
}
#[stable(feature = "signed_nonzero_neg", since = "1.71.0")]
#[rustc_const_unstable(feature = "const_ops", issue = "143802")]
impl const Neg for &NonZero<i128> {
type Output = <NonZero<i128> as Neg>::Output;
#[inline]
fn neg(self) -> <NonZero<i128> as Neg>::Output { Neg::neg(*self) }
}nonzero_integer! {
2548 Self = NonZeroI128,
2549 Primitive = signed i128,
2550 UnsignedPrimitive = u128,
2551 rot = 16,
2552 rot_op = "0x13f40000000000000000000000004f76",
2553 rot_result = "0x4f7613f4",
2554 swap_op = "0x12345678901234567890123456789012",
2555 swapped = "0x12907856341290785634129078563412",
2556 reversed = "0x48091e6a2c48091e6a2c48091e6a2c48",
2557}
2558
2559#[cfg(target_pointer_width = "16")]
2560nonzero_integer! {
2561 Self = NonZeroIsize,
2562 Primitive = signed isize,
2563 UnsignedPrimitive = usize,
2564 rot = 4,
2565 rot_op = "-0x5ffd",
2566 rot_result = "0x3a",
2567 swap_op = "0x1234",
2568 swapped = "0x3412",
2569 reversed = "0x2c48",
2570}
2571
2572#[cfg(target_pointer_width = "32")]
2573nonzero_integer! {
2574 Self = NonZeroIsize,
2575 Primitive = signed isize,
2576 UnsignedPrimitive = usize,
2577 rot = 8,
2578 rot_op = "0x10000b3",
2579 rot_result = "0xb301",
2580 swap_op = "0x12345678",
2581 swapped = "0x78563412",
2582 reversed = "0x1e6a2c48",
2583}
2584
2585#[cfg(target_pointer_width = "64")]
2586#[doc = "An [`isize`] that is known not to equal zero."]
#[doc = "For example, `Option<NonZeroIsize>` is the same size as `isize`:"]
#[doc =
"assert_eq!(size_of::<Option<core::num::NonZeroIsize>>(), size_of::<isize>());"]
#[doc =
"`NonZeroIsize` is guaranteed to have the same layout and bit validity as `isize`"]
#[doc = "`Option<NonZeroIsize>` is guaranteed to be compatible with `isize`,"]
#[doc = "`NonZeroIsize` and `Option<NonZeroIsize>`"]
#[doc = "use std::num::NonZeroIsize;"]
#[doc =
"assert_eq!(size_of::<NonZeroIsize>(), size_of::<Option<NonZeroIsize>>());"]
#[doc =
"assert_eq!(align_of::<NonZeroIsize>(), align_of::<Option<NonZeroIsize>>());"]
#[doc = "`NonZeroIsize`"]
#[doc = "use std::num::NonZeroIsize;"]
#[doc =
"const TEN: NonZeroIsize = NonZeroIsize::new(10).expect(\"ten is non-zero\");"]
#[stable(feature = "signed_nonzero", since = "1.34.0")]
pub type NonZeroIsize = NonZero<isize>;
impl NonZero<isize> {
#[doc = "This value is equal to [`isize::BITS`]."]
#[doc = "assert_eq!(NonZero::<isize>::BITS, isize::BITS);"]
#[stable(feature = "nonzero_bits", since = "1.67.0")]
pub const BITS: u32 = <isize>::BITS;
#[doc = "let n = NonZero::<isize>::new(-1isize)?;"]
#[stable(feature = "nonzero_leading_trailing_zeros", since = "1.53.0")]
#[rustc_const_stable(feature = "nonzero_leading_trailing_zeros", since =
"1.53.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn leading_zeros(self) -> u32 {
unsafe { intrinsics::ctlz_nonzero(self.get() as usize) }
}
#[doc = "let n = NonZero::<isize>::new(0b0101000)?;"]
#[stable(feature = "nonzero_leading_trailing_zeros", since = "1.53.0")]
#[rustc_const_stable(feature = "nonzero_leading_trailing_zeros", since =
"1.53.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn trailing_zeros(self) -> u32 {
unsafe { intrinsics::cttz_nonzero(self.get() as usize) }
}
#[doc = "let a = NonZero::<isize>::new(0b_01100100)?;"]
#[doc = "let b = NonZero::<isize>::new(0b_01000000)?;"]
#[stable(feature = "isolate_most_least_significant_one", since =
"1.97.0")]
#[rustc_const_stable(feature = "isolate_most_least_significant_one", since
= "1.97.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn isolate_highest_one(self) -> Self {
unsafe {
let bit =
(((1 as usize) <<
(<usize>::BITS - 1)).unchecked_shr(self.leading_zeros()));
NonZero::new_unchecked(bit as isize)
}
}
#[doc = "let a = NonZero::<isize>::new(0b_01100100)?;"]
#[doc = "let b = NonZero::<isize>::new(0b_00000100)?;"]
#[stable(feature = "isolate_most_least_significant_one", since =
"1.97.0")]
#[rustc_const_stable(feature = "isolate_most_least_significant_one", since
= "1.97.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn isolate_lowest_one(self) -> Self {
let n = self.get();
let n = n & n.wrapping_neg();
unsafe { NonZero::new_unchecked(n) }
}
#[doc = "assert_eq!(NonZero::<isize>::new(0b1)?.highest_one(), 0);"]
#[doc = "assert_eq!(NonZero::<isize>::new(0b1_0000)?.highest_one(), 4);"]
#[doc = "assert_eq!(NonZero::<isize>::new(0b1_1111)?.highest_one(), 4);"]
#[stable(feature = "int_lowest_highest_one", since = "1.97.0")]
#[rustc_const_stable(feature = "int_lowest_highest_one", since =
"1.97.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn highest_one(self) -> u32 {
Self::BITS - 1 - self.leading_zeros()
}
#[doc = "assert_eq!(NonZero::<isize>::new(0b1)?.lowest_one(), 0);"]
#[doc = "assert_eq!(NonZero::<isize>::new(0b1_0000)?.lowest_one(), 4);"]
#[doc = "assert_eq!(NonZero::<isize>::new(0b1_1111)?.lowest_one(), 0);"]
#[stable(feature = "int_lowest_highest_one", since = "1.97.0")]
#[rustc_const_stable(feature = "int_lowest_highest_one", since =
"1.97.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn lowest_one(self) -> u32 { self.trailing_zeros() }
#[doc = "let a = NonZero::<isize>::new(0b100_0000)?;"]
#[doc = "let b = NonZero::<isize>::new(0b100_0011)?;"]
#[stable(feature = "non_zero_count_ones", since = "1.86.0")]
#[rustc_const_stable(feature = "non_zero_count_ones", since = "1.86.0")]
#[doc(alias = "popcount")]
#[doc(alias = "popcnt")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn count_ones(self) -> NonZero<u32> {
unsafe { NonZero::new_unchecked(self.get().count_ones()) }
}
#[doc = "let n = NonZero::new(0xaa00000000006e1isize)?;"]
#[doc = "let m = NonZero::new(0x6e10aa)?;"]
#[doc = "assert_eq!(n.rotate_left(12), m);"]
#[unstable(feature = "nonzero_bitwise", issue = "128281")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn rotate_left(self, n: u32) -> Self {
let result = self.get().rotate_left(n);
unsafe { Self::new_unchecked(result) }
}
#[doc = "let n = NonZero::new(0x6e10aaisize)?;"]
#[doc = "let m = NonZero::new(0xaa00000000006e1)?;"]
#[doc = "assert_eq!(n.rotate_right(12), m);"]
#[unstable(feature = "nonzero_bitwise", issue = "128281")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn rotate_right(self, n: u32) -> Self {
let result = self.get().rotate_right(n);
unsafe { Self::new_unchecked(result) }
}
#[doc = "let n = NonZero::new(0x1234567890123456isize)?;"]
#[doc = "assert_eq!(m, NonZero::new(0x5634129078563412)?);"]
#[unstable(feature = "nonzero_bitwise", issue = "128281")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn swap_bytes(self) -> Self {
let result = self.get().swap_bytes();
unsafe { Self::new_unchecked(result) }
}
#[doc = "let n = NonZero::new(0x1234567890123456isize)?;"]
#[doc = "assert_eq!(m, NonZero::new(0x6a2c48091e6a2c48)?);"]
#[unstable(feature = "nonzero_bitwise", issue = "128281")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn reverse_bits(self) -> Self {
let result = self.get().reverse_bits();
unsafe { Self::new_unchecked(result) }
}
#[doc = "use std::num::NonZeroIsize;"]
#[doc = "let n = NonZero::new(0x1Aisize)?;"]
#[doc = " assert_eq!(NonZeroIsize::from_be(n), n)"]
#[doc = " assert_eq!(NonZeroIsize::from_be(n), n.swap_bytes())"]
#[unstable(feature = "nonzero_bitwise", issue = "128281")]
#[must_use]
#[inline(always)]
pub const fn from_be(x: Self) -> Self {
let result = isize::from_be(x.get());
unsafe { Self::new_unchecked(result) }
}
#[doc = "use std::num::NonZeroIsize;"]
#[doc = "let n = NonZero::new(0x1Aisize)?;"]
#[doc = " assert_eq!(NonZeroIsize::from_le(n), n)"]
#[doc = " assert_eq!(NonZeroIsize::from_le(n), n.swap_bytes())"]
#[unstable(feature = "nonzero_bitwise", issue = "128281")]
#[must_use]
#[inline(always)]
pub const fn from_le(x: Self) -> Self {
let result = isize::from_le(x.get());
unsafe { Self::new_unchecked(result) }
}
#[doc = "let n = NonZero::new(0x1Aisize)?;"]
#[unstable(feature = "nonzero_bitwise", issue = "128281")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn to_be(self) -> Self {
let result = self.get().to_be();
unsafe { Self::new_unchecked(result) }
}
#[doc = "let n = NonZero::new(0x1Aisize)?;"]
#[unstable(feature = "nonzero_bitwise", issue = "128281")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn to_le(self) -> Self {
let result = self.get().to_le();
unsafe { Self::new_unchecked(result) }
}
#[doc = "equal to [`isize::MIN`]."]
#[doc = "assert_eq!(NonZero::<isize>::MIN.get(), isize::MIN);"]
#[stable(feature = "nonzero_min_max", since = "1.70.0")]
pub const MIN: Self = Self::new(<isize>::MIN).unwrap();
#[doc = "equal to [`isize::MAX`]."]
#[doc = "assert_eq!(NonZero::<isize>::MAX.get(), isize::MAX);"]
#[stable(feature = "nonzero_min_max", since = "1.70.0")]
pub const MAX: Self = Self::new(<isize>::MAX).unwrap();
#[doc = "See [`isize::abs`]"]
#[doc = "let pos = NonZero::new(1isize)?;"]
#[doc = "let neg = NonZero::new(-1isize)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn abs(self) -> Self {
unsafe { Self::new_unchecked(self.get().abs()) }
}
#[doc = "`self == NonZero::<isize>::MIN`."]
#[doc = "let pos = NonZero::new(1isize)?;"]
#[doc = "let neg = NonZero::new(-1isize)?;"]
#[doc = "let min = NonZero::new(isize::MIN)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn checked_abs(self) -> Option<Self> {
if let Some(nz) = self.get().checked_abs() {
Some(unsafe { Self::new_unchecked(nz) })
} else { None }
}
#[doc = "[`isize::overflowing_abs`]."]
#[doc = "let pos = NonZero::new(1isize)?;"]
#[doc = "let neg = NonZero::new(-1isize)?;"]
#[doc = "let min = NonZero::new(isize::MIN)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn overflowing_abs(self) -> (Self, bool) {
let (nz, flag) = self.get().overflowing_abs();
(unsafe { Self::new_unchecked(nz) }, flag)
}
#[doc = "[`isize::saturating_abs`]."]
#[doc = "let pos = NonZero::new(1isize)?;"]
#[doc = "let neg = NonZero::new(-1isize)?;"]
#[doc = "let min = NonZero::new(isize::MIN)?;"]
#[doc = "let min_plus = NonZero::new(isize::MIN + 1)?;"]
#[doc = "let max = NonZero::new(isize::MAX)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn saturating_abs(self) -> Self {
unsafe { Self::new_unchecked(self.get().saturating_abs()) }
}
#[doc = "[`isize::wrapping_abs`]."]
#[doc = "let pos = NonZero::new(1isize)?;"]
#[doc = "let neg = NonZero::new(-1isize)?;"]
#[doc = "let min = NonZero::new(isize::MIN)?;"]
#[doc = "# let max = NonZero::new(isize::MAX)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn wrapping_abs(self) -> Self {
unsafe { Self::new_unchecked(self.get().wrapping_abs()) }
}
#[doc = "let u_pos = NonZero::new(1usize)?;"]
#[doc = "let i_pos = NonZero::new(1isize)?;"]
#[doc = "let i_neg = NonZero::new(-1isize)?;"]
#[doc = "let i_min = NonZero::new(isize::MIN)?;"]
#[doc = "let u_max = NonZero::new(usize::MAX / 2 + 1)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn unsigned_abs(self) -> NonZero<usize> {
unsafe { NonZero::new_unchecked(self.get().unsigned_abs()) }
}
#[doc = "let pos_five = NonZero::new(5isize)?;"]
#[doc = "let neg_five = NonZero::new(-5isize)?;"]
#[must_use]
#[inline]
#[stable(feature = "nonzero_negation_ops", since = "1.71.0")]
#[rustc_const_stable(feature = "nonzero_negation_ops", since = "1.71.0")]
pub const fn is_positive(self) -> bool { self.get().is_positive() }
#[doc = "let pos_five = NonZero::new(5isize)?;"]
#[doc = "let neg_five = NonZero::new(-5isize)?;"]
#[must_use]
#[inline]
#[stable(feature = "nonzero_negation_ops", since = "1.71.0")]
#[rustc_const_stable(feature = "nonzero_negation_ops", since = "1.71.0")]
pub const fn is_negative(self) -> bool { self.get().is_negative() }
#[doc = "returning `None` if `self == NonZero::<isize>::MIN`."]
#[doc = "let pos_five = NonZero::new(5isize)?;"]
#[doc = "let neg_five = NonZero::new(-5isize)?;"]
#[doc = "let min = NonZero::new(isize::MIN)?;"]
#[inline]
#[stable(feature = "nonzero_negation_ops", since = "1.71.0")]
#[rustc_const_stable(feature = "nonzero_negation_ops", since = "1.71.0")]
pub const fn checked_neg(self) -> Option<Self> {
if let Some(result) = self.get().checked_neg() {
return Some(unsafe { Self::new_unchecked(result) });
}
None
}
#[doc = "See [`isize::overflowing_neg`]"]
#[doc = "let pos_five = NonZero::new(5isize)?;"]
#[doc = "let neg_five = NonZero::new(-5isize)?;"]
#[doc = "let min = NonZero::new(isize::MIN)?;"]
#[inline]
#[stable(feature = "nonzero_negation_ops", since = "1.71.0")]
#[rustc_const_stable(feature = "nonzero_negation_ops", since = "1.71.0")]
pub const fn overflowing_neg(self) -> (Self, bool) {
let (result, overflow) = self.get().overflowing_neg();
((unsafe { Self::new_unchecked(result) }), overflow)
}
#[doc = "returning [`NonZero::<isize>::MAX`]"]
#[doc = "if `self == NonZero::<isize>::MIN`"]
#[doc = "let pos_five = NonZero::new(5isize)?;"]
#[doc = "let neg_five = NonZero::new(-5isize)?;"]
#[doc = "let min = NonZero::new(isize::MIN)?;"]
#[doc = "let min_plus_one = NonZero::new(isize::MIN + 1)?;"]
#[doc = "let max = NonZero::new(isize::MAX)?;"]
#[inline]
#[stable(feature = "nonzero_negation_ops", since = "1.71.0")]
#[rustc_const_stable(feature = "nonzero_negation_ops", since = "1.71.0")]
pub const fn saturating_neg(self) -> Self {
if let Some(result) = self.checked_neg() { return result; }
Self::MAX
}
#[doc = "See [`isize::wrapping_neg`]"]
#[doc = "let pos_five = NonZero::new(5isize)?;"]
#[doc = "let neg_five = NonZero::new(-5isize)?;"]
#[doc = "let min = NonZero::new(isize::MIN)?;"]
#[inline]
#[stable(feature = "nonzero_negation_ops", since = "1.71.0")]
#[rustc_const_stable(feature = "nonzero_negation_ops", since = "1.71.0")]
pub const fn wrapping_neg(self) -> Self {
let result = self.get().wrapping_neg();
unsafe { Self::new_unchecked(result) }
}
#[doc = "let n = NonZero::new(-1isize).unwrap();"]
#[doc = "assert_eq!(n.cast_unsigned(), NonZero::<usize>::MAX);"]
#[stable(feature = "integer_sign_cast", since = "1.87.0")]
#[rustc_const_stable(feature = "integer_sign_cast", since = "1.87.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline(always)]
pub const fn cast_unsigned(self) -> NonZero<usize> {
unsafe { NonZero::new_unchecked(self.get().cast_unsigned()) }
}
#[doc = "let two = NonZero::new(2isize)?;"]
#[doc = "let four = NonZero::new(4isize)?;"]
#[doc = "let max = NonZero::new(isize::MAX)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn checked_mul(self, other: Self) -> Option<Self> {
if let Some(result) = self.get().checked_mul(other.get()) {
Some(unsafe { Self::new_unchecked(result) })
} else { None }
}
#[doc = "Return [`NonZero::<isize>::MAX`] on overflow."]
#[doc = "let two = NonZero::new(2isize)?;"]
#[doc = "let four = NonZero::new(4isize)?;"]
#[doc = "let max = NonZero::new(isize::MAX)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn saturating_mul(self, other: Self) -> Self {
unsafe { Self::new_unchecked(self.get().saturating_mul(other.get())) }
}
#[doc = "`self * rhs > isize::MAX`, or `self * rhs < isize::MIN`."]
#[doc = "let two = NonZero::new(2isize)?;"]
#[doc = "let four = NonZero::new(4isize)?;"]
#[unstable(feature = "nonzero_ops", issue = "84186")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const unsafe fn unchecked_mul(self, other: Self) -> Self {
unsafe { Self::new_unchecked(self.get().unchecked_mul(other.get())) }
}
#[doc = "let three = NonZero::new(3isize)?;"]
#[doc = "let twenty_seven = NonZero::new(27isize)?;"]
#[doc = "let half_max = NonZero::new(isize::MAX / 2)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn checked_pow(self, other: u32) -> Option<Self> {
if let Some(result) = self.get().checked_pow(other) {
Some(unsafe { Self::new_unchecked(result) })
} else { None }
}
#[doc =
"Return [`NonZero::<isize>::MIN`] or [`NonZero::<isize>::MAX`] on overflow."]
#[doc = "let three = NonZero::new(3isize)?;"]
#[doc = "let twenty_seven = NonZero::new(27isize)?;"]
#[doc = "let max = NonZero::new(isize::MAX)?;"]
#[stable(feature = "nonzero_checked_ops", since = "1.64.0")]
#[rustc_const_stable(feature = "const_nonzero_checked_ops", since =
"1.64.0")]
#[must_use =
"this returns the result of the operation, \
without modifying the original"]
#[inline]
pub const fn saturating_pow(self, other: u32) -> Self {
unsafe { Self::new_unchecked(self.get().saturating_pow(other)) }
}
#[doc = " `+` or `-` "]
#[doc =
"assert_eq!(NonZero::<isize>::from_ascii(b\"+10\"), Ok(NonZero::new(10)?));"]
#[doc = "assert!(NonZero::<isize>::from_ascii(b\"1 \").is_err());"]
#[unstable(feature = "int_from_ascii", issue = "134821")]
#[inline]
pub const fn from_ascii(src: &[u8]) -> Result<Self, ParseIntError> {
Self::from_ascii_radix(src, 10)
}
#[doc = " `+` or `-` "]
#[doc =
"assert_eq!(NonZero::<isize>::from_ascii_radix(b\"A\", 16), Ok(NonZero::new(10)?));"]
#[doc =
"assert!(NonZero::<isize>::from_ascii_radix(b\"1 \", 10).is_err());"]
#[unstable(feature = "int_from_ascii", issue = "134821")]
#[inline]
pub const fn from_ascii_radix(src: &[u8], radix: u32)
-> Result<Self, ParseIntError> {
let n =
match <isize>::from_ascii_radix(src, radix) {
Ok(n) => n,
Err(err) => return Err(err),
};
if let Some(n) = Self::new(n) {
Ok(n)
} else { Err(ParseIntError { kind: IntErrorKind::Zero }) }
}
#[doc = " `+` or `-` "]
#[doc =
"assert_eq!(NonZero::<isize>::from_str_radix(\"A\", 16), Ok(NonZero::new(10)?));"]
#[doc = "assert!(NonZero::<isize>::from_str_radix(\"1 \", 10).is_err());"]
#[unstable(feature = "nonzero_from_str_radix", issue = "152193")]
#[inline]
pub const fn from_str_radix(src: &str, radix: u32)
-> Result<Self, ParseIntError> {
Self::from_ascii_radix(src.as_bytes(), radix)
}
}
#[stable(feature = "nonzero_parse", since = "1.35.0")]
impl FromStr for NonZero<isize> {
type Err = ParseIntError;
fn from_str(src: &str) -> Result<Self, Self::Err> {
Self::from_str_radix(src, 10)
}
}
#[stable(feature = "signed_nonzero_neg", since = "1.71.0")]
#[rustc_const_unstable(feature = "const_ops", issue = "143802")]
impl const Neg for NonZero<isize> {
type Output = Self;
#[inline]
fn neg(self) -> Self { unsafe { Self::new_unchecked(self.get().neg()) } }
}
#[stable(feature = "signed_nonzero_neg", since = "1.71.0")]
#[rustc_const_unstable(feature = "const_ops", issue = "143802")]
impl const Neg for &NonZero<isize> {
type Output = <NonZero<isize> as Neg>::Output;
#[inline]
fn neg(self) -> <NonZero<isize> as Neg>::Output { Neg::neg(*self) }
}nonzero_integer! {
2587 Self = NonZeroIsize,
2588 Primitive = signed isize,
2589 UnsignedPrimitive = usize,
2590 rot = 12,
2591 rot_op = "0xaa00000000006e1",
2592 rot_result = "0x6e10aa",
2593 swap_op = "0x1234567890123456",
2594 swapped = "0x5634129078563412",
2595 reversed = "0x6a2c48091e6a2c48",
2596}