@mikrojs/eslint-plugin 0.8.0 → 0.9.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/index.d.ts +3 -0
- package/dist/index.js +3 -0
- package/dist/index.js.map +1 -1
- package/dist/rules/no-bigint.d.ts +4 -0
- package/dist/rules/no-bigint.js +27 -0
- package/dist/rules/no-bigint.js.map +1 -0
- package/dist/rules/no-bigint.test.d.ts +1 -0
- package/dist/rules/no-bigint.test.js +43 -0
- package/dist/rules/no-bigint.test.js.map +1 -0
- package/package.json +1 -1
package/dist/index.d.ts
CHANGED
|
@@ -25,6 +25,9 @@ declare const plugin: {
|
|
|
25
25
|
'no-intl': import("@typescript-eslint/utils/ts-eslint").RuleModule<"noIntl", [], unknown, import("@typescript-eslint/utils/ts-eslint").RuleListener> & {
|
|
26
26
|
name: string;
|
|
27
27
|
};
|
|
28
|
+
'no-bigint': import("@typescript-eslint/utils/ts-eslint").RuleModule<"noBigInt", [], unknown, import("@typescript-eslint/utils/ts-eslint").RuleListener> & {
|
|
29
|
+
name: string;
|
|
30
|
+
};
|
|
28
31
|
'no-temporal': import("@typescript-eslint/utils/ts-eslint").RuleModule<"noTemporal", [], unknown, import("@typescript-eslint/utils/ts-eslint").RuleListener> & {
|
|
29
32
|
name: string;
|
|
30
33
|
};
|
package/dist/index.js
CHANGED
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
import { noBigInt } from './rules/no-bigint.js';
|
|
1
2
|
import { noDeviceImportsInConfig } from './rules/no-device-imports-in-config.js';
|
|
2
3
|
import { noDotCatch } from './rules/no-dot-catch.js';
|
|
3
4
|
import { noEval } from './rules/no-eval.js';
|
|
@@ -21,6 +22,7 @@ const plugin = {
|
|
|
21
22
|
'no-dot-catch': noDotCatch,
|
|
22
23
|
'no-eval': noEval,
|
|
23
24
|
'no-intl': noIntl,
|
|
25
|
+
'no-bigint': noBigInt,
|
|
24
26
|
'no-temporal': noTemporal,
|
|
25
27
|
'no-sparse-arrays': noSparseArrays,
|
|
26
28
|
'no-device-imports-in-config': noDeviceImportsInConfig,
|
|
@@ -45,6 +47,7 @@ Object.assign(plugin.configs, {
|
|
|
45
47
|
'@mikrojs/no-dot-catch': 'error',
|
|
46
48
|
'@mikrojs/no-eval': 'error',
|
|
47
49
|
'@mikrojs/no-intl': 'error',
|
|
50
|
+
'@mikrojs/no-bigint': 'error',
|
|
48
51
|
'@mikrojs/no-temporal': 'error',
|
|
49
52
|
'@mikrojs/no-sparse-arrays': 'warn',
|
|
50
53
|
'@mikrojs/no-device-imports-in-config': 'error',
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,uBAAuB,EAAC,MAAM,wCAAwC,CAAA;AAC9E,OAAO,EAAC,UAAU,EAAC,MAAM,yBAAyB,CAAA;AAClD,OAAO,EAAC,MAAM,EAAC,MAAM,oBAAoB,CAAA;AACzC,OAAO,EAAC,MAAM,EAAC,MAAM,oBAAoB,CAAA;AACzC,OAAO,EAAC,eAAe,EAAC,MAAM,8BAA8B,CAAA;AAC5D,OAAO,EAAC,cAAc,EAAC,MAAM,6BAA6B,CAAA;AAC1D,OAAO,EAAC,UAAU,EAAC,MAAM,wBAAwB,CAAA;AACjD,OAAO,EAAC,OAAO,EAAC,MAAM,qBAAqB,CAAA;AAC3C,OAAO,EAAC,UAAU,EAAC,MAAM,yBAAyB,CAAA;AAClD,OAAO,EAAC,iBAAiB,EAAC,MAAM,gCAAgC,CAAA;AAEhE,MAAM,MAAM,GAAG;IACb,IAAI,EAAE;QACJ,IAAI,EAAE,wBAAwB;QAC9B,OAAO,EAAE,OAAO;KACjB;IACD,KAAK,EAAE;QACL,qBAAqB,EAAE,iBAAiB;QACxC,UAAU,EAAE,OAAO;QACnB,cAAc,EAAE,UAAU;QAC1B,mBAAmB,EAAE,eAAe;QACpC,cAAc,EAAE,UAAU;QAC1B,SAAS,EAAE,MAAM;QACjB,SAAS,EAAE,MAAM;QACjB,aAAa,EAAE,UAAU;QACzB,kBAAkB,EAAE,cAAc;QAClC,6BAA6B,EAAE,uBAAuB;KACvD;IACD,OAAO,EAAE,EAA+B;CACzC,CAAA;AAED,yDAAyD;AACzD,0EAA0E;AAC1E,yDAAyD;AACzD,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,OAAO,EAAE;IAC5B,WAAW,EAAE;QACX;YACE,KAAK,EAAE,CAAC,SAAS,EAAE,UAAU,CAAC;YAC9B,OAAO,EAAE;gBACP,UAAU,EAAE,MAAM;aACnB;YACD,KAAK,EAAE;gBACL,8BAA8B,EAAE,OAAO;gBACvC,mBAAmB,EAAE,OAAO;gBAC5B,uBAAuB,EAAE,OAAO;gBAChC,4BAA4B,EAAE,OAAO;gBACrC,uBAAuB,EAAE,OAAO;gBAChC,kBAAkB,EAAE,OAAO;gBAC3B,kBAAkB,EAAE,OAAO;gBAC3B,sBAAsB,EAAE,OAAO;gBAC/B,2BAA2B,EAAE,MAAM;gBACnC,sCAAsC,EAAE,OAAO;aAChD;SACF;KACF;CACF,CAAC,CAAA;AAEF,eAAe,MAAM,CAAA"}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,QAAQ,EAAC,MAAM,sBAAsB,CAAA;AAC7C,OAAO,EAAC,uBAAuB,EAAC,MAAM,wCAAwC,CAAA;AAC9E,OAAO,EAAC,UAAU,EAAC,MAAM,yBAAyB,CAAA;AAClD,OAAO,EAAC,MAAM,EAAC,MAAM,oBAAoB,CAAA;AACzC,OAAO,EAAC,MAAM,EAAC,MAAM,oBAAoB,CAAA;AACzC,OAAO,EAAC,eAAe,EAAC,MAAM,8BAA8B,CAAA;AAC5D,OAAO,EAAC,cAAc,EAAC,MAAM,6BAA6B,CAAA;AAC1D,OAAO,EAAC,UAAU,EAAC,MAAM,wBAAwB,CAAA;AACjD,OAAO,EAAC,OAAO,EAAC,MAAM,qBAAqB,CAAA;AAC3C,OAAO,EAAC,UAAU,EAAC,MAAM,yBAAyB,CAAA;AAClD,OAAO,EAAC,iBAAiB,EAAC,MAAM,gCAAgC,CAAA;AAEhE,MAAM,MAAM,GAAG;IACb,IAAI,EAAE;QACJ,IAAI,EAAE,wBAAwB;QAC9B,OAAO,EAAE,OAAO;KACjB;IACD,KAAK,EAAE;QACL,qBAAqB,EAAE,iBAAiB;QACxC,UAAU,EAAE,OAAO;QACnB,cAAc,EAAE,UAAU;QAC1B,mBAAmB,EAAE,eAAe;QACpC,cAAc,EAAE,UAAU;QAC1B,SAAS,EAAE,MAAM;QACjB,SAAS,EAAE,MAAM;QACjB,WAAW,EAAE,QAAQ;QACrB,aAAa,EAAE,UAAU;QACzB,kBAAkB,EAAE,cAAc;QAClC,6BAA6B,EAAE,uBAAuB;KACvD;IACD,OAAO,EAAE,EAA+B;CACzC,CAAA;AAED,yDAAyD;AACzD,0EAA0E;AAC1E,yDAAyD;AACzD,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,OAAO,EAAE;IAC5B,WAAW,EAAE;QACX;YACE,KAAK,EAAE,CAAC,SAAS,EAAE,UAAU,CAAC;YAC9B,OAAO,EAAE;gBACP,UAAU,EAAE,MAAM;aACnB;YACD,KAAK,EAAE;gBACL,8BAA8B,EAAE,OAAO;gBACvC,mBAAmB,EAAE,OAAO;gBAC5B,uBAAuB,EAAE,OAAO;gBAChC,4BAA4B,EAAE,OAAO;gBACrC,uBAAuB,EAAE,OAAO;gBAChC,kBAAkB,EAAE,OAAO;gBAC3B,kBAAkB,EAAE,OAAO;gBAC3B,oBAAoB,EAAE,OAAO;gBAC7B,sBAAsB,EAAE,OAAO;gBAC/B,2BAA2B,EAAE,MAAM;gBACnC,sCAAsC,EAAE,OAAO;aAChD;SACF;KACF;CACF,CAAC,CAAA;AAEF,eAAe,MAAM,CAAA"}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import { ESLintUtils } from '@typescript-eslint/utils';
|
|
2
|
+
const createRule = ESLintUtils.RuleCreator((name) => `https://github.com/mikrojs/mikrojs/blob/main/docs/rules/${name}.md`);
|
|
3
|
+
export const noBigInt = createRule({
|
|
4
|
+
name: 'no-bigint',
|
|
5
|
+
meta: {
|
|
6
|
+
type: 'problem',
|
|
7
|
+
docs: {
|
|
8
|
+
description: 'Disallow use of BigInt. The mikrojs runtime omits the BigInt intrinsic to save memory, so it is not available at runtime.',
|
|
9
|
+
},
|
|
10
|
+
messages: {
|
|
11
|
+
noBigInt: 'BigInt is not available in the mikrojs runtime. Use Number, typed arrays, or string-based math instead.',
|
|
12
|
+
},
|
|
13
|
+
schema: [],
|
|
14
|
+
},
|
|
15
|
+
defaultOptions: [],
|
|
16
|
+
create(context) {
|
|
17
|
+
const report = (node) => context.report({ node, messageId: 'noBigInt' });
|
|
18
|
+
return {
|
|
19
|
+
'Literal[bigint]': report,
|
|
20
|
+
'CallExpression[callee.name="BigInt"]': report,
|
|
21
|
+
'MemberExpression[object.name="BigInt"]': report,
|
|
22
|
+
'NewExpression[callee.name=/^Big(Int|Uint)64Array$/]': report,
|
|
23
|
+
'MemberExpression[object.name=/^Big(Int|Uint)64Array$/]': report,
|
|
24
|
+
};
|
|
25
|
+
},
|
|
26
|
+
});
|
|
27
|
+
//# sourceMappingURL=no-bigint.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"no-bigint.js","sourceRoot":"","sources":["../../src/rules/no-bigint.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,WAAW,EAAgB,MAAM,0BAA0B,CAAA;AAEnE,MAAM,UAAU,GAAG,WAAW,CAAC,WAAW,CACxC,CAAC,IAAI,EAAE,EAAE,CAAC,2DAA2D,IAAI,KAAK,CAC/E,CAAA;AAED,MAAM,CAAC,MAAM,QAAQ,GAAG,UAAU,CAAC;IACjC,IAAI,EAAE,WAAW;IACjB,IAAI,EAAE;QACJ,IAAI,EAAE,SAAS;QACf,IAAI,EAAE;YACJ,WAAW,EACT,2HAA2H;SAC9H;QACD,QAAQ,EAAE;YACR,QAAQ,EACN,yGAAyG;SAC5G;QACD,MAAM,EAAE,EAAE;KACX;IACD,cAAc,EAAE,EAAE;IAClB,MAAM,CAAC,OAAO;QACZ,MAAM,MAAM,GAAG,CAAC,IAAmB,EAAE,EAAE,CAAC,OAAO,CAAC,MAAM,CAAC,EAAC,IAAI,EAAE,SAAS,EAAE,UAAU,EAAC,CAAC,CAAA;QACrF,OAAO;YACL,iBAAiB,EAAE,MAAM;YACzB,sCAAsC,EAAE,MAAM;YAC9C,wCAAwC,EAAE,MAAM;YAChD,qDAAqD,EAAE,MAAM;YAC7D,wDAAwD,EAAE,MAAM;SACjE,CAAA;IACH,CAAC;CACF,CAAC,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
import { RuleTester } from '@typescript-eslint/rule-tester';
|
|
2
|
+
import { afterAll, describe, it } from 'vitest';
|
|
3
|
+
import { noBigInt } from './no-bigint.js';
|
|
4
|
+
RuleTester.afterAll = afterAll;
|
|
5
|
+
RuleTester.describe = describe;
|
|
6
|
+
RuleTester.it = it;
|
|
7
|
+
const ruleTester = new RuleTester();
|
|
8
|
+
ruleTester.run('no-bigint', noBigInt, {
|
|
9
|
+
valid: [
|
|
10
|
+
'const n = 42',
|
|
11
|
+
'Number.MAX_SAFE_INTEGER',
|
|
12
|
+
'new Int32Array(1)',
|
|
13
|
+
'const obj = {BigInt: 1}',
|
|
14
|
+
'foo.BigInt',
|
|
15
|
+
],
|
|
16
|
+
invalid: [
|
|
17
|
+
{
|
|
18
|
+
code: 'const n = 123n',
|
|
19
|
+
errors: [{ messageId: 'noBigInt' }],
|
|
20
|
+
},
|
|
21
|
+
{
|
|
22
|
+
code: 'const n = BigInt(5)',
|
|
23
|
+
errors: [{ messageId: 'noBigInt' }],
|
|
24
|
+
},
|
|
25
|
+
{
|
|
26
|
+
code: 'BigInt.asIntN(64, 1n)',
|
|
27
|
+
errors: [{ messageId: 'noBigInt' }, { messageId: 'noBigInt' }],
|
|
28
|
+
},
|
|
29
|
+
{
|
|
30
|
+
code: 'new BigInt64Array(1)',
|
|
31
|
+
errors: [{ messageId: 'noBigInt' }],
|
|
32
|
+
},
|
|
33
|
+
{
|
|
34
|
+
code: 'new BigUint64Array(1)',
|
|
35
|
+
errors: [{ messageId: 'noBigInt' }],
|
|
36
|
+
},
|
|
37
|
+
{
|
|
38
|
+
code: 'BigInt64Array.from([])',
|
|
39
|
+
errors: [{ messageId: 'noBigInt' }],
|
|
40
|
+
},
|
|
41
|
+
],
|
|
42
|
+
});
|
|
43
|
+
//# sourceMappingURL=no-bigint.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"no-bigint.test.js","sourceRoot":"","sources":["../../src/rules/no-bigint.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,UAAU,EAAC,MAAM,gCAAgC,CAAA;AACzD,OAAO,EAAC,QAAQ,EAAE,QAAQ,EAAE,EAAE,EAAC,MAAM,QAAQ,CAAA;AAE7C,OAAO,EAAC,QAAQ,EAAC,MAAM,gBAAgB,CAAA;AAEvC,UAAU,CAAC,QAAQ,GAAG,QAAQ,CAAA;AAC9B,UAAU,CAAC,QAAQ,GAAG,QAAQ,CAAA;AAC9B,UAAU,CAAC,EAAE,GAAG,EAAE,CAAA;AAElB,MAAM,UAAU,GAAG,IAAI,UAAU,EAAE,CAAA;AAEnC,UAAU,CAAC,GAAG,CAAC,WAAW,EAAE,QAAQ,EAAE;IACpC,KAAK,EAAE;QACL,cAAc;QACd,yBAAyB;QACzB,mBAAmB;QACnB,yBAAyB;QACzB,YAAY;KACb;IACD,OAAO,EAAE;QACP;YACE,IAAI,EAAE,gBAAgB;YACtB,MAAM,EAAE,CAAC,EAAC,SAAS,EAAE,UAAU,EAAC,CAAC;SAClC;QACD;YACE,IAAI,EAAE,qBAAqB;YAC3B,MAAM,EAAE,CAAC,EAAC,SAAS,EAAE,UAAU,EAAC,CAAC;SAClC;QACD;YACE,IAAI,EAAE,uBAAuB;YAC7B,MAAM,EAAE,CAAC,EAAC,SAAS,EAAE,UAAU,EAAC,EAAE,EAAC,SAAS,EAAE,UAAU,EAAC,CAAC;SAC3D;QACD;YACE,IAAI,EAAE,sBAAsB;YAC5B,MAAM,EAAE,CAAC,EAAC,SAAS,EAAE,UAAU,EAAC,CAAC;SAClC;QACD;YACE,IAAI,EAAE,uBAAuB;YAC7B,MAAM,EAAE,CAAC,EAAC,SAAS,EAAE,UAAU,EAAC,CAAC;SAClC;QACD;YACE,IAAI,EAAE,wBAAwB;YAC9B,MAAM,EAAE,CAAC,EAAC,SAAS,EAAE,UAAU,EAAC,CAAC;SAClC;KACF;CACF,CAAC,CAAA"}
|