1use crate::fmt;
4use crate::ops::{
5 Add, AddAssign, BitAnd, BitAndAssign, BitOr, BitOrAssign, BitXor, BitXorAssign, Div, DivAssign,
6 Mul, MulAssign, Neg, Not, Rem, RemAssign, Sub, SubAssign,
7};
8
9#[stable(feature = "saturating_int_impl", since = "1.74.0")]
35#[derive(PartialEq, Eq, PartialOrd, Ord, Clone, Copy, Default, Hash)]
36#[repr(transparent)]
37#[rustc_diagnostic_item = "Saturating"]
38pub struct Saturating<T>(#[stable(feature = "saturating_int_impl", since = "1.74.0")] pub T);
39
40#[stable(feature = "saturating_int_impl", since = "1.74.0")]
41impl<T: fmt::Debug> fmt::Debug for Saturating<T> {
42 fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
43 self.0.fmt(f)
44 }
45}
46
47#[stable(feature = "saturating_int_impl", since = "1.74.0")]
48impl<T: fmt::Display> fmt::Display for Saturating<T> {
49 fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
50 self.0.fmt(f)
51 }
52}
53
54#[stable(feature = "saturating_int_impl", since = "1.74.0")]
55impl<T: fmt::Binary> fmt::Binary for Saturating<T> {
56 fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
57 self.0.fmt(f)
58 }
59}
60
61#[stable(feature = "saturating_int_impl", since = "1.74.0")]
62impl<T: fmt::Octal> fmt::Octal for Saturating<T> {
63 fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
64 self.0.fmt(f)
65 }
66}
67
68#[stable(feature = "saturating_int_impl", since = "1.74.0")]
69impl<T: fmt::LowerHex> fmt::LowerHex for Saturating<T> {
70 fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
71 self.0.fmt(f)
72 }
73}
74
75#[stable(feature = "saturating_int_impl", since = "1.74.0")]
76impl<T: fmt::UpperHex> fmt::UpperHex for Saturating<T> {
77 fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
78 self.0.fmt(f)
79 }
80}
81
82macro_rules! saturating_impl {
214 ($($t:ty)*) => ($(
215 #[stable(feature = "saturating_int_impl", since = "1.74.0")]
216 #[rustc_const_unstable(feature = "const_ops", issue = "143802")]
217 impl const Add for Saturating<$t> {
218 type Output = Saturating<$t>;
219
220 #[inline]
221 fn add(self, other: Saturating<$t>) -> Saturating<$t> {
222 Saturating(self.0.saturating_add(other.0))
223 }
224 }
225 forward_ref_binop! { impl Add, add for Saturating<$t>, Saturating<$t>,
226 #[stable(feature = "saturating_int_impl", since = "1.74.0")]
227 #[rustc_const_unstable(feature = "const_ops", issue = "143802")] }
228
229 #[stable(feature = "saturating_int_impl", since = "1.74.0")]
230 #[rustc_const_unstable(feature = "const_ops", issue = "143802")]
231 impl const AddAssign for Saturating<$t> {
232 #[inline]
233 fn add_assign(&mut self, other: Saturating<$t>) {
234 *self = *self + other;
235 }
236 }
237 forward_ref_op_assign! { impl AddAssign, add_assign for Saturating<$t>, Saturating<$t>,
238 #[stable(feature = "saturating_int_impl", since = "1.74.0")]
239 #[rustc_const_unstable(feature = "const_ops", issue = "143802")] }
240
241 #[stable(feature = "saturating_int_assign_impl", since = "1.74.0")]
242 #[rustc_const_unstable(feature = "const_ops", issue = "143802")]
243 impl const AddAssign<$t> for Saturating<$t> {
244 #[inline]
245 fn add_assign(&mut self, other: $t) {
246 *self = *self + Saturating(other);
247 }
248 }
249 forward_ref_op_assign! { impl AddAssign, add_assign for Saturating<$t>, $t,
250 #[stable(feature = "saturating_int_impl", since = "1.74.0")]
251 #[rustc_const_unstable(feature = "const_ops", issue = "143802")] }
252
253 #[stable(feature = "saturating_int_impl", since = "1.74.0")]
254 #[rustc_const_unstable(feature = "const_ops", issue = "143802")]
255 impl const Sub for Saturating<$t> {
256 type Output = Saturating<$t>;
257
258 #[inline]
259 fn sub(self, other: Saturating<$t>) -> Saturating<$t> {
260 Saturating(self.0.saturating_sub(other.0))
261 }
262 }
263 forward_ref_binop! { impl Sub, sub for Saturating<$t>, Saturating<$t>,
264 #[stable(feature = "saturating_int_impl", since = "1.74.0")]
265 #[rustc_const_unstable(feature = "const_ops", issue = "143802")] }
266
267 #[stable(feature = "saturating_int_impl", since = "1.74.0")]
268 #[rustc_const_unstable(feature = "const_ops", issue = "143802")]
269 impl const SubAssign for Saturating<$t> {
270 #[inline]
271 fn sub_assign(&mut self, other: Saturating<$t>) {
272 *self = *self - other;
273 }
274 }
275 forward_ref_op_assign! { impl SubAssign, sub_assign for Saturating<$t>, Saturating<$t>,
276 #[stable(feature = "saturating_int_impl", since = "1.74.0")]
277 #[rustc_const_unstable(feature = "const_ops", issue = "143802")] }
278
279 #[stable(feature = "saturating_int_assign_impl", since = "1.74.0")]
280 #[rustc_const_unstable(feature = "const_ops", issue = "143802")]
281 impl const SubAssign<$t> for Saturating<$t> {
282 #[inline]
283 fn sub_assign(&mut self, other: $t) {
284 *self = *self - Saturating(other);
285 }
286 }
287 forward_ref_op_assign! { impl SubAssign, sub_assign for Saturating<$t>, $t,
288 #[stable(feature = "saturating_int_impl", since = "1.74.0")]
289 #[rustc_const_unstable(feature = "const_ops", issue = "143802")] }
290
291 #[stable(feature = "saturating_int_impl", since = "1.74.0")]
292 #[rustc_const_unstable(feature = "const_ops", issue = "143802")]
293 impl const Mul for Saturating<$t> {
294 type Output = Saturating<$t>;
295
296 #[inline]
297 fn mul(self, other: Saturating<$t>) -> Saturating<$t> {
298 Saturating(self.0.saturating_mul(other.0))
299 }
300 }
301 forward_ref_binop! { impl Mul, mul for Saturating<$t>, Saturating<$t>,
302 #[stable(feature = "saturating_int_impl", since = "1.74.0")]
303 #[rustc_const_unstable(feature = "const_ops", issue = "143802")] }
304
305 #[stable(feature = "saturating_int_impl", since = "1.74.0")]
306 #[rustc_const_unstable(feature = "const_ops", issue = "143802")]
307 impl const MulAssign for Saturating<$t> {
308 #[inline]
309 fn mul_assign(&mut self, other: Saturating<$t>) {
310 *self = *self * other;
311 }
312 }
313 forward_ref_op_assign! { impl MulAssign, mul_assign for Saturating<$t>, Saturating<$t>,
314 #[stable(feature = "saturating_int_impl", since = "1.74.0")]
315 #[rustc_const_unstable(feature = "const_ops", issue = "143802")] }
316
317 #[stable(feature = "saturating_int_assign_impl", since = "1.74.0")]
318 #[rustc_const_unstable(feature = "const_ops", issue = "143802")]
319 impl const MulAssign<$t> for Saturating<$t> {
320 #[inline]
321 fn mul_assign(&mut self, other: $t) {
322 *self = *self * Saturating(other);
323 }
324 }
325 forward_ref_op_assign! { impl MulAssign, mul_assign for Saturating<$t>, $t,
326 #[stable(feature = "saturating_int_impl", since = "1.74.0")]
327 #[rustc_const_unstable(feature = "const_ops", issue = "143802")] }
328
329 #[doc = concat!("assert_eq!(Saturating(2", stringify!($t), "), Saturating(5", stringify!($t), ") / Saturating(2));")]
335 #[doc = concat!("assert_eq!(Saturating(", stringify!($t), "::MAX), Saturating(", stringify!($t), "::MAX) / Saturating(1));")]
336 #[doc = concat!("assert_eq!(Saturating(", stringify!($t), "::MIN), Saturating(", stringify!($t), "::MIN) / Saturating(1));")]
337 #[doc = concat!("let _ = Saturating(0", stringify!($t), ") / Saturating(0);")]
343 #[stable(feature = "saturating_int_impl", since = "1.74.0")]
345 #[rustc_const_unstable(feature = "const_ops", issue = "143802")]
346 impl const Div for Saturating<$t> {
347 type Output = Saturating<$t>;
348
349 #[inline]
350 fn div(self, other: Saturating<$t>) -> Saturating<$t> {
351 Saturating(self.0.saturating_div(other.0))
352 }
353 }
354 forward_ref_binop! { impl Div, div for Saturating<$t>, Saturating<$t>,
355 #[stable(feature = "saturating_int_impl", since = "1.74.0")]
356 #[rustc_const_unstable(feature = "const_ops", issue = "143802")] }
357
358 #[stable(feature = "saturating_int_impl", since = "1.74.0")]
359 #[rustc_const_unstable(feature = "const_ops", issue = "143802")]
360 impl const DivAssign for Saturating<$t> {
361 #[inline]
362 fn div_assign(&mut self, other: Saturating<$t>) {
363 *self = *self / other;
364 }
365 }
366 forward_ref_op_assign! { impl DivAssign, div_assign for Saturating<$t>, Saturating<$t>,
367 #[stable(feature = "saturating_int_impl", since = "1.74.0")]
368 #[rustc_const_unstable(feature = "const_ops", issue = "143802")] }
369
370 #[stable(feature = "saturating_int_assign_impl", since = "1.74.0")]
371 #[rustc_const_unstable(feature = "const_ops", issue = "143802")]
372 impl const DivAssign<$t> for Saturating<$t> {
373 #[inline]
374 fn div_assign(&mut self, other: $t) {
375 *self = *self / Saturating(other);
376 }
377 }
378 forward_ref_op_assign! { impl DivAssign, div_assign for Saturating<$t>, $t,
379 #[stable(feature = "saturating_int_impl", since = "1.74.0")]
380 #[rustc_const_unstable(feature = "const_ops", issue = "143802")] }
381
382 #[stable(feature = "saturating_int_impl", since = "1.74.0")]
383 #[rustc_const_unstable(feature = "const_ops", issue = "143802")]
384 impl const Rem for Saturating<$t> {
385 type Output = Saturating<$t>;
386
387 #[inline]
388 fn rem(self, other: Saturating<$t>) -> Saturating<$t> {
389 Saturating(self.0.rem(other.0))
390 }
391 }
392 forward_ref_binop! { impl Rem, rem for Saturating<$t>, Saturating<$t>,
393 #[stable(feature = "saturating_int_impl", since = "1.74.0")]
394 #[rustc_const_unstable(feature = "const_ops", issue = "143802")] }
395
396 #[stable(feature = "saturating_int_impl", since = "1.74.0")]
397 #[rustc_const_unstable(feature = "const_ops", issue = "143802")]
398 impl const RemAssign for Saturating<$t> {
399 #[inline]
400 fn rem_assign(&mut self, other: Saturating<$t>) {
401 *self = *self % other;
402 }
403 }
404 forward_ref_op_assign! { impl RemAssign, rem_assign for Saturating<$t>, Saturating<$t>,
405 #[stable(feature = "saturating_int_impl", since = "1.74.0")]
406 #[rustc_const_unstable(feature = "const_ops", issue = "143802")] }
407
408 #[stable(feature = "saturating_int_assign_impl", since = "1.74.0")]
409 #[rustc_const_unstable(feature = "const_ops", issue = "143802")]
410 impl const RemAssign<$t> for Saturating<$t> {
411 #[inline]
412 fn rem_assign(&mut self, other: $t) {
413 *self = *self % Saturating(other);
414 }
415 }
416 forward_ref_op_assign! { impl RemAssign, rem_assign for Saturating<$t>, $t,
417 #[stable(feature = "saturating_int_impl", since = "1.74.0")]
418 #[rustc_const_unstable(feature = "const_ops", issue = "143802")] }
419
420 #[stable(feature = "saturating_int_impl", since = "1.74.0")]
421 #[rustc_const_unstable(feature = "const_ops", issue = "143802")]
422 impl const Not for Saturating<$t> {
423 type Output = Saturating<$t>;
424
425 #[inline]
426 fn not(self) -> Saturating<$t> {
427 Saturating(!self.0)
428 }
429 }
430 forward_ref_unop! { impl Not, not for Saturating<$t>,
431 #[stable(feature = "saturating_int_impl", since = "1.74.0")]
432 #[rustc_const_unstable(feature = "const_ops", issue = "143802")] }
433
434 #[stable(feature = "saturating_int_impl", since = "1.74.0")]
435 #[rustc_const_unstable(feature = "const_ops", issue = "143802")]
436 impl const BitXor for Saturating<$t> {
437 type Output = Saturating<$t>;
438
439 #[inline]
440 fn bitxor(self, other: Saturating<$t>) -> Saturating<$t> {
441 Saturating(self.0 ^ other.0)
442 }
443 }
444 forward_ref_binop! { impl BitXor, bitxor for Saturating<$t>, Saturating<$t>,
445 #[stable(feature = "saturating_int_impl", since = "1.74.0")]
446 #[rustc_const_unstable(feature = "const_ops", issue = "143802")] }
447
448 #[stable(feature = "saturating_int_impl", since = "1.74.0")]
449 #[rustc_const_unstable(feature = "const_ops", issue = "143802")]
450 impl const BitXorAssign for Saturating<$t> {
451 #[inline]
452 fn bitxor_assign(&mut self, other: Saturating<$t>) {
453 *self = *self ^ other;
454 }
455 }
456 forward_ref_op_assign! { impl BitXorAssign, bitxor_assign for Saturating<$t>, Saturating<$t>,
457 #[stable(feature = "saturating_int_impl", since = "1.74.0")]
458 #[rustc_const_unstable(feature = "const_ops", issue = "143802")] }
459
460 #[stable(feature = "saturating_int_assign_impl", since = "1.74.0")]
461 #[rustc_const_unstable(feature = "const_ops", issue = "143802")]
462 impl const BitXorAssign<$t> for Saturating<$t> {
463 #[inline]
464 fn bitxor_assign(&mut self, other: $t) {
465 *self = *self ^ Saturating(other);
466 }
467 }
468 forward_ref_op_assign! { impl BitXorAssign, bitxor_assign for Saturating<$t>, $t,
469 #[stable(feature = "saturating_int_impl", since = "1.74.0")]
470 #[rustc_const_unstable(feature = "const_ops", issue = "143802")] }
471
472 #[stable(feature = "saturating_int_impl", since = "1.74.0")]
473 #[rustc_const_unstable(feature = "const_ops", issue = "143802")]
474 impl const BitOr for Saturating<$t> {
475 type Output = Saturating<$t>;
476
477 #[inline]
478 fn bitor(self, other: Saturating<$t>) -> Saturating<$t> {
479 Saturating(self.0 | other.0)
480 }
481 }
482 forward_ref_binop! { impl BitOr, bitor for Saturating<$t>, Saturating<$t>,
483 #[stable(feature = "saturating_int_impl", since = "1.74.0")]
484 #[rustc_const_unstable(feature = "const_ops", issue = "143802")] }
485
486 #[stable(feature = "saturating_int_impl", since = "1.74.0")]
487 #[rustc_const_unstable(feature = "const_ops", issue = "143802")]
488 impl const BitOrAssign for Saturating<$t> {
489 #[inline]
490 fn bitor_assign(&mut self, other: Saturating<$t>) {
491 *self = *self | other;
492 }
493 }
494 forward_ref_op_assign! { impl BitOrAssign, bitor_assign for Saturating<$t>, Saturating<$t>,
495 #[stable(feature = "saturating_int_impl", since = "1.74.0")]
496 #[rustc_const_unstable(feature = "const_ops", issue = "143802")] }
497
498 #[stable(feature = "saturating_int_assign_impl", since = "1.74.0")]
499 #[rustc_const_unstable(feature = "const_ops", issue = "143802")]
500 impl const BitOrAssign<$t> for Saturating<$t> {
501 #[inline]
502 fn bitor_assign(&mut self, other: $t) {
503 *self = *self | Saturating(other);
504 }
505 }
506 forward_ref_op_assign! { impl BitOrAssign, bitor_assign for Saturating<$t>, $t,
507 #[stable(feature = "saturating_int_impl", since = "1.74.0")]
508 #[rustc_const_unstable(feature = "const_ops", issue = "143802")] }
509
510 #[stable(feature = "saturating_int_impl", since = "1.74.0")]
511 #[rustc_const_unstable(feature = "const_ops", issue = "143802")]
512 impl const BitAnd for Saturating<$t> {
513 type Output = Saturating<$t>;
514
515 #[inline]
516 fn bitand(self, other: Saturating<$t>) -> Saturating<$t> {
517 Saturating(self.0 & other.0)
518 }
519 }
520 forward_ref_binop! { impl BitAnd, bitand for Saturating<$t>, Saturating<$t>,
521 #[stable(feature = "saturating_int_impl", since = "1.74.0")]
522 #[rustc_const_unstable(feature = "const_ops", issue = "143802")] }
523
524 #[stable(feature = "saturating_int_impl", since = "1.74.0")]
525 #[rustc_const_unstable(feature = "const_ops", issue = "143802")]
526 impl const BitAndAssign for Saturating<$t> {
527 #[inline]
528 fn bitand_assign(&mut self, other: Saturating<$t>) {
529 *self = *self & other;
530 }
531 }
532 forward_ref_op_assign! { impl BitAndAssign, bitand_assign for Saturating<$t>, Saturating<$t>,
533 #[stable(feature = "saturating_int_impl", since = "1.74.0")]
534 #[rustc_const_unstable(feature = "const_ops", issue = "143802")] }
535
536 #[stable(feature = "saturating_int_assign_impl", since = "1.74.0")]
537 #[rustc_const_unstable(feature = "const_ops", issue = "143802")]
538 impl const BitAndAssign<$t> for Saturating<$t> {
539 #[inline]
540 fn bitand_assign(&mut self, other: $t) {
541 *self = *self & Saturating(other);
542 }
543 }
544 forward_ref_op_assign! { impl BitAndAssign, bitand_assign for Saturating<$t>, $t,
545 #[stable(feature = "saturating_int_impl", since = "1.74.0")]
546 #[rustc_const_unstable(feature = "const_ops", issue = "143802")] }
547
548 )*)
549}
550
551saturating_impl! { usize u8 u16 u32 u64 u128 isize i8 i16 i32 i64 i128 }
552
553macro_rules! saturating_int_impl {
554 ($($t:ty)*) => ($(
555 impl Saturating<$t> {
556 #[doc = concat!("assert_eq!(<Saturating<", stringify!($t), ">>::MIN, Saturating(", stringify!($t), "::MIN));")]
564 #[stable(feature = "saturating_int_impl", since = "1.74.0")]
566 pub const MIN: Self = Self(<$t>::MIN);
567
568 #[doc = concat!("assert_eq!(<Saturating<", stringify!($t), ">>::MAX, Saturating(", stringify!($t), "::MAX));")]
576 #[stable(feature = "saturating_int_impl", since = "1.74.0")]
578 pub const MAX: Self = Self(<$t>::MAX);
579
580 #[doc = concat!("assert_eq!(<Saturating<", stringify!($t), ">>::BITS, ", stringify!($t), "::BITS);")]
588 #[stable(feature = "saturating_int_impl", since = "1.74.0")]
590 pub const BITS: u32 = <$t>::BITS;
591
592 #[doc = concat!("let n = Saturating(0b01001100", stringify!($t), ");")]
600 #[inline]
604 #[doc(alias = "popcount")]
605 #[doc(alias = "popcnt")]
606 #[must_use = "this returns the result of the operation, \
607 without modifying the original"]
608 #[rustc_const_stable(feature = "saturating_int_impl", since = "1.74.0")]
609 #[stable(feature = "saturating_int_impl", since = "1.74.0")]
610 pub const fn count_ones(self) -> u32 {
611 self.0.count_ones()
612 }
613
614 #[doc = concat!("assert_eq!(Saturating(!0", stringify!($t), ").count_zeros(), 0);")]
622 #[inline]
624 #[must_use = "this returns the result of the operation, \
625 without modifying the original"]
626 #[rustc_const_stable(feature = "saturating_int_impl", since = "1.74.0")]
627 #[stable(feature = "saturating_int_impl", since = "1.74.0")]
628 pub const fn count_zeros(self) -> u32 {
629 self.0.count_zeros()
630 }
631
632 #[doc = concat!("let n = Saturating(0b0101000", stringify!($t), ");")]
640 #[inline]
644 #[must_use = "this returns the result of the operation, \
645 without modifying the original"]
646 #[rustc_const_stable(feature = "saturating_int_impl", since = "1.74.0")]
647 #[stable(feature = "saturating_int_impl", since = "1.74.0")]
648 pub const fn trailing_zeros(self) -> u32 {
649 self.0.trailing_zeros()
650 }
651
652 #[inline]
670 #[must_use = "this returns the result of the operation, \
671 without modifying the original"]
672 #[rustc_const_stable(feature = "saturating_int_impl", since = "1.74.0")]
673 #[stable(feature = "saturating_int_impl", since = "1.74.0")]
674 pub const fn rotate_left(self, n: u32) -> Self {
675 Saturating(self.0.rotate_left(n))
676 }
677
678 #[inline]
696 #[must_use = "this returns the result of the operation, \
697 without modifying the original"]
698 #[rustc_const_stable(feature = "saturating_int_impl", since = "1.74.0")]
699 #[stable(feature = "saturating_int_impl", since = "1.74.0")]
700 pub const fn rotate_right(self, n: u32) -> Self {
701 Saturating(self.0.rotate_right(n))
702 }
703
704 #[inline]
720 #[must_use = "this returns the result of the operation, \
721 without modifying the original"]
722 #[rustc_const_stable(feature = "saturating_int_impl", since = "1.74.0")]
723 #[stable(feature = "saturating_int_impl", since = "1.74.0")]
724 pub const fn swap_bytes(self) -> Self {
725 Saturating(self.0.swap_bytes())
726 }
727
728 #[inline]
747 #[rustc_const_stable(feature = "saturating_int_impl", since = "1.74.0")]
748 #[stable(feature = "saturating_int_impl", since = "1.74.0")]
749 #[must_use = "this returns the result of the operation, \
750 without modifying the original"]
751 pub const fn reverse_bits(self) -> Self {
752 Saturating(self.0.reverse_bits())
753 }
754
755 #[doc = concat!("let n = Saturating(0x1A", stringify!($t), ");")]
766 #[doc = concat!(" assert_eq!(<Saturating<", stringify!($t), ">>::from_be(n), n)")]
769 #[doc = concat!(" assert_eq!(<Saturating<", stringify!($t), ">>::from_be(n), n.swap_bytes())")]
771 #[inline]
774 #[must_use]
775 #[rustc_const_stable(feature = "saturating_int_impl", since = "1.74.0")]
776 #[stable(feature = "saturating_int_impl", since = "1.74.0")]
777 pub const fn from_be(x: Self) -> Self {
778 Saturating(<$t>::from_be(x.0))
779 }
780
781 #[doc = concat!("let n = Saturating(0x1A", stringify!($t), ");")]
792 #[doc = concat!(" assert_eq!(<Saturating<", stringify!($t), ">>::from_le(n), n)")]
795 #[doc = concat!(" assert_eq!(<Saturating<", stringify!($t), ">>::from_le(n), n.swap_bytes())")]
797 #[inline]
800 #[must_use]
801 #[rustc_const_stable(feature = "saturating_int_impl", since = "1.74.0")]
802 #[stable(feature = "saturating_int_impl", since = "1.74.0")]
803 pub const fn from_le(x: Self) -> Self {
804 Saturating(<$t>::from_le(x.0))
805 }
806
807 #[doc = concat!("let n = Saturating(0x1A", stringify!($t), ");")]
818 #[inline]
826 #[rustc_const_stable(feature = "saturating_int_impl", since = "1.74.0")]
827 #[stable(feature = "saturating_int_impl", since = "1.74.0")]
828 #[must_use = "this returns the result of the operation, \
829 without modifying the original"]
830 pub const fn to_be(self) -> Self {
831 Saturating(self.0.to_be())
832 }
833
834 #[doc = concat!("let n = Saturating(0x1A", stringify!($t), ");")]
845 #[inline]
853 #[rustc_const_stable(feature = "saturating_int_impl", since = "1.74.0")]
854 #[stable(feature = "saturating_int_impl", since = "1.74.0")]
855 #[must_use = "this returns the result of the operation, \
856 without modifying the original"]
857 pub const fn to_le(self) -> Self {
858 Saturating(self.0.to_le())
859 }
860
861 #[doc = concat!("assert_eq!(Saturating(3", stringify!($t), ").pow(4), Saturating(81));")]
869 #[inline]
880 #[rustc_const_stable(feature = "saturating_int_impl", since = "1.74.0")]
881 #[stable(feature = "saturating_int_impl", since = "1.74.0")]
882 #[must_use = "this returns the result of the operation, \
883 without modifying the original"]
884 pub const fn pow(self, exp: u32) -> Self {
885 Saturating(self.0.saturating_pow(exp))
886 }
887 }
888 )*)
889}
890
891saturating_int_impl! { usize u8 u16 u32 u64 u128 isize i8 i16 i32 i64 i128 }
892
893macro_rules! saturating_int_impl_signed {
894 ($($t:ty)*) => ($(
895 impl Saturating<$t> {
896 #[doc = concat!("let n = Saturating(", stringify!($t), "::MAX >> 2);")]
904 #[inline]
908 #[rustc_const_stable(feature = "saturating_int_impl", since = "1.74.0")]
909 #[stable(feature = "saturating_int_impl", since = "1.74.0")]
910 #[must_use = "this returns the result of the operation, \
911 without modifying the original"]
912 pub const fn leading_zeros(self) -> u32 {
913 self.0.leading_zeros()
914 }
915
916 #[doc = concat!("assert_eq!(Saturating(100", stringify!($t), ").abs(), Saturating(100));")]
925 #[doc = concat!("assert_eq!(Saturating(-100", stringify!($t), ").abs(), Saturating(100));")]
926 #[doc = concat!("assert_eq!(Saturating(", stringify!($t), "::MIN).abs(), Saturating((", stringify!($t), "::MIN + 1).abs()));")]
927 #[doc = concat!("assert_eq!(Saturating(", stringify!($t), "::MIN).abs(), Saturating(", stringify!($t), "::MIN.saturating_abs()));")]
928 #[doc = concat!("assert_eq!(Saturating(", stringify!($t), "::MIN).abs(), Saturating(", stringify!($t), "::MAX));")]
929 #[inline]
931 #[rustc_const_stable(feature = "saturating_int_impl", since = "1.74.0")]
932 #[stable(feature = "saturating_int_impl", since = "1.74.0")]
933 #[must_use = "this returns the result of the operation, \
934 without modifying the original"]
935 pub const fn abs(self) -> Saturating<$t> {
936 Saturating(self.0.saturating_abs())
937 }
938
939 #[doc = concat!("assert_eq!(Saturating(10", stringify!($t), ").signum(), Saturating(1));")]
951 #[doc = concat!("assert_eq!(Saturating(0", stringify!($t), ").signum(), Saturating(0));")]
952 #[doc = concat!("assert_eq!(Saturating(-10", stringify!($t), ").signum(), Saturating(-1));")]
953 #[inline]
955 #[rustc_const_stable(feature = "saturating_int_impl", since = "1.74.0")]
956 #[stable(feature = "saturating_int_impl", since = "1.74.0")]
957 #[must_use = "this returns the result of the operation, \
958 without modifying the original"]
959 pub const fn signum(self) -> Saturating<$t> {
960 Saturating(self.0.signum())
961 }
962
963 #[doc = concat!("assert!(Saturating(10", stringify!($t), ").is_positive());")]
972 #[doc = concat!("assert!(!Saturating(-10", stringify!($t), ").is_positive());")]
973 #[must_use]
975 #[inline]
976 #[rustc_const_stable(feature = "saturating_int_impl", since = "1.74.0")]
977 #[stable(feature = "saturating_int_impl", since = "1.74.0")]
978 pub const fn is_positive(self) -> bool {
979 self.0.is_positive()
980 }
981
982 #[doc = concat!("assert!(Saturating(-10", stringify!($t), ").is_negative());")]
991 #[doc = concat!("assert!(!Saturating(10", stringify!($t), ").is_negative());")]
992 #[must_use]
994 #[inline]
995 #[rustc_const_stable(feature = "saturating_int_impl", since = "1.74.0")]
996 #[stable(feature = "saturating_int_impl", since = "1.74.0")]
997 pub const fn is_negative(self) -> bool {
998 self.0.is_negative()
999 }
1000 }
1001
1002 #[stable(feature = "saturating_int_impl", since = "1.74.0")]
1003 #[rustc_const_unstable(feature = "const_ops", issue = "143802")]
1004 impl const Neg for Saturating<$t> {
1005 type Output = Self;
1006 #[inline]
1007 fn neg(self) -> Self {
1008 Saturating(self.0.saturating_neg())
1009 }
1010 }
1011 forward_ref_unop! { impl Neg, neg for Saturating<$t>,
1012 #[stable(feature = "saturating_int_impl", since = "1.74.0")]
1013 #[rustc_const_unstable(feature = "const_ops", issue = "143802")] }
1014 )*)
1015}
1016
1017saturating_int_impl_signed! { isize i8 i16 i32 i64 i128 }
1018
1019macro_rules! saturating_int_impl_unsigned {
1020 ($($t:ty)*) => ($(
1021 impl Saturating<$t> {
1022 #[doc = concat!("let n = Saturating(", stringify!($t), "::MAX >> 2);")]
1030 #[inline]
1034 #[rustc_const_stable(feature = "saturating_int_impl", since = "1.74.0")]
1035 #[stable(feature = "saturating_int_impl", since = "1.74.0")]
1036 #[must_use = "this returns the result of the operation, \
1037 without modifying the original"]
1038 pub const fn leading_zeros(self) -> u32 {
1039 self.0.leading_zeros()
1040 }
1041
1042 #[doc = concat!("assert!(Saturating(16", stringify!($t), ").is_power_of_two());")]
1050 #[doc = concat!("assert!(!Saturating(10", stringify!($t), ").is_power_of_two());")]
1051 #[must_use]
1053 #[inline]
1054 #[rustc_const_stable(feature = "saturating_int_impl", since = "1.74.0")]
1055 #[stable(feature = "saturating_int_impl", since = "1.74.0")]
1056 pub const fn is_power_of_two(self) -> bool {
1057 self.0.is_power_of_two()
1058 }
1059
1060 }
1061 )*)
1062}
1063
1064saturating_int_impl_unsigned! { usize u8 u16 u32 u64 u128 }
1065
1066