-
-
Notifications
You must be signed in to change notification settings - Fork 43
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
fix!: mixed-esm-and-cjs
should only add the deviating type aside from base
#300
base: master
Are you sure you want to change the base?
Conversation
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Can you explain a bit what problem you encountered?
I think it's currently working as expected - type: module
means *.js
is an esm, but
we cannot tell *.ts
is or not.
and it's a breaking change. :)
mixed-esm-and-cjs
should only add the deviating type aside from basemixed-esm-and-cjs
should only add the deviating type aside from base
My first problem was that I used I then opted for Maybe I'm thinking wrong, but my impression was that Maybe we should add a new |
So if I understand you correctly, you want to use this plugin in a ts project? in the new config, by default, eslint only lints files that match the patterns **/.js, **/.cjs, and **/*.mjs: https://eslint.org/docs/latest/use/configure/configuration-files#specifying-files-and-ignores. to lint ts, you will need to specify files, something like: import pluginNode from "eslint-plugin-n";
export default [
...pluginNode.configs["flat/mixed-esm-and-cjs"],
{files: ["**/*.ts"], pluginNode.configs["flat/recommended-module"]}, // if you are writing esm in ts files
] |
no no, sorry do ignore my This is just about only doing We know that we don't need to support some rules on some files, this just makes that specific. |
@scagood it's still not clear to me why the config does not work for you. it seems working as you expected: { files: ["**/*.js"], ...recommendedConfig.flat }, // => it's depended on the pkg.type
{ files: ["**/*.mjs"], ...esmConfig.flat }, // recommended-module
{ files: ["**/*.cjs"], ...cjsConfig.flat }, // recommended-script or can you create an example to illustrate? |
no, you're right! |
Two things: Firstly, it duplicates an entire ruleset, since this: { files: ["**/*.js"], ...recommendedConfig.flat }, // => it's depended on the pkg.type
{ files: ["**/*.mjs"], ...esmConfig.flat }, // recommended-module
{ files: ["**/*.cjs"], ...cjsConfig.flat }, // recommended-script Is equivalent to this: {
files: ["**/*.js", recommendedConfig.isModule ? "**/*.mjs" : "**/*cjs"],
...recommendedConfig.flat
},
recommendedConfig.isModule
? { files: ["**/*.cjs"], ...cjsConfig.flat }
: { files: ["**/*.mjs"], ...esmConfig.flat }, (Screenshots from the config inspector) Secondly, the docs also say:
If I modify the above to become this: { files: ['*.jsx'] },
recommendedConfig.flat, // has no files-key
{ files: ["**/*.js"], ...recommendedConfig.flat }, // => it's depended on the pkg.type
{ files: ["**/*.mjs"], ...esmConfig.flat }, // recommended-module
{ files: ["**/*.cjs"], ...cjsConfig.flat }, // recommended-script Then for a The yellow border means that the config directly included the file, no yellow border the config is because its a general config. For a The plain I think this is the way to set up flat configs: [
{ files: ['*.jsx'] },
...pluginNode.configs["flat/mixed-esm-and-cjs"],
unicornPlugin.configs['flat/recommended'],
securityPlugin.configs.recommended,
] Not this: [
...pluginNode.configs["flat/mixed-esm-and-cjs"],
unicornPlugin.configs['flat/recommended'],
securityPlugin.configs.recommended,
{ files: ["**/*.jsx"], ...pluginNode.configs["flat/recommended-module"] },
{ files: ["**/*.jsx"], ...unicornPlugin.configs['flat/recommended'] },
{ files: ["**/*.jsx"], ...securityPlugin.configs.recommended },
] |
well, I got the point, so we are on the same page now. :) I'm 100% agree to the 1st point.
I'm not fully convinced about the second point. The new config format offers users flexibility in organizing their configurations, and I don't want to force a specific approach on them. Regarding the exported config:
|
It's the current approach that are forcing a specific approach, by actively limiting itself to specific file extensions rather than behaving like ESLint itself does and only specify file extensions for the exceptions from the default |
I'm a bit hesitant about this change: on the one hand it facilitates the use of scenarios like the ones you propose; on the other hand it could also accidently lead to wrong configurations being applied to these files: for example, cjs configs applied to ts written with esm, and even non-js files could apply configs specific to js. As eslint is introducing a new concept |
This is the default config that ESLint itself prepends to all configs: https://github.com/eslint/eslint/blob/21d3766c3f4efd981d3cc294c2c82c8014815e6e/lib/config/default-config.js#L66-L69 I think mimicking what they do would be desirable |
I am starting to lean towards just removing all parser/langauge options from the published configs. The one slight exception here (that I am tossing up in my head) are the global variables and node scope. That being said, the globals that we currently support (lib/configs/recommended-module.js:16) are a far cry from what node supports (lib/unsupported-features/node-globals.js:30) I think we may be going about this the wrong way. I am not sure we should have different rules for eg: Is there something I am missing in regards to why we dont do this? In the longer term it may be better to simply merge the seperated rules together and publish one recomended config, (and one legacy config) In the shorter term I think this is a fine approach given what we have. |
Yes, if this would be possible, then agree
Agree, especially since the only difference between the two is only three things: Source type: < "sourceType": "commonjs",
---
> "sourceType": "module", Globals: 6,7c6,7
< "__dirname": "readonly",
< "__filename": "readonly",
---
> "__dirname": "off",
> "__filename": "off",
30c30
< "exports": "writable",
---
> "exports": "off",
40c40
< "module": "readonly",
---
> "module": "off",
60c60
< "require": "readonly",
---
> "require": "off",
157c157,159
< "ignores": []
---
> "ignores": [
> "modules"
> ] |
Digging further into this: Out of those globals that are defined: The |
Took some ideas from neostandard/neostandard#130 as well and made an update that exposes a new {
name: "node/recommended",
rules: commonRules,
}, Also adds a new name for Unfortunately its very breaking to replace |
This avoids specifying
**/*.js
and makes the base apply to all files that the main config at large is matching, with only deviating type added for either**/.mjs
or**/*.cjs
This ensures that the rules still match eg.
*.ts
,*.jsx
etc if the main config does