From fde7a1311543badd1052a757d1e2c68272be1188 Mon Sep 17 00:00:00 2001 From: JJ Date: Tue, 2 Jan 2024 13:49:25 -0800 Subject: std: more fleshing out. merge std.magic back into std.prelude. --- std/magic/numbers.pk | 77 ---------------------------------------------------- 1 file changed, 77 deletions(-) delete mode 100644 std/magic/numbers.pk (limited to 'std/magic/numbers.pk') diff --git a/std/magic/numbers.pk b/std/magic/numbers.pk deleted file mode 100644 index 007f4b7..0000000 --- a/std/magic/numbers.pk +++ /dev/null @@ -1,77 +0,0 @@ -## std.numbers: Operations on numbers and such. -## A stub module for documentation. -# reference: https://en.wikipedia.org/wiki/IEEE_754 - -## The default integer type. Size depends on architecture. -pub type int -## A signed 8-bit integer. -pub type i8 -## A signed 16-bit integer. -pub type i16 -## A signed 32-bit integer. -pub type i32 -## A signed 64-bit integer. -pub type i64 -## A signed 128-bit integer. -pub type i128 - -## The default unsigned integer type. Size depends on architecture. -pub type uint -## An unsigned 8-bit integer. -pub type u8 -## An unsigned 16-bit integer. -pub type u16 -## An unsigned 32-bit integer. -pub type u32 -## An unsigned 64-bit integer. -pub type u64 -## An unsigned 128-bit integer. -pub type u128 - -## A floating-point type. Takes up 64 bits by default. -pub type float = f64 -## A 32-bit floating point type. Single precision. -pub type f32 -## A 64-bit floating point type. Double precision. -pub type f64 -## A 128-bit floating point type. Quadruple precision. -pub type f128 - -## A decimal type, according to IEEE 754. Takes up 64 bits by default. -pub type decimal = dec64 -## A 64-bit decimal type. -pub type dec64 -## A 128-bit decimal type. -pub type dec128 - -## 8-bit bytes. -pub type byte = u8 -## 4-byte chars. These represent distinct Unicode characters. -pub type char = distinct u32 -## An alias to `char`, to match with `str`. -pub type chr = char - -## The IEEE floating point value of *Not a Number*. -pub const NaN: f64 = 0x7FF7FFFFFFFFFFFF -## The IEEE floating point value of positive infinity. -pub const Inf: f64 = 0x7FF0000000000000 -## The IEEE floating point value of negative infinity. -pub const NegInf: f64 = 0xFFF0000000000000 - -# todo: type conversions - -pub func +[T](a: T, b: T): T -pub func -[T](a: T, b: T): T -pub func *[T](a: T, b: T): T -pub func /[T](a: T, b: T): float -pub func ^[T](a: T, b: T): T # todo: should be exp? - -pub func div[T](a: T, b: T): T -pub func mod[T](a: T, b: T): T # fixme -pub func rem[T](a: T, b: T): T - -pub func shl[T](a: T): T -pub func shr[T](a: T): T - -pub func abs[T](a: T): T -pub func neg[T](a: T): bool -- cgit v1.2.3-70-g09d2