Struct typenum::int::NInt[][src]

pub struct NInt<U: Unsigned + NonZero> { /* fields omitted */ }

Type-level signed integers with negative sign.

Methods

impl<U: Unsigned + NonZero> NInt<U>
[src]

Instantiates a singleton representing this strictly negative integer.

Trait Implementations

impl<U: Eq + Unsigned + NonZero> Eq for NInt<U>
[src]

impl<U: PartialEq + Unsigned + NonZero> PartialEq for NInt<U>
[src]

This method tests for self and other values to be equal, and is used by ==. Read more

This method tests for !=.

impl<U: Ord + Unsigned + NonZero> Ord for NInt<U>
[src]

This method returns an Ordering between self and other. Read more

Compares and returns the maximum of two values. Read more

Compares and returns the minimum of two values. Read more

impl<U: PartialOrd + Unsigned + NonZero> PartialOrd for NInt<U>
[src]

This method returns an ordering between self and other values if one exists. Read more

This method tests less than (for self and other) and is used by the < operator. Read more

This method tests less than or equal to (for self and other) and is used by the <= operator. Read more

This method tests greater than (for self and other) and is used by the > operator. Read more

This method tests greater than or equal to (for self and other) and is used by the >= operator. Read more

impl<U: Clone + Unsigned + NonZero> Clone for NInt<U>
[src]

Returns a copy of the value. Read more

Performs copy-assignment from source. Read more

impl<U: Copy + Unsigned + NonZero> Copy for NInt<U>
[src]

impl<U: Hash + Unsigned + NonZero> Hash for NInt<U>
[src]

Feeds this value into the given [Hasher]. Read more

Feeds a slice of this type into the given [Hasher]. Read more

impl<U: Debug + Unsigned + NonZero> Debug for NInt<U>
[src]

Formats the value using the given formatter. Read more

impl<U: Default + Unsigned + NonZero> Default for NInt<U>
[src]

Returns the "default value" for a type. Read more

impl<U: Unsigned + NonZero> NonZero for NInt<U>
[src]

impl<U: Unsigned + NonZero> Integer for NInt<U>
[src]

I8: i8 = -<U>::I8

I16: i16 = -<U>::I16

I32: i32 = -<U>::I32

I64: i64 = -<U>::I64

ISIZE: isize = -<U>::ISIZE

impl<U: Unsigned + NonZero> Neg for NInt<U>
[src]

-NInt = PInt

The resulting type after applying the - operator.

Performs the unary - operation.

impl<U: Unsigned + NonZero> Add<Z0> for NInt<U>
[src]

NInt + Z0 = NInt

The resulting type after applying the + operator.

Performs the + operation.

impl<Ul: Unsigned + NonZero, Ur: Unsigned + NonZero> Add<NInt<Ur>> for NInt<Ul> where
    Ul: Add<Ur>,
    <Ul as Add<Ur>>::Output: Unsigned + NonZero
[src]

N(Ul) + N(Ur) = N(Ul + Ur)

The resulting type after applying the + operator.

Performs the + operation.

impl<Ul: Unsigned + NonZero, Ur: Unsigned + NonZero> Add<NInt<Ur>> for PInt<Ul> where
    Ul: Cmp<Ur> + PrivateIntegerAdd<<Ul as Cmp<Ur>>::Output, Ur>, 
[src]

P(Ul) + N(Ur): We resolve this with our PrivateAdd

The resulting type after applying the + operator.

Performs the + operation.

impl<Ul: Unsigned + NonZero, Ur: Unsigned + NonZero> Add<PInt<Ur>> for NInt<Ul> where
    Ur: Cmp<Ul> + PrivateIntegerAdd<<Ur as Cmp<Ul>>::Output, Ul>, 
[src]

N(Ul) + P(Ur): We resolve this with our PrivateAdd

The resulting type after applying the + operator.

Performs the + operation.

