Use Vim as a Perl IDE
This is a general guide for using SpaceVim as a perl IDE, including layer configuration and usage. Each of the following sections will be covered:
- Enable language layer
- Code completion
- Syntax linting
- Jump to test file
- running code
- Code formatting
- REPL support <!-- vim-markdown-toc --> ### Enable language layer
To add perl language support in SpaceVim, you need to enable the lang#perl
layer. Press SPC f v d
to openSpaceVim configuration file, and add following configuration:
[[layers]]
name = "lang#perl"
for more info, you can read the lang#perl layer documentation.
Code completion
lang#perl
layer will load the perl plugin automatically, unless overriden in your init.toml
.The completion menu will be opened as you type.
Syntax linting
The checkers layer is enabled by default. This layer provides asynchronous syntax linting via neomake.It will run perl and perlcritic asynchronously.
Install perlcritic via cpan:
cpanm Perl::Critic
Jump to test file
SpaceVim use built-in plugin to manager the files in a project, you can add a .project_alt.json
to the root of your project with following content:
{
"src/*.pl": {"alternate": "test/{}.pl"},
"test/*.pl": {"alternate": "src/{}.pl"}
}
with this configuration, you can jump between the source code and test file via command :A
running code
To run current script, you can press SPC l r
, and a split windowswill be openen, the output of the script will be shown in this windows.It is running asynchronously, and will not block your vim.
Code formatting
The format layer is also enabled by default, with this layer you can use key binding SPC b f
to format current buffer.Before using this feature, please install perltidy:
cpanm Perl::Tidy
REPL support
Start a perli
or perl -del
inferior REPL process with SPC l s i
. After the REPL process has been started. you can send code to inferior process, all key bindings are begin with SPC l s
prefix, including sending line, sending selection or evensend whole buffer.
Top comments (0)