-
-
Notifications
You must be signed in to change notification settings - Fork 17
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
[question] Can arduino-language-server use arduino-lint to provide diagnostic for arduino language? #164
Comments
Hi @Freed-Wu. Arduino Language Server does not use Arduino Lint in any way. Arduino Lint wouldn't actually have much to offer to the language server because there is actually only one rule related to sketch code ( General linting of Arduino code was considered out of scope for Arduino Lint because the Arduino language is essentially C++ and there are already excellent tools available for linting C++ code. Arduino Language Server acts as a translator between the Arduino sketch build system and the clangd C++ language server. Arduino Language Server handles the process of running Clangd on the C++ code generated from the sketch code by the build system in Arduino CLI and then translating the Clangd results to be relevant for the source Arduino sketch code. In this way, this existing excellent C++ language server is leveraged for the benefit of Arduino users rather than Arduino having to create something from scratch. If you are interested in diagnostics for other types of Arduino project files, many of Arduino Lint's rules are based on JSON schema. In theory, it should be possible to incorporate the schemas into a high quality programming editor such as VS Code to enhance the process of editing those project files: https://github.com/arduino/arduino-lint/tree/main/etc/schemas Since the package index files use the standard JSON data format, I think the package index schema should be relatively easy to use. Unfortunately I think the other schemas will be more challenging though. The reason is that the |
I know: arduino-language-server use clangd to diagnostic which is better than arduino-lint from scratch.
Why it doesn't push https://github.com/arduino/arduino-lint/tree/main/etc/schemas to https://www.schemastore.org/json/? I use coc.nvim which has many extensions diagnostic json, yaml, toml, ... by json schema from https://www.schemastore.org/json/. |
Thanks for the suggestion. This idea is actually something we had in the internal issue tracker for the last couple years. I have now published it to the public issue tracker: arduino/arduino-lint#567 As I mentioned above, I am skeptical about whether anyone would be able to use the schemas for the "properties" data format files, but it would be worth at least considering publishing the Arduino package index schema. |
Does arduino-language-server use arduino-lint to provide diagnostic for arduino language?
The text was updated successfully, but these errors were encountered: