|
| 1 | +fn main() { |
| 2 | + let x: i128 = -1; |
| 3 | + assert_eq!(0, !x); |
| 4 | + let y: i128 = -2; |
| 5 | + assert_eq!(!1, y); |
| 6 | + let z: i128 = 0xABCD_EF; |
| 7 | + assert_eq!(-z * -z * -z * -z, 0x33EE_0E2A_54E2_59DA_A0E7_8E41); |
| 8 | + assert_eq!(-z + -z + -z + -z, -0x2AF3_7BC); |
| 9 | + let k: i128 = -0x1234_5678_9ABC_DEFF_EDCB_A987_6543_210; |
| 10 | + assert_eq!(k + k, -0x2468_ACF1_3579_BDFF_DB97_530E_CA86_420); |
| 11 | + assert_eq!(0, k - k); |
| 12 | + assert_eq!(-0x1234_5678_9ABC_DEFF_EDCB_A987_5A86_421, k + z); |
| 13 | + assert_eq!(-0x1000_0000_0000_0000_0000_0000_0000_000, |
| 14 | + k + 0x234_5678_9ABC_DEFF_EDCB_A987_6543_210); |
| 15 | + assert_eq!(-0x6EF5_DE4C_D3BC_2AAA_3BB4_CC5D_D6EE_8, k / 42); |
| 16 | + assert_eq!(-k, k / -1); |
| 17 | + assert_eq!(-0x91A2_B3C4_D5E6_F8, k >> 65); |
| 18 | + assert_eq!(-0xFDB9_7530_ECA8_6420_0000_0000_0000_0000, k << 65); |
| 19 | + assert!(k < z); |
| 20 | + assert!(y > k); |
| 21 | + assert!(y < x); |
| 22 | + assert_eq!(x as i64, -1); |
| 23 | + assert_eq!(z as i64, 0xABCD_EF); |
| 24 | + assert_eq!(k as i64, -0xFEDC_BA98_7654_3210); |
| 25 | + assert_eq!(k as u128, 0xFEDC_BA98_7654_3210_0123_4567_89AB_CDF0); |
| 26 | + assert_eq!(-k as u128, 0x1234_5678_9ABC_DEFF_EDCB_A987_6543_210); |
| 27 | + // formatting |
| 28 | + let j: i128 = -(1 << 67); |
| 29 | + assert_eq!("-147573952589676412928", format!("{}", j)); |
| 30 | + assert_eq!("fffffffffffffff80000000000000000", format!("{:x}", j)); |
| 31 | + assert_eq!("3777777777777777777760000000000000000000000", format!("{:o}", j)); |
| 32 | + assert_eq!("1111111111111111111111111111111111111111111111111111111111111\ |
| 33 | + 0000000000000000000000000000000000000000000000000000000000000000000", |
| 34 | + format!("{:b}", j)); |
| 35 | + assert_eq!("-147573952589676412928", format!("{:?}", j)); |
| 36 | + // common traits |
| 37 | + x.clone(); |
| 38 | +} |
0 commit comments