Sha256: 521f9f4dd927972ed9867e3eb2f0dd6990151f9edbb608ce59911864a9a2712d

Contents?: true

Size: 1.05 KB

Versions: 28

Compression:

Stored size: 1.05 KB

Contents

import type {Not} from './internal';
import type {IsFloat} from './is-float';
import type {PositiveInfinity, NegativeInfinity} from './numeric';

/**
Returns a boolean for whether the given number is a integer, like `-5`, `1.0` or `100`.

Like [`Number#IsInteger()`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Number/IsInteger) but for types.

Use-case:
- If you want to make a conditional branch based on the result of whether a number is a intrger or not.

@example
```
type Integer = IsInteger<1>;
//=> true

type IntegerWithDecimal = IsInteger<1.0>;
//=> true

type NegativeInteger = IsInteger<-1>;
//=> true

type Float = IsInteger<1.5>;
//=> false

// Supports non-decimal numbers

type OctalInteger: IsInteger<0o10>;
//=> true

type BinaryInteger: IsInteger<0b10>;
//=> true

type HexadecimalInteger: IsInteger<0x10>;
//=> true
```
*/
export type IsInteger<T> =
T extends bigint
	? true
	: T extends number
		? number extends T
			? false
			: T extends PositiveInfinity | NegativeInfinity
				? false
				: Not<IsFloat<T>>
		: false;

Version data entries

28 entries across 28 versions & 2 rubygems

Version Path
clapton-0.0.26 lib/clapton/javascripts/node_modules/type-fest/source/is-integer.d.ts
clapton-0.0.25 lib/clapton/javascripts/node_modules/type-fest/source/is-integer.d.ts
clapton-0.0.24 lib/clapton/javascripts/node_modules/type-fest/source/is-integer.d.ts
clapton-0.0.23 lib/clapton/javascripts/node_modules/type-fest/source/is-integer.d.ts
clapton-0.0.22 lib/clapton/javascripts/node_modules/type-fest/source/is-integer.d.ts
clapton-0.0.21 lib/clapton/javascripts/node_modules/type-fest/source/is-integer.d.ts
clapton-0.0.20 lib/clapton/javascripts/node_modules/type-fest/source/is-integer.d.ts
clapton-0.0.19 lib/clapton/javascripts/node_modules/type-fest/source/is-integer.d.ts
clapton-0.0.18 lib/clapton/javascripts/node_modules/type-fest/source/is-integer.d.ts
clapton-0.0.17 lib/clapton/javascripts/node_modules/type-fest/source/is-integer.d.ts
clapton-0.0.16 lib/clapton/javascripts/node_modules/type-fest/source/is-integer.d.ts
clapton-0.0.15 lib/clapton/javascripts/node_modules/type-fest/source/is-integer.d.ts
clapton-0.0.14 lib/clapton/javascripts/node_modules/type-fest/source/is-integer.d.ts
clapton-0.0.13 lib/clapton/javascripts/node_modules/type-fest/source/is-integer.d.ts
clapton-0.0.12 lib/clapton/javascripts/node_modules/type-fest/source/is-integer.d.ts
clapton-0.0.11 lib/clapton/javascripts/node_modules/type-fest/source/is-integer.d.ts
clapton-0.0.10 lib/clapton/javascripts/node_modules/type-fest/source/is-integer.d.ts
clapton-0.0.9 lib/clapton/javascripts/node_modules/type-fest/source/is-integer.d.ts
clapton-0.0.8 lib/clapton/javascripts/node_modules/type-fest/source/is-integer.d.ts
clapton-0.0.7 lib/clapton/javascripts/node_modules/type-fest/source/is-integer.d.ts