impl<U: Unsigned + NonZero> Sub<NInt<U>> for Z0
[src]

Z0 - N = P

The resulting type after applying the - operator.

Performs the - operation.

impl<U: Unsigned + NonZero> Sub<Z0> for NInt<U>
[src]

NInt - Z0 = NInt

The resulting type after applying the - operator.

Performs the - operation.

impl<Ul: Unsigned + NonZero, Ur: Unsigned + NonZero> Sub<NInt<Ur>> for PInt<Ul> where
    Ul: Add<Ur>,
    <Ul as Add<Ur>>::Output: Unsigned + NonZero
[src]

P(Ul) - N(Ur) = P(Ul + Ur)

The resulting type after applying the - operator.

Performs the - operation.

impl<Ul: Unsigned + NonZero, Ur: Unsigned + NonZero> Sub<PInt<Ur>> for NInt<Ul> where
    Ul: Add<Ur>,
    <Ul as Add<Ur>>::Output: Unsigned + NonZero
[src]

N(Ul) - P(Ur) = N(Ul + Ur)

The resulting type after applying the - operator.

Performs the - operation.

impl<Ul: Unsigned + NonZero, Ur: Unsigned + NonZero> Sub<NInt<Ur>> for NInt<Ul> where
    Ur: Cmp<Ul> + PrivateIntegerAdd<<Ur as Cmp<Ul>>::Output, Ul>, 
[src]

N(Ul) - N(Ur): We resolve this with our PrivateAdd

The resulting type after applying the - operator.

Performs the - operation.

impl<U: Unsigned + NonZero> Mul<Z0> for NInt<U>
[src]

N * Z0 = Z0

The resulting type after applying the * operator.

Performs the * operation.

impl<Ul: Unsigned + NonZero, Ur: Unsigned + NonZero> Mul<NInt<Ur>> for NInt<Ul> where
    Ul: Mul<Ur>,
    <Ul as Mul<Ur>>::Output: Unsigned + NonZero
[src]

N(Ul) * N(Ur) = P(Ul * Ur)

The resulting type after applying the * operator.

Performs the * operation.

impl<Ul: Unsigned + NonZero, Ur: Unsigned + NonZero> Mul<NInt<Ur>> for PInt<Ul> where
    Ul: Mul<Ur>,
    <Ul as Mul<Ur>>::Output: Unsigned + NonZero
[src]

P(Ul) * N(Ur) = N(Ul * Ur)

The resulting type after applying the * operator.

Performs the * operation.

impl<Ul: Unsigned + NonZero, Ur: Unsigned + NonZero> Mul<PInt<Ur>> for NInt<Ul> where
    Ul: Mul<Ur>,
    <Ul as Mul<Ur>>::Output: Unsigned + NonZero
[src]

N(Ul) * P(Ur) = N(Ul * Ur)

The resulting type after applying the * operator.

Performs the * operation.

impl<Ul: Unsigned + NonZero, Ur: Unsigned + NonZero> Div<NInt<Ur>> for PInt<Ul> where
    Ul: Cmp<Ur>,
    PInt<Ul>: PrivateDivInt<<Ul as Cmp<Ur>>::Output, NInt<Ur>>, 
[src]

$A<Ul> / $B<Ur> = $R<Ul / Ur>

The resulting type after applying the / operator.

Performs the / operation.

impl<Ul: Unsigned + NonZero, Ur: Unsigned + NonZero> Div<PInt<Ur>> for NInt<Ul> where
    Ul: Cmp<Ur>,
    NInt<Ul>: PrivateDivInt<<Ul as Cmp<Ur>>::Output, PInt<Ur>>, 
[src]

$A<Ul> / $B<Ur> = $R<Ul / Ur>

The resulting type after applying the / operator.

Performs the / operation.

