Merge pull request #5146 from ch-cn/master

translated
This commit is contained in:
VicYu 2017-02-17 15:40:50 +08:00 committed by GitHub
commit 2d9cc58f6f
2 changed files with 116 additions and 118 deletions

View File

@ -1,118 +0,0 @@
Vim Editor Modes Explained
#ch-cn translating
============================================================
### On this page
1. [System and local vimrc][1]
2. [What compatibility are we talking][2]
3. [How to enable/disable these modes?][3]
4. [Other useful details][4]
So far, in our tutorials centered around [Vim][5], we discussed the editor's Modeline feature as well as how Vim's feature-set can be expanded using [plugins][6]. However, as we all know, Vim offers a plethora of in-built features; so taking the discussion further, in this tutorial, we will discuss the available modes in which the editor can be launched.
But before we do that, please note that all the examples, commands, and instructions mentioned in this tutorial have been tested on Ubuntu 14.04, and the Vim version we've used is 7.4.
# Compatible and Nocompatible modes in Vim
To properly understand the aforementioned Vim modes, you'll first have to understand an important aspect of the editor's initialization process.
### System and local vimrc
The aspect in question is: when Vim is launched, a system-level 'vimrc' file is searched by the editor to carry out system-wide default initializations.
This file is usually located at the **$VIM/vimrc** path on your system, but if that's not the case, then you can find the exact location by running the **:version** command inside Vim. For example, in my case, here's the relevant excerpt of the output the command produced:
```
...
...
...
system vimrc file: "$VIM/vimrc"
user vimrc file: "$HOME/.vimrc"
2nd user vimrc file: "~/.vim/vimrc"
user exrc file: "$HOME/.exrc"
fall-back for $VIM: "/usr/share/vim"
...
...
...
```
So the system 'vimrc' file is indeed located at **$VIM/vimrc**, but I checked that the $VIM environment variable isn't set on my machine. So in that case - as you can see in the output above - there's a fall back value for $VIM, which in my case is **/usr/share/vim**. When I tried searching for 'vimrc' at this path, I observed the file is present. So that's my system vimrc, which - as I mentioned earlier - is read when Vim is launched.
After this system vimrc is parsed, the editor looks for a user-specific (or local) 'vimrc' file. The [order of search][7] for the local vimrc is: environment variable VIMINIT, $HOME/.vimrc, environment variable EXINIT, and a file named 'exrc'. Usually, it's the $HOME/.vimrc or ~/.vimrc that exists and is treated as local vimrc.
### What compatibility are we talking
As we're discussing Vim's compatible and nocompatible modes, it's worth knowing what kind of compatibility does these modes enable and disable. For this, one should first be aware that Vim is a short form of **V**i **IM**proved, and as the full name suggests, the editor is an improved version of the Vi editor.
By improved, what is meant is that the feature set that Vim offers is larger than that of Vi. For a better understanding of difference between the two editors, head [here][8].
So while discussing Vim's compatible and nocompatible modes, the compatibility we're talking about is Vim's compatibility with Vi. When run in compatible mode, most of the enhancements and improvements of Vim get disabled. However, keep in mind that in this mode, Vim doesn't simply emulate Vi - the mode basically sets some default options to the way the Vi editor works.
The nocompatible mode - needless to say - makes Vim work without being Vi-compatible, making it all its enhancements/improvements/features available to the user.
### How to enable/disable these modes?
Try running the **:help compatible** command in Vim, and you should see the following syntax:
```
'compatible' 'cp' boolean (default on, off when a |vimrc| or |gvimrc|
file is found)
```
So the description says the compatible mode is ON by default, but gets turned OFF when a vimrc file is found. But which vimrc are we talking about? The answer is local vimrc. Delve into the details that the **:help compatible** command offers and you'll find the following line, which should make things more clear:
```
Effectively, this means that when a |vimrc| or |gvimrc| file exists, Vim will use the Vim defaults,otherwise it will use the Vi defaults. (Note: This doesn't happen for the system-wide vimrc or gvimrc file, nor for a file given with the |-u| argument).
```
So, what actually happens is, whenever Vim is launched, it first parses the system vimrc file - at this time the compatible mode is ON by default. Now, whenever a user (or local) vimrc is found, the nocompatible mode gets turned on. The **:help compatible-default** command makes it quite clear:
```
When Vim starts, the 'compatible' option is on. This will be used when Vim starts its initializations. But as soon as a user vimrc file is found, or a vimrc file in the current directory, or the "VIMINIT" environment variable is set, it will be set to 'nocompatible'.
```
In case you want to override the default behavior, and turn on the nocompatible mode when the editor starts parsing the system vimrc file, this can be done by adding the following command to that file in the beginning:
```
:set nocompatible
```
### Other useful details
Here are some more useful details about these modes:
```
But there is a side effect of setting or resetting 'compatible' at the moment a .vimrc file is found: Mappings are interpreted the moment they are encountered. This makes a difference when using things like "<CR>". If the mappings depend on a certain value of 'compatible', set or reset it before
giving the mapping.
The above behavior can be overridden in these ways:
- If the "-N" command line argument is given, 'nocompatible' will be used, even when no vimrc file exists.
- If the "-C" command line argument is given, 'compatible' will be used, even when a vimrc file exists.
- If the "-u {vimrc}" argument is used, 'compatible' will be used.
- When the name of the executable ends in "ex", then this works like the "-C" argument was given: 'compatible' will be used, even when a vimrc file exists. This has been done to make Vim behave like "ex", when it is started as "ex".
```
# Conclusion
Agreed, chances are that you may not find yourself in a situation where-in you'll have turn on the Vi-compatible mode of Vim, but that doesn't mean you should be ignorant of the editor's initialization process. After all, you never know when this knowledge might be of your help.
--------------------------------------------------------------------------------
via: https://www.howtoforge.com/tutorial/vim-editor-modes-explained/
作者:[Himanshu Arora][a]
译者:[译者ID](https://github.com/译者ID)
校对:[校对者ID](https://github.com/校对者ID)
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创编译,[Linux中国](https://linux.cn/) 荣誉推出
[a]:https://www.howtoforge.com/tutorial/vim-editor-modes-explained/
[1]:https://www.howtoforge.com/tutorial/vim-editor-modes-explained/#system-and-local-vimrc
[2]:https://www.howtoforge.com/tutorial/vim-editor-modes-explained/#what-compatibility-are-we-talking
[3]:https://www.howtoforge.com/tutorial/vim-editor-modes-explained/#how-to-enabledisable-these-modes
[4]:https://www.howtoforge.com/tutorial/vim-editor-modes-explained/#other-useful-details
[5]:https://www.howtoforge.com/vim-basics
[6]:https://www.howtoforge.com/tutorial/vim-editor-plugins-for-software-developers-3/
[7]:http://vimdoc.sourceforge.net/htmldoc/starting.html#system-vimrc
[8]:http://askubuntu.com/questions/418396/what-is-the-difference-between-vi-and-vim

View File

@ -0,0 +1,116 @@
Vim 编辑器模式讲解
============================================================
### 在本页
1. [系统及本地 vimrc 文件][1]
2. [我们谈论的是什么兼容性][2]
3. [怎么启用/禁用这些模式?][3]
4. [其他有用细节][4]
目前,在我们以 [Vim][5] 为中心的教程中,我们讨论过编辑器的 Modeline 功能以及怎样用 [plugins][6] 扩展 Vim 的功能集。可正如我们所知Vim 提供了非常多的内置功能:因此在本教程中更进一步,我们来谈谈在编辑器启动时的可用模式。
但在我们开始之前,请注意在本教程中提及的所有例子、命令及用法说明都是在 Ubuntu 14.04 上测试的,我们测试用的 Vim 版本是 7.4 。
# 在 Vim 中的兼容与不兼容模式
为了更好理解上述的 Vim 模式,你有必要先去了解下此编辑器初始化过程的一个重要方面。
### 系统及本地 vimrc 文件
所说的这方面是:当 Vim 启动时,编辑器会去搜索一个系统级的 'vimrc' 文件来进行系统范围内的默认初始化工作。
这个文件通常在你系统里 **$VIM/vimrc** 的路径下,如果没在那里,那你可以通过在 Vim 里面运行 **:version** 命令来找到它的正确存放位置。比如说,在我这,这个命令的相关部分的输出结果如下:
```
...
...
...
system vimrc file: "$VIM/vimrc"
user vimrc file: "$HOME/.vimrc"
2nd user vimrc file: "~/.vim/vimrc"
user exrc file: "$HOME/.exrc"
fall-back for $VIM: "/usr/share/vim"
...
...
...
```
可以看到那个系统 'vimrc' 文件确实位于 **$VIM/vimrc** ,但我检查了我机子上 $VIM 环境变量没设置过。所以在这个例子里 - 正如你在上面的输出所看到的 - $VIM 在我这的路径是 **/usr/share/vim** ,是一个回落值。于是我试着在这个路径寻找 'vimrc' ,我看到这个文件是存在的。如上即是我的系统 vimrc 文件,就如前面提过的那样 - 它在 Vim 启动时会被读取。
在这个系统 vimrc 被读取解析完后,编辑器会查找一个用户特定(或本地) 'vimrc' 文件。这个本地 vimrc 的 [搜索顺序][7] 是:环境变量 VIMINIT、$HOME/.vimrc、环境变量 EXINIT 和一个叫 'exrc' 的文件。通常情况下,会存在 $HOME/.vimrc 或 ~/.vimrc 这样的文件,这个文件可看作是本地 vimrc。
### 我们谈论的是什么兼容性
就像我们谈论 Vim 的兼容性和不兼容性模式那样,这些模式的开启和禁用会做出什么样的兼容性也值得了解。要了解这些,先要知道 Vim 是 **V**i **IM**proved 的缩写像这个全名暗示的那样Vim 编辑器是 Vi 编辑器的改进版。
经过改进意味着 Vim 的功能集比 Vi 的更大。为了更好的理解这俩编辑器的区别,点[这里][8]。
当谈论 Vim 的兼容和不兼容模式时,我们所说的兼容性是指 Vim 兼容 Vi。在兼容模式下运行时Vim 大部分增强及改善的功能就不可用了。不管怎样要记住这种模式下Vim 并不能简单等同 Vi - 此模式只是设定一些类似 Vi 编辑器工作方式的默认选项。
不兼容模式 - 不用多说 - 使得 Vim 用起来跟 Vi 不兼容,也使得用户可以用到它的所有增强、改善及特征。
### 怎么启用/禁用 这些模式?
在 Vim 中尝试运行 **:help compatible** 命令,接着你会看到如下语法:
```
'compatible' 'cp' boolean (默认开启 ,当 |vimrc| 或 |gvimrc| 存在时关闭)
```
描述中说到兼容模式默认开启的,不过当 vimrc 文件存在时会关闭。但说的是哪种 vimrc 文件呢?答案是本地 vimrc。深入研究下 **:help compatible** 命令给出的详情,你会发现下面内容说得更清楚:
```
事实上,这意味着当一个 |vimrc| 或 |gvimrc| 文件存在时Vim 会用默认的 Vim否则它会用 Vi 默认的。(注:对一个系统范围内的 vimrc 或 gvimrc 文件来说,如果文件中带有 |-u| 参数,这些情况就不会出现)。
```
那么在 Vim 启动时,实际上进行的动作是,首先会解析系统 vimrc 文件 - 在这时兼容性模式默认开启状态。现在,无论何时发现一个用户(或本地) vimrc ,不兼容模式都会打开。**:help compatible-default**命令说的很清楚:
```
在 Vim 启动时,兼容的选项是打开的。这将在 Vim 开始初始化时应用。但是一旦一个用户 vimrc 文件被发现,或在当前目录有一个 vimrc 文件,抑或 “VIMINIT” 环境变量已设置Vim 就会被设为不兼容。
```
假如你想无视默认的行为,要在编辑器开始解析系统 vimrc 文件时打开不兼容模式,你可以通过添加如下命令到那个文件的开头来完成这个操作。
```
:set nocompatible
```
### 其他有用细节
这儿是一些关于这些模式的更有用的细节:
```
现在通过创建一个 .vimrc 文件来设置或重置兼容性会有一个副作用:映射在解释的时候会有冲突。这使得在用诸如回车控制符 "<CR>" 等情况时会有影响。如果映射关系依赖于兼容性的某个特定值,在给出映射前设置或者重置它。
上述行为能够用以下方式能覆盖:
- 如果给出 "-N" 命令行参数,即使不存在 vimrc 文件, ‘不兼容模式’ 也会启用。
- 如果给出 "-C" 命令行参数,即使存在 vimrc 文件, ‘兼容模式’ 也会启用。
- 如果应用了 "-u {vimrc}" 参数,‘兼容模式’将会启用。
- 当可执行文件的名称以 "ex" 结尾时,那这个效果跟给出 "-C" 参数一样:即使存在一个 vimrc 文件,’兼容模式‘ 也会启用,因为当 Vim 作为 ”ex“ 启用时,就已经完成了让 Vim 表现得更像 ”前任“ 的工作。
```
# 结论
我们都同意,你可能不会发现你自己有机会处于一种你需要打开 Vim 的 Vi 兼容模式的情形中,但是那并不意味着你应该忽视此编辑器的初始化过程。毕竟,你绝不会知道这些知识什么时候会帮到你。
--------------------------------------------------------------------------------
via: https://www.howtoforge.com/tutorial/vim-editor-modes-explained/
作者:[Himanshu Arora][a]
译者:[ch-cn](https://github.com/ch-cn)
校对:[校对者ID](https://github.com/校对者ID)
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创编译,[Linux中国](https://linux.cn/) 荣誉推出
[a]:https://www.howtoforge.com/tutorial/vim-editor-modes-explained/
[1]:https://www.howtoforge.com/tutorial/vim-editor-modes-explained/#system-and-local-vimrc
[2]:https://www.howtoforge.com/tutorial/vim-editor-modes-explained/#what-compatibility-are-we-talking
[3]:https://www.howtoforge.com/tutorial/vim-editor-modes-explained/#how-to-enabledisable-these-modes
[4]:https://www.howtoforge.com/tutorial/vim-editor-modes-explained/#other-useful-details
[5]:https://www.howtoforge.com/vim-basics
[6]:https://www.howtoforge.com/tutorial/vim-editor-plugins-for-software-developers-3/
[7]:http://vimdoc.sourceforge.net/htmldoc/starting.html#system-vimrc
[8]:http://askubuntu.com/questions/418396/what-is-the-difference-between-vi-and-vim