PLS implements features of the Language Server Protocol for Perl 5.
It is still very much in its early stages and Pull Requests are more than welcome.
The features currently implemented are:
- Go to definition (for packages, subroutines, and variables)
- Listing all symbols in a document
- Hovering to show documentation
- Signature help (showing parameters for a function as you type)
- Formatting
- Range Formatting
- Auto-completion
- Syntax checking
- Linting (using perlcritic)
- Sorting imports
Install the PLS package from CPAN: https://metacpan.org/pod/PLS
Install the fractalboy.pls extension in Visual Studio Code: https://marketplace.visualstudio.com/items?itemName=FractalBoy.pls
Using the built-in LSP features requires Neovim 0.5 or greater.
A default configuration for PLS is
available through nvim-lspconfig. Its name is perlpls; do not confuse this with perlls which is the default
configuration for Perl::LanguageServer.
See perldoc PLS for details about available configuration items.
The instructions assume that pls is in your $PATH. By default Perl Critic integration will be turned off.
If you are using a Vimscript configuration remember to wrap everything in a Lua here-doc, e.g.:
lua <<EOF
...config...
EOF
Install nvim-lspconfig.
Place the following in your Neovim config:
vim.lsp.enable('perlpls')
This will set you up with the defaults.
A more complex configuration will look like this:
vim.lsp.config('perlpls', {
cmd = { '/opt/bin/pls' }, -- complete path to where PLS is located
settings = {
pls = {
inc = { '/my/perl/5.34/lib', '/some/other/perl/lib' }, -- add list of dirs to @INC
cwd = { '/my/projects' }, -- working directory for PLS
perlcritic = { enabled = true, perlcriticrc = '/my/projects/.perlcriticrc' }, -- use perlcritic and pass a non-default location for its config
syntax = { enabled = true, perl = '/usr/bin/perl', args = { 'arg1', 'arg2' } }, -- enable syntax checking and use a non-default perl binary
perltidy = { perltidyrc = '/my/projects/.perltidyrc' } -- non-default location for perltidy's config
}
}
})
vim.lsp.enable('perlpls')
Install nvim-lspconfig.
For Neovim 0.9, make sure to pin the version to v1.8.0.
For Neovim 0.10, make sure to pin the version to v2.5.0.
Place the following in your Neovim config:
require('lspconfig')['perlpls'].setup({})
This will set you up with the defaults.
A more complex configuration will look like this:
require('lspconfig')['perlpls'].setup({
cmd = { '/opt/bin/pls' }, -- complete path to where PLS is located
settings = {
pls = {
inc = { '/my/perl/5.34/lib', '/some/other/perl/lib' }, -- add list of dirs to @INC
cwd = { '/my/projects' }, -- working directory for PLS
perlcritic = { enabled = true, perlcriticrc = '/my/projects/.perlcriticrc' }, -- use perlcritic and pass a non-default location for its config
syntax = { enabled = true, perl = '/usr/bin/perl', args = { 'arg1', 'arg2' } }, -- enable syntax checking and use a non-default perl binary
perltidy = { perltidyrc = '/my/projects/.perltidyrc' } -- non-default location for perltidy's config
}
}
})
nvim-lspconfig does not offer full backwards compatibility for old Neovim versions.
For such versions, you'll probably want to manually set up the language server. Instructions on how to do this for your
version can be found in :h lsp-quickstart. You may still copy and use the default configuration provided by the
nvim-lspconfig repository (see above).
BBEdit version 14.0 and higher adds support for Language Server Protocols, including PLS. Add the following JSON configuration file, adjusting paths accordingly, to the folder ~/Library/Application Support/BBEdit/Language Servers/Configuration/. Then enable the language server support for Perl following their recommendations, selecting the file you saved for the configuration.
{
"initializationOptions": {},
"workspaceConfigurations": {
"*": {
"pls": {
"inc": [],
"syntax": {
"enabled": true,
"perl": "/usr/bin/perl",
"args": []
},
"perltidy": {
"perltidyrc": "~/.perltidyrc"
},
"perlcritic": {
"enabled": true,
"perlcriticrc": "~/.perlcriticrc"
},
"cwd": "."
}
}
}
}
Several LSP client implementations for Emacs exist in the form of Emacs packages. This installation instruction covers the LSP Mode package.
Starting with version 9.0.0, LSP Mode has built-in support for
PLS. Thus, after installing PLS, all you need to do is to make sure
that the lsp-mode package is installed into Emacs, and gets
activated when Emacs opens a Perl file. Both steps are described in
the LSP Mode installation
instructions.
If pls should not be in your $PATH, you will need to set the
variable lsp-pls-executable in Emacs to point to the pls
executable. All PLS related, configurable options are available in the
customisation group lsp-pls in Emacs (M-x customize-group lsp-pls).
That's all. Now, a PLS server instance will be fired up when not already running, whenever a Perl file is opened in Emacs. For more details, or what to do next, see the extensive LSP Mode documentation.
- Make sure that
pls.cmdis set to the path to theplsscript on your system. If you rely on your$PATH, ensure that your editor is configured with the correct path, which may not be the same one that your terminal uses. - Add any additional arguments needed to execute
plsto thepls.argssetting. For example, if you runplsin a docker container,pls.cmdwould bedocker, andpls.argswould be["run", "--rm", "-i", "<image name>", "pls"]. - Optionally, change the current working directory to run PLS in by modifying the
pls.cwdsetting. If you use${workspaceFolder}here, it will be replaced by the first or only workspace folder. - Add paths to
@INCby modifying thepls.incsetting. You can use the${workspaceFolder}variable to stand in for your project's root directory, for example${workspaceFolder}/lib. If you are using multiple workspace folders and use${workspaceFolder}, the path will be multiplied by the number of workspace folders, and will be replaced that many times. - Configure the path to your
.perltidyrcfile using thepls.perltidy.perltidyrcsetting. The default is~/.perltidyrcif not configured. - Configure the path to your
.perlcriticrcfile using thepls.perlcritic.perlcriticrcsetting. The default is~/.perlcriticrcif not configured. - Disable
perlcriticchecking entirely by settingpls.perlcritic.enabledtofalse. - Disable
podcheckerchecking entirely by settingpls.podchecker.enabledtofalse. - Optionally, configure the path to an alternate
perlto use for syntax checking using thepls.syntax.perlsetting. By default, theperlused to run PLS will be used. - Disable syntax checking entirely by setting
pls.syntax.enabledtofalse. - Pass arguments to your code when syntax checking by setting
pls.syntax.args.- This is likely not useful for most developers, unless your code base changes behavior based on
@ARGVin aBEGINblock.
- This is likely not useful for most developers, unless your code base changes behavior based on
- Create a
.plsignorefile in your workspace root with Perl glob patterns that you do not wish to index. By default, PLS will index all files ending with.pl,.pm, or haveperlin the shebang line that are not.tfiles.- If you have a lot of files that are not Perl files in your workspace, it may slow down indexing if they are not ignored. This is the case for PLS itself, where the entire
clientdirectory is not Perl and contains many small files innode_modules.
- If you have a lot of files that are not Perl files in your workspace, it may slow down indexing if they are not ignored. This is the case for PLS itself, where the entire