-
-
Notifications
You must be signed in to change notification settings - Fork 461
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
Linters integration discussion #922
Comments
While I understand that the removal is an inconvenience. There were many more issues than just the ESLint 6 issue. When looking at usage (in public repos at least), it looks like usage of As a temporary solution, you can install a specific version of the plugin https://code.visualstudio.com/updates/v1_30#_install-previous-versions I'm happy to have the discussion, but when I solicited feedback on this a few weeks ago very few people responded. I am also happy to accept a pull request that adds back this integration - but I would prefer that if we add it back that we also detect and handle the cases of invalid configurations (which can be many) and better warn the users of why it isn't working and provide docs on how to fix it. |
Can you come back prettier.eslintIntegration |
See my comment on #870. I am going to keep the existing behavior but mark it as deprecated. If the bugs are fixed in the downstream dependancies maybe we can keep it. If not, I will likely remove it in future versions. |
Given that this is a vscode plugin and not a build tool, does the dependency graph of I wonder if you would consider checking actual usage of the feature with this plugin. I haven't used it personally, but I think this would allow for that rather easily. Here are some other metrics that might be noteworthy:
All that said, I haven't had time to learn enough about the inner workings of eslint to help with this problem, so I fully understand the time constraints. I also realize that a lot of the concerns users have with this are outside the scope of this plugin, but IMO "inconvenience" is an understatement. There is no less-convenient workaround within the editor. It completely breaks the functionality for anyone with that checkbox on... |
@ehaynes99 Those stats aren't really deterministic or even related to this feature. This doesn't have anything to do with As mentioned in the above comment, I decided to not remove the linters for now, but rather mark them as deprecated. I am in the process of adding telemetry to determine usage. I suspect it is not that high, but I'll wait for the data. |
I'm not sure how that document -- which lists other ways to run prettier -- has to do with this plugin -- which runs prettier. I also don't see how it would be viewed as impractical to want a single editor command that formats code according to the project's formatting rules. Anyway, I didn't want to start an argument, just my $0.02 for discussion. I've loved being able to use both tools with this plugin. If it's heading away from that, though, fair enough. Thanks for the deprecation strategy. |
I do agree with you on there being some benefit about using a single tool and having simpler configuration, but I am also trying to weigh that against how much effort it is to support - and if it is really the best option. There have been a lot of changes to ESLint and VS Code over the last few years and in my opinion, you get the best setup by using both ESLint plugin and Prettier plugin with configs for both. Here is a good article on the type of setup I am recommending: https://dorshinar.me/linting-your-react+typescript-project-with-eslint-and-prettier I push out a version this morning with telemetry to track usage of TSLint, ESLint, and Stylelint. So far almost nobody is using stylelint, about 2% are using TSLint, and about 10% are using ESLint. Given that TSLint is being deprecated in favor of ESLint and Stylelint gets almost no usage I think those are strong candidates for removal. ESLint obviously is harder to say. If those numbers hold for all users of this extension then 10% is a fair number. I will wait a bit and see if those numbers hold over time before I make the final call. I would be interested in somebody who is passionate about the ESLint portion to help out with the project. If it is just me though, I am probably going to focus on other areas. |
First of all, thank you @ntotten for volunteering to help maintain prettier-vscode and your work so far :)
Sorry, I missed this the first time around :) Context: I'm a core maintainer of stylelint-prettier and eslint-plugin-prettier, while I technically have a commit bit on prettier-eslint I've not interacted with that project. I'd be interested in helping out if it would ensure the continued existence of this feature. Throwing a comment in here to back continuing to support prettier-eslint and prettier-stylelint. My biggest concern is that by removing this functionality we push the complexity of having to configure multiple auto formatters onto the end user. As it currently stands it is straightforward to say "autoformat everything you can with the prettier plugin" and everything works. However removing this feature means two things happen:
By making the users configure this on their own there is scope for misconfiguration and While having to maintain the integration with these liners is a burden, I think it is worth the effort for the improved developer experience it provides. Tangentially related: How do those metrics work for cases where people have enabled the prettier plugin globally but have opted into the eslint/stylelint plugins on a per project basis? That is how the majority of our projects at work are configured. I worry that this might result in skewing the numbers to be lower than actual usage. |
I agree with @BPScott. That functionality removed was something a lot of folks have come to rely on.
|
We have a team of developers who rely upon stylelint and Prettier in VSCode to auto-fix SCSS on save. At the time of this comment, I don't think there is any other way to do this in VSCode without |
@BPScott Hey, thanks for the comment. If you’re willing to help that certainly makes keeping it easier. If you have some time, I’d like to chat next week and see if we can come up with a good path forward to fixing these open issues and improving the experience to reduce all these bugs we seem to get. Regarding the metrics, they are reported when a project is opened. The project config overrides the global, so the metrics should account for this. |
@ryanolsonx nothing has been removed. That’s what this discussion is about. |
Hi @ntotten, setting up a chat this week would be good. Drop me an email: ben.scott@shopify.com and we can sort out a date/time (I'm PST-based). |
Moving the discussion to issue #958. |
This issue has been automatically locked since there has not been any recent activity after it was closed. Please open a new issue for related bugs. |
This issue is about the proposed removal of the eslintIntegration and tslintIntegration options.
On several projects, we use eslint 5.16.0, with which integration works successfully. And I was surprised when I opened the project an hour ago, but the extension did not work, and the linter integration settings were highlighted as unknown.
It seems to me that it is wrong to completely remove these properties before solving the problem with eslint 6. I suggest returning the properties and renaming them to something like oldEslintIntegration and oldTslintIntegration.
The text was updated successfully, but these errors were encountered: