Struct typenum::int::PInt[][src]

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

Type-level signed integers with positive sign.

Methods

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

Instantiates a singleton representing this strictly positive integer.

Trait Implementations

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

impl<U: PartialEq + Unsigned + NonZero> PartialEq for PInt<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 PInt<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 PInt<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 PInt<U>
[src]

Returns a copy of the value. Read more

Performs copy-assignment from source. Read more

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

impl<U: Hash + Unsigned + NonZero> Hash for PInt<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 PInt<U>
[src]

Formats the value using the given formatter. Read more

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

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

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

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

impl<U: Unsigned + NonZero> Integer for PInt<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 PInt<U>
[src]

-PInt = NInt

The resulting type after applying the - operator.

Performs the unary - operation.

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

PInt + Z0 = PInt

The resulting type after applying the + operator.

Performs the + operation.

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

P(Ul) + P(Ur) = P(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<PInt<U>> for Z0
[src]

Z0 - P = N

The resulting type after applying the - operator.

Performs the - operation.

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

PInt - Z0 = PInt

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<PInt<Ur>> for PInt<Ul> where
    Ul: Cmp<Ur> + PrivateIntegerAdd<<Ul as Cmp<Ur>>::Output, Ur>, 
[src]

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

The resulting type after applying the - operator.

Performs the - operation.

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

P * Z0 = Z0

The resulting type after applying the * operator.

Performs the * operation.

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

P(Ul) * P(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<PInt<Ur>> for PInt<Ul> where
    Ul: Cmp<Ur>,
    PInt<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 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<U: Unsigned + NonZero> Cmp<PInt<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 PInt<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<Pl: Cmp<Pr> + Unsigned + NonZero, Pr: Unsigned + NonZero> Cmp<PInt<Pr>> for PInt<Pl>
[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<PInt<Ur>> for PInt<Ul> where
    Ul: Rem<Ur>,
    PInt<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 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<U: Unsigned + NonZero> Pow<PInt<U>> for Z0
[src]

0^P = 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<Z0> for PInt<U>
[src]

P^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 + NonZero> Pow<PInt<Ur>> for PInt<Ul> where
    Ul: Pow<Ur>,
    <Ul as Pow<Ur>>::Output: Unsigned + NonZero
[src]

P(Ul)^P(Ur) = P(Ul^Ur)

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<PInt<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 PInt<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 PInt<Ul> where
    Ul: Unsigned + NonZero + Min<Ur>,
    Ur: Unsigned + NonZero,
    Minimum<Ul, Ur>: 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<U> Max<PInt<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 PInt<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 PInt<Ul> where
    Ul: Unsigned + NonZero + Max<Ur>,
    Ur: Unsigned + NonZero,
    Maximum<Ul, Ur>: 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<U: Unsigned + NonZero> Abs for PInt<U>
[src]

The absolute value.

impl<U: Unsigned + NonZero> Pow<PInt<U>> for f32
[src]

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<PInt<U>> for f64
[src]

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<PInt<U>> for u8
[src]

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<PInt<U>> for u16
[src]

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<PInt<U>> for u32
[src]

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<PInt<U>> for u64
[src]

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<PInt<U>> for usize
[src]

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<PInt<U>> for i8
[src]

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<PInt<U>> for i16
[src]

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<PInt<U>> for i32
[src]

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<PInt<U>> for i64
[src]

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<PInt<U>> for isize
[src]

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> Mul<ATerm> for PInt<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 PInt<U> where
    U: Unsigned + NonZero,
    PInt<U>: Mul<A> + Mul<V>, 
[src]

The resulting type after applying the * operator.

Performs the * operation.

Auto Trait Implementations

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

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