2017-03-02 22:20:46 +08:00
|
|
|
|
"=============================================================================
|
|
|
|
|
" SpaceVim.vim --- Initialization and core files for SpaceVim
|
2023-03-26 13:44:47 +08:00
|
|
|
|
" Copyright (c) 2016-2023 Wang Shidong & Contributors
|
2022-03-27 13:38:54 +08:00
|
|
|
|
" Author: Shidong Wang < wsdjeg@outlook.com >
|
2017-03-06 23:39:03 +08:00
|
|
|
|
" URL: https://spacevim.org
|
2018-02-15 22:25:03 +08:00
|
|
|
|
" License: GPLv3
|
2017-03-02 22:20:46 +08:00
|
|
|
|
"=============================================================================
|
2021-01-02 17:58:45 +08:00
|
|
|
|
scriptencoding utf-8
|
2017-03-02 22:20:46 +08:00
|
|
|
|
|
2017-01-02 10:38:23 +08:00
|
|
|
|
""
|
|
|
|
|
" @section Introduction, intro
|
2017-02-10 00:02:00 +08:00
|
|
|
|
" @stylized spacevim
|
2017-01-10 21:00:14 +08:00
|
|
|
|
" @library
|
2024-06-15 11:11:59 +08:00
|
|
|
|
" @order intro options config functions layers usage plugins api dev community faq roadmap changelog
|
2024-06-18 21:47:05 +08:00
|
|
|
|
" SpaceVim is a modular configuration of Vim and Neovim.
|
|
|
|
|
" It's inspired by spacemacs. It manages collections of plugins in layers,
|
|
|
|
|
" which help to collect related packages together to provide features.
|
|
|
|
|
" This approach helps keep the configuration organized and reduces
|
|
|
|
|
" overhead for the user by keeping them from having to think about
|
|
|
|
|
" what packages to install.
|
|
|
|
|
|
|
|
|
|
""
|
|
|
|
|
" @section Highlighted Features, features
|
|
|
|
|
" @parentsection intro
|
|
|
|
|
" 1. Modularization: Plugins are organized in @section(layers).
|
|
|
|
|
" 2. Compatible API: A series of @section(api) for Vim/Neovim.
|
|
|
|
|
" 3. Great documentation: Everything is documented in `:h SpaceVim`.
|
|
|
|
|
" 4. Better experience: Most of the core plugins have been rewritten using Lua.
|
|
|
|
|
" 5. Beautiful UI: The interface has been carefully designed.
|
|
|
|
|
" 6. Mnemonic key bindings: Key bindings are organized using mnemonic prefixes.
|
|
|
|
|
" 7. Lower the risk of RSI: Heavily using the `<Space>` key instead of modifiers.
|
2017-01-27 21:49:05 +08:00
|
|
|
|
|
2024-06-27 20:14:02 +08:00
|
|
|
|
|
|
|
|
|
""
|
|
|
|
|
" @section Update and Rollback, update-and-rollback
|
|
|
|
|
" @parentsection intro
|
|
|
|
|
" @subsection Update SpaceVim itself
|
|
|
|
|
"
|
|
|
|
|
" There are several methods of updating the core files of SpaceVim.
|
|
|
|
|
" It is recommended to update the packages first; see the next section.
|
|
|
|
|
"
|
|
|
|
|
" 1. Automatic Updates
|
|
|
|
|
"
|
|
|
|
|
" By default, this feature is disabled.
|
|
|
|
|
" It would slow down the startup of Vim/Neovim.
|
|
|
|
|
" If you like this feature,
|
|
|
|
|
" add the following to your custom configuration file.
|
|
|
|
|
" >
|
|
|
|
|
" [options]
|
|
|
|
|
" automatic_update = true
|
|
|
|
|
" <
|
|
|
|
|
"
|
|
|
|
|
" SpaceVim will automatically check for a new version
|
|
|
|
|
" every startup. You have to restart Vim after updating.
|
|
|
|
|
"
|
|
|
|
|
" 2. Updating from the SpaceVim Buffer
|
|
|
|
|
"
|
|
|
|
|
" Users can use command `:SPUpdate SpaceVim` to update SpaceVim.
|
|
|
|
|
" This command will open a new buffer to show the process of updating.
|
|
|
|
|
"
|
|
|
|
|
" 3. Updating Manually with git
|
|
|
|
|
"
|
|
|
|
|
" For users who prefer to use the command line, they can use the following command
|
|
|
|
|
" in a terminal to update SpaceVim manually:
|
|
|
|
|
" >
|
|
|
|
|
" git -C ~/.SpaceVim pull
|
|
|
|
|
" <
|
|
|
|
|
"
|
|
|
|
|
" @subsection Update plugins
|
|
|
|
|
"
|
|
|
|
|
" Use `:SPUpdate` command to update all the plugins and
|
|
|
|
|
" SpaceVim itself. After `:SPUpdate`, you can assign
|
|
|
|
|
" plugins need to be updated. Use `Tab` to complete
|
|
|
|
|
" plugin names after `:SPUpdate`.
|
|
|
|
|
"
|
|
|
|
|
" @subsection Reinstall plugins
|
|
|
|
|
"
|
|
|
|
|
" When a plugin has failed to update or is broken, Use the `:SPReinstall`
|
|
|
|
|
" command to reinstall the plugin. The plugin's name can be completed via the key binding `<Tab>`.
|
|
|
|
|
"
|
|
|
|
|
" For example:
|
|
|
|
|
" >
|
|
|
|
|
" :SPReinstall echodoc.vim
|
|
|
|
|
" <
|
|
|
|
|
"
|
|
|
|
|
" @subsection Get SpaceVim log
|
|
|
|
|
"
|
|
|
|
|
" The runtime log of SpaceVim can be obtained via the key binding `SPC h L`.
|
|
|
|
|
" To get the debug information about the current SpaceVim environment,
|
|
|
|
|
" Use the command `:SPDebugInfo!`. This command will open a new buffer where default information will be shown.
|
|
|
|
|
" You can also use `SPC h I` to open a buffer with SpaceVim's issue template.
|
|
|
|
|
|
2017-01-27 21:49:05 +08:00
|
|
|
|
""
|
2018-05-27 13:05:57 +08:00
|
|
|
|
" @section Options, options
|
2024-06-19 20:43:09 +08:00
|
|
|
|
" The very first time SpaceVim starts up, it will ask you to choose a mode,
|
|
|
|
|
" `basic mode` or `dark powered mode`. Then it will create a
|
|
|
|
|
" `.SpaceVim.d/init.toml` file in your $HOME directory.
|
|
|
|
|
" All the user configuration files are stored in ~/.SpaceVim.d/ directory.
|
|
|
|
|
"
|
|
|
|
|
" `~/.SpaceVim.d/` will also be added to |'runtimepath'|.
|
|
|
|
|
"
|
|
|
|
|
" It is also possible to override the location of `~/.SpaceVim.d/` by
|
|
|
|
|
" using the environment variable `$SPACEVIMDIR`.
|
|
|
|
|
" Of course, symlinks can be used to change the location of this directory.
|
|
|
|
|
"
|
|
|
|
|
" SpaceVim also supports project specific configuration files.
|
|
|
|
|
" The project configuration file is `.SpaceVim.d/init.toml` in the root of
|
|
|
|
|
" the project. The directory `{project root}/.SpaceVim.d/` will also be
|
|
|
|
|
" added to the |'runtimepath'|.
|
|
|
|
|
"
|
|
|
|
|
" NOTE:Please be aware that if there are errors in your init.toml,
|
|
|
|
|
" all the setting in this toml file will not be applied.
|
|
|
|
|
"
|
|
|
|
|
" All SpaceVim options can be found in @section(options), the option name is
|
|
|
|
|
" same as the old vim option, but with the `g:spacevim_` prefix removed. For example:
|
|
|
|
|
" >
|
|
|
|
|
" g:spacevim_enable_statusline_tag -> enable_statusline_tag
|
|
|
|
|
" <
|
|
|
|
|
" If the fuzzy finder layer is loaded, users can use key binding `SPC h SPC`
|
|
|
|
|
" to fuzzy find the documentation of SpaceVim options.
|
|
|
|
|
"
|
|
|
|
|
" @subsection Add custom plugins
|
|
|
|
|
"
|
|
|
|
|
" If you want to add plugins from GitHub, just add the repo name to the custom_plugins section:
|
|
|
|
|
" >
|
|
|
|
|
" [[custom_plugins]]
|
|
|
|
|
" repo = 'lilydjwg/colorizer'
|
|
|
|
|
" # `on_cmd` option means this plugin will be loaded
|
|
|
|
|
" # only when the specific commands are called.
|
|
|
|
|
" # for example, when `:ColorHighlight` or `:ColorToggle`
|
|
|
|
|
" # commands are called.
|
|
|
|
|
" on_cmd = ['ColorHighlight', 'ColorToggle']
|
|
|
|
|
" # `on_func` option means this plugin will be loaded
|
|
|
|
|
" # only when the specific functions are called.
|
|
|
|
|
" # for example, when `colorizer#ColorToggle()` function is called.
|
|
|
|
|
" on_func = 'colorizer#ColorToggle'
|
|
|
|
|
" # `merged` option is used for merging plugins directory.
|
|
|
|
|
" # When `merged` is `true`, all files in this custom plugin
|
|
|
|
|
" # will be merged into `~/.cache/vimfiles/.cache/init.vim/`
|
|
|
|
|
" # for neovim or `~/.cache/vimfiles/.cache/vimrc/` for vim.
|
|
|
|
|
" merged = false
|
|
|
|
|
" # For more options see `:h dein-options`.
|
|
|
|
|
" <
|
|
|
|
|
" You can also use the url of the repository, for example:
|
|
|
|
|
" >
|
|
|
|
|
" [[custom_plugins]]
|
|
|
|
|
" repo = "https://gitlab.com/code-stats/code-stats-vim.git"
|
|
|
|
|
" merged = false
|
|
|
|
|
" <
|
|
|
|
|
" To add multiple custom plugins:
|
|
|
|
|
" >
|
|
|
|
|
" [[custom_plugins]]
|
|
|
|
|
" repo = 'lilydjwg/colorizer'
|
|
|
|
|
" merged = false
|
|
|
|
|
"
|
|
|
|
|
" [[custom_plugins]]
|
|
|
|
|
" repo = 'joshdick/onedark.vim'
|
|
|
|
|
" merged = false
|
|
|
|
|
" <
|
|
|
|
|
" If you want to disable plugins which are added by SpaceVim,
|
|
|
|
|
" you can use the options: @section(options-disabled_plugins).
|
2018-06-10 23:30:02 +08:00
|
|
|
|
" >
|
|
|
|
|
" [options]
|
2024-06-19 20:43:09 +08:00
|
|
|
|
" # NOTE: the value should be a list, and each item is the name of the plugin.
|
|
|
|
|
" disabled_plugins = ["clighter", "clighter8"]
|
2018-06-10 23:30:02 +08:00
|
|
|
|
" <
|
2017-01-02 10:38:23 +08:00
|
|
|
|
|
2018-05-27 13:05:57 +08:00
|
|
|
|
|
|
|
|
|
""
|
|
|
|
|
" @section Configuration, config
|
2018-06-15 20:41:11 +08:00
|
|
|
|
" If you still want to use `~/.SpaceVim.d/init.vim` as configuration file,
|
2022-01-02 22:06:01 +08:00
|
|
|
|
" please take a look at the following options add @section(functions)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
""
|
|
|
|
|
" @section Public functions, functions
|
|
|
|
|
" All of these functions can be used in `~/.SpaceVim.d/init.vim` and bootstrap
|
|
|
|
|
" functions.
|
|
|
|
|
|
2018-05-27 13:05:57 +08:00
|
|
|
|
|
2021-01-02 17:58:45 +08:00
|
|
|
|
let s:SYSTEM = SpaceVim#api#import('system')
|
|
|
|
|
|
2018-02-22 21:15:46 +08:00
|
|
|
|
" Public SpaceVim Options {{{
|
|
|
|
|
|
2017-01-04 23:53:49 +08:00
|
|
|
|
""
|
|
|
|
|
" Version of SpaceVim , this value can not be changed.
|
2024-03-24 14:57:36 +08:00
|
|
|
|
let g:spacevim_version = '2.4.0-dev'
|
2018-02-22 21:15:46 +08:00
|
|
|
|
|
2018-06-15 20:41:11 +08:00
|
|
|
|
""
|
|
|
|
|
" @section default_indent, options-default_indent
|
|
|
|
|
" @parentsection options
|
|
|
|
|
" Change the default indentation of SpaceVim. Default is 2.
|
|
|
|
|
" >
|
|
|
|
|
" default_indent = 2
|
|
|
|
|
" <
|
|
|
|
|
|
2017-01-02 10:38:23 +08:00
|
|
|
|
""
|
2017-02-17 13:56:55 +08:00
|
|
|
|
" Change the default indentation of SpaceVim. Default is 2.
|
2017-01-03 00:27:11 +08:00
|
|
|
|
" >
|
|
|
|
|
" let g:spacevim_default_indent = 2
|
|
|
|
|
" <
|
2017-01-02 10:38:23 +08:00
|
|
|
|
let g:spacevim_default_indent = 2
|
2022-03-20 15:42:03 +08:00
|
|
|
|
""
|
|
|
|
|
" @section expand_tab, options-expand_tab
|
|
|
|
|
" @parentsection options
|
|
|
|
|
" In Insert mode: Use the appropriate number of spaces to insert a <Tab>
|
|
|
|
|
|
2017-01-02 10:38:23 +08:00
|
|
|
|
""
|
2018-04-01 21:13:49 +08:00
|
|
|
|
" In Insert mode: Use the appropriate number of spaces to insert a <Tab>
|
|
|
|
|
let g:spacevim_expand_tab = 1
|
2018-06-10 23:30:02 +08:00
|
|
|
|
|
2024-07-05 23:11:59 +08:00
|
|
|
|
""
|
|
|
|
|
" @section if_ruby, options-if_ruby
|
|
|
|
|
" @parentsection options
|
|
|
|
|
" Neovim if_ruby provider is too slow, If you are sure that your nvim does not
|
|
|
|
|
" support ruby, set this option to false. default is true.
|
|
|
|
|
|
|
|
|
|
let g:spacevim_if_ruby = 1
|
|
|
|
|
|
2023-03-24 09:13:44 +08:00
|
|
|
|
""
|
|
|
|
|
" @section enable_list_mode, options-enable_list_mode
|
|
|
|
|
" @parentsection options
|
|
|
|
|
" Enable/Disable list mode, by default it is disabled.
|
|
|
|
|
|
|
|
|
|
""
|
|
|
|
|
" Enable/Disable list mode, by default it is disabled.
|
2023-03-24 09:21:57 +08:00
|
|
|
|
let g:spacevim_enable_list_mode = 0
|
2023-03-24 09:13:44 +08:00
|
|
|
|
|
2024-07-07 22:38:26 +08:00
|
|
|
|
""
|
|
|
|
|
" @section lazy_conf_timeout, options-lazy_conf_timeout
|
|
|
|
|
" @parentsection options
|
|
|
|
|
" set the waiting time of lazy loading config in milliseconds. This will be
|
|
|
|
|
" applied to load layer config, and lazy plugin, and end function of SpaceVim.
|
|
|
|
|
" default is 300 ms.
|
|
|
|
|
|
|
|
|
|
let g:spacevim_lazy_conf_timeout = 200
|
|
|
|
|
|
2018-06-10 23:30:02 +08:00
|
|
|
|
""
|
|
|
|
|
" @section relativenumber, options-relativenumber
|
|
|
|
|
" @parentsection options
|
|
|
|
|
" Enable/Disable relativenumber, by default it is enabled.
|
|
|
|
|
" >
|
|
|
|
|
" relativenumber = true
|
|
|
|
|
" <
|
|
|
|
|
|
2018-04-01 21:13:49 +08:00
|
|
|
|
""
|
2019-04-26 21:43:46 +08:00
|
|
|
|
" Enable/Disable relativenumber in current windows, by default it is enabled.
|
2017-06-27 15:31:34 +08:00
|
|
|
|
let g:spacevim_relativenumber = 1
|
2018-06-10 23:30:02 +08:00
|
|
|
|
|
2021-06-21 22:49:20 +08:00
|
|
|
|
""
|
|
|
|
|
" Enable/Disable line wrap of vim
|
|
|
|
|
let g:spacevim_wrap_line = 0
|
2019-04-13 22:12:33 +08:00
|
|
|
|
|
|
|
|
|
""
|
|
|
|
|
" @section enable_bepo_layout, options-enable_bepo_layout
|
|
|
|
|
" @parentsection options
|
|
|
|
|
" Enable/Disable bepo layout, by default it is disabled.
|
|
|
|
|
" >
|
|
|
|
|
" enable_bepo_layout = true
|
|
|
|
|
" <
|
|
|
|
|
|
|
|
|
|
""
|
|
|
|
|
" Enable/Disable bepo layout, by default it is disabled.
|
|
|
|
|
let g:spacevim_enable_bepo_layout = 0
|
|
|
|
|
|
|
|
|
|
|
2018-06-10 23:30:02 +08:00
|
|
|
|
""
|
|
|
|
|
" @section max_column, options-max_column
|
|
|
|
|
" @parentsection options
|
|
|
|
|
" Change the max number of columns for SpaceVim. Default is 120.
|
|
|
|
|
" >
|
|
|
|
|
" max_column = 120
|
|
|
|
|
" <
|
|
|
|
|
|
2017-06-27 15:31:34 +08:00
|
|
|
|
""
|
2017-02-17 13:56:55 +08:00
|
|
|
|
" Change the max number of columns for SpaceVim. Default is 120.
|
2017-01-03 00:27:11 +08:00
|
|
|
|
" >
|
|
|
|
|
" let g:spacevim_max_column = 120
|
|
|
|
|
" <
|
2017-01-02 10:38:23 +08:00
|
|
|
|
let g:spacevim_max_column = 120
|
2018-06-10 23:30:02 +08:00
|
|
|
|
|
2021-11-12 10:36:47 +08:00
|
|
|
|
""
|
|
|
|
|
" @section windisk_encoding, options-windisk_encoding
|
|
|
|
|
" @parentsection options
|
|
|
|
|
" Setting the encoding of windisk info. by default it is `cp936`.
|
|
|
|
|
" >
|
|
|
|
|
" windisk_encoding = 'cp936'
|
|
|
|
|
" <
|
|
|
|
|
|
|
|
|
|
let g:spacevim_windisk_encoding = 'cp936'
|
2020-12-20 20:32:21 +08:00
|
|
|
|
|
|
|
|
|
""
|
|
|
|
|
" @section default_custom_leader, options-default_custom_leader
|
|
|
|
|
" @parentsection options
|
|
|
|
|
" Change the default custom leader of SpaceVim. Default is <Space>.
|
|
|
|
|
" >
|
|
|
|
|
" default_custom_leader = "<Space>"
|
|
|
|
|
" <
|
|
|
|
|
|
|
|
|
|
""
|
|
|
|
|
" Change the default custom leader of SpaceVim. Default is <Space>.
|
|
|
|
|
" >
|
|
|
|
|
" let g:spacevim_default_custom_leader = '<Space>'
|
|
|
|
|
" <
|
|
|
|
|
let g:spacevim_default_custom_leader = '<Space>'
|
|
|
|
|
|
2019-04-02 21:08:08 +08:00
|
|
|
|
""
|
2019-05-09 23:19:29 +08:00
|
|
|
|
" @section home_files_number, options-home_files_number
|
2019-04-02 21:08:08 +08:00
|
|
|
|
" @parentsection options
|
|
|
|
|
" Change the list number of files for SpaceVim home. Default is 6.
|
|
|
|
|
" >
|
|
|
|
|
" home_files_number = 6
|
|
|
|
|
" <
|
|
|
|
|
|
|
|
|
|
""
|
|
|
|
|
" Change the list number of files for SpaceVim home. Default is 6.
|
|
|
|
|
" >
|
|
|
|
|
" let g:spacevim_home_files_number = 6
|
|
|
|
|
" <
|
|
|
|
|
let g:spacevim_home_files_number = 6
|
2021-10-01 15:25:42 +08:00
|
|
|
|
""
|
|
|
|
|
" @section code_runner_focus, options-code_runner_focus
|
|
|
|
|
" @parentsection options
|
|
|
|
|
" enable/disable code runner window focus mode, by default this option is
|
|
|
|
|
" `false`, to enable this mode, set this option to `true`.
|
|
|
|
|
" >
|
|
|
|
|
" code_runner_focus = true
|
|
|
|
|
" <
|
2019-04-02 21:08:08 +08:00
|
|
|
|
|
2021-10-01 15:25:42 +08:00
|
|
|
|
""
|
|
|
|
|
" enable/disable code runner window focus mode, by default this option is 0,
|
|
|
|
|
" to enable this mode, set this option to 1.
|
|
|
|
|
let g:spacevim_code_runner_focus = 0
|
2019-04-02 21:08:08 +08:00
|
|
|
|
|
2018-06-10 23:30:02 +08:00
|
|
|
|
""
|
|
|
|
|
" @section enable_guicolors, options-enable_guicolors
|
|
|
|
|
" @parentsection options
|
2019-06-02 11:59:43 +08:00
|
|
|
|
" Enable true color support in terminal. Default is false.
|
2018-06-10 23:30:02 +08:00
|
|
|
|
" >
|
|
|
|
|
" enable_guicolors = true
|
|
|
|
|
" <
|
|
|
|
|
|
2017-01-03 00:27:11 +08:00
|
|
|
|
""
|
2019-06-02 11:59:43 +08:00
|
|
|
|
" Enable true color support in terminal. Default is 0.
|
2017-01-06 19:13:33 +08:00
|
|
|
|
" >
|
|
|
|
|
" let g:spacevim_enable_guicolors = 1
|
|
|
|
|
" <
|
2019-06-02 11:59:43 +08:00
|
|
|
|
let g:spacevim_enable_guicolors = 0
|
2018-06-10 23:30:02 +08:00
|
|
|
|
|
2020-06-30 22:25:15 +08:00
|
|
|
|
""
|
|
|
|
|
" @section escape_key_binding, options-escape_key_binding
|
|
|
|
|
" @parentsection options
|
|
|
|
|
" Set the key binding for switch to normal mode in insert mode.
|
|
|
|
|
" Default is `jk`, to disable this key binding, set this option to empty
|
|
|
|
|
" string.
|
|
|
|
|
" >
|
|
|
|
|
" escape_key_binding = 'jk'
|
|
|
|
|
" <
|
|
|
|
|
|
|
|
|
|
""
|
|
|
|
|
" Set the key binding for switch to normal mode in insert mode.
|
|
|
|
|
" Default is `jk`, to disable this key binding, set this option to empty
|
|
|
|
|
" string.
|
|
|
|
|
" >
|
|
|
|
|
" let g:spacevim_escape_key_binding = 'jk'
|
|
|
|
|
" <
|
|
|
|
|
let g:spacevim_escape_key_binding = 'jk'
|
|
|
|
|
|
2021-05-01 22:47:19 +08:00
|
|
|
|
""
|
|
|
|
|
" @section file_searching_tools, options-file_searching_tools
|
|
|
|
|
" @parentsection options
|
|
|
|
|
" Set the default file searching tool used by `SPC f /`, by default it is `[]`.
|
|
|
|
|
" The first item in this list is the name of the tool, the second one is the
|
|
|
|
|
" default command. for example:
|
|
|
|
|
" >
|
|
|
|
|
" file_searching_tools = ['find', 'find -not -iwholename "*.git*" ']
|
|
|
|
|
" <
|
|
|
|
|
|
|
|
|
|
let g:spacevim_file_searching_tools = []
|
|
|
|
|
|
2018-06-10 23:30:02 +08:00
|
|
|
|
""
|
|
|
|
|
" @section enable_googlesuggest, options-enable_googlesuggest
|
|
|
|
|
" @parentsection options
|
|
|
|
|
" Enable/Disable Google suggestions for neocomplete. Default is false.
|
|
|
|
|
" >
|
|
|
|
|
" enable_googlesuggest = false
|
|
|
|
|
" <
|
|
|
|
|
|
2017-01-06 19:13:33 +08:00
|
|
|
|
""
|
2017-02-17 13:56:55 +08:00
|
|
|
|
" Enable/Disable Google suggestions for neocomplete. Default is 0.
|
2017-01-03 00:27:11 +08:00
|
|
|
|
" >
|
|
|
|
|
" let g:spacevim_enable_googlesuggest = 1
|
|
|
|
|
" <
|
2017-01-02 10:38:23 +08:00
|
|
|
|
let g:spacevim_enable_googlesuggest = 0
|
2018-06-10 23:30:02 +08:00
|
|
|
|
|
|
|
|
|
""
|
|
|
|
|
" @section windows_leader, options-windows_leader
|
|
|
|
|
" @parentsection options
|
2018-12-19 23:59:41 +08:00
|
|
|
|
" Window functions leader for SpaceVim. Default is `s`.
|
2018-06-10 23:30:02 +08:00
|
|
|
|
" Set to empty to disable this feature, or you can set to another char.
|
|
|
|
|
" >
|
|
|
|
|
" windows_leader = ""
|
|
|
|
|
" <
|
|
|
|
|
|
|
|
|
|
|
2017-01-11 23:00:28 +08:00
|
|
|
|
""
|
2018-12-19 23:59:41 +08:00
|
|
|
|
" Window functions leader for SpaceVim. Default is `s`.
|
2017-02-17 13:56:55 +08:00
|
|
|
|
" Set to empty to disable this feature, or you can set to another char.
|
2017-01-11 23:00:28 +08:00
|
|
|
|
" >
|
|
|
|
|
" let g:spacevim_windows_leader = ''
|
|
|
|
|
" <
|
|
|
|
|
let g:spacevim_windows_leader = 's'
|
2018-06-10 23:30:02 +08:00
|
|
|
|
|
2020-03-29 08:34:31 +08:00
|
|
|
|
""
|
|
|
|
|
" @section data_dir, options-data_dir
|
|
|
|
|
" @parentsection options
|
|
|
|
|
" Set the cache directory of SpaceVim. Default is `$XDG_CACHE_HOME`
|
|
|
|
|
" or if not set `~/.cache¸.
|
|
|
|
|
" >
|
|
|
|
|
" data_dir = "~/.cache"
|
|
|
|
|
" <
|
|
|
|
|
|
|
|
|
|
""
|
|
|
|
|
" Set the cache directory of SpaceVim. Default is `$XDG_CACHE_HOME`
|
|
|
|
|
" or if not set `~/.cache¸.
|
|
|
|
|
" >
|
|
|
|
|
" let g:spacevim_data_dir = '~/.cache'
|
|
|
|
|
" <
|
|
|
|
|
let g:spacevim_data_dir
|
|
|
|
|
\ = $XDG_CACHE_HOME != ''
|
|
|
|
|
\ ? $XDG_CACHE_HOME . SpaceVim#api#import('file').separator
|
|
|
|
|
\ : expand($HOME. join(['', '.cache', ''],
|
|
|
|
|
\ SpaceVim#api#import('file').separator))
|
|
|
|
|
|
2020-08-29 16:46:57 +08:00
|
|
|
|
if !isdirectory(g:spacevim_data_dir)
|
|
|
|
|
call mkdir(g:spacevim_data_dir, 'p')
|
|
|
|
|
endif
|
|
|
|
|
|
2018-06-10 23:30:02 +08:00
|
|
|
|
""
|
|
|
|
|
" @section plugin_bundle_dir, options-plugin_bundle_dir
|
|
|
|
|
" @parentsection options
|
2020-03-29 08:34:31 +08:00
|
|
|
|
" Set the cache directory of plugins. Default is `$data_dir/vimfiles`.
|
2018-06-10 23:30:02 +08:00
|
|
|
|
" >
|
|
|
|
|
" plugin_bundle_dir = "~/.cache/vimplugs"
|
|
|
|
|
" <
|
|
|
|
|
|
2017-01-03 22:56:34 +08:00
|
|
|
|
""
|
2020-03-29 08:34:31 +08:00
|
|
|
|
" Set the cache directory of plugins. Default is `$data_dir/vimfiles`.
|
2017-01-03 22:56:34 +08:00
|
|
|
|
" >
|
2021-08-18 20:54:54 +08:00
|
|
|
|
" let g:spacevim_plugin_bundle_dir = g:spacevim_data_dir.'vimplugs'
|
2017-01-03 22:56:34 +08:00
|
|
|
|
" <
|
2017-03-07 22:11:41 +08:00
|
|
|
|
let g:spacevim_plugin_bundle_dir
|
2020-03-29 08:34:31 +08:00
|
|
|
|
\ = g:spacevim_data_dir . join(['vimfiles', ''],
|
2017-03-07 22:11:41 +08:00
|
|
|
|
\ SpaceVim#api#import('file').separator)
|
2018-06-10 23:30:02 +08:00
|
|
|
|
|
|
|
|
|
""
|
|
|
|
|
" @section realtime_leader_guide, options-realtime_leader_guide
|
|
|
|
|
" @parentsection options
|
|
|
|
|
" Enable/Disable realtime leader guide. Default is true. to disable it:
|
|
|
|
|
" >
|
|
|
|
|
" realtime_leader_guide = false
|
|
|
|
|
" <
|
|
|
|
|
|
2017-01-15 19:50:56 +08:00
|
|
|
|
""
|
2017-05-14 23:30:12 +08:00
|
|
|
|
" Enable/Disable realtime leader guide. Default is 1. to disable it:
|
2017-01-15 19:50:56 +08:00
|
|
|
|
" >
|
2017-05-14 23:30:12 +08:00
|
|
|
|
" let g:spacevim_realtime_leader_guide = 0
|
2017-01-15 19:50:56 +08:00
|
|
|
|
" <
|
2017-05-14 23:30:12 +08:00
|
|
|
|
let g:spacevim_realtime_leader_guide = 1
|
2023-06-28 01:20:11 +08:00
|
|
|
|
""
|
|
|
|
|
" @section leader_guide_theme, options-leader_guide_theme
|
|
|
|
|
" @parentsection options
|
|
|
|
|
" Enable/Disable realtime leader guide. Default is true. to disable it:
|
|
|
|
|
" Set the key mapping guide theme, the default theme is `leaderguide`.
|
|
|
|
|
"
|
|
|
|
|
" available themes:
|
|
|
|
|
"
|
|
|
|
|
" - `leaderguide`: same as LeaderGuide.vim
|
|
|
|
|
"
|
|
|
|
|
" - `whichkey`: same as which-key.nvim
|
|
|
|
|
" >
|
|
|
|
|
" leader_guide_theme = 'leaderguide'
|
|
|
|
|
" <
|
|
|
|
|
|
|
|
|
|
""
|
|
|
|
|
" Enable/Disable realtime leader guide. Default is true. to disable it:
|
|
|
|
|
" Set the key mapping guide theme, the default theme is `leaderguide`.
|
|
|
|
|
"
|
|
|
|
|
" available themes:
|
|
|
|
|
"
|
|
|
|
|
" - `leaderguide`: same as LeaderGuide.vim
|
|
|
|
|
"
|
|
|
|
|
" - `whichkey`: same as which-key.nvim
|
|
|
|
|
" >
|
|
|
|
|
" let g:spacevim_leader_guide_theme = 'leaderguide'
|
|
|
|
|
" <
|
|
|
|
|
let g:spacevim_leader_guide_theme = 'leaderguide'
|
2019-05-30 21:14:39 +08:00
|
|
|
|
|
|
|
|
|
""
|
|
|
|
|
" @section enable_key_frequency, options-enable_key_frequency
|
|
|
|
|
" @parentsection options
|
|
|
|
|
" Enable/Disable key frequency catching of SpaceVim. default value is 0. to
|
|
|
|
|
" enable it:
|
|
|
|
|
" >
|
|
|
|
|
" enable_key_frequency = true
|
|
|
|
|
" <
|
|
|
|
|
|
2017-04-03 12:52:09 +08:00
|
|
|
|
""
|
2017-04-03 13:12:35 +08:00
|
|
|
|
" Enable/Disable key frequency catching of SpaceVim. default value is 0. to
|
|
|
|
|
" enable it:
|
|
|
|
|
" >
|
|
|
|
|
" let g:spacevim_enable_key_frequency = 1
|
|
|
|
|
" <
|
|
|
|
|
let g:spacevim_enable_key_frequency = 0
|
2024-06-16 15:18:05 +08:00
|
|
|
|
if has('nvim-0.9.0')
|
|
|
|
|
let g:spacevim_autocomplete_method = 'nvim-cmp'
|
|
|
|
|
elseif (has('python3')
|
2021-04-02 23:32:59 +08:00
|
|
|
|
\ && (SpaceVim#util#haspy3lib('neovim')
|
|
|
|
|
\ || SpaceVim#util#haspy3lib('pynvim'))) &&
|
2018-04-09 20:07:27 +08:00
|
|
|
|
\ (has('nvim') || (has('patch-8.0.0027')))
|
2019-05-30 21:14:39 +08:00
|
|
|
|
|
|
|
|
|
""
|
|
|
|
|
" @section autocomplete_method, options-autocomplete_method
|
|
|
|
|
" @parentsection options
|
|
|
|
|
" Set the autocomplete engine of spacevim, the default logic is:
|
|
|
|
|
" >
|
2024-06-16 15:18:05 +08:00
|
|
|
|
" if has('nvim-0.9.0')
|
|
|
|
|
" let g:spacevim_autocomplete_method = 'nvim-cmp'
|
|
|
|
|
" elseif has('python3')
|
2019-05-30 21:14:39 +08:00
|
|
|
|
" let g:spacevim_autocomplete_method = 'deoplete'
|
|
|
|
|
" elseif has('lua')
|
|
|
|
|
" let g:spacevim_autocomplete_method = 'neocomplete'
|
|
|
|
|
" elseif has('python')
|
|
|
|
|
" let g:spacevim_autocomplete_method = 'completor'
|
|
|
|
|
" elseif has('timers')
|
|
|
|
|
" let g:spacevim_autocomplete_method = 'asyncomplete'
|
|
|
|
|
" else
|
|
|
|
|
" let g:spacevim_autocomplete_method = 'neocomplcache'
|
|
|
|
|
" endif
|
|
|
|
|
" <
|
|
|
|
|
"
|
|
|
|
|
" and you can alse set this option to coc, then coc.nvim will be used.
|
2022-04-13 13:24:05 +08:00
|
|
|
|
" If you are using neovim, you can also set this option to `nvim-cmp`, then
|
|
|
|
|
" nvim-cmp will be used.
|
2019-05-30 21:14:39 +08:00
|
|
|
|
|
2017-11-23 10:39:06 +08:00
|
|
|
|
""
|
|
|
|
|
" Set the autocomplete engine of spacevim, the default logic is:
|
|
|
|
|
" >
|
2024-06-16 15:18:05 +08:00
|
|
|
|
" if has('nvim-0.9.0')
|
|
|
|
|
" let g:spacevim_autocomplete_method = 'nvim-cmp'
|
|
|
|
|
" elseif has('python3')
|
2017-11-23 10:39:06 +08:00
|
|
|
|
" let g:spacevim_autocomplete_method = 'deoplete'
|
|
|
|
|
" elseif has('lua')
|
|
|
|
|
" let g:spacevim_autocomplete_method = 'neocomplete'
|
|
|
|
|
" elseif has('python')
|
|
|
|
|
" let g:spacevim_autocomplete_method = 'completor'
|
|
|
|
|
" elseif has('timers')
|
|
|
|
|
" let g:spacevim_autocomplete_method = 'asyncomplete'
|
|
|
|
|
" else
|
|
|
|
|
" let g:spacevim_autocomplete_method = 'neocomplcache'
|
|
|
|
|
" endif
|
|
|
|
|
" <
|
2018-12-13 23:07:55 +08:00
|
|
|
|
"
|
2019-05-08 13:34:49 +08:00
|
|
|
|
" and you can alse set this option to coc, then coc.nvim will be used.
|
2017-11-23 10:39:06 +08:00
|
|
|
|
let g:spacevim_autocomplete_method = 'deoplete'
|
2021-04-02 23:32:59 +08:00
|
|
|
|
|
|
|
|
|
" neocomplete does not work with Vim 8.2.1066
|
|
|
|
|
elseif has('lua') && !has('patch-8.2.1066')
|
2017-11-23 10:39:06 +08:00
|
|
|
|
let g:spacevim_autocomplete_method = 'neocomplete'
|
2018-04-09 22:05:21 +08:00
|
|
|
|
elseif has('python') && ((has('job') && has('timers') && has('lambda')) || has('nvim'))
|
2017-11-23 10:39:06 +08:00
|
|
|
|
let g:spacevim_autocomplete_method = 'completor'
|
|
|
|
|
elseif has('timers')
|
|
|
|
|
let g:spacevim_autocomplete_method = 'asyncomplete'
|
|
|
|
|
else
|
|
|
|
|
let g:spacevim_autocomplete_method = 'neocomplcache'
|
|
|
|
|
endif
|
2018-06-10 23:30:02 +08:00
|
|
|
|
|
|
|
|
|
""
|
2021-02-10 10:31:34 +08:00
|
|
|
|
" @section lint_engine, options-lint_engine
|
2018-06-10 23:30:02 +08:00
|
|
|
|
" @parentsection options
|
2021-02-10 10:31:34 +08:00
|
|
|
|
" Set the lint engine used in checkers layer, the default engine is neomake,
|
|
|
|
|
" if you want to use ale, use:
|
2018-06-10 23:30:02 +08:00
|
|
|
|
" >
|
2021-02-10 10:31:34 +08:00
|
|
|
|
" lint_engine = 'ale'
|
2018-06-10 23:30:02 +08:00
|
|
|
|
" <
|
2021-02-10 10:31:34 +08:00
|
|
|
|
" NOTE: the `enable_neomake` and `enable_ale` option has been deprecated.
|
|
|
|
|
" *spacevim-options-enable_naomake*
|
|
|
|
|
" *spacevim-options-enable_ale*
|
2018-06-10 23:30:02 +08:00
|
|
|
|
|
2017-02-16 20:01:33 +08:00
|
|
|
|
""
|
2021-02-10 10:31:34 +08:00
|
|
|
|
" Set the lint engine used in checkers layer, the default engine is neomake,
|
|
|
|
|
" if you want to use ale, use:
|
2017-02-16 20:01:33 +08:00
|
|
|
|
" >
|
2021-02-10 10:31:34 +08:00
|
|
|
|
" let g:spacevim_lint_engine = 'ale'
|
2017-02-16 20:01:33 +08:00
|
|
|
|
" <
|
2021-02-10 10:31:34 +08:00
|
|
|
|
let g:spacevim_lint_engine = 'neomake'
|
2018-06-10 23:30:02 +08:00
|
|
|
|
|
|
|
|
|
""
|
|
|
|
|
" @section guifont, options-guifont
|
|
|
|
|
" @parentsection options
|
|
|
|
|
" Set the guifont of SpaceVim. Default is empty.
|
|
|
|
|
" >
|
2018-12-23 21:55:41 +08:00
|
|
|
|
" guifont = "SauceCodePro Nerd Font Mono:h11"
|
2018-06-10 23:30:02 +08:00
|
|
|
|
" <
|
|
|
|
|
|
2017-10-25 09:41:04 +08:00
|
|
|
|
""
|
2017-02-17 13:56:55 +08:00
|
|
|
|
" Set the guifont of SpaceVim. Default is empty.
|
2017-01-11 01:03:52 +08:00
|
|
|
|
" >
|
2018-12-23 21:55:41 +08:00
|
|
|
|
" let g:spacevim_guifont = "SauceCodePro Nerd Font Mono:h11"
|
2017-01-11 01:03:52 +08:00
|
|
|
|
" <
|
2023-05-30 21:47:32 +08:00
|
|
|
|
let g:spacevim_guifont = 'SauceCodePro Nerd Font Mono:h11'
|
2018-06-10 23:30:02 +08:00
|
|
|
|
|
|
|
|
|
""
|
|
|
|
|
" @section enable_ycm, options-enable_ycm
|
|
|
|
|
" @parentsection options
|
|
|
|
|
" Enable/Disable YouCompleteMe. Default is false.
|
|
|
|
|
" >
|
|
|
|
|
" enable_ycm = true
|
|
|
|
|
" <
|
|
|
|
|
|
2017-01-02 10:38:23 +08:00
|
|
|
|
""
|
2017-02-17 13:56:55 +08:00
|
|
|
|
" Enable/Disable YouCompleteMe. Default is 0.
|
2017-01-11 01:03:52 +08:00
|
|
|
|
" >
|
|
|
|
|
" let g:spacevim_enable_ycm = 1
|
|
|
|
|
" <
|
2017-01-02 10:38:23 +08:00
|
|
|
|
let g:spacevim_enable_ycm = 0
|
2018-06-10 23:30:02 +08:00
|
|
|
|
|
|
|
|
|
""
|
|
|
|
|
" @section sidebar_width, options-sidebar_width
|
|
|
|
|
" @parentsection options
|
|
|
|
|
" Set the width of the SpaceVim sidebar. Default is 30.
|
2021-09-19 17:32:31 +08:00
|
|
|
|
" This value will be used by tagbar and filetree.
|
2018-06-10 23:30:02 +08:00
|
|
|
|
|
2017-02-16 21:27:49 +08:00
|
|
|
|
""
|
2017-02-17 13:56:55 +08:00
|
|
|
|
" Set the width of the SpaceVim sidebar. Default is 30.
|
2021-09-19 17:32:31 +08:00
|
|
|
|
" This value will be used by tagbar and filetree.
|
2017-02-16 21:27:49 +08:00
|
|
|
|
let g:spacevim_sidebar_width = 30
|
2018-06-10 23:30:02 +08:00
|
|
|
|
|
|
|
|
|
""
|
|
|
|
|
" @section snippet_engine, options-snippet_engine
|
|
|
|
|
" @parentsection options
|
|
|
|
|
" Set the snippet engine of SpaceVim, default is neosnippet. to enable
|
|
|
|
|
" ultisnips:
|
|
|
|
|
" >
|
|
|
|
|
" snippet_engine = "ultisnips"
|
|
|
|
|
" <
|
|
|
|
|
|
2017-04-02 19:39:42 +08:00
|
|
|
|
""
|
|
|
|
|
" Set the snippet engine of SpaceVim, default is neosnippet. to enable
|
|
|
|
|
" ultisnips:
|
|
|
|
|
" >
|
2018-06-10 23:30:02 +08:00
|
|
|
|
" let g:spacevim_snippet_engine = "ultisnips"
|
2017-04-02 19:39:42 +08:00
|
|
|
|
" <
|
|
|
|
|
let g:spacevim_snippet_engine = 'neosnippet'
|
2017-01-02 10:38:23 +08:00
|
|
|
|
let g:spacevim_enable_neocomplcache = 0
|
2019-05-30 21:14:39 +08:00
|
|
|
|
|
|
|
|
|
""
|
|
|
|
|
" @section enable_cursorline, options-enable_cursorline
|
|
|
|
|
" @parentsection options
|
|
|
|
|
" Enable/Disable cursorline. Default is true, cursorline will be
|
|
|
|
|
" highlighted in normal mode.To disable this feature:
|
|
|
|
|
" >
|
|
|
|
|
" enable_cursorline = false
|
|
|
|
|
" <
|
|
|
|
|
|
2017-01-11 01:03:52 +08:00
|
|
|
|
""
|
2017-05-06 20:33:50 +08:00
|
|
|
|
" Enable/Disable cursorline. Default is 1, cursorline will be
|
|
|
|
|
" highlighted in normal mode.To disable this feature:
|
2017-01-11 01:03:52 +08:00
|
|
|
|
" >
|
2017-05-06 20:33:50 +08:00
|
|
|
|
" let g:spacevim_enable_cursorline = 0
|
2017-01-11 01:03:52 +08:00
|
|
|
|
" <
|
2017-05-06 20:33:50 +08:00
|
|
|
|
let g:spacevim_enable_cursorline = 1
|
2019-05-30 21:14:39 +08:00
|
|
|
|
""
|
|
|
|
|
" @section statusline_separator, options-statusline_separator
|
|
|
|
|
" @parentsection options
|
2019-06-02 11:59:43 +08:00
|
|
|
|
" Set the statusline separators of statusline, default is 'nil'
|
2019-05-30 21:14:39 +08:00
|
|
|
|
" >
|
|
|
|
|
" Separators options:
|
|
|
|
|
" 1. arrow
|
|
|
|
|
" 2. curve
|
|
|
|
|
" 3. slant
|
|
|
|
|
" 4. nil
|
|
|
|
|
" 5. fire
|
|
|
|
|
" <
|
|
|
|
|
"
|
|
|
|
|
" See more details in: http://spacevim.org/documentation/#statusline
|
|
|
|
|
"
|
|
|
|
|
|
2017-05-06 20:33:50 +08:00
|
|
|
|
""
|
2019-06-02 11:59:43 +08:00
|
|
|
|
" Set the statusline separators of statusline, default is 'nil'
|
2017-06-21 21:14:30 +08:00
|
|
|
|
" >
|
2018-03-23 22:08:37 +08:00
|
|
|
|
" Separators options:
|
2017-06-21 21:14:30 +08:00
|
|
|
|
" 1. arrow
|
|
|
|
|
" 2. curve
|
|
|
|
|
" 3. slant
|
|
|
|
|
" 4. nil
|
|
|
|
|
" 5. fire
|
|
|
|
|
" <
|
|
|
|
|
"
|
|
|
|
|
" See more details in: http://spacevim.org/documentation/#statusline
|
|
|
|
|
"
|
2019-06-02 11:59:43 +08:00
|
|
|
|
let g:spacevim_statusline_separator = 'nil'
|
2019-05-30 21:14:39 +08:00
|
|
|
|
""
|
|
|
|
|
" @section statusline_iseparator, options-statusline_iseparator
|
|
|
|
|
" @parentsection options
|
|
|
|
|
" Set the statusline separators of statusline in inactive windows, default is
|
2019-06-02 11:59:43 +08:00
|
|
|
|
" 'nil'
|
2019-05-30 21:14:39 +08:00
|
|
|
|
" >
|
|
|
|
|
" Separators options:
|
|
|
|
|
" 1. arrow
|
|
|
|
|
" 2. curve
|
|
|
|
|
" 3. slant
|
|
|
|
|
" 4. nil
|
|
|
|
|
" 5. fire
|
|
|
|
|
" <
|
|
|
|
|
"
|
|
|
|
|
" See more details in: http://spacevim.org/documentation/#statusline
|
|
|
|
|
"
|
2017-11-19 09:29:34 +08:00
|
|
|
|
|
2018-12-30 14:03:47 +08:00
|
|
|
|
""
|
2019-05-30 21:14:39 +08:00
|
|
|
|
" Set the statusline separators of statusline in inactive windows, default is
|
2019-06-02 11:59:43 +08:00
|
|
|
|
" 'nil'
|
2019-05-30 21:14:39 +08:00
|
|
|
|
" >
|
|
|
|
|
" Separators options:
|
|
|
|
|
" 1. arrow
|
|
|
|
|
" 2. curve
|
|
|
|
|
" 3. slant
|
|
|
|
|
" 4. nil
|
|
|
|
|
" 5. fire
|
|
|
|
|
" <
|
|
|
|
|
"
|
|
|
|
|
" See more details in: http://spacevim.org/documentation/#statusline
|
|
|
|
|
"
|
2019-06-02 11:59:43 +08:00
|
|
|
|
let g:spacevim_statusline_iseparator = 'nil'
|
2019-05-30 21:14:39 +08:00
|
|
|
|
|
|
|
|
|
""
|
|
|
|
|
" @section enable_statusline_bfpath, options-enable_statusline_bfpath
|
|
|
|
|
" @parentsection options
|
|
|
|
|
" Enable/Disable showing full path of current buffer on statusline, disabled
|
|
|
|
|
" by default, to enable this feature:
|
|
|
|
|
" >
|
|
|
|
|
" enable_statusline_bfpath = true
|
|
|
|
|
" <
|
|
|
|
|
|
|
|
|
|
""
|
|
|
|
|
" Enable/Disable showing full path of current buffer on statusline, disabled
|
|
|
|
|
" by default, to enable this feature:
|
|
|
|
|
" >
|
|
|
|
|
" enable_statusline_bfpath = true
|
|
|
|
|
" <
|
2018-12-30 14:03:47 +08:00
|
|
|
|
let g:spacevim_enable_statusline_bfpath = 0
|
|
|
|
|
|
2018-12-31 23:09:35 +08:00
|
|
|
|
""
|
|
|
|
|
" @section enable_statusline_tag, options-enable_statusline_tag
|
|
|
|
|
" @parentsection options
|
|
|
|
|
" Enable/Disable showing current tag on statusline
|
|
|
|
|
" >
|
|
|
|
|
" enable_statusline_tag = false
|
|
|
|
|
" <
|
|
|
|
|
|
|
|
|
|
""
|
|
|
|
|
" Enable/Disable showing current tag on statusline
|
|
|
|
|
let g:spacevim_enable_statusline_tag = 1
|
2019-05-30 21:14:39 +08:00
|
|
|
|
""
|
2022-04-14 17:33:50 +08:00
|
|
|
|
" @section statusline_left, options-statusline_left
|
2019-05-30 21:14:39 +08:00
|
|
|
|
" @parentsection options
|
|
|
|
|
" Define the left section of statusline in active windows. By default:
|
|
|
|
|
" >
|
2022-04-14 17:33:50 +08:00
|
|
|
|
" statusline_left = [
|
2019-05-30 21:14:39 +08:00
|
|
|
|
" 'winnr',
|
|
|
|
|
" 'filename',
|
|
|
|
|
" 'major mode',
|
|
|
|
|
" 'minor mode lighters',
|
|
|
|
|
" 'version control info'
|
|
|
|
|
" ]
|
|
|
|
|
" <
|
2022-04-14 17:27:22 +08:00
|
|
|
|
" `statusline_left_sections` is deprecated, use `statusline_left` instead.
|
2018-12-31 23:09:35 +08:00
|
|
|
|
|
2017-11-19 10:18:32 +08:00
|
|
|
|
""
|
|
|
|
|
" Define the left section of statusline in active windows. By default:
|
|
|
|
|
" >
|
2022-04-14 17:27:22 +08:00
|
|
|
|
" let g:spacevim_statusline_left =
|
2017-11-19 10:18:32 +08:00
|
|
|
|
" \ [
|
|
|
|
|
" \ 'winnr',
|
|
|
|
|
" \ 'filename',
|
|
|
|
|
" \ 'major mode',
|
|
|
|
|
" \ 'minor mode lighters',
|
|
|
|
|
" \ 'version control info'
|
|
|
|
|
" \ ]
|
|
|
|
|
" <
|
2022-04-14 17:27:22 +08:00
|
|
|
|
" `g:spacevim_statusline_left_sections` is deprecated,
|
|
|
|
|
" use `g:spacevim_statusline_left` instead.
|
|
|
|
|
let g:spacevim_statusline_left = ['winnr', 'filename', 'major mode',
|
2019-09-19 22:43:59 +08:00
|
|
|
|
\ 'search count',
|
2018-01-18 20:34:43 +08:00
|
|
|
|
\ 'syntax checking', 'minor mode lighters',
|
2018-03-12 21:00:24 +08:00
|
|
|
|
\ ]
|
2022-03-20 10:13:18 +08:00
|
|
|
|
""
|
2022-04-14 17:33:50 +08:00
|
|
|
|
" @section statusline_right, options-statusline_right
|
2022-03-20 10:13:18 +08:00
|
|
|
|
" @parentsection options
|
|
|
|
|
" Define the right section of statusline in active windows. By default:
|
|
|
|
|
" >
|
2022-04-14 17:33:50 +08:00
|
|
|
|
" statusline_right = [
|
2022-03-20 10:13:18 +08:00
|
|
|
|
" 'fileformat',
|
|
|
|
|
" 'cursorpos',
|
|
|
|
|
" 'percentage'
|
|
|
|
|
" ]
|
|
|
|
|
" <
|
|
|
|
|
"
|
|
|
|
|
" The following sections can be used in this option:
|
|
|
|
|
" - fileformat: the format of current file
|
|
|
|
|
" - cursorpos: the corsur position
|
|
|
|
|
" - percentage: the percent of current page
|
|
|
|
|
" - totallines: the total lines of current buffer
|
2022-04-14 17:27:22 +08:00
|
|
|
|
"
|
|
|
|
|
" `statusline_right_sections` is deprecated, use `statusline_right` instead.
|
2022-03-20 10:13:18 +08:00
|
|
|
|
|
2017-11-19 10:18:32 +08:00
|
|
|
|
""
|
|
|
|
|
" Define the right section of statusline in active windows. By default:
|
|
|
|
|
" >
|
2022-04-14 17:27:22 +08:00
|
|
|
|
" g:spacevim_statusline_right =
|
2018-01-18 20:34:43 +08:00
|
|
|
|
" \ [
|
|
|
|
|
" \ 'fileformat',
|
|
|
|
|
" \ 'cursorpos',
|
|
|
|
|
" \ 'percentage'
|
|
|
|
|
" \ ]
|
2017-11-19 10:18:32 +08:00
|
|
|
|
" <
|
2022-04-14 17:27:22 +08:00
|
|
|
|
"
|
|
|
|
|
" `g:spacevim_statusline_right_sections` is deprecated,
|
|
|
|
|
" use `g:spacevim_statusline_right` instead.
|
|
|
|
|
let g:spacevim_statusline_right = ['fileformat', 'cursorpos', 'percentage']
|
2017-11-19 09:29:34 +08:00
|
|
|
|
|
2017-05-19 20:45:03 +08:00
|
|
|
|
""
|
2021-09-25 21:09:11 +08:00
|
|
|
|
" @section statusline_unicode, options-statusline_unicode
|
2020-09-26 11:14:25 +08:00
|
|
|
|
" @parentsection options
|
|
|
|
|
" Enable/Disable unicode symbols in statusline, includes the mode icons and
|
|
|
|
|
" fileformat icons. This option is enabled by default, to disable it:
|
|
|
|
|
" >
|
2021-09-25 21:09:11 +08:00
|
|
|
|
" statusline_unicode = false
|
2020-09-26 11:14:25 +08:00
|
|
|
|
" <
|
|
|
|
|
|
|
|
|
|
""
|
|
|
|
|
" Enable/Disable unicode symbols in statusline, includes the mode icons and
|
|
|
|
|
" fileformat icons. This option is enabled by default, to disable it:
|
|
|
|
|
" >
|
2021-09-25 21:09:11 +08:00
|
|
|
|
" let g:spacevim_statusline_unicode = 0
|
2020-09-26 11:14:25 +08:00
|
|
|
|
" <
|
2021-09-25 21:09:11 +08:00
|
|
|
|
let g:spacevim_statusline_unicode = 1
|
2017-09-20 21:03:01 +08:00
|
|
|
|
""
|
2018-01-07 12:12:34 +08:00
|
|
|
|
" Enable/Disable language specific leader, by default you can use `,` ket
|
|
|
|
|
" instead of `SPC` `l`.
|
|
|
|
|
let g:spacevim_enable_language_specific_leader = 1
|
2018-06-10 23:30:02 +08:00
|
|
|
|
|
|
|
|
|
""
|
2018-06-18 16:12:31 +08:00
|
|
|
|
" @section enable_statusline_mode, options-enable_statusline_mode
|
2018-06-10 23:30:02 +08:00
|
|
|
|
" @parentsection options
|
|
|
|
|
" Enable/Disable display mode. Default is 0, mode will be
|
|
|
|
|
" displayed in statusline. To enable this feature:
|
|
|
|
|
" >
|
2018-06-18 16:12:31 +08:00
|
|
|
|
" enable_statusline_mode = true
|
2018-06-10 23:30:02 +08:00
|
|
|
|
" <
|
|
|
|
|
|
2018-01-07 12:12:34 +08:00
|
|
|
|
""
|
2017-10-19 19:04:43 +08:00
|
|
|
|
" Enable/Disable display mode. Default is 0, mode will be
|
|
|
|
|
" displayed in statusline. To enable this feature:
|
|
|
|
|
" >
|
2018-06-18 16:12:31 +08:00
|
|
|
|
" let g:spacevim_enable_statusline_mode = 1
|
2017-10-19 19:04:43 +08:00
|
|
|
|
" <
|
2018-06-18 16:12:31 +08:00
|
|
|
|
let g:spacevim_enable_statusline_mode = 0
|
2017-10-19 19:04:43 +08:00
|
|
|
|
""
|
2017-10-23 03:13:42 +08:00
|
|
|
|
" Set the statusline/tabline palette of color, default values depends on the theme
|
|
|
|
|
" >
|
|
|
|
|
" let g:spacevim_custom_color_palette = [
|
|
|
|
|
" \ ['#282828', '#b8bb26', 246, 235],
|
|
|
|
|
" \ ['#a89984', '#504945', 239, 246],
|
|
|
|
|
" \ ['#a89984', '#3c3836', 237, 246],
|
|
|
|
|
" \ ['#665c54', 241],
|
|
|
|
|
" \ ['#282828', '#83a598', 235, 109],
|
|
|
|
|
" \ ['#282828', '#fe8019', 235, 208],
|
|
|
|
|
" \ ['#282828', '#8ec07c', 235, 108],
|
2018-03-24 21:15:45 +08:00
|
|
|
|
" \ ['#282828', '#689d6a', 235, 72],
|
|
|
|
|
" \ ['#282828', '#8f3f71', 235, 132],
|
2017-10-23 03:13:42 +08:00
|
|
|
|
" \ ]
|
|
|
|
|
" <
|
|
|
|
|
"
|
|
|
|
|
let g:spacevim_custom_color_palette = []
|
2019-10-03 22:00:09 +08:00
|
|
|
|
|
|
|
|
|
""
|
|
|
|
|
" @section enable_cursorcolumn, options-enable_cursorcolumn
|
|
|
|
|
" @parentsection options
|
|
|
|
|
" Enable/Disable cursorcolumn. Default is 0, cursorcolumn will be
|
|
|
|
|
" highlighted in normal mode. To enable this feature:
|
|
|
|
|
" >
|
|
|
|
|
" enable_cursorcolumn = true
|
|
|
|
|
" <
|
|
|
|
|
|
2017-10-23 03:13:42 +08:00
|
|
|
|
""
|
2017-05-06 20:36:39 +08:00
|
|
|
|
" Enable/Disable cursorcolumn. Default is 0, cursorcolumn will be
|
|
|
|
|
" highlighted in normal mode. To enable this feature:
|
2017-05-06 20:33:50 +08:00
|
|
|
|
" >
|
2017-05-06 20:36:39 +08:00
|
|
|
|
" let g:spacevim_enable_cursorcolumn = 1
|
2017-05-06 20:33:50 +08:00
|
|
|
|
" <
|
2017-05-06 20:36:39 +08:00
|
|
|
|
let g:spacevim_enable_cursorcolumn = 0
|
2018-06-10 23:30:02 +08:00
|
|
|
|
|
|
|
|
|
""
|
|
|
|
|
" @section error_symbol, options-error_symbol
|
|
|
|
|
" @parentsection options
|
|
|
|
|
" Set the error symbol for SpaceVim's syntax maker. Default is '✖'.
|
|
|
|
|
" >
|
|
|
|
|
" error_symbol = "+"
|
|
|
|
|
" <
|
|
|
|
|
|
2017-01-02 10:38:23 +08:00
|
|
|
|
""
|
2017-02-17 13:56:55 +08:00
|
|
|
|
" Set the error symbol for SpaceVim's syntax maker. Default is '✖'.
|
|
|
|
|
" >
|
2017-01-19 20:41:06 +08:00
|
|
|
|
" let g:spacevim_error_symbol = '+'
|
|
|
|
|
" <
|
2017-01-02 10:38:23 +08:00
|
|
|
|
let g:spacevim_error_symbol = '✖'
|
2019-05-30 21:14:39 +08:00
|
|
|
|
|
|
|
|
|
""
|
|
|
|
|
" @section warning_symbol, options-warning_symbol
|
|
|
|
|
" @parentsection options
|
|
|
|
|
" Set the warning symbol for SpaceVim's syntax maker. Default is '⚠'.
|
|
|
|
|
" >
|
|
|
|
|
" warning_symbol = '!'
|
|
|
|
|
" <
|
|
|
|
|
|
2017-01-19 20:41:06 +08:00
|
|
|
|
""
|
2017-02-17 13:56:55 +08:00
|
|
|
|
" Set the warning symbol for SpaceVim's syntax maker. Default is '⚠'.
|
|
|
|
|
" >
|
2017-01-19 20:41:06 +08:00
|
|
|
|
" let g:spacevim_warning_symbol = '!'
|
|
|
|
|
" <
|
2017-01-02 10:38:23 +08:00
|
|
|
|
let g:spacevim_warning_symbol = '⚠'
|
2019-05-30 21:14:39 +08:00
|
|
|
|
|
|
|
|
|
""
|
|
|
|
|
" @section info_symbol, options-info_symbol
|
|
|
|
|
" @parentsection options
|
|
|
|
|
" Set the information symbol for SpaceVim's syntax maker. Default is '🛈'.
|
|
|
|
|
" >
|
|
|
|
|
" info_symbol = 'i'
|
|
|
|
|
" <
|
|
|
|
|
|
2017-03-26 16:37:49 +08:00
|
|
|
|
""
|
2017-11-19 10:32:59 +08:00
|
|
|
|
" Set the information symbol for SpaceVim's syntax maker. Default is '🛈'.
|
|
|
|
|
" >
|
|
|
|
|
" let g:spacevim_info_symbol = 'i'
|
|
|
|
|
" <
|
2018-01-07 11:01:04 +08:00
|
|
|
|
let g:spacevim_info_symbol = SpaceVim#api#import('messletters').circled_letter('i')
|
2019-05-30 21:14:39 +08:00
|
|
|
|
|
|
|
|
|
""
|
|
|
|
|
" @section terminal_cursor_shape, options-terminal_cursor_shape
|
|
|
|
|
" @parentsection options
|
|
|
|
|
" Set the SpaceVim cursor shape in the terminal.
|
|
|
|
|
" >
|
|
|
|
|
" 0 : to prevent Nvim from changing the cursor shape.
|
|
|
|
|
" 1 : to enable non-blinking mode-sensitive cursor.
|
|
|
|
|
" 2 : to enable blinking mode-sensitive cursor (default).
|
|
|
|
|
" >
|
|
|
|
|
" Host terminal must support the DECSCUSR CSI escape sequence.
|
|
|
|
|
" Depending on the terminal emulator, using this option with nvim under
|
|
|
|
|
" tmux might require adding the following to ~/.tmux.conf:
|
|
|
|
|
" >
|
|
|
|
|
" set -ga terminal-overrides ',*:Ss=\E[%p1%d q:Se=\E[2 q'
|
|
|
|
|
" <
|
|
|
|
|
|
2017-11-19 10:32:59 +08:00
|
|
|
|
""
|
2018-12-19 23:59:41 +08:00
|
|
|
|
" Set the SpaceVim cursor shape in the terminal.
|
2017-12-10 00:23:18 +08:00
|
|
|
|
" >
|
|
|
|
|
" 0 : to prevent Nvim from changing the cursor shape.
|
|
|
|
|
" 1 : to enable non-blinking mode-sensitive cursor.
|
|
|
|
|
" 2 : to enable blinking mode-sensitive cursor (default).
|
|
|
|
|
" >
|
|
|
|
|
" Host terminal must support the DECSCUSR CSI escape sequence.
|
2017-03-26 16:37:49 +08:00
|
|
|
|
" Depending on the terminal emulator, using this option with nvim under
|
|
|
|
|
" tmux might require adding the following to ~/.tmux.conf:
|
|
|
|
|
" >
|
|
|
|
|
" set -ga terminal-overrides ',*:Ss=\E[%p1%d q:Se=\E[2 q'
|
|
|
|
|
" <
|
|
|
|
|
let g:spacevim_terminal_cursor_shape = 2
|
2019-10-03 22:00:09 +08:00
|
|
|
|
""
|
|
|
|
|
" @section vim_help_language, options-vim_help_language
|
|
|
|
|
" @parentsection options
|
|
|
|
|
" Set the help language of vim. Default is 'en'.
|
|
|
|
|
" You can change it to Chinese.
|
|
|
|
|
" >
|
|
|
|
|
" vim_help_language = "cn"
|
|
|
|
|
" <
|
|
|
|
|
|
2017-01-19 20:41:06 +08:00
|
|
|
|
""
|
2018-12-19 23:59:41 +08:00
|
|
|
|
" Set the help language of vim. Default is 'en'.
|
2017-02-17 13:56:55 +08:00
|
|
|
|
" You can change it to Chinese.
|
2017-01-19 20:41:06 +08:00
|
|
|
|
" >
|
2017-10-23 21:25:59 +08:00
|
|
|
|
" let g:spacevim_vim_help_language = 'cn'
|
2017-01-19 20:41:06 +08:00
|
|
|
|
" <
|
2017-01-02 10:38:23 +08:00
|
|
|
|
let g:spacevim_vim_help_language = 'en'
|
2019-05-30 21:14:39 +08:00
|
|
|
|
""
|
|
|
|
|
" @section language, options-language
|
|
|
|
|
" @parentsection options
|
|
|
|
|
" Set the message language of vim. Default is 'en_US.UTF-8'.
|
|
|
|
|
" >
|
|
|
|
|
" language = 'en_CA.utf8'
|
|
|
|
|
" <
|
|
|
|
|
|
2017-01-02 10:38:23 +08:00
|
|
|
|
""
|
2017-02-17 13:56:55 +08:00
|
|
|
|
" Set the message language of vim. Default is 'en_US.UTF-8'.
|
2017-01-30 20:36:03 +08:00
|
|
|
|
" >
|
|
|
|
|
" let g:spacevim_language = 'en_CA.utf8'
|
|
|
|
|
" <
|
|
|
|
|
let g:spacevim_language = ''
|
2019-05-30 21:14:39 +08:00
|
|
|
|
""
|
|
|
|
|
" @section keep_server_alive, options-keep_server_alive
|
|
|
|
|
" @parentsection options
|
|
|
|
|
" Option for keep the spacevim server ailive
|
|
|
|
|
|
2017-01-30 20:36:03 +08:00
|
|
|
|
""
|
2017-10-04 13:49:14 +08:00
|
|
|
|
" Option for keep the spacevim server ailive
|
|
|
|
|
let g:spacevim_keep_server_alive = 1
|
2019-05-30 21:14:39 +08:00
|
|
|
|
""
|
|
|
|
|
" @section colorscheme, options-colorscheme
|
|
|
|
|
" @parentsection options
|
|
|
|
|
" The colorscheme of SpaceVim. Default is 'gruvbox'.
|
|
|
|
|
|
2017-10-04 13:49:14 +08:00
|
|
|
|
""
|
2017-02-17 13:56:55 +08:00
|
|
|
|
" The colorscheme of SpaceVim. Default is 'gruvbox'.
|
2017-01-02 10:38:23 +08:00
|
|
|
|
let g:spacevim_colorscheme = 'gruvbox'
|
2019-05-30 21:14:39 +08:00
|
|
|
|
""
|
|
|
|
|
" @section colorscheme_bg, options-colorscheme_bg
|
|
|
|
|
" @parentsection options
|
|
|
|
|
" The background of colorscheme. Default is 'dark'.
|
|
|
|
|
|
2017-01-02 10:38:23 +08:00
|
|
|
|
""
|
2017-04-30 15:34:09 +08:00
|
|
|
|
" The background of colorscheme. Default is 'dark'.
|
|
|
|
|
let g:spacevim_colorscheme_bg = 'dark'
|
|
|
|
|
""
|
2018-12-19 23:59:41 +08:00
|
|
|
|
" The default colorscheme of SpaceVim. Default is 'desert'.
|
|
|
|
|
" This colorscheme will be used if the colorscheme set by
|
2017-02-17 13:56:55 +08:00
|
|
|
|
" `g:spacevim_colorscheme` is not installed.
|
2017-01-11 15:40:19 +08:00
|
|
|
|
" >
|
|
|
|
|
" let g:spacevim_colorscheme_default = 'other_color'
|
|
|
|
|
" <
|
2017-01-02 10:38:23 +08:00
|
|
|
|
let g:spacevim_colorscheme_default = 'desert'
|
2019-05-30 21:14:39 +08:00
|
|
|
|
""
|
|
|
|
|
" @section filemanager, options-filemanager
|
|
|
|
|
" @parentsection options
|
2021-09-12 23:06:37 +08:00
|
|
|
|
" The default file manager of SpaceVim. Default is 'nerdtree'.
|
2024-06-27 20:31:55 +08:00
|
|
|
|
" you can also use:
|
|
|
|
|
" 1. defx
|
|
|
|
|
" 2. vimfiler
|
|
|
|
|
" 3. neo-tree
|
|
|
|
|
" 4: nvim-tree
|
2019-05-30 21:14:39 +08:00
|
|
|
|
|
2017-01-11 15:40:19 +08:00
|
|
|
|
""
|
2021-09-12 23:06:37 +08:00
|
|
|
|
" The default file manager of SpaceVim. Default is 'nerdtree'.
|
|
|
|
|
" you can also use defx or vimfiler
|
|
|
|
|
let g:spacevim_filemanager = 'nerdtree'
|
2019-05-30 21:14:39 +08:00
|
|
|
|
""
|
|
|
|
|
" @section filetree_direction, options-filetree_direction
|
|
|
|
|
" @parentsection options
|
|
|
|
|
" Config the direction of file tree. Default is 'right'. you can also set to
|
2020-12-20 19:36:17 +08:00
|
|
|
|
" 'left'.
|
2019-05-30 21:14:39 +08:00
|
|
|
|
"
|
|
|
|
|
" NOTE: if it is 'left', the tagbar will be move to right.
|
2018-09-15 09:21:38 +08:00
|
|
|
|
|
2019-03-14 00:03:35 +08:00
|
|
|
|
""
|
|
|
|
|
" Config the direction of file tree. Default is 'right'. you can also set to
|
2020-12-20 19:36:17 +08:00
|
|
|
|
" 'left'.
|
2019-03-14 00:03:35 +08:00
|
|
|
|
"
|
|
|
|
|
" NOTE: if it is 'left', the tagbar will be move to right.
|
|
|
|
|
let g:spacevim_filetree_direction = 'right'
|
|
|
|
|
|
2018-09-15 09:21:38 +08:00
|
|
|
|
let g:spacevim_sidebar_direction = ''
|
2017-01-02 10:38:23 +08:00
|
|
|
|
""
|
2018-07-21 15:34:13 +08:00
|
|
|
|
" The default plugin manager of SpaceVim.
|
|
|
|
|
" if has patch 7.4.2071, the default value is dein. Otherwise it is neobundle.
|
2017-02-17 13:56:55 +08:00
|
|
|
|
" Options are dein, neobundle, or vim-plug.
|
2021-02-21 15:56:37 +08:00
|
|
|
|
if has('patch-7.4.2071')
|
2018-07-21 15:34:13 +08:00
|
|
|
|
let g:spacevim_plugin_manager = 'dein'
|
|
|
|
|
else
|
|
|
|
|
let g:spacevim_plugin_manager = 'neobundle'
|
|
|
|
|
endif
|
2018-06-10 23:30:02 +08:00
|
|
|
|
|
|
|
|
|
""
|
|
|
|
|
" @section plugin_manager_processes, options-plugin_manager_processes
|
|
|
|
|
" @parentsection options
|
|
|
|
|
" Set the max process of SpaceVim plugin manager
|
|
|
|
|
|
2017-01-06 21:42:33 +08:00
|
|
|
|
""
|
2017-04-04 23:01:41 +08:00
|
|
|
|
" Set the max process of SpaceVim plugin manager
|
2018-06-10 23:30:02 +08:00
|
|
|
|
let g:spacevim_plugin_manager_processes = 16
|
|
|
|
|
|
|
|
|
|
""
|
|
|
|
|
" @section checkinstall, options-checkinstall
|
|
|
|
|
" @parentsection options
|
|
|
|
|
" Enable/Disable checkinstall on SpaceVim startup. Default is true.
|
|
|
|
|
" >
|
|
|
|
|
" checkinstall = true
|
|
|
|
|
" <
|
|
|
|
|
|
2017-04-04 23:01:41 +08:00
|
|
|
|
""
|
2017-03-29 22:35:02 +08:00
|
|
|
|
" Enable/Disable checkinstall on SpaceVim startup. Default is 1.
|
2017-02-17 13:56:55 +08:00
|
|
|
|
" >
|
2017-03-27 21:19:24 +08:00
|
|
|
|
" let g:spacevim_checkinstall = 1
|
2017-01-06 21:42:33 +08:00
|
|
|
|
" <
|
2017-03-29 22:35:02 +08:00
|
|
|
|
let g:spacevim_checkinstall = 1
|
2017-01-08 16:27:18 +08:00
|
|
|
|
""
|
2019-10-03 22:00:09 +08:00
|
|
|
|
" @section vimcompatible, options-vimcompatible
|
|
|
|
|
" @parentsection options
|
2020-12-20 19:36:17 +08:00
|
|
|
|
" Enable/Disable vimcompatible mode, by default it is false.
|
2019-10-03 22:00:09 +08:00
|
|
|
|
" to enable vimcompatible mode, just add:
|
|
|
|
|
" >
|
|
|
|
|
" vimcompatible = true
|
|
|
|
|
" <
|
|
|
|
|
" In vimcompatible mode all vim origin key bindings will not be changed.
|
|
|
|
|
"
|
|
|
|
|
" Includes:
|
|
|
|
|
" >
|
|
|
|
|
" q smart quit windows
|
|
|
|
|
" s windows key bindings leader
|
2020-04-17 22:23:43 +08:00
|
|
|
|
" , language specific leader
|
|
|
|
|
" <C-a> move cursor to beginning in command line mode
|
|
|
|
|
" <C-b> move cursor to left in command line mode
|
|
|
|
|
" <C-f> move cursor to right in command line mode
|
2019-10-03 22:00:09 +08:00
|
|
|
|
" <C-x> switch buffer
|
|
|
|
|
" <
|
|
|
|
|
|
|
|
|
|
""
|
2020-12-20 19:36:17 +08:00
|
|
|
|
" Enable/Disable vimcompatible mode, by default it is false.
|
2019-10-03 22:00:09 +08:00
|
|
|
|
" to enable vimcompatible mode, just add:
|
|
|
|
|
" >
|
|
|
|
|
" let g:spacevim_vimcompatible = 1
|
|
|
|
|
" <
|
|
|
|
|
" In vimcompatible mode all vim origin key bindings will not be changed.
|
2018-04-29 09:19:12 +08:00
|
|
|
|
"
|
|
|
|
|
" Includes:
|
|
|
|
|
" >
|
|
|
|
|
" q smart quit windows
|
|
|
|
|
" s windows key bindings leader
|
2020-04-17 22:23:43 +08:00
|
|
|
|
" , language specific leader
|
|
|
|
|
" <C-a> move cursor to beginning in command line mode
|
|
|
|
|
" <C-b> move cursor to left in command line mode
|
|
|
|
|
" <C-f> move cursor to right in command line mode
|
2018-04-29 09:19:12 +08:00
|
|
|
|
" <C-x> switch buffer
|
|
|
|
|
" <
|
2018-04-12 20:47:22 +08:00
|
|
|
|
let g:spacevim_vimcompatible = 0
|
2019-05-30 21:14:39 +08:00
|
|
|
|
""
|
|
|
|
|
" @section enable_debug, options-enable_debug
|
|
|
|
|
" @parentsection options
|
|
|
|
|
" Enable/Disable debug mode for SpaceVim. Default is false.
|
|
|
|
|
" >
|
|
|
|
|
" enable_debug = true
|
|
|
|
|
" <
|
|
|
|
|
|
2018-04-12 20:47:22 +08:00
|
|
|
|
""
|
2017-02-17 13:56:55 +08:00
|
|
|
|
" Enable/Disable debug mode for SpaceVim. Default is 0.
|
|
|
|
|
" >
|
2017-01-08 16:27:18 +08:00
|
|
|
|
" let g:spacevim_enable_debug = 1
|
|
|
|
|
" <
|
|
|
|
|
let g:spacevim_enable_debug = 0
|
2017-01-08 23:02:49 +08:00
|
|
|
|
""
|
2017-05-31 22:00:17 +08:00
|
|
|
|
" Auto disable touchpad when switch to insert mode or focuslost in neovim.
|
|
|
|
|
let g:spacevim_auto_disable_touchpad = 1
|
|
|
|
|
""
|
2017-04-07 23:17:01 +08:00
|
|
|
|
" Set the debug level of SpaceVim. Default is 1. see
|
|
|
|
|
" |SpaceVim#logger#setLevel()|
|
2017-01-08 23:02:49 +08:00
|
|
|
|
let g:spacevim_debug_level = 1
|
2017-01-02 10:38:23 +08:00
|
|
|
|
let g:spacevim_hiddenfileinfo = 1
|
2017-11-14 23:08:36 +08:00
|
|
|
|
let g:spacevim_gitcommit_pr_icon = ''
|
2017-11-14 23:16:24 +08:00
|
|
|
|
let g:spacevim_gitcommit_issue_icon = ''
|
2017-02-26 00:46:44 +08:00
|
|
|
|
""
|
2019-06-02 11:59:43 +08:00
|
|
|
|
" @section buffer_index_type, options-buffer_index_type
|
|
|
|
|
" @parentsection options
|
|
|
|
|
" Set SpaceVim buffer index type, default is 4.
|
|
|
|
|
" >
|
|
|
|
|
" # types:
|
|
|
|
|
" # 0: 1 ➛ ➊
|
|
|
|
|
" # 1: 1 ➛ ➀
|
|
|
|
|
" # 2: 1 ➛ ⓵
|
|
|
|
|
" # 3: 1 ➛ ¹
|
|
|
|
|
" # 4: 1 ➛ 1
|
|
|
|
|
" buffer_index_type = 1
|
|
|
|
|
" <
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
""
|
|
|
|
|
" Set SpaceVim buffer index type, default is 4.
|
2017-02-26 00:46:44 +08:00
|
|
|
|
" >
|
|
|
|
|
" " types:
|
2018-12-19 23:59:41 +08:00
|
|
|
|
" " 0: 1 ➛ ➊
|
2017-02-26 00:46:44 +08:00
|
|
|
|
" " 1: 1 ➛ ➀
|
|
|
|
|
" " 2: 1 ➛ ⓵
|
2017-02-26 01:24:03 +08:00
|
|
|
|
" " 3: 1 ➛ ¹
|
|
|
|
|
" " 4: 1 ➛ 1
|
2017-02-26 00:46:44 +08:00
|
|
|
|
" let g:spacevim_buffer_index_type = 1
|
|
|
|
|
" <
|
2019-06-02 11:59:43 +08:00
|
|
|
|
let g:spacevim_buffer_index_type = 4
|
|
|
|
|
|
|
|
|
|
""
|
|
|
|
|
" @section windows_index_type, options-windows_index_type
|
|
|
|
|
" @parentsection options
|
|
|
|
|
" Set SpaceVim windows index type, default is 3.
|
|
|
|
|
" >
|
|
|
|
|
" # types:
|
|
|
|
|
" # 0: 1 ➛ ➊
|
|
|
|
|
" # 1: 1 ➛ ➀
|
|
|
|
|
" # 2: 1 ➛ ⓵
|
|
|
|
|
" # 3: 1 ➛ 1
|
|
|
|
|
" windows_index_type = 1
|
|
|
|
|
" <
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2017-01-02 10:38:23 +08:00
|
|
|
|
""
|
2019-06-02 11:59:43 +08:00
|
|
|
|
" Set SpaceVim windows index type, default is 3.
|
2017-06-01 00:18:32 +08:00
|
|
|
|
" >
|
|
|
|
|
" " types:
|
2018-12-19 23:59:41 +08:00
|
|
|
|
" " 0: 1 ➛ ➊
|
2017-06-01 00:18:32 +08:00
|
|
|
|
" " 1: 1 ➛ ➀
|
|
|
|
|
" " 2: 1 ➛ ⓵
|
2017-09-20 21:24:57 +08:00
|
|
|
|
" " 3: 1 ➛ 1
|
2017-06-01 00:18:32 +08:00
|
|
|
|
" let g:spacevim_windows_index_type = 1
|
|
|
|
|
" <
|
2019-06-02 11:59:43 +08:00
|
|
|
|
let g:spacevim_windows_index_type = 3
|
|
|
|
|
""
|
|
|
|
|
" @section enable_tabline_ft_icon, options-enable_tabline_ft_icon
|
|
|
|
|
" @parentsection options
|
|
|
|
|
" Enable/Disable tabline filetype icon. default is false. To enable this
|
|
|
|
|
" feature:
|
|
|
|
|
" >
|
|
|
|
|
" enable_tabline_ft_icon = true
|
|
|
|
|
" <
|
|
|
|
|
|
|
|
|
|
|
2017-06-01 00:18:32 +08:00
|
|
|
|
""
|
2017-02-26 12:46:31 +08:00
|
|
|
|
" Enable/Disable tabline filetype icon. default is 0.
|
2019-06-02 11:59:43 +08:00
|
|
|
|
let g:spacevim_enable_tabline_ft_icon = 0
|
2017-02-26 12:46:31 +08:00
|
|
|
|
""
|
2017-03-01 21:14:03 +08:00
|
|
|
|
" Enable/Disable os fileformat icon. default is 0.
|
|
|
|
|
let g:spacevim_enable_os_fileformat_icon = 0
|
|
|
|
|
""
|
2017-06-01 20:59:59 +08:00
|
|
|
|
" Set the github username, It will be used for getting your starred repos, and
|
|
|
|
|
" fuzzy find the repo you want.
|
|
|
|
|
let g:spacevim_github_username = ''
|
2019-10-03 22:00:09 +08:00
|
|
|
|
""
|
|
|
|
|
" @section windows_smartclose, options-windows_smartclose
|
|
|
|
|
" @parentsection options
|
|
|
|
|
" Set the default key for smart close windows, default is `q`.
|
|
|
|
|
" to disable this feature, just set it to empty string:
|
|
|
|
|
" >
|
|
|
|
|
" windows_smartclose = ""
|
|
|
|
|
" <
|
|
|
|
|
|
2017-06-01 20:59:59 +08:00
|
|
|
|
""
|
2018-01-14 23:48:44 +08:00
|
|
|
|
" Set the default key for smart close windows, default is `q`.
|
|
|
|
|
let g:spacevim_windows_smartclose = 'q'
|
2022-10-10 02:08:14 +08:00
|
|
|
|
""
|
|
|
|
|
" @section disabled_plugins, options-disabled_plugins
|
|
|
|
|
" @parentsection options
|
|
|
|
|
" >
|
|
|
|
|
" disabled_plugins = ['vim-foo', 'vim-bar']
|
|
|
|
|
" <
|
|
|
|
|
|
2018-01-14 23:48:44 +08:00
|
|
|
|
""
|
2017-02-17 13:56:55 +08:00
|
|
|
|
" Disable plugins by name.
|
|
|
|
|
" >
|
2017-01-05 21:16:45 +08:00
|
|
|
|
" let g:spacevim_disabled_plugins = ['vim-foo', 'vim-bar']
|
|
|
|
|
" <
|
|
|
|
|
let g:spacevim_disabled_plugins = []
|
2020-05-06 20:59:34 +08:00
|
|
|
|
""
|
|
|
|
|
" @section custom_plugins, usage-custom_plugins
|
|
|
|
|
" @parentsection usage
|
2021-10-28 13:46:17 +08:00
|
|
|
|
" If you want to add custom plugin, use `custom_plugins` section. For example:
|
|
|
|
|
" if you want to add https://github.com/vimwiki/vimwiki, add following code
|
|
|
|
|
" into your configuration file.
|
2020-05-06 20:59:34 +08:00
|
|
|
|
" >
|
|
|
|
|
" [[custom_plugins]]
|
2020-07-19 10:47:58 +08:00
|
|
|
|
" repo = 'vimwiki/vimwiki'
|
2020-05-06 20:59:34 +08:00
|
|
|
|
" merged = false
|
|
|
|
|
" <
|
2021-10-28 13:46:17 +08:00
|
|
|
|
" Use one custom_plugins for each plugin, example:
|
|
|
|
|
" >
|
|
|
|
|
" [[custom_plugins]]
|
|
|
|
|
" repo = 'vimwiki/vimwiki'
|
|
|
|
|
" merged = false
|
|
|
|
|
" [[custom_plugins]]
|
|
|
|
|
" repo = 'wsdjeg/vim-j'
|
|
|
|
|
" merged = false
|
|
|
|
|
" <
|
2020-05-06 20:59:34 +08:00
|
|
|
|
|
2017-01-05 21:16:45 +08:00
|
|
|
|
""
|
2017-02-17 13:56:55 +08:00
|
|
|
|
" Add custom plugins.
|
2017-01-09 22:50:06 +08:00
|
|
|
|
" >
|
|
|
|
|
" let g:spacevim_custom_plugins = [
|
|
|
|
|
" \ ['plasticboy/vim-markdown', 'on_ft' : 'markdown'],
|
|
|
|
|
" \ ['wsdjeg/GitHub.vim'],
|
|
|
|
|
" \ ]
|
|
|
|
|
" <
|
|
|
|
|
let g:spacevim_custom_plugins = []
|
|
|
|
|
""
|
2018-01-17 21:34:44 +08:00
|
|
|
|
" change the default filetype icon for a specific filtype.
|
|
|
|
|
" >
|
|
|
|
|
" let g:spacevim_filetype_icons['md'] = ''
|
|
|
|
|
" <
|
|
|
|
|
let g:spacevim_filetype_icons = {}
|
|
|
|
|
""
|
2017-02-17 13:56:55 +08:00
|
|
|
|
" SpaceVim will load the global config after local config if set to 1. Default
|
2018-12-19 23:59:41 +08:00
|
|
|
|
" is 0. If you have a local config, the global config will not be loaded.
|
2017-01-10 00:27:52 +08:00
|
|
|
|
" >
|
|
|
|
|
" let g:spacevim_force_global_config = 1
|
|
|
|
|
" <
|
|
|
|
|
let g:spacevim_force_global_config = 0
|
|
|
|
|
""
|
2017-02-17 13:56:55 +08:00
|
|
|
|
" Enable/Disable powerline symbols. Default is 1.
|
2017-01-02 10:38:23 +08:00
|
|
|
|
let g:spacevim_enable_powerline_fonts = 1
|
2017-01-07 23:01:13 +08:00
|
|
|
|
""
|
2017-02-17 13:56:55 +08:00
|
|
|
|
" Enable/Disable lint on save feature of SpaceVim's maker. Default is 1.
|
2017-01-07 23:01:13 +08:00
|
|
|
|
" >
|
|
|
|
|
" let g:spacevim_lint_on_save = 0
|
|
|
|
|
" <
|
2022-05-22 17:10:34 +08:00
|
|
|
|
" NOTE: the `lint_on_save` option has been deprecated. Please use layer option
|
|
|
|
|
" of @section(layers-checkers) layer.
|
2017-01-07 23:01:13 +08:00
|
|
|
|
let g:spacevim_lint_on_save = 1
|
2020-08-21 22:36:25 +08:00
|
|
|
|
""
|
|
|
|
|
" @section search_tools, options-search_tools
|
|
|
|
|
" @parentsection options
|
|
|
|
|
" Default search tools supported by flygrep. The default order is ['rg', 'ag',
|
|
|
|
|
" 'pt', 'ack', 'grep', 'findstr', 'git']
|
|
|
|
|
" The `git` command means using `git-grep`. If you prefer to use `git-grep` by
|
|
|
|
|
" default. You can change this option to:
|
|
|
|
|
" >
|
|
|
|
|
" [options]
|
|
|
|
|
" search_tools = ['git', 'rg', 'ag']
|
|
|
|
|
" <
|
|
|
|
|
|
2018-12-15 14:16:11 +08:00
|
|
|
|
""
|
|
|
|
|
" Default search tools supported by flygrep. The default order is ['rg', 'ag',
|
2020-08-21 22:36:25 +08:00
|
|
|
|
" 'pt', 'ack', 'grep', 'findstr', 'git']
|
|
|
|
|
let g:spacevim_search_tools = ['rg', 'ag', 'pt', 'ack', 'grep', 'findstr', 'git']
|
2017-02-04 00:47:16 +08:00
|
|
|
|
""
|
2020-09-27 22:49:44 +08:00
|
|
|
|
" @section project_rooter_patterns, options-project_rooter_patterns
|
|
|
|
|
" @parentsection options
|
|
|
|
|
" Set the project root patterns, SpaceVim determines the root directory of the
|
|
|
|
|
" project based on this option. By default it is:
|
|
|
|
|
" >
|
|
|
|
|
" ['.git/', '_darcs/', '.hg/', '.bzr/', '.svn/']
|
|
|
|
|
" <
|
|
|
|
|
|
|
|
|
|
""
|
|
|
|
|
" Set the project root patterns, SpaceVim determines the root directory of the
|
|
|
|
|
" project based on this option. By default it is:
|
|
|
|
|
" >
|
|
|
|
|
" ['.git/', '_darcs/', '.hg/', '.bzr/', '.svn/']
|
|
|
|
|
" <
|
2018-01-14 23:08:56 +08:00
|
|
|
|
let g:spacevim_project_rooter_patterns = ['.git/', '_darcs/', '.hg/', '.bzr/', '.svn/']
|
2022-04-16 20:41:01 +08:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
""
|
|
|
|
|
" @section project_non_root, options-project_non_root
|
|
|
|
|
" @parentsection options
|
|
|
|
|
" This option set the default behavior for non-project files.
|
|
|
|
|
" - `current`: change to file's dir, like `autochdir`
|
|
|
|
|
" - `''`: do not change directory
|
|
|
|
|
" - `home`: change to home directory
|
|
|
|
|
|
|
|
|
|
let g:spacevim_project_non_root = ''
|
|
|
|
|
|
|
|
|
|
|
2020-09-27 22:49:44 +08:00
|
|
|
|
""
|
2020-10-08 12:05:34 +08:00
|
|
|
|
" @section enable_projects_cache, options-enable_projects_cache
|
|
|
|
|
" @parentsection options
|
|
|
|
|
" Enable/Disable cross session projects cache. Enabled by default.
|
|
|
|
|
|
|
|
|
|
""
|
|
|
|
|
" Enable/Disable cross session projects cache. Enabled by default.
|
|
|
|
|
let g:spacevim_enable_projects_cache = 1
|
|
|
|
|
""
|
|
|
|
|
" @section projects_cache_num, options-projects_cache_num
|
|
|
|
|
" @parentsection options
|
|
|
|
|
" Setting the numbers of cached projects, by default it is 20.
|
|
|
|
|
|
|
|
|
|
""
|
|
|
|
|
" Setting the numbers of cached projects, by default it is 20.
|
|
|
|
|
let g:spacevim_projects_cache_num = 20
|
|
|
|
|
""
|
2021-09-25 21:00:22 +08:00
|
|
|
|
" @section project_auto_root, options-project_auto_root
|
2020-09-27 22:49:44 +08:00
|
|
|
|
" @parentsection options
|
|
|
|
|
" Enable/Disable project root detection. By default, SpaceVim will change the
|
|
|
|
|
" directory to the project root directory based on `project_rooter_patterns`
|
|
|
|
|
" option. To disable this feature:
|
|
|
|
|
" >
|
|
|
|
|
" [options]
|
2021-09-25 21:00:22 +08:00
|
|
|
|
" project_auto_root = false
|
2020-09-27 22:49:44 +08:00
|
|
|
|
" <
|
2021-09-25 21:00:22 +08:00
|
|
|
|
" NOTE: *g:spacevim_project_rooter_automatically* and
|
|
|
|
|
" *SpaceVim-options-project_rooter_automatically* are deprecated.
|
2020-09-27 22:49:44 +08:00
|
|
|
|
|
2018-01-14 23:08:56 +08:00
|
|
|
|
""
|
|
|
|
|
" Enable/Disable changing directory automatically. Enabled by default.
|
2021-09-25 21:00:22 +08:00
|
|
|
|
let g:spacevim_project_auto_root = 1
|
2020-07-05 22:09:46 +08:00
|
|
|
|
""
|
2020-09-27 22:49:44 +08:00
|
|
|
|
" @section project_rooter_outermost, options-project_rooter_outermost
|
|
|
|
|
" @parentsection options
|
2020-07-05 22:09:46 +08:00
|
|
|
|
" Enable/Disable finding outermost directory for project root detection.
|
2020-09-27 22:49:44 +08:00
|
|
|
|
" By default SpaceVim will find the outermost directory based on
|
|
|
|
|
" `project_rooter_patterns`. To find nearest directory, you need to disable
|
|
|
|
|
" this option:
|
|
|
|
|
" >
|
|
|
|
|
" [options]
|
|
|
|
|
" project_rooter_outermost = false
|
|
|
|
|
" <
|
|
|
|
|
|
|
|
|
|
""
|
|
|
|
|
" Enable/Disable finding outermost directory for project root detection.
|
|
|
|
|
" By default SpaceVim will find the outermost directory based on
|
|
|
|
|
" `project_rooter_patterns`. To find nearest directory, you need to disable
|
|
|
|
|
" this option:
|
|
|
|
|
" >
|
|
|
|
|
" let g:spacevim_project_rooter_outermost = 0
|
|
|
|
|
" <
|
2020-07-05 22:09:46 +08:00
|
|
|
|
let g:spacevim_project_rooter_outermost = 1
|
2022-04-06 23:48:01 +08:00
|
|
|
|
""
|
|
|
|
|
" @section commandline_prompt, options-commandline_prompt
|
|
|
|
|
" @parentsection options
|
|
|
|
|
" Config the command line prompt for flygrep and denite etc.
|
|
|
|
|
" Default is `>`, for example:
|
|
|
|
|
" >
|
|
|
|
|
" commandline_prompt = '➭'
|
|
|
|
|
" <
|
2018-06-10 23:30:02 +08:00
|
|
|
|
|
2018-12-22 22:18:19 +08:00
|
|
|
|
""
|
|
|
|
|
" Config the command line prompt for flygrep and denite etc.
|
2022-04-06 23:48:01 +08:00
|
|
|
|
let g:spacevim_commandline_prompt = '>'
|
2018-12-22 22:18:19 +08:00
|
|
|
|
|
2022-04-05 20:17:35 +08:00
|
|
|
|
""
|
|
|
|
|
" @section todo_labels, options-todo_labels
|
|
|
|
|
" @parentsection options
|
|
|
|
|
" Option for setting todo labels in current project.
|
|
|
|
|
|
2020-02-19 18:47:38 +08:00
|
|
|
|
""
|
|
|
|
|
" Option for setting todo labels in current project.
|
2022-04-10 21:37:27 +08:00
|
|
|
|
let g:spacevim_todo_labels = ['fixme', 'question', 'todo', 'idea']
|
|
|
|
|
|
2024-03-24 21:46:37 +08:00
|
|
|
|
""
|
|
|
|
|
" @section todo_close_list, options-close_list
|
|
|
|
|
" @parentsection options
|
|
|
|
|
" Option for setting todo windows behavior when open item in todo list.
|
|
|
|
|
" Default is `true`, set to `false` will not close todo windows.
|
|
|
|
|
|
|
|
|
|
""
|
|
|
|
|
" Option for setting todo windows behavior when open item in todo list.
|
|
|
|
|
" Default is 1, set to 0 will not close todo windows.
|
|
|
|
|
let g:spacevim_todo_close_list = 0
|
|
|
|
|
|
2022-04-10 21:37:27 +08:00
|
|
|
|
""
|
|
|
|
|
" @section todo_prefix, options-todo_prefix
|
|
|
|
|
" @parentsection options
|
|
|
|
|
" Option for setting todo prefix in current project.
|
|
|
|
|
" The default is `@`
|
|
|
|
|
|
|
|
|
|
let g:spacevim_todo_prefix = '@'
|
2020-02-19 18:47:38 +08:00
|
|
|
|
|
2018-06-10 23:30:02 +08:00
|
|
|
|
""
|
|
|
|
|
" @section lint_on_the_fly, options-lint_on_the_fly
|
|
|
|
|
" @parentsection options
|
|
|
|
|
" Enable/Disable lint on the fly feature of SpaceVim's maker. Default is true.
|
|
|
|
|
" >
|
|
|
|
|
" lint_on_the_fly = false
|
|
|
|
|
" <
|
2022-05-22 17:10:34 +08:00
|
|
|
|
" NOTE: the `lint_on_the_fly` option has been deprecated. Please use layer option
|
|
|
|
|
" of @section(layers-checkers) layer.
|
2018-06-10 23:30:02 +08:00
|
|
|
|
|
2018-01-14 23:08:56 +08:00
|
|
|
|
""
|
2017-04-08 23:54:44 +08:00
|
|
|
|
" Enable/Disable lint on the fly feature of SpaceVim's maker. Default is 0.
|
|
|
|
|
" >
|
|
|
|
|
" let g:spacevim_lint_on_the_fly = 0
|
|
|
|
|
" <
|
|
|
|
|
let g:spacevim_lint_on_the_fly = 0
|
2019-05-06 10:34:02 +08:00
|
|
|
|
|
|
|
|
|
""
|
|
|
|
|
" @section retry_cnt, options-retry_cnt
|
|
|
|
|
" @parentsection options
|
|
|
|
|
" Set the number of retries for SpaceVim Update when failed. Default is 3.
|
|
|
|
|
" Set to 0 to disable this feature, or you can set to another number.
|
|
|
|
|
" >
|
|
|
|
|
" update_retry_cnt = 3
|
|
|
|
|
" <
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
""
|
|
|
|
|
" Set the number of retries for SpaceVim Update when failed. Default is 3.
|
|
|
|
|
" Set to 0 to disable this feature, or you can set to another number.
|
|
|
|
|
" >
|
|
|
|
|
" let g:spacevim_update_retry_cnt = 3
|
|
|
|
|
" <
|
|
|
|
|
let g:spacevim_update_retry_cnt = 3
|
2019-06-08 21:14:13 +08:00
|
|
|
|
""
|
|
|
|
|
" @section enable_vimfiler_welcome, options-enable_vimfiler_welcome
|
|
|
|
|
" @parentsection options
|
|
|
|
|
" Enable/Disable vimfiler in the welcome windows. Default is true.
|
|
|
|
|
" This will cause vim to start up slowly if there are too many files in the
|
|
|
|
|
" current directory.
|
|
|
|
|
" >
|
|
|
|
|
" enable_vimfiler_welcome = false
|
|
|
|
|
" <
|
2019-05-06 10:34:02 +08:00
|
|
|
|
|
2017-04-08 23:54:44 +08:00
|
|
|
|
""
|
2018-12-19 23:59:41 +08:00
|
|
|
|
" Enable/Disable vimfiler in the welcome windows. Default is 1.
|
2017-02-17 13:56:55 +08:00
|
|
|
|
" This will cause vim to start up slowly if there are too many files in the
|
2018-12-19 23:59:41 +08:00
|
|
|
|
" current directory.
|
2017-02-04 00:47:16 +08:00
|
|
|
|
" >
|
|
|
|
|
" let g:spacevim_enable_vimfiler_welcome = 0
|
|
|
|
|
" <
|
|
|
|
|
let g:spacevim_enable_vimfiler_welcome = 1
|
2017-04-03 19:32:19 +08:00
|
|
|
|
""
|
2019-10-01 11:34:24 +08:00
|
|
|
|
" @section autocomplete_parens, options-autocomplete_parens
|
|
|
|
|
" @parentsection options
|
|
|
|
|
" Enable/Disable autocompletion of parentheses, default is true (enabled).
|
|
|
|
|
" >
|
|
|
|
|
" autocomplete_parens = false
|
|
|
|
|
" <
|
|
|
|
|
|
|
|
|
|
""
|
|
|
|
|
" Enable/Disable autocompletion of parentheses, default is 1 (enabled).
|
|
|
|
|
let g:spacevim_autocomplete_parens = 1
|
2017-01-02 10:38:23 +08:00
|
|
|
|
let g:spacevim_smartcloseignorewin = ['__Tagbar__' , 'vimfiler:default']
|
2017-12-13 22:28:26 +08:00
|
|
|
|
let g:spacevim_smartcloseignoreft = [
|
|
|
|
|
\ 'tagbar',
|
2023-06-11 20:17:47 +08:00
|
|
|
|
\ 'neo-tree',
|
2017-12-13 22:28:26 +08:00
|
|
|
|
\ 'vimfiler',
|
2019-03-10 20:49:12 +08:00
|
|
|
|
\ 'defx',
|
2022-05-19 09:03:59 +08:00
|
|
|
|
\ 'NvimTree',
|
2017-12-13 22:28:26 +08:00
|
|
|
|
\ 'SpaceVimRunner',
|
|
|
|
|
\ 'SpaceVimREPL',
|
|
|
|
|
\ 'SpaceVimQuickFix',
|
|
|
|
|
\ 'HelpDescribe',
|
|
|
|
|
\ 'VebuggerShell',
|
|
|
|
|
\ 'VebuggerTerminal',
|
2024-02-23 17:08:52 +08:00
|
|
|
|
\ 'SpaceVimTabsManager',
|
|
|
|
|
\ 'SpaceVimGitRemoteManager'
|
2017-12-13 22:28:26 +08:00
|
|
|
|
\ ]
|
2018-07-28 15:25:12 +08:00
|
|
|
|
let g:_spacevim_altmoveignoreft = ['Tagbar' , 'vimfiler']
|
2024-03-21 18:25:14 +08:00
|
|
|
|
let g:_spacevim_mappings_space = {}
|
|
|
|
|
let g:_spacevim_mappings_prefixs = {}
|
|
|
|
|
let g:_spacevim_mappings_windows = {}
|
2017-01-02 10:38:23 +08:00
|
|
|
|
let g:spacevim_enable_javacomplete2_py = 0
|
2023-03-31 12:18:23 +08:00
|
|
|
|
""
|
|
|
|
|
" @section src_root, options-src_root
|
|
|
|
|
" @parentsection options
|
|
|
|
|
" set default sources root of all your projects. default is `E:\sources\`.
|
|
|
|
|
" >
|
|
|
|
|
" src_root = 'E:\sources\'
|
|
|
|
|
" <
|
|
|
|
|
|
2017-01-02 10:38:23 +08:00
|
|
|
|
let g:spacevim_src_root = 'E:\sources\'
|
|
|
|
|
""
|
2017-02-17 13:56:55 +08:00
|
|
|
|
" The host file url. This option is for Chinese users who can not use
|
|
|
|
|
" Google and Twitter.
|
2017-03-07 22:11:41 +08:00
|
|
|
|
let g:spacevim_hosts_url
|
|
|
|
|
\ = 'https://raw.githubusercontent.com/racaljk/hosts/master/hosts'
|
2022-04-06 00:38:39 +08:00
|
|
|
|
""
|
|
|
|
|
" @section wildignore, options-wildignore
|
|
|
|
|
" @parentsection options
|
|
|
|
|
" A list of file patterns when file match it will be ignored.
|
|
|
|
|
" >
|
|
|
|
|
" wildignore = '*/tmp/*,*.so,*.swp,*.zip,*.class,tags,*.jpg,*.ttf,*.TTF,*.png,*/target/*,.git,.svn,.hg,.DS_Store,*.svg'
|
|
|
|
|
" <
|
|
|
|
|
|
2017-03-07 22:11:41 +08:00
|
|
|
|
let g:spacevim_wildignore
|
2022-04-06 00:38:39 +08:00
|
|
|
|
\ = '*/tmp/*,*.so,*.swp,*.zip,*.class,tags,*.jpg,*.ttf,*.TTF,*.png,*/target/*,.git,.svn,.hg,.DS_Store,*.svg'
|
2018-02-22 21:15:46 +08:00
|
|
|
|
|
|
|
|
|
" }}}
|
|
|
|
|
|
|
|
|
|
|
2018-08-01 06:44:34 +08:00
|
|
|
|
" Private SpaceVim options
|
2017-03-14 00:57:16 +08:00
|
|
|
|
let g:_spacevim_mappings = {}
|
2017-05-14 22:14:38 +08:00
|
|
|
|
let g:_spacevim_mappings_space_custom = []
|
2017-12-01 20:16:24 +08:00
|
|
|
|
let g:_spacevim_mappings_space_custom_group_name = []
|
2022-10-24 22:24:51 +08:00
|
|
|
|
let g:_spacevim_mappings_leader_custom = []
|
|
|
|
|
let g:_spacevim_mappings_leader_custom_group_name = []
|
2020-12-20 19:36:17 +08:00
|
|
|
|
let g:_spacevim_mappings_language_specified_space_custom = {}
|
2021-11-04 14:37:30 +08:00
|
|
|
|
let g:_spacevim_mappings_lang_group_name = {}
|
2018-06-15 20:41:11 +08:00
|
|
|
|
let g:_spacevim_neobundle_installed = 0
|
|
|
|
|
let g:_spacevim_dein_installed = 0
|
|
|
|
|
let g:_spacevim_vim_plug_installed = 0
|
2017-03-14 00:57:16 +08:00
|
|
|
|
|
|
|
|
|
if !exists('g:leaderGuide_vertical')
|
2017-03-14 06:56:03 +08:00
|
|
|
|
let g:leaderGuide_vertical = 0
|
2017-03-14 00:57:16 +08:00
|
|
|
|
endif
|
|
|
|
|
|
2017-03-16 23:48:50 +08:00
|
|
|
|
let g:spacevim_leader_guide_vertical = 0
|
|
|
|
|
|
2017-03-14 00:57:16 +08:00
|
|
|
|
if !exists('g:leaderGuide_sort_horizontal')
|
2017-03-14 06:56:03 +08:00
|
|
|
|
let g:leaderGuide_sort_horizontal = 0
|
2017-03-14 00:57:16 +08:00
|
|
|
|
endif
|
|
|
|
|
|
2017-03-16 23:48:50 +08:00
|
|
|
|
let g:spacevim_leader_guide_sort_horizontal = 0
|
|
|
|
|
|
2017-03-14 00:57:16 +08:00
|
|
|
|
if !exists('g:leaderGuide_position')
|
2017-03-14 06:56:03 +08:00
|
|
|
|
let g:leaderGuide_position = 'botright'
|
2017-03-14 00:57:16 +08:00
|
|
|
|
endif
|
|
|
|
|
|
2017-03-16 23:48:50 +08:00
|
|
|
|
let g:spacevim_leader_guide_position = 'botright'
|
|
|
|
|
|
2017-03-14 00:57:16 +08:00
|
|
|
|
if !exists('g:leaderGuide_run_map_on_popup')
|
2017-03-14 06:56:03 +08:00
|
|
|
|
let g:leaderGuide_run_map_on_popup = 1
|
2017-03-14 00:57:16 +08:00
|
|
|
|
endif
|
|
|
|
|
|
2017-03-16 23:48:50 +08:00
|
|
|
|
let g:spacevim_leader_guide_run_map_on_popup = 1
|
|
|
|
|
|
2018-02-03 21:13:00 +08:00
|
|
|
|
if !exists('g:leaderGuide_hspace')
|
2017-03-14 06:56:03 +08:00
|
|
|
|
let g:leaderGuide_hspace = 5
|
2017-03-14 00:57:16 +08:00
|
|
|
|
endif
|
|
|
|
|
|
2017-03-16 23:48:50 +08:00
|
|
|
|
let g:spacevim_leader_guide_hspace = 5
|
|
|
|
|
|
2018-02-03 21:13:00 +08:00
|
|
|
|
if !exists('g:leaderGuide_flatten')
|
2017-03-14 06:56:03 +08:00
|
|
|
|
let g:leaderGuide_flatten = 1
|
2017-03-14 00:57:16 +08:00
|
|
|
|
endif
|
|
|
|
|
|
2017-03-16 23:48:50 +08:00
|
|
|
|
let g:spacevim_leader_guide_flatten = 1
|
|
|
|
|
|
2018-02-03 21:13:00 +08:00
|
|
|
|
if !exists('g:leaderGuide_default_group_name')
|
|
|
|
|
let g:leaderGuide_default_group_name = ''
|
2017-03-14 00:57:16 +08:00
|
|
|
|
endif
|
|
|
|
|
|
2018-02-03 21:13:00 +08:00
|
|
|
|
let g:spacevim_leader_guide_default_group_name = ''
|
2017-03-16 23:48:50 +08:00
|
|
|
|
|
2018-02-03 21:13:00 +08:00
|
|
|
|
if !exists('g:leaderGuide_max_size')
|
2017-03-14 06:56:03 +08:00
|
|
|
|
let g:leaderGuide_max_size = 0
|
2017-03-14 00:57:16 +08:00
|
|
|
|
endif
|
|
|
|
|
|
2017-03-16 23:48:50 +08:00
|
|
|
|
let g:spacevim_leader_guide_max_size = 0
|
|
|
|
|
|
2018-02-03 21:13:00 +08:00
|
|
|
|
if !exists('g:leaderGuide_submode_mappings')
|
2018-12-19 23:59:41 +08:00
|
|
|
|
let g:leaderGuide_submode_mappings =
|
2017-04-22 08:21:27 +08:00
|
|
|
|
\ { '<C-C>': 'win_close', 'n': 'page_down', 'p': 'page_up', 'u' : 'undo'}
|
2017-03-14 00:57:16 +08:00
|
|
|
|
endif
|
|
|
|
|
|
2018-02-03 21:13:00 +08:00
|
|
|
|
let g:spacevim_leader_guide_submode_mappings = {'<C-C>': 'win_close'}
|
2017-03-14 00:57:16 +08:00
|
|
|
|
|
2017-11-19 22:35:28 +08:00
|
|
|
|
" SpaceVim/LanguageClient-neovim {{{
|
|
|
|
|
if !exists('g:LanguageClient_serverCommands')
|
|
|
|
|
let g:LanguageClient_serverCommands = {}
|
|
|
|
|
endif
|
|
|
|
|
" }}}
|
2017-03-14 00:57:16 +08:00
|
|
|
|
|
|
|
|
|
|
2022-04-11 22:03:48 +08:00
|
|
|
|
command! -nargs=1 LeaderGuide call SpaceVim#mapping#guide#start_by_prefix('0', <args>)
|
|
|
|
|
command! -range -nargs=1 LeaderGuideVisual call SpaceVim#mapping#guide#start_by_prefix('1', <args>)
|
2016-12-29 18:53:29 +08:00
|
|
|
|
|
2024-07-05 23:11:59 +08:00
|
|
|
|
function! s:lazy_end(...) abort
|
2024-07-09 17:31:23 +08:00
|
|
|
|
|
2019-10-03 22:00:09 +08:00
|
|
|
|
if g:spacevim_vimcompatible
|
2018-04-12 20:47:22 +08:00
|
|
|
|
let g:spacevim_windows_leader = ''
|
2019-10-03 22:00:09 +08:00
|
|
|
|
let g:spacevim_windows_smartclose = ''
|
2018-04-12 20:47:22 +08:00
|
|
|
|
endif
|
2018-09-17 21:09:15 +08:00
|
|
|
|
|
|
|
|
|
if !g:spacevim_vimcompatible
|
|
|
|
|
cnoremap <C-f> <Right>
|
|
|
|
|
" Navigation in command line
|
|
|
|
|
cnoremap <C-a> <Home>
|
|
|
|
|
cnoremap <C-b> <Left>
|
2020-02-14 21:39:42 +08:00
|
|
|
|
" @bug_vim with <silent> command line can not be cleared
|
|
|
|
|
cnoremap <expr> <C-k> repeat('<Delete>', strchars(getcmdline()) - getcmdpos() + 1)
|
2020-06-30 22:25:15 +08:00
|
|
|
|
|
|
|
|
|
"Use escape_key_binding switch to normal mode
|
|
|
|
|
if !empty(g:spacevim_escape_key_binding)
|
|
|
|
|
exe printf('inoremap %s <esc>', g:spacevim_escape_key_binding)
|
|
|
|
|
endif
|
2018-09-17 21:09:15 +08:00
|
|
|
|
endif
|
2021-01-02 17:58:45 +08:00
|
|
|
|
|
2018-02-22 21:15:46 +08:00
|
|
|
|
call SpaceVim#server#connect()
|
|
|
|
|
|
2017-11-23 09:44:40 +08:00
|
|
|
|
if g:spacevim_enable_neocomplcache
|
|
|
|
|
let g:spacevim_autocomplete_method = 'neocomplcache'
|
|
|
|
|
endif
|
|
|
|
|
if g:spacevim_enable_ycm
|
|
|
|
|
if has('python') || has('python3')
|
|
|
|
|
let g:spacevim_autocomplete_method = 'ycm'
|
|
|
|
|
else
|
|
|
|
|
call SpaceVim#logger#warn('YCM need +python or +python3 support, force to using ' . g:spacevim_autocomplete_method)
|
|
|
|
|
endif
|
|
|
|
|
endif
|
2017-10-04 13:49:14 +08:00
|
|
|
|
if g:spacevim_keep_server_alive
|
|
|
|
|
call SpaceVim#server#export_server()
|
|
|
|
|
endif
|
2017-03-06 23:26:26 +08:00
|
|
|
|
if !empty(g:spacevim_windows_leader)
|
|
|
|
|
call SpaceVim#mapping#leader#defindWindowsLeader(g:spacevim_windows_leader)
|
|
|
|
|
endif
|
2018-01-05 01:36:27 +08:00
|
|
|
|
call SpaceVim#mapping#g#init()
|
|
|
|
|
call SpaceVim#mapping#z#init()
|
2017-05-07 23:33:03 +08:00
|
|
|
|
call SpaceVim#mapping#leader#defindKEYs()
|
|
|
|
|
call SpaceVim#mapping#space#init()
|
2017-04-04 10:35:38 +08:00
|
|
|
|
if !SpaceVim#mapping#guide#has_configuration()
|
|
|
|
|
let g:leaderGuide_map = {}
|
|
|
|
|
call SpaceVim#mapping#guide#register_prefix_descriptions('', 'g:leaderGuide_map')
|
|
|
|
|
endif
|
2018-03-03 21:52:08 +08:00
|
|
|
|
if g:spacevim_vim_help_language ==# 'cn'
|
2018-09-29 23:16:47 +08:00
|
|
|
|
let &helplang = 'cn'
|
2018-03-03 21:52:08 +08:00
|
|
|
|
elseif g:spacevim_vim_help_language ==# 'ja'
|
2018-09-29 23:16:47 +08:00
|
|
|
|
let &helplang = 'jp'
|
2017-03-06 23:26:26 +08:00
|
|
|
|
endif
|
|
|
|
|
" generate tags for SpaceVim
|
2019-02-03 00:07:31 +08:00
|
|
|
|
let help = fnamemodify(g:_spacevim_root_dir, ':p:h') . '/doc'
|
2018-02-22 21:15:46 +08:00
|
|
|
|
try
|
|
|
|
|
exe 'helptags ' . help
|
|
|
|
|
catch
|
|
|
|
|
call SpaceVim#logger#warn('Failed to generate helptags for SpaceVim')
|
|
|
|
|
endtry
|
2017-03-06 23:26:26 +08:00
|
|
|
|
" set language
|
|
|
|
|
if !empty(g:spacevim_language)
|
|
|
|
|
silent exec 'lan ' . g:spacevim_language
|
|
|
|
|
endif
|
2018-04-01 21:13:49 +08:00
|
|
|
|
" tab options:
|
|
|
|
|
set smarttab
|
|
|
|
|
let &expandtab = g:spacevim_expand_tab
|
2021-06-21 22:49:20 +08:00
|
|
|
|
let &wrap = g:spacevim_wrap_line
|
2023-03-24 09:13:44 +08:00
|
|
|
|
let &list = g:spacevim_enable_list_mode
|
2021-04-04 13:46:48 +08:00
|
|
|
|
|
2021-03-02 09:04:03 +08:00
|
|
|
|
if g:spacevim_default_indent > 0
|
|
|
|
|
let &tabstop = g:spacevim_default_indent
|
|
|
|
|
let &softtabstop = g:spacevim_default_indent
|
|
|
|
|
let &shiftwidth = g:spacevim_default_indent
|
|
|
|
|
endif
|
2017-12-15 21:12:35 +08:00
|
|
|
|
|
2019-06-09 13:04:26 +08:00
|
|
|
|
let g:unite_source_menu_menus =
|
|
|
|
|
\ get(g:,'unite_source_menu_menus',{})
|
|
|
|
|
let g:unite_source_menu_menus.CustomKeyMaps = {'description':
|
|
|
|
|
\ 'Custom mapped keyboard shortcuts [unite]<SPACE>'}
|
|
|
|
|
let g:unite_source_menu_menus.CustomKeyMaps.command_candidates =
|
|
|
|
|
\ get(g:unite_source_menu_menus.CustomKeyMaps,'command_candidates', [])
|
|
|
|
|
let g:unite_source_menu_menus.MyStarredrepos = {'description':
|
|
|
|
|
\ 'All github repos starred by me <leader>ls'}
|
|
|
|
|
let g:unite_source_menu_menus.MyStarredrepos.command_candidates =
|
|
|
|
|
\ get(g:unite_source_menu_menus.MyStarredrepos,'command_candidates', [])
|
|
|
|
|
let g:unite_source_menu_menus.MpvPlayer = {'description':
|
|
|
|
|
\ 'Musics list <leader>lm'}
|
|
|
|
|
let g:unite_source_menu_menus.MpvPlayer.command_candidates =
|
|
|
|
|
\ get(g:unite_source_menu_menus.MpvPlayer,'command_candidates', [])
|
2018-04-01 21:13:49 +08:00
|
|
|
|
|
2017-03-14 06:56:03 +08:00
|
|
|
|
if g:spacevim_realtime_leader_guide
|
|
|
|
|
nnoremap <silent><nowait> <leader> :<c-u>LeaderGuide get(g:, 'mapleader', '\')<CR>
|
|
|
|
|
vnoremap <silent> <leader> :<c-u>LeaderGuideVisual get(g:, 'mapleader', '\')<CR>
|
|
|
|
|
endif
|
|
|
|
|
let g:leaderGuide_max_size = 15
|
2021-01-02 17:58:45 +08:00
|
|
|
|
exe 'set wildignore+=' . g:spacevim_wildignore
|
|
|
|
|
" shell
|
|
|
|
|
if has('filterpipe')
|
|
|
|
|
set noshelltemp
|
|
|
|
|
endif
|
2024-07-05 23:11:59 +08:00
|
|
|
|
|
|
|
|
|
endfunction
|
|
|
|
|
|
2024-07-09 17:31:23 +08:00
|
|
|
|
let g:_spacevim_mappings_prefixs['[SPC]'] = {'name' : '+SPC prefix'}
|
|
|
|
|
let g:_spacevim_mappings_space.t = {'name' : '+Toggles'}
|
|
|
|
|
let g:_spacevim_mappings_space.t.h = {'name' : '+Toggles highlight'}
|
|
|
|
|
let g:_spacevim_mappings_space.t.m = {'name' : '+modeline'}
|
|
|
|
|
let g:_spacevim_mappings_space.T = {'name' : '+UI toggles/themes'}
|
|
|
|
|
let g:_spacevim_mappings_space.a = {'name' : '+Applications'}
|
|
|
|
|
let g:_spacevim_mappings_space.b = {'name' : '+Buffers'}
|
|
|
|
|
let g:_spacevim_mappings_space.f = {'name' : '+Files'}
|
|
|
|
|
let g:_spacevim_mappings_space.j = {'name' : '+Jump/Join/Split'}
|
|
|
|
|
let g:_spacevim_mappings_space.m = {'name' : '+Major-mode'}
|
|
|
|
|
let g:_spacevim_mappings_space.w = {'name' : '+Windows'}
|
|
|
|
|
let g:_spacevim_mappings_space.p = {'name' : '+Projects/Packages'}
|
|
|
|
|
let g:_spacevim_mappings_space.h = {'name' : '+Help'}
|
|
|
|
|
let g:_spacevim_mappings_space.n = {'name' : '+Narrow/Numbers'}
|
|
|
|
|
let g:_spacevim_mappings_space.q = {'name' : '+Quit'}
|
|
|
|
|
let g:_spacevim_mappings_space.l = {'name' : '+Language Specified'}
|
|
|
|
|
let g:_spacevim_mappings_space.s = {'name' : '+Searching/Symbol'}
|
|
|
|
|
let g:_spacevim_mappings_space.r = {'name' : '+Registers/rings/resume'}
|
|
|
|
|
let g:_spacevim_mappings_space.d = {'name' : '+Debug'}
|
|
|
|
|
let g:_spacevim_mappings_space.e = {'name' : '+Errors/Encoding'}
|
|
|
|
|
let g:_spacevim_mappings_space.B = {'name' : '+Global buffers'}
|
|
|
|
|
let g:_spacevim_mappings_space.f.v = {'name' : '+Vim/SpaceVim'}
|
2024-07-08 23:01:40 +08:00
|
|
|
|
|
|
|
|
|
function! SpaceVim#end() abort
|
2024-07-05 23:11:59 +08:00
|
|
|
|
let &tabline = ' '
|
|
|
|
|
if has('timers')
|
2024-07-07 22:38:26 +08:00
|
|
|
|
call timer_start(g:spacevim_lazy_conf_timeout, function('s:lazy_end'))
|
2024-07-05 23:11:59 +08:00
|
|
|
|
else
|
|
|
|
|
call s:lazy_end()
|
|
|
|
|
endif
|
|
|
|
|
|
|
|
|
|
if SpaceVim#layers#isLoaded('core#statusline')
|
|
|
|
|
call SpaceVim#layers#core#statusline#init()
|
|
|
|
|
endif
|
|
|
|
|
|
|
|
|
|
call SpaceVim#plugins#load()
|
|
|
|
|
|
2021-01-02 17:58:45 +08:00
|
|
|
|
if g:spacevim_enable_guicolors == 1
|
|
|
|
|
if !has('nvim') && has('patch-7.4.1770')
|
|
|
|
|
let &t_8f = "\<Esc>[38;2;%lu;%lu;%lum"
|
|
|
|
|
let &t_8b = "\<Esc>[48;2;%lu;%lu;%lum"
|
|
|
|
|
endif
|
|
|
|
|
if exists('+termguicolors')
|
|
|
|
|
set termguicolors
|
|
|
|
|
elseif exists('+guicolors')
|
|
|
|
|
set guicolors
|
|
|
|
|
endif
|
|
|
|
|
endif
|
2022-01-02 16:42:59 +08:00
|
|
|
|
|
|
|
|
|
call SpaceVim#autocmds#init()
|
|
|
|
|
|
2021-01-02 17:58:45 +08:00
|
|
|
|
if g:spacevim_colorscheme !=# '' "{{{
|
|
|
|
|
try
|
|
|
|
|
exec 'set background=' . g:spacevim_colorscheme_bg
|
|
|
|
|
exec 'colorscheme ' . g:spacevim_colorscheme
|
|
|
|
|
catch
|
|
|
|
|
exec 'colorscheme '. g:spacevim_colorscheme_default
|
|
|
|
|
endtry
|
|
|
|
|
else
|
|
|
|
|
exec 'colorscheme '. g:spacevim_colorscheme_default
|
|
|
|
|
endif
|
|
|
|
|
if g:spacevim_hiddenfileinfo == 1 && has('patch-7.4.1570')
|
|
|
|
|
set shortmess+=F
|
|
|
|
|
endif
|
2022-05-29 12:44:36 +08:00
|
|
|
|
if !empty(g:spacevim_guifont)
|
|
|
|
|
try
|
2021-01-02 17:58:45 +08:00
|
|
|
|
let &guifont = g:spacevim_guifont
|
2022-05-29 12:44:36 +08:00
|
|
|
|
catch
|
|
|
|
|
call SpaceVim#logger#error('failed to set guifont to: '
|
|
|
|
|
\ . g:spacevim_guifont)
|
|
|
|
|
call SpaceVim#logger#error(' exception: ' . v:exception)
|
|
|
|
|
call SpaceVim#logger#error(' throwpoint: ' . v:throwpoint)
|
|
|
|
|
endtry
|
2021-01-02 17:58:45 +08:00
|
|
|
|
endif
|
2018-02-22 21:15:46 +08:00
|
|
|
|
|
2021-04-04 13:46:48 +08:00
|
|
|
|
if !has('nvim-0.2.0') && !has('nvim')
|
|
|
|
|
" In old version of neovim, &guicursor do not support cursor shape
|
|
|
|
|
" setting.
|
|
|
|
|
let $NVIM_TUI_ENABLE_CURSOR_SHAPE = g:spacevim_terminal_cursor_shape
|
|
|
|
|
else
|
|
|
|
|
if g:spacevim_terminal_cursor_shape == 0
|
|
|
|
|
" prevent nvim from changing the cursor shape
|
|
|
|
|
set guicursor=
|
|
|
|
|
elseif g:spacevim_terminal_cursor_shape == 1
|
|
|
|
|
" enable non-blinking mode-sensitive cursor
|
|
|
|
|
set guicursor=n-v-c:block-blinkon0,i-ci-ve:ver25-blinkon0,r-cr:hor20,o:hor50
|
|
|
|
|
elseif g:spacevim_terminal_cursor_shape == 2
|
|
|
|
|
" enable blinking mode-sensitive cursor
|
|
|
|
|
set guicursor=n-v-c:block-blinkon10,i-ci-ve:ver25-blinkon10,r-cr:hor20,o:hor50
|
2021-01-02 17:58:45 +08:00
|
|
|
|
endif
|
2022-04-05 20:02:08 +08:00
|
|
|
|
set guicursor+=a:Cursor/lCursor
|
2021-01-02 17:58:45 +08:00
|
|
|
|
endif
|
2018-02-22 21:15:46 +08:00
|
|
|
|
filetype plugin indent on
|
|
|
|
|
syntax on
|
2016-12-29 18:53:29 +08:00
|
|
|
|
endfunction
|
|
|
|
|
|
|
|
|
|
|
2018-10-01 10:55:58 +08:00
|
|
|
|
" return [status, dir]
|
|
|
|
|
" status: 0 : no argv
|
|
|
|
|
" 1 : dir
|
2021-10-21 21:52:38 +08:00
|
|
|
|
" 2 : default arguments
|
2022-04-14 00:33:16 +08:00
|
|
|
|
"
|
|
|
|
|
" argc() return number of files
|
|
|
|
|
" argv() return a list of files/directories
|
2018-10-01 10:55:58 +08:00
|
|
|
|
function! s:parser_argv() abort
|
2022-04-20 22:16:18 +08:00
|
|
|
|
if exists('v:argv')
|
2024-03-05 23:57:33 +08:00
|
|
|
|
call SpaceVim#logger#info('v:argv is:' . string(v:argv))
|
2022-04-20 22:16:18 +08:00
|
|
|
|
" if use embed nvim
|
|
|
|
|
" for exmaple: neovim-qt
|
2022-04-21 00:18:09 +08:00
|
|
|
|
" or only run vim/neovim without argvs
|
2024-06-25 10:26:31 +08:00
|
|
|
|
if len(v:argv) == 1 || (len(v:argv) == 2 && index(v:argv, '--embed') == 1)
|
2022-04-20 22:16:18 +08:00
|
|
|
|
return [0]
|
2022-11-13 00:02:20 +08:00
|
|
|
|
elseif index(v:argv, '--embed') !=# -1
|
|
|
|
|
if v:argv[-1] =~# '/$'
|
|
|
|
|
let f = fnamemodify(expand(v:argv[-1]), ':p')
|
|
|
|
|
if isdirectory(f)
|
|
|
|
|
return [1, f]
|
|
|
|
|
else
|
|
|
|
|
return [1, getcwd()]
|
|
|
|
|
endif
|
|
|
|
|
elseif v:argv[-1] ==# '.'
|
|
|
|
|
return [1, getcwd()]
|
|
|
|
|
elseif isdirectory(expand(v:argv[-1]))
|
|
|
|
|
return [1, fnamemodify(expand(v:argv[-1]), ':p')]
|
|
|
|
|
elseif filereadable(v:argv[-1])
|
|
|
|
|
return [2, get(v:, 'argv', ['failed to get v:argv'])]
|
2024-03-10 12:15:53 +08:00
|
|
|
|
elseif v:argv[-1] == '-p' && v:argv[-2] == '--embed'
|
|
|
|
|
return [0]
|
2023-05-30 18:56:26 +08:00
|
|
|
|
elseif v:argv[-1] != '--embed' && get(v:argv, -2, '') != '--cmd'
|
2023-05-07 21:50:36 +08:00
|
|
|
|
return [2, v:argv[-1]]
|
2022-11-13 00:02:20 +08:00
|
|
|
|
else
|
|
|
|
|
return [0]
|
|
|
|
|
endif
|
2022-09-25 17:50:08 +08:00
|
|
|
|
elseif index(v:argv, '-d') !=# -1
|
|
|
|
|
" this is diff mode
|
2023-03-26 13:57:31 +08:00
|
|
|
|
return [2, 'diff mode, use default arguments:' . string(v:argv)]
|
2022-09-25 17:50:08 +08:00
|
|
|
|
elseif v:argv[-1] =~# '/$'
|
|
|
|
|
let f = fnamemodify(expand(v:argv[-1]), ':p')
|
2022-04-20 22:16:18 +08:00
|
|
|
|
if isdirectory(f)
|
|
|
|
|
return [1, f]
|
|
|
|
|
else
|
|
|
|
|
return [1, getcwd()]
|
|
|
|
|
endif
|
2022-09-25 17:50:08 +08:00
|
|
|
|
elseif v:argv[-1] ==# '.'
|
2018-10-01 10:55:58 +08:00
|
|
|
|
return [1, getcwd()]
|
2022-09-25 17:50:08 +08:00
|
|
|
|
elseif isdirectory(expand(v:argv[-1]))
|
2022-11-13 00:02:20 +08:00
|
|
|
|
return [1, fnamemodify(expand(v:argv[-1]), ':p')]
|
2024-06-05 18:45:08 +08:00
|
|
|
|
elseif len(v:argv) == 3 && v:argv[-1] == 'VIM' && v:argv[-2] == '--servername'
|
|
|
|
|
return [0]
|
2022-04-20 22:16:18 +08:00
|
|
|
|
else
|
|
|
|
|
return [2, get(v:, 'argv', ['failed to get v:argv'])]
|
2018-10-01 10:55:58 +08:00
|
|
|
|
endif
|
|
|
|
|
else
|
2024-06-02 13:35:55 +08:00
|
|
|
|
call SpaceVim#logger#info(printf('argc is %s, argv is %s, line2byte is %s', string(argc()), string(argv()), string(line2byte('$'))))
|
2022-04-20 22:16:18 +08:00
|
|
|
|
if !argc() && line2byte('$') == -1
|
|
|
|
|
return [0]
|
2022-04-25 10:38:14 +08:00
|
|
|
|
elseif argv()[0] =~# '/$'
|
|
|
|
|
let f = fnamemodify(expand(argv()[0]), ':p')
|
|
|
|
|
if isdirectory(f)
|
|
|
|
|
return [1, f]
|
|
|
|
|
else
|
|
|
|
|
return [1, getcwd()]
|
|
|
|
|
endif
|
|
|
|
|
elseif argv()[0] ==# '.'
|
|
|
|
|
return [1, getcwd()]
|
|
|
|
|
elseif isdirectory(expand(argv()[0]))
|
|
|
|
|
return [1, fnamemodify(expand(argv()[0]), ':p')]
|
|
|
|
|
else
|
|
|
|
|
return [2, string(argv())]
|
2022-04-20 22:16:18 +08:00
|
|
|
|
endif
|
2018-10-01 10:55:58 +08:00
|
|
|
|
endif
|
|
|
|
|
endfunction
|
|
|
|
|
|
2018-02-22 21:15:46 +08:00
|
|
|
|
function! SpaceVim#begin() abort
|
|
|
|
|
|
2021-01-02 17:58:45 +08:00
|
|
|
|
|
|
|
|
|
"Use English for anything in vim
|
|
|
|
|
try
|
|
|
|
|
if s:SYSTEM.isWindows
|
|
|
|
|
silent exec 'lan mes en_US.UTF-8'
|
|
|
|
|
elseif s:SYSTEM.isOSX
|
|
|
|
|
silent exec 'language en_US.UTF-8'
|
|
|
|
|
else
|
|
|
|
|
let s:uname = system('uname -s')
|
|
|
|
|
if s:uname ==# "Darwin\n"
|
|
|
|
|
" in mac-terminal
|
|
|
|
|
silent exec 'language en_US.UTF-8'
|
|
|
|
|
elseif s:uname ==# "SunOS\n"
|
|
|
|
|
" in Sun-OS terminal
|
|
|
|
|
silent exec 'lan en_US.UTF-8'
|
|
|
|
|
elseif s:uname ==# "FreeBSD\n"
|
|
|
|
|
" in FreeBSD terminal
|
|
|
|
|
silent exec 'lan en_US.UTF-8'
|
|
|
|
|
else
|
|
|
|
|
" in linux-terminal
|
|
|
|
|
silent exec 'lan en_US.UTF-8'
|
|
|
|
|
endif
|
|
|
|
|
endif
|
|
|
|
|
catch /^Vim\%((\a\+)\)\=:E197/
|
|
|
|
|
call SpaceVim#logger#error('Can not set language to en_US.utf8')
|
2021-11-16 01:07:20 +08:00
|
|
|
|
catch /^Vim\%((\a\+)\)\=:E319/
|
|
|
|
|
call SpaceVim#logger#error('Can not set language to en_US.utf8, language not implemented in this Vim build')
|
2021-01-02 17:58:45 +08:00
|
|
|
|
endtry
|
|
|
|
|
|
|
|
|
|
" try to set encoding to utf-8
|
|
|
|
|
if s:SYSTEM.isWindows
|
|
|
|
|
" Be nice and check for multi_byte even if the config requires
|
|
|
|
|
" multi_byte support most of the time
|
|
|
|
|
if has('multi_byte')
|
|
|
|
|
" Windows cmd.exe still uses cp850. If Windows ever moved to
|
|
|
|
|
" Powershell as the primary terminal, this would be utf-8
|
|
|
|
|
if exists('&termencoding') && !has('nvim')
|
|
|
|
|
set termencoding=cp850
|
|
|
|
|
endif
|
|
|
|
|
setglobal fileencoding=utf-8
|
|
|
|
|
" Windows has traditionally used cp1252, so it's probably wise to
|
|
|
|
|
" fallback into cp1252 instead of eg. iso-8859-15.
|
|
|
|
|
" Newer Windows files might contain utf-8 or utf-16 LE so we might
|
|
|
|
|
" want to try them first.
|
|
|
|
|
set fileencodings=ucs-bom,utf-8,gbk,utf-16le,cp1252,iso-8859-15,cp936
|
|
|
|
|
endif
|
|
|
|
|
|
|
|
|
|
else
|
|
|
|
|
if exists('&termencoding') && !has('nvim')
|
|
|
|
|
set termencoding=utf-8
|
|
|
|
|
endif
|
|
|
|
|
set fileencoding=utf-8
|
|
|
|
|
set fileencodings=utf-8,ucs-bom,gb18030,gbk,gb2312,cp936
|
|
|
|
|
endif
|
2018-02-22 21:15:46 +08:00
|
|
|
|
|
|
|
|
|
" Before loading SpaceVim, We need to parser argvs.
|
|
|
|
|
let s:status = s:parser_argv()
|
2024-03-05 23:57:33 +08:00
|
|
|
|
call SpaceVim#logger#info('startup status:' . string(s:status))
|
2018-02-22 21:15:46 +08:00
|
|
|
|
" If do not start Vim with filename, Define autocmd for opening welcome page
|
2018-10-01 10:55:58 +08:00
|
|
|
|
if s:status[0] == 0
|
|
|
|
|
let g:_spacevim_enter_dir = fnamemodify(getcwd(), ':~')
|
|
|
|
|
call SpaceVim#logger#info('Startup with no argv, current dir is used: ' . g:_spacevim_enter_dir )
|
|
|
|
|
augroup SPwelcome
|
|
|
|
|
au!
|
|
|
|
|
autocmd VimEnter * call SpaceVim#welcome()
|
|
|
|
|
augroup END
|
|
|
|
|
elseif s:status[0] == 1
|
|
|
|
|
let g:_spacevim_enter_dir = fnamemodify(s:status[1], ':~')
|
|
|
|
|
call SpaceVim#logger#info('Startup with directory: ' . g:_spacevim_enter_dir )
|
2018-02-22 21:15:46 +08:00
|
|
|
|
augroup SPwelcome
|
|
|
|
|
au!
|
|
|
|
|
autocmd VimEnter * call SpaceVim#welcome()
|
|
|
|
|
augroup END
|
2018-10-01 10:55:58 +08:00
|
|
|
|
else
|
2023-03-11 19:26:17 +08:00
|
|
|
|
call SpaceVim#logger#info('Startup with argv: ' . string(s:status[0]) )
|
2018-02-22 21:15:46 +08:00
|
|
|
|
endif
|
2022-09-11 14:46:52 +08:00
|
|
|
|
if has('nvim-0.7')
|
2023-05-30 18:56:26 +08:00
|
|
|
|
try
|
|
|
|
|
" @fixme unknown font error
|
|
|
|
|
lua require('spacevim.default').options()
|
|
|
|
|
catch
|
2023-05-30 21:30:41 +08:00
|
|
|
|
|
2023-05-30 18:56:26 +08:00
|
|
|
|
endtry
|
2022-09-11 14:46:52 +08:00
|
|
|
|
else
|
|
|
|
|
call SpaceVim#default#options()
|
|
|
|
|
endif
|
2018-02-25 21:29:43 +08:00
|
|
|
|
call SpaceVim#default#layers()
|
2017-03-07 23:31:51 +08:00
|
|
|
|
call SpaceVim#commands#load()
|
2016-12-29 18:53:29 +08:00
|
|
|
|
endfunction
|
|
|
|
|
|
2017-01-07 10:50:28 +08:00
|
|
|
|
function! SpaceVim#welcome() abort
|
2018-09-06 21:19:59 +08:00
|
|
|
|
call SpaceVim#logger#info('try to open SpaceVim welcome page')
|
2017-12-27 23:32:32 +08:00
|
|
|
|
if get(g:, '_spacevim_session_loaded', 0) == 1
|
2018-09-06 21:19:59 +08:00
|
|
|
|
call SpaceVim#logger#info('start SpaceVim with session file, skip welcome page')
|
2017-12-27 23:32:32 +08:00
|
|
|
|
return
|
|
|
|
|
endif
|
2017-06-20 07:23:14 +08:00
|
|
|
|
exe 'cd' fnameescape(g:_spacevim_enter_dir)
|
2017-04-25 21:59:35 +08:00
|
|
|
|
if exists('g:_spacevim_checking_flag') && g:_spacevim_checking_flag
|
2017-04-25 21:54:20 +08:00
|
|
|
|
return
|
|
|
|
|
endif
|
2017-03-10 20:36:26 +08:00
|
|
|
|
if exists(':Startify') == 2
|
|
|
|
|
Startify
|
2022-11-13 00:02:20 +08:00
|
|
|
|
if isdirectory(bufname(1)) && bufnr() !=# 1
|
|
|
|
|
" startify will not change the buffer name
|
|
|
|
|
" if you run `nvim test/`, the buffer name is `test/`.
|
2017-05-12 20:06:20 +08:00
|
|
|
|
bwipeout! 1
|
|
|
|
|
endif
|
2017-03-10 20:36:26 +08:00
|
|
|
|
endif
|
2017-03-09 23:51:06 +08:00
|
|
|
|
if g:spacevim_enable_vimfiler_welcome
|
2017-04-08 13:45:45 +08:00
|
|
|
|
\ && get(g:, '_spacevim_checking_flag', 0) == 0
|
2024-07-09 17:31:23 +08:00
|
|
|
|
if has('timers')
|
|
|
|
|
call timer_start(500, function('s:open_filetree'))
|
|
|
|
|
else
|
|
|
|
|
call s:open_filetree()
|
|
|
|
|
endif
|
2024-07-05 23:11:59 +08:00
|
|
|
|
endif
|
|
|
|
|
endfunction
|
|
|
|
|
|
|
|
|
|
function! s:open_filetree(...) abort
|
2024-07-09 17:31:23 +08:00
|
|
|
|
if exists(':VimFiler') == 2
|
|
|
|
|
VimFiler
|
|
|
|
|
wincmd p
|
|
|
|
|
elseif exists(':Defx') == 2
|
|
|
|
|
Defx
|
|
|
|
|
wincmd p
|
|
|
|
|
elseif exists(':NERDTree') == 2
|
|
|
|
|
NERDTree
|
|
|
|
|
wincmd p
|
|
|
|
|
elseif exists(':NvimTreeOpen') == 2
|
|
|
|
|
try
|
|
|
|
|
" @fixme there are some errors
|
|
|
|
|
NvimTreeOpen
|
|
|
|
|
catch
|
|
|
|
|
|
|
|
|
|
endtry
|
|
|
|
|
" the statusline of nvimtree is not udpated when open nvim tree in
|
|
|
|
|
" welcome function
|
|
|
|
|
doautocmd WinEnter
|
|
|
|
|
wincmd p
|
|
|
|
|
elseif exists(':Neotree') == 2
|
|
|
|
|
NeoTreeShow
|
|
|
|
|
endif
|
|
|
|
|
|
2017-01-07 10:50:28 +08:00
|
|
|
|
endfunction
|
2017-01-25 20:04:17 +08:00
|
|
|
|
|
2020-05-06 20:59:34 +08:00
|
|
|
|
""
|
|
|
|
|
" @section Usage, usage
|
2020-08-21 22:36:25 +08:00
|
|
|
|
" General guide for using SpaceVim. Including layer configuration, bootstrap
|
|
|
|
|
" function.
|
2020-05-06 20:59:34 +08:00
|
|
|
|
|
2022-02-02 15:51:40 +08:00
|
|
|
|
""
|
|
|
|
|
" @section undo-tree, usage-undotree
|
|
|
|
|
" @parentsection usage
|
|
|
|
|
" Undo tree visualizes the undo history and makes it easier to browse and
|
|
|
|
|
" switch between different undo branches.The default key binding is `F7`.
|
|
|
|
|
" If `+python` or `+python3` is enabled, `vim-mundo` will be used,
|
|
|
|
|
" otherwise `undotree` will be used.
|
|
|
|
|
"
|
|
|
|
|
" Key bindings within undo tree windows:
|
|
|
|
|
" >
|
|
|
|
|
" key bindings description
|
|
|
|
|
" `G` move bottom
|
|
|
|
|
" `J` move older write
|
|
|
|
|
" `K` move newer write
|
|
|
|
|
" `N` previous match
|
|
|
|
|
" `P` play to
|
|
|
|
|
" `<2-LeftMouse>` mouse click
|
|
|
|
|
" `/` search
|
|
|
|
|
" `<CR>` preview
|
|
|
|
|
" `d` diff
|
|
|
|
|
" `<down>` move older
|
|
|
|
|
" `<up>` move newer
|
|
|
|
|
" `i` toggle inline
|
|
|
|
|
" `j` move older
|
|
|
|
|
" `k` move newer
|
|
|
|
|
" `n` next match
|
|
|
|
|
" `o` preview
|
|
|
|
|
" `p` diff current buffer
|
|
|
|
|
" `q` quit
|
|
|
|
|
" `r` diff
|
|
|
|
|
" `gg` move top
|
|
|
|
|
" `?` toggle help
|
|
|
|
|
" <
|
|
|
|
|
|
2021-10-28 13:46:17 +08:00
|
|
|
|
""
|
|
|
|
|
" @section search-and-replace, usage-search-and-replace
|
|
|
|
|
" @parentsection usage
|
|
|
|
|
" This section document how to find and replace text in SpaceVim.
|
|
|
|
|
"
|
|
|
|
|
" @subsection Searching with an external tool
|
|
|
|
|
"
|
|
|
|
|
" SpaceVim can be interfaced with different searching tools like:
|
|
|
|
|
" 1. rg - ripgrep
|
|
|
|
|
" 2. ag - the silver searcher
|
|
|
|
|
" 3. pt - the platinum searcher
|
|
|
|
|
" 4. ack
|
|
|
|
|
" 5. grep
|
|
|
|
|
" The search commands in SpaceVim are organized under the `SPC s` prefix
|
|
|
|
|
" with the next key being the tool to use and the last key is the scope.
|
|
|
|
|
" For instance, `SPC s a b` will search in all opened buffers using `ag`.
|
|
|
|
|
"
|
|
|
|
|
" If the `<scope>` is uppercase then the current word under the cursor
|
|
|
|
|
" is used as default input for the search.
|
|
|
|
|
" For instance, `SPC s a B` will search for the word under the cursor.
|
|
|
|
|
"
|
|
|
|
|
" If the tool key is omitted then a default tool will be automatically
|
|
|
|
|
" selected for the search. This tool corresponds to the first tool found
|
|
|
|
|
" on the system from the list `search_tools`, the default order is
|
|
|
|
|
" `['rg', 'ag', 'pt', 'ack', 'grep', 'findstr', 'git']`.
|
|
|
|
|
" For instance `SPC s b` will search in the opened buffers using
|
|
|
|
|
" `pt` if `rg` and `ag` have not been found on the system.
|
|
|
|
|
"
|
|
|
|
|
" The tool keys are:
|
|
|
|
|
" >
|
|
|
|
|
" Tool | Key
|
|
|
|
|
" ---------|-----
|
|
|
|
|
" ag | a
|
|
|
|
|
" grep | g
|
|
|
|
|
" git grep | G
|
|
|
|
|
" ack | k
|
|
|
|
|
" rg | r
|
|
|
|
|
" pt | t
|
|
|
|
|
" <
|
|
|
|
|
" The available scopes and corresponding keys are:
|
|
|
|
|
" >
|
|
|
|
|
" Scope | Key
|
|
|
|
|
" ---------------------------|-----
|
|
|
|
|
" opened buffers | b
|
|
|
|
|
" buffer directory | d
|
|
|
|
|
" files in a given directory | f
|
|
|
|
|
" current project | p
|
|
|
|
|
" <
|
2022-04-14 23:21:58 +08:00
|
|
|
|
" Instead of using flygrep to search text. SpaceVim also provides a general
|
|
|
|
|
" async searcher. The key binding is `SPC s j`, an input promote will be
|
|
|
|
|
" opened. After inserting text and press enter. searching results will be
|
|
|
|
|
" displayed in quickfix window.
|
2021-10-28 13:46:17 +08:00
|
|
|
|
|
2021-05-07 19:29:32 +08:00
|
|
|
|
""
|
|
|
|
|
" @section buffers-and-files, usage-buffers-and-files
|
|
|
|
|
" @parentsection usage
|
2024-06-21 10:56:08 +08:00
|
|
|
|
" All buffer related key bindings are start with `SPC b`, and all files
|
|
|
|
|
" related key bindings are start with `SPC f`.
|
2021-05-07 19:29:32 +08:00
|
|
|
|
" @subsection Buffers manipulation key bindings
|
2024-06-21 10:56:08 +08:00
|
|
|
|
"
|
|
|
|
|
" Buffer manipulation commands (start with `b`):
|
|
|
|
|
" >
|
|
|
|
|
" Key Bindings | Descriptions
|
|
|
|
|
" -------------------| ------------------------------------------------
|
|
|
|
|
" SPC <Tab> | switch to alternate buffer in the current window
|
|
|
|
|
" SPC b . | buffer transient state
|
|
|
|
|
" SPC b b | switch to a buffer (need fuzzy finder layer)
|
|
|
|
|
" SPC b d | kill the current buffer
|
|
|
|
|
" SPC b D | kill a visible buffer using vim-choosewin
|
|
|
|
|
" SPC b Ctrl-d | kill other buffers
|
|
|
|
|
" SPC b Ctrl-Shift-d | kill buffers using a regular expression
|
|
|
|
|
" SPC b e | erase the content of the buffer (ask for confirmation)
|
|
|
|
|
" SPC b n | switch to next buffer avoiding special buffers
|
|
|
|
|
" SPC b m | open Messages buffer
|
|
|
|
|
" SPC b o | kill all saved buffers and windows
|
|
|
|
|
" SPC b p | switch to previous buffer avoiding special buffers
|
|
|
|
|
" SPC b P | copy clipboard and replace buffer
|
|
|
|
|
" SPC b R | revert the current buffer (reload from disk)
|
|
|
|
|
" SPC b s | switch to the scratch buffer (create it if needed)
|
|
|
|
|
" SPC b w | toggle read-only (writable state)
|
|
|
|
|
" SPC b Y | copy whole buffer to clipboard
|
|
|
|
|
" <
|
|
|
|
|
"
|
|
|
|
|
" @subsection Create a new empty buffer
|
|
|
|
|
"
|
|
|
|
|
" The following key bindings can be used to create new buffer.
|
|
|
|
|
" >
|
|
|
|
|
" Key Bindings | Descriptions
|
|
|
|
|
" ------------ | -----------------------------------------------------
|
|
|
|
|
" SPC b N h | create new empty buffer in a new window on the left
|
|
|
|
|
" SPC b N j | create new empty buffer in a new window at the bottom
|
|
|
|
|
" SPC b N k | create new empty buffer in a new window above
|
|
|
|
|
" SPC b N l | create new empty buffer in a new window below
|
|
|
|
|
" SPC b N n | create new empty buffer in current window
|
|
|
|
|
" <
|
|
|
|
|
" @subsection Special Buffers
|
|
|
|
|
"
|
|
|
|
|
" Buffers created by plugins are not normal files, and they will not be listed
|
|
|
|
|
" on tabline. And also will not be listed by `SPC b b` key binding in fuzzy finder
|
|
|
|
|
" layer.
|
|
|
|
|
"
|
|
|
|
|
" @subsection File manipulation key bindings
|
|
|
|
|
"
|
|
|
|
|
" Files manipulation commands (start with `f`):
|
|
|
|
|
" >
|
|
|
|
|
" Key Bindings | Descriptions
|
|
|
|
|
" ------------ | ---------------------------------------------------------
|
|
|
|
|
" SPC f / | Find files with find or fd command
|
|
|
|
|
" SPC f b | go to file bookmarks
|
|
|
|
|
" SPC f C d | convert file from unix to dos encoding
|
|
|
|
|
" SPC f C u | convert file from dos to unix encoding
|
|
|
|
|
" SPC f D | delete a file and the associated buffer with confirmation
|
|
|
|
|
" SPC f W | save a file with elevated privileges (sudo layer)
|
|
|
|
|
" SPC f f | fuzzy find files in buffer directory
|
|
|
|
|
" SPC f F | fuzzy find cursor file in buffer directory
|
|
|
|
|
" SPC f o | Find current file in file tree
|
|
|
|
|
" SPC f R | rename the current file
|
|
|
|
|
" SPC f s | save a file
|
|
|
|
|
" SPC f a | save as new file name
|
|
|
|
|
" SPC f S | save all files
|
|
|
|
|
" SPC f r | open a recent file
|
|
|
|
|
" SPC f t | toggle file tree side bar
|
|
|
|
|
" SPC f T | show file tree side bar
|
|
|
|
|
" SPC f d | toggle disk manager in Windows OS
|
|
|
|
|
" SPC f y | show and copy current file absolute path in the cmdline
|
|
|
|
|
" SPC f Y | show and copy remote url of current file
|
|
|
|
|
" <
|
|
|
|
|
" NOTE: If you are using Windows, you need to install
|
|
|
|
|
" findutils(https://www.gnu.org/software/findutils/) or
|
|
|
|
|
" fd(https://github.com/sharkdp/fd).
|
|
|
|
|
" If you are using scoop(https://github.com/lukesampson/scoop) to install
|
|
|
|
|
" packages, commands in `C:\WINDOWS\system32` will override the User `PATH`,
|
|
|
|
|
" so you need to put the scoop binary path before `C:\WINDOWS\system32` in `PATH`.
|
|
|
|
|
"
|
|
|
|
|
" After pressing `SPC f /`, the find window will be opened.
|
|
|
|
|
" It is going to run `find` or `fd` command asynchronously.
|
|
|
|
|
" By default, `find` is the default tool, you can use `ctrl-e` to switch tools.
|
|
|
|
|
"
|
|
|
|
|
" To change the default file searching tool, you can use
|
|
|
|
|
" `file_searching_tools` in the `[options]` section.
|
|
|
|
|
" It is `[]` by default.
|
|
|
|
|
" >
|
|
|
|
|
" [options]
|
|
|
|
|
" file_searching_tools = ['find', 'find -not -iwholename "*.git*" ']
|
|
|
|
|
" <
|
|
|
|
|
"
|
|
|
|
|
" The first item is the name of the tool, the second one is the default searching command.
|
|
|
|
|
"
|
|
|
|
|
" @subsection Vim and SpaceVim files
|
|
|
|
|
"
|
|
|
|
|
" Convenient key bindings are located under the prefix `SPC f v` to quickly
|
|
|
|
|
" navigate between Vim and SpaceVim specific files.
|
|
|
|
|
" >
|
|
|
|
|
" Key Bindings | Descriptions
|
|
|
|
|
" ------------ | ------------------------------------------------
|
|
|
|
|
" SPC f v v | display and copy SpaceVim version
|
|
|
|
|
" SPC f v d | open SpaceVim custom configuration file
|
|
|
|
|
" SPC f v s | list all loaded vim scripts, like :scriptnames
|
2021-05-07 19:29:32 +08:00
|
|
|
|
" <
|
|
|
|
|
|
2021-12-16 00:05:09 +08:00
|
|
|
|
|
|
|
|
|
""
|
|
|
|
|
" @section command-line-mode, usage-command-line-mode
|
|
|
|
|
" @parentsection usage
|
|
|
|
|
" After pressing `:`, you can switch to command line mode, here is a list
|
|
|
|
|
" of key bindings can be used in command line mode:
|
|
|
|
|
" >
|
|
|
|
|
" Key bindings Descriptions
|
|
|
|
|
" Ctrl-a move cursor to beginning
|
|
|
|
|
" Ctrl-b Move cursor backward in command line
|
|
|
|
|
" Ctrl-f Move cursor forward in command line
|
|
|
|
|
" Ctrl-w delete a whole word
|
|
|
|
|
" Ctrl-u remove all text before cursor
|
|
|
|
|
" Ctrl-k remove all text after cursor
|
|
|
|
|
" Ctrl-c/Esc cancel command line mode
|
|
|
|
|
" Tab next item in popup menu
|
|
|
|
|
" Shift-Tab previous item in popup menu
|
|
|
|
|
" <
|
|
|
|
|
|
2021-09-28 23:37:52 +08:00
|
|
|
|
""
|
|
|
|
|
" @section Development, dev
|
|
|
|
|
"
|
|
|
|
|
" SpaceVim is a joint effort of all contributors.
|
|
|
|
|
" We encourage you to participate in SpaceVim's development.
|
|
|
|
|
" We have some guidelines that we need all contributors to follow.
|
|
|
|
|
|
2024-02-28 11:11:56 +08:00
|
|
|
|
""
|
|
|
|
|
" @section License, dev-license
|
|
|
|
|
" @parentsection dev
|
|
|
|
|
" The license is GPLv3 for all the parts of SpaceVim. This includes:
|
|
|
|
|
" 1. The initialization and core files.
|
|
|
|
|
" 2. All the layer files.
|
|
|
|
|
" 3. The documentation
|
|
|
|
|
"
|
|
|
|
|
" For files not belonging to SpaceVim like bundle packages,
|
|
|
|
|
" refer to the header file. Those files should not have an empty header,
|
|
|
|
|
" we may not accept code without a proper header file.
|
2021-09-28 23:37:52 +08:00
|
|
|
|
|
|
|
|
|
""
|
|
|
|
|
" @section commit-style-guide, dev-commit-style-guide
|
|
|
|
|
" @parentsection dev
|
|
|
|
|
" A git commit message consists a three distinct parts separated by black line.
|
|
|
|
|
" >
|
|
|
|
|
" Type (scope): Subject
|
|
|
|
|
"
|
|
|
|
|
" body
|
|
|
|
|
"
|
|
|
|
|
" footer
|
|
|
|
|
" <
|
|
|
|
|
" types:
|
|
|
|
|
"
|
|
|
|
|
" - `feat`: a new feature
|
|
|
|
|
" - `fix`: a bug fix
|
|
|
|
|
" - `change`: no backward compatible changes
|
|
|
|
|
" - `docs`: changes to documentation
|
|
|
|
|
" - `style`: formatting, missing semi colons, etc; no code change
|
|
|
|
|
" - `refactor`: refactoring production code
|
|
|
|
|
" - `test`: adding tests, refactoring test; no production code change
|
|
|
|
|
" - `chore`: updating build tasks, package manager configs, etc; no production code change
|
|
|
|
|
"
|
|
|
|
|
" scopes:
|
|
|
|
|
"
|
|
|
|
|
" - `api`: files in `autoload/SpaceVim/api/` and `docs/api/` directory
|
|
|
|
|
" - `layer`: files in `autoload/SpaceVim/layers/` and `docs/layers/` directory
|
|
|
|
|
" - `plugin`: files in `autoload/SpaceVim/plugins/` directory
|
|
|
|
|
" - `bundle`: files in `bundle/` directory
|
|
|
|
|
" - `core`: other files in this repository
|
|
|
|
|
"
|
|
|
|
|
" subject:
|
|
|
|
|
"
|
|
|
|
|
" Subjects should be no greater than 50 characters,
|
|
|
|
|
" should begin with a capital letter and do not end with a period.
|
|
|
|
|
"
|
|
|
|
|
" Use an imperative tone to describe what a commit does,
|
|
|
|
|
" rather than what it did. For example, use change; not changed or changes.
|
|
|
|
|
"
|
|
|
|
|
" body:
|
|
|
|
|
"
|
|
|
|
|
" Not all commits are complex enough to warrant a body,
|
|
|
|
|
" therefore it is optional and only used when a commit requires a bit of explanation and context.
|
|
|
|
|
"
|
|
|
|
|
" footer:
|
|
|
|
|
"
|
|
|
|
|
" The footer is optional and is used to reference issue tracker IDs.
|
|
|
|
|
|
2024-02-25 22:49:51 +08:00
|
|
|
|
""
|
|
|
|
|
" @section merge requese, dev-merge-request
|
|
|
|
|
" @parentsection dev
|
|
|
|
|
"
|
|
|
|
|
" @subsection Steps
|
|
|
|
|
"
|
|
|
|
|
" The following steps describe how to create a new merge request using mail.
|
|
|
|
|
"
|
|
|
|
|
" 1. create new empty repository on github,gitlab or any other platform.
|
|
|
|
|
" 2. clone your repository
|
|
|
|
|
" >
|
|
|
|
|
" git clone ${YOUR_OWN_REPOSITORY_URL}
|
|
|
|
|
" <
|
|
|
|
|
" 3. add upstream remote
|
|
|
|
|
" >
|
|
|
|
|
" git remote add upstream https://spacevim.org/git/repos/SpaceVim/
|
|
|
|
|
" <
|
|
|
|
|
" 4. create new branch based on `upstream/master`
|
|
|
|
|
" >
|
|
|
|
|
" git fetch upstream
|
|
|
|
|
" git checkout -b new_branch upstream/master
|
|
|
|
|
" <
|
|
|
|
|
" 5. edit, commit and push to your own repository
|
|
|
|
|
" >
|
|
|
|
|
" git push -u origin
|
|
|
|
|
" <
|
|
|
|
|
" 6. send merge request to mail list.
|
|
|
|
|
"
|
|
|
|
|
" email address: `spacevim@googlegroups.com`
|
|
|
|
|
"
|
|
|
|
|
" email title:
|
|
|
|
|
"
|
|
|
|
|
" The title of the email should contain one of the following prefixes::
|
|
|
|
|
"
|
|
|
|
|
" `Add:` Adding new features.
|
|
|
|
|
"
|
|
|
|
|
" `Change:` Change default behaviors or the existing features.
|
|
|
|
|
"
|
|
|
|
|
" `Fix:` Fix some bugs.
|
|
|
|
|
"
|
|
|
|
|
" `Remove:` Remove some existing features.
|
|
|
|
|
"
|
|
|
|
|
" `Doc:` Update the help files.
|
|
|
|
|
"
|
|
|
|
|
" `Website:` Update the content of website.
|
|
|
|
|
"
|
|
|
|
|
" Here is an example:
|
|
|
|
|
"
|
|
|
|
|
" `Website: Update the lang#c layer page.`
|
|
|
|
|
"
|
|
|
|
|
" Email context:
|
|
|
|
|
"
|
|
|
|
|
" The context should contain the url of repository and the branch name.
|
|
|
|
|
"
|
|
|
|
|
" It is better to add some description about the changes. For example:
|
|
|
|
|
" >
|
|
|
|
|
" repo url: https://gitlab.com/wsdjeg/hello.git
|
|
|
|
|
" branch: fix_scrollbar
|
|
|
|
|
"
|
|
|
|
|
" when switch windows, the highlight of scrollbar is wrong.
|
|
|
|
|
" here is the reproduce steps:
|
|
|
|
|
"
|
|
|
|
|
" 。。。。
|
|
|
|
|
" <
|
|
|
|
|
"
|
|
|
|
|
" @subsection Simple PRs
|
|
|
|
|
"
|
|
|
|
|
" 1. Branch from `master`
|
|
|
|
|
" 2. One topic per PR
|
|
|
|
|
" 3. One commit per PR
|
|
|
|
|
" 4. If you have several commits on different topics, close the PR and create one PR per topic
|
|
|
|
|
" 5. If you still have several commits, squash them into only one commit
|
|
|
|
|
"
|
|
|
|
|
" @subsection Complex PRs
|
|
|
|
|
"
|
|
|
|
|
" Squash only the commits with uninteresting changes like typos, syntax fixes, etc.
|
|
|
|
|
" And keep the important and isolated steps in different commits.
|
|
|
|
|
"
|
|
|
|
|
" Those PRs are merged and explicitly not fast-forwarded.
|
|
|
|
|
|
2022-04-12 14:45:23 +08:00
|
|
|
|
""
|
|
|
|
|
" @section alternate file, usage-alternate-file
|
|
|
|
|
" @parentsection usage
|
|
|
|
|
" SpaceVim provides a built-in alternate file manager, the command is `:A`.
|
|
|
|
|
"
|
|
|
|
|
" To use this feature, you can create a `.project_alt.json` file in the root
|
|
|
|
|
" of your project. for example:
|
|
|
|
|
" >
|
|
|
|
|
" {
|
|
|
|
|
" "autoload/SpaceVim/layers/lang/*.vim" :
|
|
|
|
|
" {
|
|
|
|
|
" "doc" : "docs/layers/lang/{}.md"
|
|
|
|
|
" },
|
|
|
|
|
" }
|
|
|
|
|
" <
|
|
|
|
|
" after adding this configuration, when edit the source file
|
|
|
|
|
" `autoload/SpaceVim/layers/lang/java.vim`,
|
|
|
|
|
" you can use `:A doc` switch to `docs/layers/lang/java.md`
|
2021-05-07 19:29:32 +08:00
|
|
|
|
|
2024-06-23 00:22:04 +08:00
|
|
|
|
""
|
|
|
|
|
" @section Toggle UI, usage-toggle-ui
|
|
|
|
|
" @parentsection usage
|
|
|
|
|
" Some UI indicators can be toggled on and off (toggles start with t and T):
|
|
|
|
|
" >
|
|
|
|
|
" Key Bindings | Descriptions
|
|
|
|
|
" ----------------- | -----------------------------------------
|
|
|
|
|
" SPC t 8 | highlight characters past the 80th column
|
|
|
|
|
" SPC t a | toggle autocomplete
|
|
|
|
|
" SPC t f | display the fill column
|
|
|
|
|
" SPC t h h | toggle highlight of the current line
|
|
|
|
|
" SPC t h i | toggle highlight indentation levels
|
|
|
|
|
" SPC t h c | toggle highlight current column
|
|
|
|
|
" SPC t h s | toggle syntax highlighting
|
|
|
|
|
" SPC t i | toggle indentation guide at point
|
|
|
|
|
" SPC t n | toggle line numbers
|
|
|
|
|
" SPC t b | toggle background
|
|
|
|
|
" SPC t c | toggle conceal
|
|
|
|
|
" SPC t p | toggle paste mode
|
|
|
|
|
" SPC t P | toggle auto parens mode
|
|
|
|
|
" SPC t t | open tabs manager
|
|
|
|
|
" SPC T ~ | display ~ in the fringe on empty lines
|
|
|
|
|
" SPC T F / F11 | toggle frame fullscreen
|
|
|
|
|
" SPC T f | toggle display of the fringe
|
|
|
|
|
" SPC T m | toggle menu bar
|
|
|
|
|
" SPC T t | toggle tool bar
|
|
|
|
|
" <
|
2024-06-21 23:26:26 +08:00
|
|
|
|
|
|
|
|
|
""
|
|
|
|
|
" @section Error handling, usage-error-handling
|
|
|
|
|
" @parentsection usage
|
|
|
|
|
" The @section(layers-checkers) and @section(layers-lsp) provide error
|
|
|
|
|
" handling features. The checkers layer uses
|
|
|
|
|
" neomake(https://github.com/neomake/neomake) by default.
|
|
|
|
|
" The syntax checking is only performed at save time by default.
|
|
|
|
|
"
|
|
|
|
|
" Error management mappings (start with e):
|
|
|
|
|
" >
|
|
|
|
|
" Mappings | Descriptions
|
|
|
|
|
" --------- | --------------------------------------------------
|
|
|
|
|
" SPC t s | toggle syntax checker
|
|
|
|
|
" SPC e c | clear all errors
|
|
|
|
|
" SPC e h | describe a syntax checker
|
|
|
|
|
" SPC e l | toggle the display of the list of errors/warnings
|
|
|
|
|
" SPC e n | go to the next error
|
|
|
|
|
" SPC e p | go to the previous error
|
|
|
|
|
" SPC e v | verify syntax checker setup
|
|
|
|
|
" SPC e . | error transient state
|
|
|
|
|
" <
|
|
|
|
|
" The next/previous error mappings and the error transient state can be used
|
|
|
|
|
" to browse errors from syntax checkers as well as errors from location list
|
|
|
|
|
" buffers, and indeed anything that supports Vim's location list. This
|
|
|
|
|
" includes for example search results that have been saved to a location
|
|
|
|
|
" list buffer.
|
|
|
|
|
"
|
|
|
|
|
" Custom sign symbol:
|
|
|
|
|
" >
|
|
|
|
|
" Symbol | Descriptions | Custom options
|
|
|
|
|
" ------ | ------------ | ----------------
|
|
|
|
|
" ✖ | Error | error_symbol
|
|
|
|
|
" ➤ | warning | warning_symbol
|
|
|
|
|
" ⓘ | Info | info_symbol
|
|
|
|
|
" <
|
|
|
|
|
" @subsection quickfix list navigation
|
|
|
|
|
" >
|
|
|
|
|
" Mappings | Descriptions
|
|
|
|
|
" -------------- | --------------------------------------
|
|
|
|
|
" <Leader> q l | Open quickfix list window
|
|
|
|
|
" <Leader> q c | clear quickfix list
|
|
|
|
|
" <Leader> q n | jump to next item in quickfix list
|
|
|
|
|
" <Leader> q p | jump to previous item in quickfix list
|
|
|
|
|
" <
|
|
|
|
|
|
2024-06-27 13:40:47 +08:00
|
|
|
|
""
|
|
|
|
|
" @section Editing, usage-editing
|
|
|
|
|
" @parentsection usage
|
|
|
|
|
"
|
|
|
|
|
" @subsection Moving text
|
|
|
|
|
" >
|
|
|
|
|
" Key | Action
|
|
|
|
|
" ----------------- | -----------------------------
|
|
|
|
|
" > / Tab | Indent to right and re-select
|
|
|
|
|
" < / Shift-Tab | Indent to left and re-select
|
|
|
|
|
" Ctrl-Shift-Up | move lines up
|
|
|
|
|
" Ctrl-Shift-Down | move lines down
|
|
|
|
|
" <
|
|
|
|
|
" @subsection Code indentation
|
|
|
|
|
"
|
|
|
|
|
" The default indentation of code is 2, which is controlled by the option
|
|
|
|
|
" @section(options-default_indent).
|
|
|
|
|
" If you prefer to use 4 as code indentation. Just add the following snippet
|
|
|
|
|
" to the `[options]` section in the SpaceVim's configuration file:
|
|
|
|
|
" >
|
|
|
|
|
" [options]
|
|
|
|
|
" default_indent = 4
|
|
|
|
|
" <
|
|
|
|
|
" The `default_indent` option will be applied to vim's `&tabstop`,
|
|
|
|
|
" `&softtabstop` and `&shiftwidth` options. By default, when the user inserts
|
|
|
|
|
" a `<Tab>`, it will be expanded to spaces. This feature can be disabled by
|
|
|
|
|
" `expand_tab` option the `[options]` section:
|
|
|
|
|
" >
|
|
|
|
|
" [options]
|
|
|
|
|
" default_indent = 4
|
|
|
|
|
" expand_tab = true
|
|
|
|
|
" <
|
|
|
|
|
" @subsection Text manipulation commands
|
|
|
|
|
"
|
|
|
|
|
" Text related commands (start with `x`):
|
|
|
|
|
" >
|
|
|
|
|
" Key Bindings | Descriptions
|
|
|
|
|
" ---------------- | -------------------------------------------------------
|
|
|
|
|
" SPC x a # | align region at #
|
|
|
|
|
" SPC x a % | align region at %
|
|
|
|
|
" SPC x a & | align region at &
|
|
|
|
|
" SPC x a ( | align region at (
|
|
|
|
|
" SPC x a ) | align region at )
|
|
|
|
|
" SPC x a [ | align region at [
|
|
|
|
|
" SPC x a ] | align region at ]
|
|
|
|
|
" SPC x a { | align region at {
|
|
|
|
|
" SPC x a } | align region at }
|
|
|
|
|
" SPC x a , | align region at ,
|
|
|
|
|
" SPC x a . | align region at . (for numeric tables)
|
|
|
|
|
" SPC x a : | align region at :
|
|
|
|
|
" SPC x a ; | align region at ;
|
|
|
|
|
" SPC x a = | align region at =
|
|
|
|
|
" SPC x a ¦ | align region at ¦
|
|
|
|
|
" SPC x a <Bar> | align region at \|
|
|
|
|
|
" SPC x a SPC | align region at [SPC]
|
|
|
|
|
" SPC x a r | align region at user-specified regexp
|
|
|
|
|
" SPC x a o | align region at operators +-*/ etc
|
|
|
|
|
" SPC x c | count the number of chars/words/lines in the region
|
|
|
|
|
" SPC x d w | delete trailing whitespace
|
|
|
|
|
" SPC x d SPC | Delete all spaces and tabs around point
|
|
|
|
|
" SPC x g t | translate current word using Google Translate
|
|
|
|
|
" SPC x i c | change symbol style to lowerCamelCase
|
|
|
|
|
" SPC x i C | change symbol style to UpperCamelCase
|
|
|
|
|
" SPC x i i | cycle symbol naming styles (i to keep cycling)
|
|
|
|
|
" SPC x i - | change symbol style to kebab-case
|
|
|
|
|
" SPC x i k | change symbol style to kebab-case
|
|
|
|
|
" SPC x i _ | change symbol style to under_score
|
|
|
|
|
" SPC x i u | change symbol style to under_score
|
|
|
|
|
" SPC x i U | change symbol style to UP_CASE
|
|
|
|
|
" SPC x j c | set the justification to center
|
|
|
|
|
" SPC x j l | set the justification to left
|
|
|
|
|
" SPC x j r | set the justification to right
|
|
|
|
|
" SPC x J | move down a line of text (enter transient state)
|
|
|
|
|
" SPC x K | move up a line of text (enter transient state)
|
|
|
|
|
" SPC x l d | duplicate a line or region
|
|
|
|
|
" SPC x l r | reverse lines
|
|
|
|
|
" SPC x l s | sort lines (ignorecase)
|
|
|
|
|
" SPC x l S | sort lines (case-senstive)
|
|
|
|
|
" SPC x l u | uniquify lines (ignorecase)
|
|
|
|
|
" SPC x l U | uniquify lines (case-senstive)
|
|
|
|
|
" SPC x t c | swap (transpose) the current character with previous one
|
|
|
|
|
" SPC x t C | swap (transpose) the current character with next one
|
|
|
|
|
" SPC x t w | swap (transpose) the current word with previous one
|
|
|
|
|
" SPC x t W | swap (transpose) the current word with next one
|
|
|
|
|
" SPC x t l | swap (transpose) the current line with previous one
|
|
|
|
|
" SPC x t L | swap (transpose) the current line with next one
|
|
|
|
|
" SPC x u | lowercase text
|
|
|
|
|
" SPC x U | uppercase text
|
|
|
|
|
" SPC x ~ | toggle case text
|
|
|
|
|
" SPC x w c | count the words in the select region
|
|
|
|
|
" <
|
|
|
|
|
" @subsection Text insertion commands
|
|
|
|
|
"
|
|
|
|
|
" Text insertion commands (start with `i`):
|
|
|
|
|
" >
|
|
|
|
|
" Key bindings | Descriptions
|
|
|
|
|
" ------------ | ---------------------------------------------------------------------
|
|
|
|
|
" SPC i l l | insert lorem-ipsum list
|
|
|
|
|
" SPC i l p | insert lorem-ipsum paragraph
|
|
|
|
|
" SPC i l s | insert lorem-ipsum sentence
|
|
|
|
|
" SPC i p 1 | insert simple password
|
|
|
|
|
" SPC i p 2 | insert stronger password
|
|
|
|
|
" SPC i p 3 | insert password for paranoids
|
|
|
|
|
" SPC i p p | insert a phonetically easy password
|
|
|
|
|
" SPC i p n | insert a numerical password
|
|
|
|
|
" SPC i u | Search for Unicode characters and insert them into the active buffer.
|
|
|
|
|
" SPC i U 1 | insert UUIDv1 (use universal argument to insert with CID format)
|
|
|
|
|
" SPC i U 4 | insert UUIDv4 (use universal argument to insert with CID format)
|
|
|
|
|
" SPC i U U | insert UUIDv4 (use universal argument to insert with CID format)
|
|
|
|
|
" >
|
|
|
|
|
" NOTE: You can specify the number of password characters using a prefix
|
|
|
|
|
" argument (i.e. `10 SPC i p 1` will generate a 10 character simple password).
|
|
|
|
|
"
|
|
|
|
|
" @subsection Expand regions of text
|
|
|
|
|
"
|
|
|
|
|
" Key bindings available in visual mode:
|
|
|
|
|
" >
|
|
|
|
|
" Key bindings | Descriptions
|
|
|
|
|
" ------------ | -------------------------------------------------
|
|
|
|
|
" v | expand visual selection of text to larger region
|
|
|
|
|
" V | shrink visual selection of text to smaller region
|
|
|
|
|
" <
|
|
|
|
|
" @subsection Increase/Decrease numbers
|
|
|
|
|
" >
|
|
|
|
|
" Key Bindings | Descriptions
|
|
|
|
|
" ------------ | ------------------------------------------------
|
|
|
|
|
" SPC n + | increase the number and initiate transient state
|
|
|
|
|
" SPC n - | decrease the number and initiate transient state
|
|
|
|
|
" <
|
|
|
|
|
" In transient state:
|
|
|
|
|
" >
|
|
|
|
|
" Key Bindings | Descriptions
|
|
|
|
|
" ------------- | -------------------------------------------
|
|
|
|
|
" + | increase the number under the cursor by one
|
|
|
|
|
" - | decrease the number under the cursor by one
|
|
|
|
|
" Any other key | leave the transient state
|
|
|
|
|
" <
|
|
|
|
|
" Tip: You can set the step (1 by default) by using a prefix argument
|
|
|
|
|
" (i.e. `10 SPC n +` will add 10 to the number under the cursor).
|
|
|
|
|
"
|
|
|
|
|
" @subsection Copy and paste
|
|
|
|
|
"
|
|
|
|
|
" If `has('unnamedplus')`, the register used by `<Leader> y` is `+`,
|
|
|
|
|
" otherwise it is `*`. Read `:h registers` for more info about other registers.
|
|
|
|
|
" >
|
|
|
|
|
" Key | Descriptions
|
|
|
|
|
" ------------ | --------------------------------------------
|
|
|
|
|
" <Leader> y | Copy selected text to system clipboard
|
|
|
|
|
" <Leader> p | Paste text from system clipboard after here
|
|
|
|
|
" <Leader> P | Paste text from system clipboard before here
|
|
|
|
|
" <Leader> Y | Copy selected text to pastebin
|
|
|
|
|
" <
|
|
|
|
|
" To change the command of clipboard, you need to use bootstrap after function:
|
|
|
|
|
" >
|
|
|
|
|
" " for example, to use tmux clipboard:
|
|
|
|
|
" function! myspacevim#after() abort
|
|
|
|
|
" call clipboard#set('tmux load-buffer -', 'tmux save-buffer -')
|
|
|
|
|
" endfunction
|
|
|
|
|
" <
|
|
|
|
|
"
|
|
|
|
|
" within the runtime log (`SPC h L`), the clipboard command will be displayed:
|
|
|
|
|
"
|
|
|
|
|
" >
|
|
|
|
|
" [ clipboard ] [11:00:35] [670.246] [ Info ] yank_cmd is:'tmux load-buffer -'
|
|
|
|
|
" [ clipboard ] [11:00:35] [670.246] [ Info ] paste_cmd is:'tmux save-buffer -'
|
|
|
|
|
" >
|
|
|
|
|
"
|
|
|
|
|
" The `<Leader> Y` key binding will copy selected text to a pastebin server.
|
|
|
|
|
" It requires `curl` in your `$PATH`. The default command is:
|
|
|
|
|
" >
|
|
|
|
|
" curl -s -F "content=<-" http://dpaste.com/api/v2/
|
|
|
|
|
" <
|
|
|
|
|
" This command will read stdin and copy it to dpaste server. It is same as:
|
|
|
|
|
" >
|
|
|
|
|
" echo "selected text" | curl -s -F "content=<-" http://dpaste.com/api/v2/
|
|
|
|
|
" <
|
|
|
|
|
"
|
|
|
|
|
" @subsection Commenting
|
|
|
|
|
"
|
|
|
|
|
" Comments are handled by nerdcommenter, it’s bound to the following keys.
|
|
|
|
|
" >
|
|
|
|
|
" Key Bindings | Descriptions
|
|
|
|
|
" ------------ | -------------------------------------------------------
|
|
|
|
|
" SPC ; | comment operator
|
|
|
|
|
" SPC c a | switch to the alternative set of delimiters
|
|
|
|
|
" SPC c h | hide/show comments
|
|
|
|
|
" SPC c l | toggle line comments
|
|
|
|
|
" SPC c L | comment lines
|
|
|
|
|
" SPC c u | uncomment lines
|
|
|
|
|
" SPC c p | toggle paragraph comments
|
|
|
|
|
" SPC c P | comment paragraphs
|
|
|
|
|
" SPC c s | comment with pretty layout
|
|
|
|
|
" SPC c t | toggle comment on line
|
|
|
|
|
" SPC c T | comment the line under the cursor
|
|
|
|
|
" SPC c y | toggle comment and yank
|
|
|
|
|
" SPC c Y | yank and comment
|
|
|
|
|
" SPC c $ | comment current line from cursor to the end of the line
|
|
|
|
|
" <
|
|
|
|
|
" Tip: `SPC ;` will start operator mode, in this mode, you can use a motion
|
|
|
|
|
" command to comment lines. For example, `SPC ; 4 j` will comment the current
|
|
|
|
|
" line and the following 4 lines.
|
|
|
|
|
"
|
|
|
|
|
" @subsection Undo tree
|
|
|
|
|
"
|
|
|
|
|
" Undo tree visualizes the undo history and makes it easier to browse
|
|
|
|
|
" and switch between different undo branches. The default key binding is `F7`.
|
|
|
|
|
" If `+python` or `+python3` is enabled, mundo will be loaded,
|
|
|
|
|
" otherwise undotree will be loaded.
|
|
|
|
|
"
|
|
|
|
|
" Key bindings within undo tree windows:
|
|
|
|
|
" >
|
|
|
|
|
" key bindings | description
|
|
|
|
|
" --------------- | -------------------
|
|
|
|
|
" G | move bottom
|
|
|
|
|
" J | move older write
|
|
|
|
|
" K | move newer write
|
|
|
|
|
" N | previous match
|
|
|
|
|
" P | play to
|
|
|
|
|
" <2-LeftMouse> | mouse click
|
|
|
|
|
" / | search
|
|
|
|
|
" <CR> | preview
|
|
|
|
|
" d | diff
|
|
|
|
|
" <down> | move older
|
|
|
|
|
" <up> | move newer
|
|
|
|
|
" i | toggle inline
|
|
|
|
|
" j | move older
|
|
|
|
|
" k | move newer
|
|
|
|
|
" n | next match
|
|
|
|
|
" o | preview
|
|
|
|
|
" p | diff current buffer
|
|
|
|
|
" q | quit
|
|
|
|
|
" r | diff
|
|
|
|
|
" gg | move top
|
|
|
|
|
" ? | toggle help
|
|
|
|
|
" <
|
|
|
|
|
" @subsection Multi-Encodings
|
|
|
|
|
"
|
|
|
|
|
" SpaceVim uses utf-8 as the default encoding. There are four options for this:
|
|
|
|
|
"
|
|
|
|
|
" 1. fileencodings (fencs): ucs-bom,utf-8,default,latin1
|
|
|
|
|
" 2. fileencoding (fenc): utf-8
|
|
|
|
|
" 3. encoding (enc): utf-8
|
|
|
|
|
" 4. termencoding (tenc): utf-8 (only supported in Vim)
|
|
|
|
|
"
|
|
|
|
|
" To fix a messy display: `SPC e a` is the mapping to auto detect the file
|
|
|
|
|
" encoding. After detecting the file encoding, you can run the command below
|
|
|
|
|
" to fix it:
|
|
|
|
|
" >
|
|
|
|
|
" set enc=utf-8
|
|
|
|
|
" write
|
|
|
|
|
" <
|
|
|
|
|
|
2017-01-25 20:04:17 +08:00
|
|
|
|
""
|
|
|
|
|
" @section FAQ, faq
|
2020-05-06 20:59:34 +08:00
|
|
|
|
" This is a list of the frequently asked questions about SpaceVim.
|
|
|
|
|
"
|
|
|
|
|
" 1. How do I enable YouCompleteMe?
|
2017-01-25 20:44:05 +08:00
|
|
|
|
"
|
2020-05-06 20:59:34 +08:00
|
|
|
|
" Step 1: Add `enable_ycm = true` to custom_config. By default it should be
|
|
|
|
|
" `~/.SpaceVim.d/init.toml`.
|
2017-02-17 13:56:55 +08:00
|
|
|
|
"
|
|
|
|
|
" Step 2: Get into the directory of YouCompleteMe's author. By default it
|
|
|
|
|
" should be `~/.cache/vimfiles/repos/github.com/Valloric/`. If you find the
|
|
|
|
|
" directory `YouCompleteMe` in it, go into it. Otherwise clone
|
2017-01-25 20:44:05 +08:00
|
|
|
|
" YouCompleteMe repo by
|
2017-02-17 13:56:55 +08:00
|
|
|
|
" `git clone https://github.com/Valloric/YouCompleteMe.git`. After cloning,
|
|
|
|
|
" get into it and run `git submodule update --init --recursive`.
|
2017-01-25 20:44:05 +08:00
|
|
|
|
"
|
2017-02-17 13:56:55 +08:00
|
|
|
|
" Step 3: Compile YouCompleteMe with the features you want. If you just want
|
|
|
|
|
" C family support, run `./install.py --clang-completer`.
|
2020-05-06 20:59:34 +08:00
|
|
|
|
"
|
2017-02-08 20:27:27 +08:00
|
|
|
|
"
|
2017-02-17 13:56:55 +08:00
|
|
|
|
" 2. How to add custom snippet?
|
2020-05-06 20:59:34 +08:00
|
|
|
|
"
|
|
|
|
|
" SpaceVim uses neosnippet as the default snippet engine. This can be changed
|
|
|
|
|
" by @section(options-snippet_engine) option.
|
2017-02-17 13:56:55 +08:00
|
|
|
|
"
|
2020-05-06 20:59:34 +08:00
|
|
|
|
" If you want to add a snippet for a current filetype, run |:NeoSnippetEdit|
|
|
|
|
|
" command. A buffer will be opened and you can add your custom snippet.
|
|
|
|
|
" By default this buffer will be save in `~/.SpaceVim.d/snippets`.
|
|
|
|
|
"
|
|
|
|
|
" For more info about how to write snippet, please
|
|
|
|
|
" read |neosnippet-snippet-syntax|.
|
2018-12-19 23:59:41 +08:00
|
|
|
|
"
|
2017-02-08 21:01:16 +08:00
|
|
|
|
"
|
|
|
|
|
" 3. Where is `<c-f>` in cmdline-mode?
|
2020-05-06 20:59:34 +08:00
|
|
|
|
"
|
2017-02-17 13:56:55 +08:00
|
|
|
|
" `<c-f>` is the default value of |cedit| option, but in SpaceVim we use that
|
2020-05-06 20:59:34 +08:00
|
|
|
|
" binding as `<Right>`, so maybe you can change the `cedit` option or use
|
2017-02-17 13:56:55 +08:00
|
|
|
|
" `<leader>+<c-f>`.
|
2017-02-22 21:25:17 +08:00
|
|
|
|
"
|
2018-08-04 14:31:00 +08:00
|
|
|
|
" 4. How to use `<Space>` as `<Leader>`?
|
2020-05-06 20:59:34 +08:00
|
|
|
|
"
|
|
|
|
|
" Add `let g:mapleader = "\<Space>"` to bootstrap function.
|
|
|
|
|
"
|
|
|
|
|
" 5. Why does Vim freeze after pressing Ctrl-s?
|
|
|
|
|
"
|
|
|
|
|
" This is a feature of terminal emulators. You can use `Ctrl-q` to unfreeze Vim. To disable
|
|
|
|
|
" this feature you need the following in either `~/.bash_profile` or `~/.bashrc`:
|
|
|
|
|
">
|
|
|
|
|
" stty -ixon
|
|
|
|
|
"<
|
|
|
|
|
"
|
|
|
|
|
" 6. How to enable `+py` and `+py3` in Neovim?
|
|
|
|
|
"
|
|
|
|
|
" In Neovim we can use `g:python_host_prog` and `g:python3_host_prog`
|
|
|
|
|
" to config python prog. But in SpaceVim the custom configuration file is
|
|
|
|
|
" loaded after SpaceVim core code. So in SpaceVim itself, if we using `:py`
|
|
|
|
|
" command, it may cause errors.
|
|
|
|
|
"
|
|
|
|
|
" So we introduce two new environment variables: `PYTHON_HOST_PROG` and
|
|
|
|
|
" `PYTHON3_HOST_PROG`.
|
|
|
|
|
"
|
|
|
|
|
" For example:
|
2017-02-22 21:25:17 +08:00
|
|
|
|
" >
|
2020-05-06 20:59:34 +08:00
|
|
|
|
" export PYTHON_HOST_PROG='/home/q/envs/neovim2/bin/python'
|
|
|
|
|
" export PYTHON3_HOST_PROG='/home/q/envs/neovim3/bin/python'
|
2017-02-22 21:25:17 +08:00
|
|
|
|
" <
|
2017-03-06 23:26:26 +08:00
|
|
|
|
|
2024-06-15 11:11:59 +08:00
|
|
|
|
""
|
|
|
|
|
" @section Community, community
|
|
|
|
|
"
|
|
|
|
|
" @subsection News
|
|
|
|
|
"
|
|
|
|
|
" The news about spacevim will be post on twitter, feel free to follow them:
|
|
|
|
|
"
|
|
|
|
|
" https://x.com/SpaceVim
|
|
|
|
|
"
|
|
|
|
|
" @subsection Asking for help
|
|
|
|
|
"
|
|
|
|
|
" If you have any questions about using SpaceVim, check out the following context first, which may contain the answers:
|
|
|
|
|
"
|
|
|
|
|
" @section(faq): Some of the most frequently asked questions are answered there.
|
|
|
|
|
" @section(usage): It is the general documentation of SpaceVim.
|
|
|
|
|
"
|
|
|
|
|
" @subsection Feedback
|
|
|
|
|
"
|
|
|
|
|
" If you run into a bug, or want a new feature, please use the mail list:
|
|
|
|
|
"
|
|
|
|
|
" send email to spacevim@googlegroups.com
|
|
|
|
|
"
|
|
|
|
|
" To subscribe the maillist, send anything to:spacevim+subscribe@googlegroups.com
|
|
|
|
|
"
|
|
|
|
|
" @subsection Chatroom
|
|
|
|
|
"
|
|
|
|
|
" - Matrix room: #spacevim:matrix.org
|
|
|
|
|
"
|
|
|
|
|
" @subsection Forum
|
|
|
|
|
"
|
|
|
|
|
" - Reddit: https://www.reddit.com/r/SpaceVim/
|
|
|
|
|
"
|
|
|
|
|
" @subsection Others
|
|
|
|
|
"
|
|
|
|
|
" The messages from matrix also bridged to telegram, discord and slack. Please
|
|
|
|
|
" checkout the community page for more info:
|
|
|
|
|
"
|
|
|
|
|
" https://spacevim.org/community/
|
|
|
|
|
|
|
|
|
|
""
|
|
|
|
|
" @section Roadmap, roadmap
|
|
|
|
|
" The roadmap defines the project direction and priorities. If you have any
|
|
|
|
|
" suggestions , please checkout @section(community).
|
|
|
|
|
"
|
|
|
|
|
" @subsection To-Do List
|
|
|
|
|
"
|
|
|
|
|
" - [x] rewrite statusline plugin with lua
|
|
|
|
|
" - [x] rewrite tabline plugin with lua
|
|
|
|
|
" - [ ] merge website context into :h SpaceVim
|
|
|
|
|
"
|
|
|
|
|
" @subsection Completed
|
|
|
|
|
"
|
|
|
|
|
" All completed functions can be found in @section(changelog)
|
|
|
|
|
|
|
|
|
|
|
2018-06-10 23:30:02 +08:00
|
|
|
|
""
|
|
|
|
|
" @section Changelog, changelog
|
2024-02-25 22:49:51 +08:00
|
|
|
|
" Following HEAD: changes in master branch since last release v2.2.0
|
|
|
|
|
"
|
|
|
|
|
" https://spacevim.org/following-head/
|
|
|
|
|
"
|
2024-06-15 11:11:59 +08:00
|
|
|
|
" 2024-03-24: v2.3.0
|
|
|
|
|
"
|
|
|
|
|
" https://spacevim.org/SpaceVim-release-v2.3.0/
|
|
|
|
|
"
|
2024-02-25 22:49:51 +08:00
|
|
|
|
" 2023-07-05: v2.2.0
|
|
|
|
|
"
|
|
|
|
|
" https://spacevim.org/SpaceVim-release-v2.2.0/
|
|
|
|
|
"
|
|
|
|
|
" 2023-03-30: v2.1.0
|
2018-12-19 23:59:41 +08:00
|
|
|
|
"
|
2024-02-25 22:49:51 +08:00
|
|
|
|
" https://spacevim.org/SpaceVim-release-v2.1.0/
|
2018-06-10 23:30:02 +08:00
|
|
|
|
"
|
2022-11-14 20:46:44 +08:00
|
|
|
|
" 2022-07-02: v2.0.0
|
|
|
|
|
"
|
|
|
|
|
" https://spacevim.org/SpaceVim-release-v2.0.0/
|
|
|
|
|
"
|
2022-01-06 19:49:25 +08:00
|
|
|
|
" 2021-06-16: v1.9.0
|
|
|
|
|
"
|
|
|
|
|
" https://spacevim.org/SpaceVim-release-v1.9.0/
|
|
|
|
|
"
|
|
|
|
|
" 2021-06-16: v1.8.0
|
|
|
|
|
"
|
|
|
|
|
" https://spacevim.org/SpaceVim-release-v1.8.0/
|
|
|
|
|
"
|
|
|
|
|
" 2021-06-16: v1.7.0
|
2021-09-19 22:06:14 +08:00
|
|
|
|
"
|
|
|
|
|
" https://spacevim.org/SpaceVim-release-v1.7.0/
|
|
|
|
|
"
|
|
|
|
|
" 2020-12-31: v1.6.0
|
|
|
|
|
"
|
|
|
|
|
" https://spacevim.org/SpaceVim-release-v1.6.0/
|
|
|
|
|
"
|
|
|
|
|
" 2020-08-01: v1.5.0
|
|
|
|
|
"
|
|
|
|
|
" https://spacevim.org/SpaceVim-release-v1.5.0/
|
|
|
|
|
"
|
2020-05-06 20:59:34 +08:00
|
|
|
|
" 2020-04-05: v1.4.0
|
|
|
|
|
"
|
|
|
|
|
" https://spacevim.org/SpaceVim-release-v1.4.0/
|
|
|
|
|
"
|
2019-12-02 23:18:11 +08:00
|
|
|
|
" 2019-11-04: v1.3.0
|
|
|
|
|
"
|
|
|
|
|
" https://spacevim.org/SpaceVim-release-v1.3.0/
|
|
|
|
|
"
|
|
|
|
|
" 2019-07-17: v1.2.0
|
|
|
|
|
"
|
|
|
|
|
" https://spacevim.org/SpaceVim-release-v1.2.0/
|
|
|
|
|
"
|
2019-06-09 10:42:59 +08:00
|
|
|
|
" 2019-04-08: v1.1.0
|
|
|
|
|
"
|
|
|
|
|
" https://spacevim.org/SpaceVim-release-v1.1.0/
|
|
|
|
|
"
|
|
|
|
|
" 2018-12-25: v1.0.0
|
|
|
|
|
"
|
|
|
|
|
" https://spacevim.org/SpaceVim-release-v1.0.0/
|
|
|
|
|
"
|
|
|
|
|
" 2018-09-26: v0.9.0
|
|
|
|
|
"
|
|
|
|
|
" https://spacevim.org/SpaceVim-release-v0.9.0/
|
|
|
|
|
"
|
|
|
|
|
" 2018-06-18: v0.8.0
|
|
|
|
|
"
|
|
|
|
|
" https://spacevim.org/SpaceVim-release-v0.8.0/
|
|
|
|
|
"
|
|
|
|
|
" 2018-03-18: v0.7.0
|
2018-06-10 23:30:02 +08:00
|
|
|
|
"
|
|
|
|
|
" https://spacevim.org/SpaceVim-release-v0.7.0/
|
2019-06-09 10:42:59 +08:00
|
|
|
|
"
|
|
|
|
|
" 2017-12-30: v0.6.0
|
|
|
|
|
"
|
|
|
|
|
" https://spacevim.org/SpaceVim-release-v0.6.0/
|
|
|
|
|
"
|
|
|
|
|
" 2017-11-06: v0.5.0
|
|
|
|
|
"
|
|
|
|
|
" https://spacevim.org/SpaceVim-release-v0.5.0/
|
|
|
|
|
"
|
|
|
|
|
" 2017-08-05: v0.4.0
|
|
|
|
|
"
|
|
|
|
|
" https://spacevim.org/SpaceVim-release-v0.4.0/
|
|
|
|
|
"
|
|
|
|
|
" 2017-06-27: v0.3.1
|
|
|
|
|
"
|
|
|
|
|
" https://spacevim.org/SpaceVim-release-v0.3.1/
|
|
|
|
|
"
|
|
|
|
|
" 2017-05-31: v0.3.0
|
|
|
|
|
"
|
|
|
|
|
" https://spacevim.org/SpaceVim-release-v0.3.0/
|
|
|
|
|
"
|
|
|
|
|
" 2017-03-30: v0.2.0
|
|
|
|
|
"
|
|
|
|
|
" https://spacevim.org/SpaceVim-release-v0.2.0/
|
|
|
|
|
"
|
|
|
|
|
" 2017-01-26: v0.1.0
|
|
|
|
|
"
|
|
|
|
|
" https://spacevim.org/SpaceVim-release-v0.1.0/
|
2017-03-06 23:26:26 +08:00
|
|
|
|
|
2017-03-07 22:11:41 +08:00
|
|
|
|
" vim:set et sw=2 cc=80:
|