ctrl+shift+p filters: :st2 :st3 :win :osx :linux
Browse

Sublime​Linter-any-lsp

by kaste ST4

SublimeLinter adapter to any LSP server

Details

Installs

  • Total 32
  • Win 19
  • Mac 3
  • Linux 10
Sep 19 Sep 18 Sep 17 Sep 16 Sep 15 Sep 14 Sep 13 Sep 12 Sep 11 Sep 10 Sep 9 Sep 8 Sep 7 Sep 6 Sep 5 Sep 4 Sep 3 Sep 2 Sep 1 Aug 31 Aug 30 Aug 29 Aug 28 Aug 27 Aug 26 Aug 25 Aug 24 Aug 23 Aug 22 Aug 21 Aug 20 Aug 19 Aug 18 Aug 17 Aug 16 Aug 15 Aug 14 Aug 13 Aug 12 Aug 11 Aug 10 Aug 9 Aug 8 Aug 7 Aug 6
Windows 0 0 0 0 1 0 0 0 0 0 0 0 0 1 0 0 0 0 0 0 0 0 0 0 0 0 1 0 0 1 0 0 1 1 0 1 0 0 1 0 1 0 0 0 0
Mac 0 0 0 0 0 0 0 0 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0
Linux 0 0 0 0 0 0 1 1 0 0 1 0 0 0 0 0 0 2 0 0 0 1 0 0 0 0 0 0 0 0 0 1 0 2 0 0 0 0 0 0 0 0 0 0 0

Readme

Source
raw.​githubusercontent.​com

SublimeLinter-any-lsp 🎴

SublimeLinter-any-lsp is a plugin for SublimeLinter that allows you to use Language Server Protocol (LSP) servers as linters within Sublime Text.

Status

I use it since May 2024. Needs spread and contributions. Unsure about which parts (if any) should be ported to SublimeLinter core. Lack of time to make it shine, also maybe, because it just works for me.

How It Works

This package implements a generic linter backend (AnyLSP) for SublimeLinter. It communicates with LSP servers, sends file contents, and parses diagnostics messages from the server to display them as linting errors/warnings in Sublime Text.

  • Each LSP server defined by a linter class (e.g., Ruff, Pyright, Eslint) as usual, inheriting AnyLSP instead of Linter.
  • Diagnostic messages from the LSP server are mapped to SublimeLinter errors and warnings.

Design

Be open, user-friendly, playful.

# Make a config
config = ServerConfig(
    "ruff-lsp",
    ("ruff", "server", "--preview"),
    "/user/knowles/and-her-working-dir",
)
# and ask for a server attached to a view
ensure_server_for_view(config, view)
# or a plain server
server = ensure_server(config)
# and communicate with it
req = server.request("textDocument/diagnostic", inflate({
    "textDocument.uri": canoncial_uri_for_view(self.view),
}))

@req.on_response
def on_diagnostics(msg):
    ....

# done.  Idle servers shutdown automatically. 🌆

Example Linter Classes

class Ruff(AnyLSP):
    name = "ruff-lsp"
    cmd = ("ruff", "server", "--preview")
    defaults = {"selector": "source.python"}

class Pyright(AnyLSP):
    name = "pyright-lsp"
    cmd = ("pyright-langserver", "--stdio")
    defaults = {
        "disable": True,
        "selector": "source.python",
        "settings": {
            "python.analysis.autoSearchPaths": True,
            "python.analysis.diagnosticMode": "openFilesOnly",
            "python.analysis.useLibraryCodeForTypes": True,
        }
    }

Installation

Manual only. Not listed on PackageControl

Usage

  • Ships ruff-lsp, pyright and eslint out-of-the-box
  • Any other LSP (-configuration) must be added here, as a separate (private or public) package, or just in your User folder as a plugin.

Configuration

Each linter class may be configured through SublimeLinter's settings system. For example, to enable or disable specific servers, or to pass settings to the underlying LSP.

Example:

"SublimeLinter.linters.ruff-lsp.selector": "source.python",

Contributing

Contributions are welcome! Please open issues or pull requests for bug fixes, new features, or improvements.

License

MIT