2017-12-14 21:30:20 +08:00
|
|
|
---
|
|
|
|
title: "SpaceVim debug layer"
|
2021-06-21 20:39:29 +08:00
|
|
|
description: "This layer provides debug workflow support in SpaceVim"
|
2017-12-14 21:30:20 +08:00
|
|
|
---
|
|
|
|
|
2018-06-23 14:37:41 +08:00
|
|
|
# [Available Layers](../) >> debug
|
2017-12-14 21:30:20 +08:00
|
|
|
|
|
|
|
<!-- vim-markdown-toc GFM -->
|
|
|
|
|
|
|
|
- [Description](#description)
|
|
|
|
- [Install](#install)
|
2022-02-02 14:13:14 +08:00
|
|
|
- [Configuration](#configuration)
|
2017-12-14 21:30:20 +08:00
|
|
|
- [Key bindings](#key-bindings)
|
2022-02-02 14:13:14 +08:00
|
|
|
- [Using vim-debug](#using-vim-debug)
|
|
|
|
- [Using vimspector](#using-vimspector)
|
2017-12-14 21:30:20 +08:00
|
|
|
|
|
|
|
<!-- vim-markdown-toc -->
|
|
|
|
|
|
|
|
## Description
|
|
|
|
|
2021-06-21 20:39:29 +08:00
|
|
|
This layer provides debug workflow for SpaceVim. All of the functionality is based on [vim-vebugger](https://github.com/idanarye/vim-vebugger).
|
2017-12-14 21:30:20 +08:00
|
|
|
|
|
|
|
## Install
|
|
|
|
|
2021-06-21 20:39:29 +08:00
|
|
|
To use this configuration layer, add the following snippet to your custom configuration file.
|
2018-06-23 14:37:41 +08:00
|
|
|
|
|
|
|
```toml
|
|
|
|
[[layers]]
|
|
|
|
name = "debug"
|
|
|
|
```
|
2017-12-14 21:30:20 +08:00
|
|
|
|
2022-02-02 14:13:14 +08:00
|
|
|
## Configuration
|
|
|
|
|
|
|
|
Vimspector can be used as the debugger by setting the configuration.
|
|
|
|
|
|
|
|
```toml
|
|
|
|
[[layers]]
|
|
|
|
name = "debug"
|
|
|
|
debugger_plugin = "vimspector"
|
|
|
|
```
|
|
|
|
|
2017-12-14 21:30:20 +08:00
|
|
|
## Key bindings
|
|
|
|
|
2022-02-02 14:13:14 +08:00
|
|
|
### Using vim-debug
|
|
|
|
|
2017-12-14 21:30:20 +08:00
|
|
|
| Key Binding | Description |
|
|
|
|
| ----------- | ---------------------------------------- |
|
2021-06-21 20:39:29 +08:00
|
|
|
| `SPC d l` | launch the debugger |
|
2017-12-14 21:30:20 +08:00
|
|
|
| `SPC d c` | Continue the execution |
|
|
|
|
| `SPC d b` | Toggle a breakpoint for the current line |
|
|
|
|
| `SPC d B` | Clear all breakpoints |
|
|
|
|
| `SPC d o` | step over |
|
|
|
|
| `SPC d i` | step into functions |
|
|
|
|
| `SPC d O` | step out of current function |
|
|
|
|
| `SPC d e s` | Evaluate and print the selected text |
|
|
|
|
| `SPC d e e` | Evaluate the `<cword>` under the cursor |
|
|
|
|
| `SPC d e S` | Execute the selected text |
|
|
|
|
| `SPC d k` | Terminates the debugger |
|
2017-12-14 21:58:22 +08:00
|
|
|
|
|
|
|
**Debug Transient State**
|
|
|
|
|
2021-06-21 20:39:29 +08:00
|
|
|
key bindings are too long? use `SPC d .` to open the debug transient state:
|
2017-12-14 21:58:22 +08:00
|
|
|
|
2023-07-05 11:50:23 +08:00
|
|
|
![Debug Transient State](https://img.spacevim.org/33996076-b03c05bc-e0a5-11e7-90fd-5f31e2703d7e.png)
|
2022-02-02 14:13:14 +08:00
|
|
|
|
|
|
|
### Using vimspector
|
|
|
|
|
|
|
|
| Key Binding | Description |
|
|
|
|
| ----------- | ------------------------------------- |
|
|
|
|
| `SPC d c` | launch-or-continue-debugger |
|
|
|
|
| `SPC d r` | restart-debugger-with-the-same-config |
|
|
|
|
| `SPC d x` | run-to-cursor |
|
|
|
|
| `SPC d p` | pause-debugger |
|
|
|
|
| `SPC d b` | toggle-line-breakpoint |
|
|
|
|
| `SPC d B` | clear-all-breakpoints |
|
|
|
|
| `SPC d o` | step-over |
|
|
|
|
| `SPC d i` | step-into-functions |
|
|
|
|
| `SPC d O` | step-out-of-current-function |
|
|
|
|
| `SPC d u` | move-up-a-frame |
|
|
|
|
| `SPC d d` | move-down-a-frame |
|
|
|
|
| `SPC d k` | terminate-the-debugger |
|
|
|
|
| `SPC d e` | evaluate-cursor-symbol-or-selection |
|
|
|
|
|
|
|
|
**Debug Transient State**
|
|
|
|
|
|
|
|
| Key Binding | Description |
|
|
|
|
| ----------- | ---------------------------- |
|
|
|
|
| `c` | Continue execution |
|
|
|
|
| `u` | Move up a frame |
|
|
|
|
| `d` | Move down a frame |
|
|
|
|
| `o` | step over |
|
|
|
|
| `i` | step into functions |
|
|
|
|
| `O` | step out of current function |
|
|
|
|
| `k` | Terminates the debugger |
|