Language Server Protocol implementation for the SourcePawn programming language written in Rust
Feature | Status |
---|---|
Completion | ✅ |
Go To Definition | ✅ |
Find References | ✅ |
Hover | ✅ |
Rename | ✅ |
Semantic Highlighting | ✅ |
Document Symbols | ✅ |
Call Hierarchy | ✅ |
Signature Help | ✅ |
Reference | ✅ |
Diagnostics | ✅ |
The Language Server is compatible with any text editor that implements the Language Server Protocol.
For ease of use with Visual Studio Code, an extension bundles sourcepawn-lsp
with a build for each major platform and OS. You can download it from the marketplace here.
Partial support for AMXXPawn
is implemented through the --amxxpawn-mode
flag. The only difference between, the "SourcePawn mode" and the "AMXXPawn mode" boils down to what file extension the server will be looking for (.sp
vs .sma
).
A VSCode extension exists which bundles the server with the correct launch flags. You can find it here.
- How can I donate ?
- How to install the beta build ?
- How to contribute ?
- How to run the extension from its source code ?
Thanks for considering this. But please remember that all of this wouldn't be possible without the Alliedmodders community. If you wish to make a donation for this community, you can make it here. If you prefer to make a donation to me for this project, you can buy me a coffee
- Download and install the language server from the releases page.
- Open VSCode and go to the marketplace.
- In the search bar, type
SourcePawn
and select the extension. - Click on
Switch to Pre-Release
(see screenshot below).
This will install the latest development build of the extension.
Note that a new build might take a few minutes (up to 15) to propagate to the Marketplace after the release has been pushed to the releases page.
You can also install the latest pre-release by downloading the .vsix from the releases page and installing it manually.
Pull requests and suggestions are welcome.
- To make a suggestion or to report an issue, please create a new issue here.
- To make a contribution, fork the repository, make the desired changes, and open a pull request.
To run the Language Server from the source, do the following:
- Install the rust toolchain using rustup.
- Install node.js on your machine. Make sure npm is installed as well.
- Fork this repository and clone it on your machine (do this with VSCode for easier manipulation).
- From the root of the repository, run the following commands to install npm dependencies:
cd editors/code && npm i
. - Press
f5
and select theRun Extension (Debug Build)
launch task in the prompt. This will compile the Language Server server from the source code and package the VSCode extension's source code. - (Optional) You can attach a debugger to the Language Server by doing the step above, then running another task called
Attach To Server
orWin Attach To Server
on Windows and typingsourcepawn-lsp
in the prompt.