Launch Vim as vanilla

himg
himg

有时我们可能会需要 vim 加载任何插件进行启动, vim 在这方面也提供了充分的自定义选项, 根据不同需要, 可以通过不同的方式达到目的

为了尽可能清楚详尽的剖析它们的区别, 我做了如下表格

vim_rtp = /usr/share/vim/vimfiles, /usr/share/vim/vim82, /usr/share/vim/vimfiles/after

user_rtp = ~/.vim,~/.vim/after

vim_defaults_load = /usr/share/vim/vim82/defaults.vim, /usr/share/vim/vim82/filetype.vim, /usr/share/vim/vim82/ftplugin.vim, /usr/share/vim/vim82/indent.vim, /usr/share/vim/vim82/syntax/**/*.vim

vim_user_load = ~/.vim/ftdetect/**/*.vim

method&rtpload vim plugin(such as netrw)load user plugin
vim -u NONEvim_rtp + user_rtpNONENONE
vim -u DEFAULTSvim_rtp + user_rtpvim_defaults_loadvim_user_load
vim -u NORCvim_rtp + user_rtpallall(no ~/.vimrc)
vim --cleanvim_rtpvim_defaults_loadNONE
vim --clean --cmd "set loadplugins"vim_rtpallNONE
HOME=/tmp/vim_tmp vimvim_rtp + user_rtpallallfile under /tmp/vim_tmp

以上结果可以使用 echo &rtp:scriptnames 进行输出验证

单独测试某一插件

如果我们要测试一个插件的 bug, 那么最好就是使用一个干净的 vim 环境, 然后只加载此插件, 这时就可以使用 HOME=~/vim_test_home vim 这种方式了.

在这种方式下, 我们可以在 ~/vim_test_home 文件夹中只添加某一插件的相关配置, 不设任何自定义功能, 这样可以快速准确判断出该 bug 是否属于该插件

快速验证 vim 的一个默认功能

这时我们可以使用 vim --clean --cmd "set loadplugins". 为什么? 因为这样不仅可以不加载任何用户自定义的配置, 还能加载 vim 的默认插件 (比如 netrw)

一些其他启动选项

  • vim [option] [files]
    • -N: nocompatible mode
    • -i NONE: without reading your viminfo file

在 shell 环境中设置 alias

另外为了方便, 可以在 ~/.zshrc 中设置如下 alias

  • alias vn='vim -u NONE -U NONE -N -i NONE'
  • alias vc='vim --clean --cmd "set loadplugins"'
  • alias vt='HOME=~/vim_test_home vim'

load plugin at anytime

我们可以使用 runtime! plugin/**/*.vim 来加载runtimepath 下所有子文件夹plugin 下的 vim 文件

Ref

SQL Server中,当你尝试将一个字符串二进制数据插入到一个字段中,而该字段的长度不足以容纳整个数据时,会出现“将截断字符串二进制数据”的错误。这个错误通常是由于以下几种原因引起的: 1. **字段长度不足**:你尝试插入的字符串长度超过了目标字段的定义长度。例如,目标字段定义为`VARCHAR(10)`,而你尝试插入一个长度为20的字符串。 2. **数据类型不匹配**:你尝试插入的数据类型与目标字段的数据类型不兼容。例如,目标字段是`INT`类型,而你尝试插入一个字符串。 3. **数据转换问题**:在数据插入过程中,数据类型转换导致了数据截断。例如,将`NVARCHAR`类型的数据插入到`VARCHAR`类型的字段中。 要解决这个问题,你可以采取以下几种措施: 1. **增加字段长度**:检查目标字段的定义长度,并根据需要增加长度。例如,将`VARCHAR(10)`改为`VARCHAR(50)`。 2. **检查数据类型**:确保插入的数据类型与目标字段的数据类型兼容。如果需要,进行适当的数据类型转换。 3. **数据验证**:在插入数据之前,验证数据的长度和类型,确保它们符合目标字段的定义。 例如,假设你有一个表`Employees`,其中有一个字段`Name`定义为`VARCHAR(10)`,而你尝试插入一个长度为20的字符串: ```sql INSERT INTO Employees (Name) VALUES ('ThisIsAVeryLongName'); ``` 这个操作会触发“将截断字符串二进制数据”的错误。要解决这个问题,你可以增加`Name`字段的长度: ```sql ALTER TABLE Employees ALTER COLUMN Name VARCHAR(50); ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值