-
-
Notifications
You must be signed in to change notification settings - Fork 7
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
feat: Add sort-keys rule #76
base: main
Are you sure you want to change the base?
Conversation
2c210e9
to
d651aae
Compare
package.json
Outdated
@@ -83,6 +83,9 @@ | |||
"typescript": "^5.4.5", | |||
"yorkie": "^2.0.0" | |||
}, | |||
"peerDependencies": { | |||
"natural-compare": "*" |
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.
I hate to add a dependency, but since natural-compare
is already a dependency of ESLint then I hope this is OK.
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.
I believe we should use natural-compare
to maintain consistency with other sorting rules that rely on it across the ESLint plugins. Just to give you some context to consider: azat-io/eslint-plugin-perfectionist#375 (given that natural-compare
hasn’t been updated in nearly 10 years), but the sorting wouldn't be exactly the same (azat-io/eslint-plugin-perfectionist#384).
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.
It's fine to use this package. Let's move in to dependencies
instead of peerDependencies
.
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.
@nzakas Should it be pegged to a specific version? I used peerDependencies
and no specific version since natural-compare
is a dependency of eslint
here, and eslint
will presumably always be installed alongside eslint/json
, so presumably we would want to defer to whatever version of natural-compare
is required by eslint
?
Although I notice eslint
is a devDependency
of eslint/json
and not a dependency
here, so maybe that's not correct...?
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.
Added more tests for nesting: 3c1270a
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.
I also think this should be added to dependencies
.
"dependencies": {
"@eslint/plugin-kit": "^0.2.3",
"@humanwhocodes/momoa": "^3.3.4",
+ "natural-compare": "^1.4.0"
},
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.
Done! a1328df
src/rules/sort-keys.js
Outdated
}, | ||
|
||
create(context) { | ||
const [directionShort, { caseSensitive, natural, minKeys }] = |
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.
allowLineSeparatedGroups
not implemented?
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.
Oops, I added the logic for it, but forgot to add in the option. It's odd that all the tests pass without it. Will look into that today. Thanks!
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.
Updated
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.
Overall this looks good. I left some comments to clean things up.
Also, please add the rule to the rules list in README.md
.
package.json
Outdated
@@ -83,6 +83,9 @@ | |||
"typescript": "^5.4.5", | |||
"yorkie": "^2.0.0" | |||
}, | |||
"peerDependencies": { | |||
"natural-compare": "*" |
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.
It's fine to use this package. Let's move in to dependencies
instead of peerDependencies
.
tests/rules/sort-keys.test.js
Outdated
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.
Please add some additional tests here:
- When using
json/jsonc
language, please add some tests that use identifier keys instead of string keys. (For example,{ a: true, b: false, _: "foo" }
.) - When using
json/jsonc
language, please add some tests that mix identifier keys and string keys in the same object. (For example,{ a: true, "b": false, _: "foo" }
.) - Please add some tests with nested objects. (For example,
[{ a: true, b: false}, { c: true, d: false }]
and{ a: { b: true }, c: false }
.
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.
As written, eslint/json
still requires JSONC files to have string keys I think? When specifying language: "json/jsonc"
the parser fails with Parsing error: Unexpected character
on {foo: "bar"}
but correctly parses {"foo": "bar"}
.
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.
Oh, are we talking about json/json5
? That makes sense, I'll add tests for that.
Think I addressed all feedback. Thanks! |
7d9916f
to
69211e8
Compare
src/rules/sort-keys.js
Outdated
commentLines.has(`${prevLine}:${thisLine}`) || | ||
commentLines.has(`${prevLine + 1}:${thisLine}`) || | ||
commentLines.has(`${prevLine}:${thisLine - 1}`) || | ||
commentLines.has(`${prevLine + 1}:${thisLine - 1}`); |
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.
This looks like a false negative:
/* eslint json/sort-keys: ["error", "asc", { "allowLineSeparatedGroups": true }] */
{
"b": 1,
// some multiline comment
// using line comment style
"a": 2 // false negative, "a" and "b" are not line separated
}
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.
Another one:
/* eslint json/sort-keys: ["error", "asc", { "allowLineSeparatedGroups": true }] */
{
"b": 1
,
"a": 2 // false negative, "a" and "b" are not line separated
}
I think we need to check if there's a blank line between the members (context.sourceCode.lines
returns all lines), skipping lines with comments.
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.
Great catch! I'll chew on this and post a fix.
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.
@mdjermanovic Updated! 337dd83
Co-authored-by: Nicholas C. Zakas <[email protected]>
0e6aac4
to
337dd83
Compare
Prerequisites checklist
What is the purpose of this pull request?
Adds a
sort-keys
rule for JSON that mimics the functionality of the existingsort-keys
for JS.What changes did you make? (Give an overview)
Added a
sort-keys
rule and tests.Related Issues
Fixes #75
Is there anything you'd like reviewers to focus on?
I started by copying over the existing code for JS
sort-keys
, but it required some big modifications in order to work on JSON. It would be nice if there was an automated way to make sure thissort-keys
maintains parity with thatsort-keys
to keep things consistent across ESLint packages, but JS and JSON are different enough that I'm not sure how it could be done.json/tests/rules/sort-keys.test.js
Line 2 in 7fe2782
Note that I added a TODO for how comments affect line-separated groups