scala.compiletime.ops.int.scala Maven / Gradle / Ivy
package scala.compiletime
package ops
object int:
/** Successor of a natural number where zero is the type 0 and successors are reduced as if the definition was
*
* ```scala
* type S[N <: Int] <: Int = N match {
* case 0 => 1
* case 1 => 2
* case 2 => 3
* ...
* case 2147483646 => 2147483647
* }
* ```
* @syntax markdown
*/
type S[N <: Int] <: Int
/** Addition of two `Int` singleton types.
* ```scala
* val sum: 2 + 2 = 4
* ```
* @syntax markdown
*/
type +[X <: Int, Y <: Int] <: Int
/** Subtraction of two `Int` singleton types.
* ```scala
* val sub: 4 - 2 = 2
* ```
* @syntax markdown
*/
type -[X <: Int, Y <: Int] <: Int
/** Multiplication of two `Int` singleton types.
* ```scala
* val mul: 4 * 2 = 8
* ```
* @syntax markdown
*/
type *[X <: Int, Y <: Int] <: Int
/** Integer division of two `Int` singleton types.
* ```scala
* val div: 5 / 2 = 2
* ```
* @syntax markdown
*/
type /[X <: Int, Y <: Int] <: Int
/** Remainder of the division of `X` by `Y`.
* ```scala
* val mod: 5 % 2 = 1
* ```
* @syntax markdown
*/
type %[X <: Int, Y <: Int] <: Int
/** Binary left shift of `X` by `Y`.
* ```scala
* val lshift: 1 << 2 = 4
* ```
* @syntax markdown
*/
type <<[X <: Int, Y <: Int] <: Int
/** Binary right shift of `X` by `Y`.
* ```scala
* val rshift: 10 >> 1 = 5
* ```
* @syntax markdown
*/
type >>[X <: Int, Y <: Int] <: Int
/** Binary right shift of `X` by `Y`, filling the left with zeros.
* ```scala
* val rshiftzero: 10 >>> 1 = 5
* ```
* @syntax markdown
*/
type >>>[X <: Int, Y <: Int] <: Int
/** Bitwise xor of `X` and `Y`.
* ```scala
* val xor: 10 ^ 30 = 20
* ```
* @syntax markdown
*/
type ^[X <: Int, Y <: Int] <: Int
/** Less-than comparison of two `Int` singleton types.
* ```scala
* val lt1: 4 < 2 = false
* val lt2: 2 < 4 = true
* ```
* @syntax markdown
*/
type <[X <: Int, Y <: Int] <: Boolean
/** Greater-than comparison of two `Int` singleton types.
* ```scala
* val gt1: 4 > 2 = true
* val gt2: 2 > 2 = false
* ```
* @syntax markdown
*/
type >[X <: Int, Y <: Int] <: Boolean
/** Greater-or-equal comparison of two `Int` singleton types.
* ```scala
* val ge1: 4 >= 2 = true
* val ge2: 2 >= 3 = false
* ```
* @syntax markdown
*/
type >=[X <: Int, Y <: Int] <: Boolean
/** Less-or-equal comparison of two `Int` singleton types.
* ```scala
* val lt1: 4 <= 2 = false
* val lt2: 2 <= 2 = true
* ```
* @syntax markdown
*/
type <=[X <: Int, Y <: Int] <: Boolean
/** Bitwise and of `X` and `Y`.
* ```scala
* val and1: BitwiseAnd[4, 4] = 4
* val and2: BitwiseAnd[10, 5] = 0
* ```
* @syntax markdown
*/
type BitwiseAnd[X <: Int, Y <: Int] <: Int
/** Bitwise or of `X` and `Y`.
* ```scala
* val or: BitwiseOr[10, 11] = 11
* ```
* @syntax markdown
*/
type BitwiseOr[X <: Int, Y <: Int] <: Int
/** Absolute value of an `Int` singleton type.
* ```scala
* val abs: Abs[-1] = 1
* ```
* @syntax markdown
*/
type Abs[X <: Int] <: Int
/** Negation of an `Int` singleton type.
* ```scala
* val neg1: Neg[-1] = 1
* val neg2: Neg[1] = -1
* ```
* @syntax markdown
*/
type Negate[X <: Int] <: Int
/** Minimum of two `Int` singleton types.
* ```scala
* val min: Min[-1, 1] = -1
* ```
* @syntax markdown
*/
type Min[X <: Int, Y <: Int] <: Int
/** Maximum of two `Int` singleton types.
* ```scala
* val max: Max[-1, 1] = 1
* ```
* @syntax markdown
*/
type Max[X <: Int, Y <: Int] <: Int
/** String conversion of an `Int` singleton type.
* ```scala
* val abs: ToString[1] = "1"
* ```
* @syntax markdown
*/
type ToString[X <: Int] <: String
© 2015 - 2025 Weber Informatics LLC | Privacy Policy