@@ -62,8 +62,10 @@ macro_rules! impl_float {
62
62
} ;
63
63
}
64
64
65
+ impl_float ! ( f16, u16 ) ;
65
66
impl_float ! ( f32 , u32 ) ;
66
67
impl_float ! ( f64 , u64 ) ;
68
+ impl_float ! ( f128, u128 ) ;
67
69
68
70
trait FloatToInt < Int > : Copy {
69
71
fn cast ( self ) -> Int ;
@@ -85,8 +87,10 @@ macro_rules! float_to_int {
85
87
} ;
86
88
}
87
89
90
+ float_to_int ! ( f16 => i8 , u8 , i16 , u16 , i32 , u32 , i64 , u64 , i128 , u128 ) ;
88
91
float_to_int ! ( f32 => i8 , u8 , i16 , u16 , i32 , u32 , i64 , u64 , i128 , u128 ) ;
89
92
float_to_int ! ( f64 => i8 , u8 , i16 , u16 , i32 , u32 , i64 , u64 , i128 , u128 ) ;
93
+ float_to_int ! ( f128 => i8 , u8 , i16 , u16 , i32 , u32 , i64 , u64 , i128 , u128 ) ;
90
94
91
95
/// Test this cast both via `as` and via `approx_unchecked` (i.e., it must not saturate).
92
96
#[ track_caller]
@@ -468,6 +472,32 @@ macro_rules! test_ftof {
468
472
fn casts ( ) {
469
473
/* int <-> float generic tests */
470
474
475
+ test_ftoi_itof ! { f: f16, i: i8 , imin_f: -128.0 , imax_f: 127.0 } ;
476
+ test_ftoi_itof ! { f: f16, i: u8 , imin_f: 0.0 , imax_f: 255.0 } ;
477
+ test_ftoi_itof ! { f: f16, i: i16 , imin_f: -32_768.0 , imax_f: 32_767.0 } ;
478
+ test_ftoi_itof ! { f: f16, i: u16 , imin_f: 0.0 , imax_f: 65_535.0 } ;
479
+ test_ftoi_itof ! { f: f16, i: i32 , imin_f: -2_147_483_648.0 , imax_f: 2_147_483_647.0 } ;
480
+ test_ftoi_itof ! { f: f16, i: u32 , imin_f: 0.0 , imax_f: 4_294_967_295.0 } ;
481
+ test_ftoi_itof ! {
482
+ f: f16,
483
+ i: i64 ,
484
+ imin_f: -9_223_372_036_854_775_808.0 ,
485
+ imax_f: 9_223_372_036_854_775_807.0
486
+ } ;
487
+ test_ftoi_itof ! { f: f16, i: u64 , imin_f: 0.0 , imax_f: 18_446_744_073_709_551_615.0 } ;
488
+ test_ftoi_itof ! {
489
+ f: f16,
490
+ i: i128 ,
491
+ imin_f: -170_141_183_460_469_231_731_687_303_715_884_105_728.0 ,
492
+ imax_f: 170_141_183_460_469_231_731_687_303_715_884_105_727.0 ,
493
+ } ;
494
+ test_ftoi_itof ! {
495
+ f: f16,
496
+ i: u128 ,
497
+ imin_f: 0.0 ,
498
+ imax_f: 340_282_366_920_938_463_463_374_607_431_768_211_455.0
499
+ } ;
500
+
471
501
test_ftoi_itof ! { f: f32 , i: i8 , imin_f: -128.0 , imax_f: 127.0 } ;
472
502
test_ftoi_itof ! { f: f32 , i: u8 , imin_f: 0.0 , imax_f: 255.0 } ;
473
503
test_ftoi_itof ! { f: f32 , i: i16 , imin_f: -32_768.0 , imax_f: 32_767.0 } ;
@@ -520,6 +550,32 @@ fn casts() {
520
550
imax_f: 340_282_366_920_938_463_463_374_607_431_768_211_455.0
521
551
} ;
522
552
553
+ test_ftoi_itof ! { f: f128, i: i8 , imin_f: -128.0 , imax_f: 127.0 } ;
554
+ test_ftoi_itof ! { f: f128, i: u8 , imin_f: 0.0 , imax_f: 255.0 } ;
555
+ test_ftoi_itof ! { f: f128, i: i16 , imin_f: -32_768.0 , imax_f: 32_767.0 } ;
556
+ test_ftoi_itof ! { f: f128, i: u16 , imin_f: 0.0 , imax_f: 65_535.0 } ;
557
+ test_ftoi_itof ! { f: f128, i: i32 , imin_f: -2_147_483_648.0 , imax_f: 2_147_483_647.0 } ;
558
+ test_ftoi_itof ! { f: f128, i: u32 , imin_f: 0.0 , imax_f: 4_294_967_295.0 } ;
559
+ test_ftoi_itof ! {
560
+ f: f128,
561
+ i: i64 ,
562
+ imin_f: -9_223_372_036_854_775_808.0 ,
563
+ imax_f: 9_223_372_036_854_775_807.0
564
+ } ;
565
+ test_ftoi_itof ! { f: f128, i: u64 , imin_f: 0.0 , imax_f: 18_446_744_073_709_551_615.0 } ;
566
+ test_ftoi_itof ! {
567
+ f: f128,
568
+ i: i128 ,
569
+ imin_f: -170_141_183_460_469_231_731_687_303_715_884_105_728.0 ,
570
+ imax_f: 170_141_183_460_469_231_731_687_303_715_884_105_727.0 ,
571
+ } ;
572
+ test_ftoi_itof ! {
573
+ f: f128,
574
+ i: u128 ,
575
+ imin_f: 0.0 ,
576
+ imax_f: 340_282_366_920_938_463_463_374_607_431_768_211_455.0
577
+ } ;
578
+
523
579
/* int <-> float spot checks */
524
580
525
581
// int -> f32
@@ -551,8 +607,18 @@ fn casts() {
551
607
552
608
/* float -> float generic tests */
553
609
610
+ test_ftof ! { f1: f16, f2: f32 } ;
611
+ test_ftof ! { f1: f16, f2: f64 } ;
612
+ test_ftof ! { f1: f16, f2: f128 } ;
613
+ test_ftof ! { f1: f32 , f2: f16 } ;
554
614
test_ftof ! { f1: f32 , f2: f64 } ;
615
+ test_ftof ! { f1: f32 , f2: f128 } ;
616
+ test_ftof ! { f1: f64 , f2: f16 } ;
555
617
test_ftof ! { f1: f64 , f2: f32 } ;
618
+ test_ftof ! { f1: f64 , f2: f128 } ;
619
+ test_ftof ! { f1: f128, f2: f16 } ;
620
+ test_ftof ! { f1: f128, f2: f32 } ;
621
+ test_ftof ! { f1: f128, f2: f64 } ;
556
622
557
623
/* float -> float spot checks */
558
624
0 commit comments