astro-ghostcms/.pnpm-store/v3/files/0c/b2c64f4d90cec9ee72167d7f3af...

120 lines
3.4 KiB
Plaintext
Raw Normal View History

2024-02-14 14:10:47 +00:00
---
description: 'Disallow magic numbers.'
---
> 🛑 This file is source code, not the primary documentation location! 🛑
>
> See **https://typescript-eslint.io/rules/no-magic-numbers** for documentation.
This rule extends the base [`eslint/no-magic-numbers`](https://eslint.org/docs/rules/no-magic-numbers) rule.
It adds support for:
- numeric literal types (`type T = 1`),
- `enum` members (`enum Foo { bar = 1 }`),
- `readonly` class properties (`class Foo { readonly bar = 1 }`).
## Options
This rule adds the following options:
```ts
interface Options extends BaseNoMagicNumbersOptions {
ignoreEnums?: boolean;
ignoreNumericLiteralTypes?: boolean;
ignoreReadonlyClassProperties?: boolean;
ignoreTypeIndexes?: boolean;
}
const defaultOptions: Options = {
...baseNoMagicNumbersDefaultOptions,
ignoreEnums: false,
ignoreNumericLiteralTypes: false,
ignoreReadonlyClassProperties: false,
ignoreTypeIndexes: false,
};
```
### `ignoreEnums`
A boolean to specify if enums used in TypeScript are considered okay. `false` by default.
Examples of **incorrect** code for the `{ "ignoreEnums": false }` option:
```ts option='{ "ignoreEnums": false }' showPlaygroundButton
enum foo {
SECOND = 1000,
}
```
Examples of **correct** code for the `{ "ignoreEnums": true }` option:
```ts option='{ "ignoreEnums": true }' showPlaygroundButton
enum foo {
SECOND = 1000,
}
```
### `ignoreNumericLiteralTypes`
A boolean to specify if numbers used in TypeScript numeric literal types are considered okay. `false` by default.
Examples of **incorrect** code for the `{ "ignoreNumericLiteralTypes": false }` option:
```ts option='{ "ignoreNumericLiteralTypes": false }' showPlaygroundButton
type SmallPrimes = 2 | 3 | 5 | 7 | 11;
```
Examples of **correct** code for the `{ "ignoreNumericLiteralTypes": true }` option:
```ts option='{ "ignoreNumericLiteralTypes": true }' showPlaygroundButton
type SmallPrimes = 2 | 3 | 5 | 7 | 11;
```
### `ignoreReadonlyClassProperties`
Examples of **incorrect** code for the `{ "ignoreReadonlyClassProperties": false }` option:
```ts option='{ "ignoreReadonlyClassProperties": false }' showPlaygroundButton
class Foo {
readonly A = 1;
readonly B = 2;
public static readonly C = 1;
static readonly D = 1;
}
```
Examples of **correct** code for the `{ "ignoreReadonlyClassProperties": true }` option:
```ts option='{ "ignoreReadonlyClassProperties": true }' showPlaygroundButton
class Foo {
readonly A = 1;
readonly B = 2;
public static readonly C = 1;
static readonly D = 1;
}
```
### `ignoreTypeIndexes`
A boolean to specify if numbers used to index types are okay. `false` by default.
Examples of **incorrect** code for the `{ "ignoreTypeIndexes": false }` option:
```ts option='{ "ignoreTypeIndexes": false }' showPlaygroundButton
type Foo = Bar[0];
type Baz = Parameters<Foo>[2];
```
Examples of **correct** code for the `{ "ignoreTypeIndexes": true }` option:
```ts option='{ "ignoreTypeIndexes": true }' showPlaygroundButton
type Foo = Bar[0];
type Baz = Parameters<Foo>[2];
```
## When Not To Use It
If your project frequently deals with constant numbers and you don't wish to take up extra space to declare them, this rule might not be for you.
We recommend at least using descriptive comments and/or names to describe constants.
You might consider using [ESLint disable comments](https://eslint.org/docs/latest/use/configure/rules#using-configuration-comments-1) instead of completely disabling this rule.