commit ef7db9717ec6b08a7ef7ed043819bf4855e0a828 (tree)
parent 23c1b7faee13f95bce6ba48051b9ac1a1fab9576
Author: LemonBoy <thatlemon@gmail.com>
Date: Wed, 9 Dec 2020 20:42:08 +0100
std: introduce meta.traits.is{Integral,Float}
Diffstat:
1 file changed, 32 insertions(+), 0 deletions(-)
diff --git a/lib/std/meta/trait.zig b/lib/std/meta/trait.zig
@@ -312,6 +312,38 @@ test "std.meta.trait.isNumber" {
testing.expect(!isNumber(NotANumber));
}
+pub fn isIntegral(comptime T: type) bool {
+ return switch (@typeInfo(T)) {
+ .Int, .ComptimeInt => true,
+ else => false,
+ };
+}
+
+test "isIntegral" {
+ testing.expect(isIntegral(u32));
+ testing.expect(!isIntegral(f32));
+ testing.expect(isIntegral(@TypeOf(102)));
+ testing.expect(!isIntegral(@TypeOf(102.123)));
+ testing.expect(!isIntegral(*u8));
+ testing.expect(!isIntegral([]u8));
+}
+
+pub fn isFloat(comptime T: type) bool {
+ return switch (@typeInfo(T)) {
+ .Float, .ComptimeFloat => true,
+ else => false,
+ };
+}
+
+test "isFloat" {
+ testing.expect(!isFloat(u32));
+ testing.expect(isFloat(f32));
+ testing.expect(!isFloat(@TypeOf(102)));
+ testing.expect(isFloat(@TypeOf(102.123)));
+ testing.expect(!isFloat(*f64));
+ testing.expect(!isFloat([]f32));
+}
+
pub fn isConstPtr(comptime T: type) bool {
if (!comptime is(.Pointer)(T)) return false;
return @typeInfo(T).Pointer.is_const;