All Downloads are FREE. Search and download functionalities are using the official Maven repository.

scala.compiletime.ops.double.scala Maven / Gradle / Ivy

There is a newer version: 3.6.4-RC1-bin-20241220-0bfa1af-NIGHTLY
Show newest version
package scala.compiletime
package ops

import scala.annotation.experimental

@experimental
object double:
  /** Addition of two `Double` singleton types.
   *  ```scala
   *  val sum: 2.0 + 2.0 = 4.0
   *  ```
   *  @syntax markdown
   */
  type +[+X <: Double, +Y <: Double] <: Double

  /** Subtraction of two `Double` singleton types.
   *  ```scala
   *  val sub: 4.0 - 2.0 = 2.0
   *  ```
   *  @syntax markdown
   */
  type -[+X <: Double, +Y <: Double] <: Double

  /** Multiplication of two `Double` singleton types.
   *  ```scala
   *  val mul: 4.0 * 2.0 = 8.0
   *  ```
   *  @syntax markdown
   */
  type *[+X <: Double, +Y <: Double] <: Double

  /** Integer division of two `Double` singleton types.
   *  ```scala
   *  val div: 5.0 / 2.0 = 2.5
   *  ```
   *  @syntax markdown
   */
  type /[+X <: Double, +Y <: Double] <: Double

  /** Remainder of the division of `X` by `Y`.
   *  ```scala
   *  val mod: 5.0 % 2.0 = 1.0
   *  ```
   *  @syntax markdown
   */
  type %[+X <: Double, +Y <: Double] <: Double

  /** Less-than comparison of two `Double` singleton types.
   *  ```scala
   *  val lt1: 4.0 < 2.0 = false
   *  val lt2: 2.0 < 4.0 = true
   *  ```
   *  @syntax markdown
   */
  type <[+X <: Double, +Y <: Double] <: Boolean

  /** Greater-than comparison of two `Double` singleton types.
   *  ```scala
   *  val gt1: 4.0 > 2.0 = true
   *  val gt2: 2.0 > 2.0 = false
   *  ```
   *  @syntax markdown
   */
  type >[+X <: Double, +Y <: Double] <: Boolean

  /** Greater-or-equal comparison of two `Double` singleton types.
   *  ```scala
   *  val ge1: 4.0 >= 2.0 = true
   *  val ge2: 2.0 >= 3.0 = false
   *  ```
   *  @syntax markdown
   */
  type >=[+X <: Double, +Y <: Double] <: Boolean

  /** Less-or-equal comparison of two `Double` singleton types.
   *  ```scala
   *  val lt1: 4.0 <= 2.0 = false
   *  val lt2: 2.0 <= 2.0 = true
   *  ```
   *  @syntax markdown
   */
  type <=[+X <: Double, +Y <: Double] <: Boolean

  /** Absolute value of an `Double` singleton type.
   *  ```scala
   *  val abs: Abs[-1.0] = 1.0
   *  ```
   *  @syntax markdown
   */
  type Abs[+X <: Double] <: Double

  /** Negation of an `Double` singleton type.
   *  ```scala
   *  val neg1: Negate[-1.0] = 1.0
   *  val neg2: Negate[1.0] = -1.0
   *  ```
   *  @syntax markdown
   */
  type Negate[+X <: Double] <: Double

  /** Minimum of two `Double` singleton types.
   *  ```scala
   *  val min: Min[-1.0, 1.0] = -1.0
   *  ```
   *  @syntax markdown
   */
  type Min[+X <: Double, +Y <: Double] <: Double

  /** Maximum of two `Double` singleton types.
   *  ```scala
   *  val max: Max[-1.0, 1.0] = 1.0
   *  ```
   *  @syntax markdown
   */
  type Max[+X <: Double, +Y <: Double] <: Double

  /** Int conversion of a `Double` singleton type.
   *  ```scala
   *  val x: ToInt[1.0] = 1
   *  ```
   *  @syntax markdown
   */
  type ToInt[+X <: Double] <: Int

  /** Long conversion of a `Double` singleton type.
   *  ```scala
   *  val x: ToLong[1.0] = 1L
   *  ```
   *  @syntax markdown
   */
  type ToLong[+X <: Double] <: Long

  /** Float conversion of a `Double` singleton type.
   *  ```scala
   *  val x: ToFloat[1.0] = 1.0f
   *  ```
   *  @syntax markdown
   */
  type ToFloat[+X <: Double] <: Float




© 2015 - 2025 Weber Informatics LLC | Privacy Policy