This is the language server for Alive: The Average Lisp VSCode Environment.
For newcomers it could be difficult to start with Common LISP specially if the tech stack is not known yet. These instructions helps to have the server up and running as easy as possible. Steps are:
- Install your LISP Implementation
- Install a library/package manager
- Clone this repository
- Load the
alive-lsp
project and start the server
Here let's assume we install sbcl
# debian
apt-get install sbcl
# macos
brew install sbcl
Here let's assume we use quicklisp
curl -O https://beta.quicklisp.org/quicklisp.lisp
curl -O https://beta.quicklisp.org/quicklisp.lisp.asc
gpg --verify quicklisp.lisp.asc quicklisp.lisp
sbcl --load quicklisp.lisp
# ....
* (quicklisp-quickstart:install)
# it is also advisable to:
* (ql:add-to-init-file)
Previous step should have created a directory in your home directory: ~/quicklisp
, unless you decided to install it in another directory
(quicklisp-quickstart:install :path "~/.quicklisp")
just keep in mind the directory, let's called here $QUICKLISP_HOME
. Let's clone this repository in $QUICKLISP_HOME/local-projects
, so that it will be discovered automatically by Quicklisp when loading the project:
git clone [email protected]:nobody-famous/alive-lsp.git $QUICKLISP_HOME/local-projects/alive-lsp
sbcl
This is SBCL 2.2.11, an implementation of ANSI Common Lisp.
More information about SBCL is available at <http://www.sbcl.org/>.
SBCL is free software, provided as is, with absolutely no warranty.
It is mostly in the public domain; some portions are provided under
BSD-style licenses. See the CREDITS and COPYING files in the
distribution for more information.
* (ql:quickload "alive-lsp")
To load "alive-lsp":
Load 1 ASDF system:
alive-lsp
; Loading "alive-lsp"
.
("alive-lsp")
* (alive/server::start :port 8006)
#<SB-THREAD:THREAD "Alive LSP Server" RUNNING {70069B3BE3}>
Your language server works! You can stop it now (Ctrl C) and proceed to properly configure you Alive Extension in vscode:
{
"alive.lsp.startCommand": [
"sbcl",
"--eval",
"(require :asdf)",
"--eval",
"(asdf:load-system :alive-lsp)",
"--eval",
"(alive/server:start)"
]
}
note that alive.lsp.startCommand
could also be the one used before in the REPL session, something like:
{
"alive.lsp.remote.port": "8006",
"alive.lsp.startCommand": [
"sbcl",
"--noinform",
"--eval",
"ql:quickload \"alive-lsp\")",
"--eval",
"(alive/server::start :port 8006)"
]
}
just be sure to also configure the port if you specify one on the command for starting the server.
Take a look at thread #31
If you are interesting in making changes to Alive-lsp you should take a look at the Development Notes.