impl<Ul: Unsigned + NonZero, Ur: Unsigned + NonZero> Div<NInt<Ur>> for NInt<Ul> where
    Ul: Cmp<Ur>,
    NInt<Ul>: PrivateDivInt<<Ul as Cmp<Ur>>::Output, NInt<Ur>>, 
[src]

$A<Ul> / $B<Ur> = $R<Ul / Ur>

The resulting type after applying the / operator.

Performs the / operation.

impl<U: Unsigned + NonZero> Cmp<NInt<U>> for Z0
[src]

0 > -X

The result of the comparison. It should only ever be one of Greater, Less, or Equal.

impl<U: Unsigned + NonZero> Cmp<Z0> for NInt<U>
[src]

-X < 0

The result of the comparison. It should only ever be one of Greater, Less, or Equal.

impl<P: Unsigned + NonZero, N: Unsigned + NonZero> Cmp<PInt<P>> for NInt<N>
[src]

-X < Y

The result of the comparison. It should only ever be one of Greater, Less, or Equal.

impl<P: Unsigned + NonZero, N: Unsigned + NonZero> Cmp<NInt<N>> for PInt<P>
[src]

X > - Y

The result of the comparison. It should only ever be one of Greater, Less, or Equal.

impl<Nl: Unsigned + NonZero, Nr: Cmp<Nl> + Unsigned + NonZero> Cmp<NInt<Nr>> for NInt<Nl>
[src]

-X <==> -Y

The result of the comparison. It should only ever be one of Greater, Less, or Equal.

impl<Ul: Unsigned + NonZero, Ur: Unsigned + NonZero> Rem<NInt<Ur>> for PInt<Ul> where
    Ul: Rem<Ur>,
    PInt<Ul>: PrivateRem<<Ul as Rem<Ur>>::Output, NInt<Ur>>, 
[src]

$A<Ul> % $B<Ur> = $R<Ul % Ur>

The resulting type after applying the % operator.

Performs the % operation.

impl<Ul: Unsigned + NonZero, Ur: Unsigned + NonZero> Rem<PInt<Ur>> for NInt<Ul> where
    Ul: Rem<Ur>,
    NInt<Ul>: PrivateRem<<Ul as Rem<Ur>>::Output, PInt<Ur>>, 
[src]

$A<Ul> % $B<Ur> = $R<Ul % Ur>

The resulting type after applying the % operator.

Performs the % operation.

impl<Ul: Unsigned + NonZero, Ur: Unsigned + NonZero> Rem<NInt<Ur>> for NInt<Ul> where
    Ul: Rem<Ur>,
    NInt<Ul>: PrivateRem<<Ul as Rem<Ur>>::Output, NInt<Ur>>, 
[src]

$A<Ul> % $B<Ur> = $R<Ul % Ur>

The resulting type after applying the % operator.

Performs the % operation.

impl<U: Unsigned + NonZero> Pow<NInt<U>> for Z0
[src]

0^N = 0

The result of the exponentiation.

This function isn't used in this crate, but may be useful for others. It is implemented for primitives. Read more

impl<U: Unsigned + NonZero> Pow<NInt<U>> for P1
[src]

1^N = 1

The result of the exponentiation.

This function isn't used in this crate, but may be useful for others. It is implemented for primitives. Read more

impl<U: Unsigned> Pow<NInt<UInt<U, B0>>> for N1
[src]

(-1)^N = 1 if N is even

The result of the exponentiation.

This function isn't used in this crate, but may be useful for others. It is implemented for primitives. Read more

impl<U: Unsigned> Pow<NInt<UInt<U, B1>>> for N1
[src]

(-1)^N = -1 if N is odd

The result of the exponentiation.

This function isn't used in this crate, but may be useful for others. It is implemented for primitives. Read more

impl<U: Unsigned + NonZero> Pow<Z0> for NInt<U>
[src]

N^0 = 1

The result of the exponentiation.

This function isn't used in this crate, but may be useful for others. It is implemented for primitives. Read more

