mirror of
https://github.com/SpaceVim/SpaceVim.git
synced 2025-01-23 22:40:04 +08:00
79 lines
2.0 KiB
Markdown
79 lines
2.0 KiB
Markdown
---
|
|
title: "SpaceVim lang#scheme layer"
|
|
description: "This layer adds Scheme language support to SpaceVim"
|
|
image: https://user-images.githubusercontent.com/13142418/46590501-4e50b100-cae6-11e8-9366-6772d129a13b.png
|
|
---
|
|
|
|
# [Available Layers](../../) >> lang#scheme
|
|
|
|
<!-- vim-markdown-toc GFM -->
|
|
|
|
- [Description](#description)
|
|
- [Features](#features)
|
|
- [Install](#install)
|
|
- [Options](#options)
|
|
- [Key bindings](#key-bindings)
|
|
- [Inferior REPL process](#inferior-repl-process)
|
|
- [Running current script](#running-current-script)
|
|
|
|
<!-- vim-markdown-toc -->
|
|
|
|
## Description
|
|
|
|
This layer adds [Scheme](http://www.scheme-reports.org) support to SpaceVim.
|
|
The following scheme dialect support has been added:
|
|
|
|
- [MIT Scheme](https://www.gnu.org/software/mit-scheme/)
|
|
- [Chez Scheme](https://cisco.github.io/ChezScheme/)
|
|
- [guile](https://www.gnu.org/software/guile/)
|
|
|
|
|
|
## Features
|
|
|
|
- code runner
|
|
- REPL support
|
|
|
|
## Install
|
|
|
|
To use this configuration layer, update your custom configuration file with:
|
|
|
|
```toml
|
|
[[layers]]
|
|
name = "lang#scheme"
|
|
```
|
|
|
|
## Options
|
|
|
|
- `scheme_dialect`: specify which scheme dialect is used.
|
|
- `scheme_interpreter`: option for setting scheme interperter.
|
|
|
|
for example:
|
|
|
|
```toml
|
|
[[layers]]
|
|
name = 'lang#scheme'
|
|
scheme_dialect = 'mit-scheme'
|
|
scheme_interpreter = 'C:\Program Files (x86)\MIT-GNU Scheme\bin\mit-scheme.exe'
|
|
```
|
|
|
|
## Key bindings
|
|
|
|
### Inferior REPL process
|
|
|
|
Start a `scheme` inferior REPL process with `SPC l s i`.
|
|
|
|
Send code to inferior process commands:
|
|
|
|
| Key Bindings | Descriptions |
|
|
| ------------ | ------------------------------------------------ |
|
|
| `SPC l s b` | send buffer and keep code buffer focused |
|
|
| `SPC l s l` | send line and keep code buffer focused |
|
|
| `SPC l s s` | send selection text and keep code buffer focused |
|
|
|
|
|
|
### Running current script
|
|
|
|
To run the current script, you can press `SPC l r`
|
|
to run the current file without losing focus,
|
|
and the result will be shown in a runner buffer.
|