impl<Ul: Unsigned + NonZero, Ur: Unsigned> Pow<PInt<UInt<Ur, B0>>> for NInt<Ul> where
    Ul: Pow<UInt<Ur, B0>>,
    <Ul as Pow<UInt<Ur, B0>>>::Output: Unsigned + NonZero
[src]

N(Ul)^P(Ur) = P(Ul^Ur) if Ur is even

The result of the exponentiation.

This function isn't used in this crate, but may be useful for others. It is implemented for primitives. Read more

impl<Ul: Unsigned + NonZero, Ur: Unsigned> Pow<PInt<UInt<Ur, B1>>> for NInt<Ul> where
    Ul: Pow<UInt<Ur, B1>>,
    <Ul as Pow<UInt<Ur, B1>>>::Output: Unsigned + NonZero
[src]

N(Ul)^P(Ur) = N(Ul^Ur) if Ur is odd

The result of the exponentiation.

This function isn't used in this crate, but may be useful for others. It is implemented for primitives. Read more

impl<U> Min<NInt<U>> for Z0 where
    U: Unsigned + NonZero
[src]

The type of the minimum of Self and Rhs

Method returning the minimum

impl<U> Min<Z0> for NInt<U> where
    U: Unsigned + NonZero
[src]

The type of the minimum of Self and Rhs

Method returning the minimum

impl<Ul, Ur> Min<PInt<Ur>> for NInt<Ul> where
    Ul: Unsigned + NonZero,
    Ur: Unsigned + NonZero
[src]

The type of the minimum of Self and Rhs

Method returning the minimum

impl<Ul, Ur> Min<NInt<Ur>> for PInt<Ul> where
    Ul: Unsigned + NonZero,
    Ur: Unsigned + NonZero
[src]

The type of the minimum of Self and Rhs

Method returning the minimum

impl<Ul, Ur> Min<NInt<Ur>> for NInt<Ul> where
    Ul: Unsigned + NonZero + Max<Ur>,
    Ur: Unsigned + NonZero,
    Maximum<Ul, Ur>: Unsigned + NonZero
[src]

The type of the minimum of Self and Rhs

Method returning the minimum

impl<U> Max<NInt<U>> for Z0 where
    U: Unsigned + NonZero
[src]

The type of the maximum of Self and Rhs

Method returning the maximum

impl<U> Max<Z0> for NInt<U> where
    U: Unsigned + NonZero
[src]

The type of the maximum of Self and Rhs

Method returning the maximum

impl<Ul, Ur> Max<PInt<Ur>> for NInt<Ul> where
    Ul: Unsigned + NonZero,
    Ur: Unsigned + NonZero
[src]

The type of the maximum of Self and Rhs

Method returning the maximum

impl<Ul, Ur> Max<NInt<Ur>> for PInt<Ul> where
    Ul: Unsigned + NonZero,
    Ur: Unsigned + NonZero
[src]

The type of the maximum of Self and Rhs

Method returning the maximum

impl<Ul, Ur> Max<NInt<Ur>> for NInt<Ul> where
    Ul: Unsigned + NonZero + Min<Ur>,
    Ur: Unsigned + NonZero,
    Minimum<Ul, Ur>: Unsigned + NonZero
[src]

The type of the maximum of Self and Rhs

Method returning the maximum

impl<U: Unsigned + NonZero> Abs for NInt<U>
[src]

The absolute value.

impl<U> Mul<ATerm> for NInt<U> where
    U: Unsigned + NonZero
[src]

The resulting type after applying the * operator.

Performs the * operation.

impl<V, A, U> Mul<TArr<V, A>> for NInt<U> where
    U: Unsigned + NonZero,
    NInt<U>: Mul<A> + Mul<V>, 
[src]

The resulting type after applying the * operator.

Performs the * operation.

Auto Trait Implementations

impl<U> Send for NInt<U> where
    U: Send

impl<U> Sync for NInt<U> where
    U: Sync