usr_05.txt 21 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583
  1. *usr_05.txt* Nvim
  2. VIM USER MANUAL - by Bram Moolenaar
  3. Set your settings
  4. Vim can be tuned to work like you want it to. This chapter shows you how to
  5. make Vim start with options set to different values. Add plugins to extend
  6. Vim's capabilities. Or define your own macros.
  7. |05.1| The vimrc file
  8. |05.2| Example vimrc contents
  9. |05.3| Simple mappings
  10. |05.4| Adding a package
  11. |05.5| Adding a plugin
  12. |05.6| Adding a help file
  13. |05.7| The option window
  14. |05.8| Often used options
  15. Next chapter: |usr_06.txt| Using syntax highlighting
  16. Previous chapter: |usr_04.txt| Making small changes
  17. Table of contents: |usr_toc.txt|
  18. ==============================================================================
  19. *05.1* The vimrc file *vimrc-intro*
  20. You probably got tired of typing commands that you use very often. To start
  21. Vim with all your favorite option settings and mappings, you write them in
  22. what is called the init.vim file. Vim executes the commands in this file when
  23. it starts up.
  24. If you already have a init.vim file (e.g., when your sysadmin has one setup
  25. for you), you can edit it this way: >
  26. :edit $MYVIMRC
  27. If you don't have a vimrc file yet, see |init.vim| to find out where you can
  28. create a vimrc file.
  29. This file is always used and is recommended:
  30. ~/.config/nvim/init.vim (Unix and OSX) ~
  31. ~/AppData/Local/nvim/init.vim (Windows) ~
  32. The vimrc file can contain all the commands that you type after a colon. The
  33. simplest ones are for setting options. For example, if you want Vim to always
  34. start with the 'ignorecase' option on, add this line your vimrc file: >
  35. set ignorecase
  36. For this new line to take effect you need to exit Vim and start it again.
  37. Later you will learn how to do this without exiting Vim.
  38. This chapter only explains the most basic items. For more information on how
  39. to write a Vim script file: |usr_41.txt|.
  40. ==============================================================================
  41. *05.2* Example vimrc contents *vimrc_example.vim*
  42. In the first chapter was explained how to create a vimrc file. >
  43. :exe 'edit' stdpath('config').'/init.vim'
  44. In this section we will explain the various commands that can be specified in
  45. this file. This will give you hints about how to set up your own preferences.
  46. Not everything will be explained though. Use the ":help" command to find out
  47. more.
  48. >
  49. set backup
  50. This tells Vim to keep a backup copy of a file when overwriting it. The backup
  51. file will have the same name as the original file with "~" added. See |07.4|
  52. >
  53. set history=50
  54. <
  55. Keep 50 commands and 50 search patterns in the history. Use another number if
  56. you want to remember fewer or more lines.
  57. >
  58. map Q gq
  59. This defines a key mapping. More about that in the next section. This
  60. defines the "Q" command to do formatting with the "gq" operator. Otherwise the
  61. "Q" command repeats the last recorded register.
  62. >
  63. vnoremap _g y:exe "grep /" .. escape(@", '\\/') .. "/ *.c *.h"<CR>
  64. This mapping yanks the visually selected text and searches for it in C files.
  65. This is a complicated mapping. You can see that mappings can be used to do
  66. quite complicated things. Still, it is just a sequence of commands that are
  67. executed like you typed them.
  68. *vimrc-filetype*
  69. >
  70. filetype plugin indent on
  71. This switches on three very clever mechanisms:
  72. 1. Filetype detection.
  73. Whenever you start editing a file, Vim will try to figure out what kind of
  74. file this is. When you edit "main.c", Vim will see the ".c" extension and
  75. recognize this as a "c" filetype. When you edit a file that starts with
  76. "#!/bin/sh", Vim will recognize it as a "sh" filetype.
  77. The filetype detection is used for syntax highlighting and the other two
  78. items below.
  79. See |filetypes|.
  80. 2. Using filetype plugin files
  81. Many different filetypes are edited with different options. For example,
  82. when you edit a "c" file, it's very useful to set the 'cindent' option to
  83. automatically indent the lines. These commonly useful option settings are
  84. included with Vim in filetype plugins. You can also add your own, see
  85. |write-filetype-plugin|.
  86. 3. Using indent files
  87. When editing programs, the indent of a line can often be computed
  88. automatically. Vim comes with these indent rules for a number of
  89. filetypes. See |:filetype-indent-on| and 'indentexpr'.
  90. *restore-cursor* *last-position-jump* >
  91. augroup RestoreCursor
  92. autocmd!
  93. autocmd BufReadPre * autocmd FileType <buffer> ++once
  94. \ let s:line = line("'\"")
  95. \ | if s:line >= 1 && s:line <= line("$") && &filetype !~# 'commit'
  96. \ && index(['xxd', 'gitrebase'], &filetype) == -1
  97. \ | execute "normal! g`\""
  98. \ | endif
  99. augroup END
  100. Another autocommand. This time it is used after reading any file. The
  101. complicated stuff after it checks if the '" mark is defined, and jumps to it
  102. if so. It doesn't do that for a commit or rebase message, which are likely
  103. a different one than last time, and when using xxd(1) to filter and edit
  104. binary files, which transforms input files back and forth, causing them to
  105. have dual nature, so to speak. See also |using-xxd|.
  106. The backslash at the start of a line is used to continue the command from the
  107. previous line. That avoids a line getting very long. See |line-continuation|.
  108. This only works in a Vim script file, not when typing commands at the
  109. command line.
  110. >
  111. command DiffOrig vert new | set bt=nofile | r ++edit # | 0d_ | diffthis
  112. \ | wincmd p | diffthis
  113. This adds the ":DiffOrig" command. Use this in a modified buffer to see the
  114. differences with the file it was loaded from. See |diff| and |:DiffOrig|.
  115. >
  116. set nolangremap
  117. Prevent that the langmap option applies to characters that result from a
  118. mapping. If set (default), this may break plugins (but it's backward
  119. compatible). See 'langremap'.
  120. ==============================================================================
  121. *05.3* Simple mappings
  122. A mapping enables you to bind a set of Vim commands to a single key. Suppose,
  123. for example, that you need to surround certain words with curly braces. In
  124. other words, you need to change a word such as "amount" into "{amount}". With
  125. the :map command, you can tell Vim that the F5 key does this job. The command
  126. is as follows: >
  127. :map <F5> i{<Esc>ea}<Esc>
  128. <
  129. Note:
  130. When entering this command, you must enter <F5> by typing four
  131. characters. Similarly, <Esc> is not entered by pressing the <Esc>
  132. key, but by typing five characters. Watch out for this difference
  133. when reading the manual!
  134. Let's break this down:
  135. <F5> The F5 function key. This is the trigger key that causes the
  136. command to be executed as the key is pressed.
  137. i{<Esc> Insert the { character. The <Esc> key ends Insert mode.
  138. e Move to the end of the word.
  139. a}<Esc> Append the } to the word.
  140. After you execute the ":map" command, all you have to do to put {} around a
  141. word is to put the cursor on the first character and press F5.
  142. In this example, the trigger is a single key; it can be any string. But when
  143. you use an existing Vim command, that command will no longer be available.
  144. You better avoid that.
  145. One key that can be used with mappings is the backslash. Since you
  146. probably want to define more than one mapping, add another character. You
  147. could map "\p" to add parentheses around a word, and "\c" to add curly braces,
  148. for example: >
  149. :map \p i(<Esc>ea)<Esc>
  150. :map \c i{<Esc>ea}<Esc>
  151. You need to type the \ and the p quickly after another, so that Vim knows they
  152. belong together.
  153. The ":map" command (with no arguments) lists your current mappings. At
  154. least the ones for Normal mode. More about mappings in section |40.1|.
  155. ==============================================================================
  156. *05.4* Adding a package *add-package*
  157. You may use |:packadd| to enable packages on demand. This is useful for plugins
  158. you want to enable only sometimes. To enable `example_package`, use the
  159. following command: >
  160. packadd example_package
  161. That's all! Now you can find help about this plugin: >
  162. :help example_package
  163. This works, because when `:packadd` loaded the plugin it also added the
  164. package directory in 'runtimepath', so that the help file can be found.
  165. A package is a set of files that you can add to Vim. There are two kinds of
  166. packages: optional and automatically loaded on startup.
  167. You can find packages on the Internet in various places. It usually comes as
  168. an archive or as a repository. For an archive you can follow these steps:
  169. 1. create the package directory: >
  170. mkdir -p ~/.local/share/nvim/site/pack/fancy
  171. < "fancy" can be any name of your liking. Use one that describes the
  172. package.
  173. 2. unpack the archive in that directory. This assumes the top
  174. directory in the archive is "start": >
  175. cd ~/.local/share/nvim/site/pack/fancy
  176. unzip /tmp/fancy.zip
  177. < If the archive layout is different make sure that you end up with a
  178. path like this:
  179. ~/.local/share/nvim/site/pack/fancy/start/fancytext/plugin/fancy.vim ~
  180. Here "fancytext" is the name of the package, it can be anything
  181. else.
  182. Adding nohlsearch package *nohlsearch-install*
  183. Load the plugin with this command: >
  184. packadd nohlsearch
  185. <
  186. Automatically execute |:nohlsearch| after 'updatetime' or getting into
  187. |Insert| mode.
  188. Thus assuming default updatetime, hlsearch would be suspended/turned off after
  189. 4 seconds of idle time.
  190. To disable the effect of the plugin after it has been loaded: >
  191. au! nohlsearch
  192. <
  193. More information about packages can be found here: |packages|.
  194. ==============================================================================
  195. *05.5* Adding a plugin *add-plugin* *plugin*
  196. Vim's functionality can be extended by adding plugins. A plugin is nothing
  197. more than a Vim script file that is loaded automatically when Vim starts. You
  198. can add a plugin very easily by dropping it in your plugin directory.
  199. There are two types of plugins:
  200. global plugin: Used for all kinds of files
  201. filetype plugin: Only used for a specific type of file
  202. The global plugins will be discussed first, then the filetype ones
  203. |add-filetype-plugin|.
  204. GLOBAL PLUGINS *standard-plugin*
  205. When you start Vim, it will automatically load a number of global plugins.
  206. You don't have to do anything for this. They add functionality that most
  207. people will want to use, but which was implemented as a Vim script instead of
  208. being compiled into Vim. You can find them listed in the help index
  209. |standard-plugin-list|. Also see |load-plugins|.
  210. *add-global-plugin*
  211. You can add a global plugin to add functionality that will always be present
  212. when you use Vim. There are only two steps for adding a global plugin:
  213. 1. Get a copy of the plugin.
  214. 2. Drop it in the right directory.
  215. GETTING A GLOBAL PLUGIN
  216. Where can you find plugins?
  217. - Some are always loaded, you can see them in the directory $VIMRUNTIME/plugin.
  218. - Some come with Vim. You can find them in the directory $VIMRUNTIME/macros
  219. and its sub-directories and under $VIM/vimfiles/pack/dist/opt/.
  220. - Download from the net. There is a large collection on https://www.vim.org.
  221. - They are sometimes posted in a Vim maillist.
  222. - You could write one yourself, see |write-plugin|.
  223. USING A GLOBAL PLUGIN
  224. First read the text in the plugin itself to check for any special conditions.
  225. Then copy the file to your plugin directory:
  226. system plugin directory ~
  227. Unix ~/.local/share/nvim/site/plugin
  228. Example for Unix (assuming you didn't have a plugin directory yet): >
  229. mkdir -p ~/.local/share/nvim/site/plugin
  230. cp /tmp/yourplugin.vim ~/.local/share/nvim/site/plugin
  231. That's all! Now you can use the commands defined in this plugin.
  232. Instead of putting plugins directly into the plugin/ directory, you may
  233. better organize them by putting them into subdirectories under plugin/.
  234. As an example, consider using "~/.local/share/nvim/site/plugin/perl/*.vim" for
  235. all your Perl plugins.
  236. FILETYPE PLUGINS *add-filetype-plugin* *ftplugins*
  237. The Vim distribution comes with a set of plugins for different filetypes that
  238. you can start using with this command: >
  239. :filetype plugin on
  240. That's all! See |vimrc-filetype|.
  241. If you are missing a plugin for a filetype you are using, or you found a
  242. better one, you can add it. There are two steps for adding a filetype plugin:
  243. 1. Get a copy of the plugin.
  244. 2. Drop it in the right directory.
  245. GETTING A FILETYPE PLUGIN
  246. You can find them in the same places as the global plugins. Watch out if the
  247. type of file is mentioned, then you know if the plugin is a global or a
  248. filetype one. The scripts in $VIMRUNTIME/macros are global ones, the filetype
  249. plugins are in $VIMRUNTIME/ftplugin.
  250. USING A FILETYPE PLUGIN *ftplugin-name*
  251. You can add a filetype plugin by dropping it in the right directory. The
  252. name of this directory is in the same directory mentioned above for global
  253. plugins, but the last part is "ftplugin". Suppose you have found a plugin for
  254. the "stuff" filetype, and you are on Unix. Then you can move this file to the
  255. ftplugin directory: >
  256. mkdir -p ~/.local/share/nvim/site/ftplugin
  257. mv thefile ~/.local/share/nvim/site/ftplugin/stuff.vim
  258. If that file already exists you already have a plugin for "stuff". You might
  259. want to check if the existing plugin doesn't conflict with the one you are
  260. adding. If it's OK, you can give the new one another name: >
  261. mv thefile ~/.local/share/nvim/site/ftplugin/stuff_too.vim
  262. The underscore is used to separate the name of the filetype from the rest,
  263. which can be anything. If you use "otherstuff.vim" it wouldn't work, it would
  264. be loaded for the "otherstuff" filetype.
  265. The generic names for the filetype plugins are: >
  266. ftplugin/<filetype>.vim
  267. ftplugin/<filetype>_<name>.vim
  268. ftplugin/<filetype>/<name>.vim
  269. Here "<name>" can be any name that you prefer.
  270. Examples for the "stuff" filetype on Unix: >
  271. ~/.local/share/nvim/site/ftplugin/stuff.vim
  272. ~/.local/share/nvim/site/ftplugin/stuff_def.vim
  273. ~/.local/share/nvim/site/ftplugin/stuff/header.vim
  274. The <filetype> part is the name of the filetype the plugin is to be used for.
  275. Only files of this filetype will use the settings from the plugin. The <name>
  276. part of the plugin file doesn't matter, you can use it to have several plugins
  277. for the same filetype. Note that it must end in ".vim" or ".lua".
  278. Further reading:
  279. |filetype-plugins| Documentation for the filetype plugins and information
  280. about how to avoid that mappings cause problems.
  281. |load-plugins| When the global plugins are loaded during startup.
  282. |ftplugin-overrule| Overruling the settings from a global plugin.
  283. |write-plugin| How to write a plugin script.
  284. |plugin-details| For more information about using plugins or when your
  285. plugin doesn't work.
  286. |new-filetype| How to detect a new file type.
  287. ==============================================================================
  288. *05.6* Adding a help file *add-local-help*
  289. If you are lucky, the plugin you installed also comes with a help file. We
  290. will explain how to install the help file, so that you can easily find help
  291. for your new plugin.
  292. Let us suppose a plugin ("my-plugin"), which comes with a help file in a
  293. non-standard place (it usually resides in a sub-folder called `doc/`).
  294. First, create a "doc" directory in one of the directories in 'runtimepath': >
  295. :!mkdir -p ~/.local/share/nvim/site/doc
  296. Now, copy the help file to the "doc" directory: >
  297. :!cp my-plugin/my-plugin-doc.txt ~/.local/share/nvim/site/doc
  298. Here comes the trick, which allows you to jump to the subjects in the new help
  299. file. Generate the local tags file with the |:helptags| command: >
  300. :helptags ~/.local/share/nvim/site/doc
  301. You can see an entry for the local help file when you do: >
  302. :help local-additions
  303. The title lines from the local help files are automagically added to this
  304. section. There you can see which local help files have been added and jump to
  305. them through the tag.
  306. For writing a local help file, see |write-local-help|.
  307. ==============================================================================
  308. *05.7* The option window
  309. If you are looking for an option that does what you want, you can search in
  310. the help files here: |options|. Another way is by using this command: >
  311. :options
  312. This opens a new window, with a list of options with a one-line explanation.
  313. The options are grouped by subject. Move the cursor to a subject and press
  314. <Enter> to jump there. Press <Enter> again to jump back. Or use CTRL-O.
  315. You can change the value of an option. For example, move to the "displaying
  316. text" subject. Then move the cursor down to this line:
  317. set wrap nowrap ~
  318. When you hit <Enter>, the line will change to:
  319. set nowrap wrap ~
  320. The option has now been switched off.
  321. Just above this line is a short description of the 'wrap' option. Move the
  322. cursor one line up to place it in this line. Now hit <Enter> and you jump to
  323. the full help on the 'wrap' option.
  324. For options that take a number or string argument you can edit the value.
  325. Then press <Enter> to apply the new value. For example, move the cursor a few
  326. lines up to this line:
  327. set so=0 ~
  328. Position the cursor on the zero with "$". Change it into a five with "r5".
  329. Then press <Enter> to apply the new value. When you now move the cursor
  330. around you will notice that the text starts scrolling before you reach the
  331. border. This is what the 'scrolloff' option does, it specifies an offset
  332. from the window border where scrolling starts.
  333. ==============================================================================
  334. *05.8* Often used options
  335. There are an awful lot of options. Most of them you will hardly ever use.
  336. Some of the more useful ones will be mentioned here. Don't forget you can
  337. find more help on these options with the ":help" command, with single quotes
  338. before and after the option name. For example: >
  339. :help 'wrap'
  340. In case you have messed up an option value, you can set it back to the
  341. default by putting an ampersand (&) after the option name. Example: >
  342. :set iskeyword&
  343. NOT WRAPPING LINES
  344. Vim normally wraps long lines, so that you can see all of the text. Sometimes
  345. it's better to let the text continue right of the window. Then you need to
  346. scroll the text left-right to see all of a long line. Switch wrapping off
  347. with this command: >
  348. :set nowrap
  349. Vim will automatically scroll the text when you move to text that is not
  350. displayed. To see a context of ten characters, do this: >
  351. :set sidescroll=10
  352. This doesn't change the text in the file, only the way it is displayed.
  353. WRAPPING MOVEMENT COMMANDS
  354. Most commands for moving around will stop moving at the start and end of a
  355. line. You can change that with the 'whichwrap' option. This sets it to the
  356. default value: >
  357. :set whichwrap=b,s
  358. This allows the <BS> key, when used in the first position of a line, to move
  359. the cursor to the end of the previous line. And the <Space> key moves from
  360. the end of a line to the start of the next one.
  361. To allow the cursor keys <Left> and <Right> to also wrap, use this command: >
  362. :set whichwrap=b,s,<,>
  363. This is still only for Normal mode. To let <Left> and <Right> do this in
  364. Insert mode as well: >
  365. :set whichwrap=b,s,<,>,[,]
  366. There are a few other flags that can be added, see 'whichwrap'.
  367. VIEWING TABS
  368. When there are tabs in a file, you cannot see where they are. To make them
  369. visible: >
  370. :set list
  371. Now every tab is displayed as ^I. And a $ is displayed at the end of each
  372. line, so that you can spot trailing spaces that would otherwise go unnoticed.
  373. A disadvantage is that this looks ugly when there are many Tabs in a file.
  374. If you have a color terminal, or are using the GUI, Vim can show the spaces
  375. and tabs as highlighted characters. Use the 'listchars' option: >
  376. :set listchars=tab:>-,trail:-
  377. Now every tab will be displayed as ">---" (with more or less "-") and trailing
  378. white space as "-". Looks a lot better, doesn't it?
  379. KEYWORDS
  380. The 'iskeyword' option specifies which characters can appear in a word: >
  381. :set iskeyword
  382. < iskeyword=@,48-57,_,192-255 ~
  383. The "@" stands for all alphabetic letters. "48-57" stands for ASCII
  384. characters 48 to 57, which are the numbers 0 to 9. "192-255" are the
  385. printable latin characters.
  386. Sometimes you will want to include a dash in keywords, so that commands
  387. like "w" consider "upper-case" to be one word. You can do it like this: >
  388. :set iskeyword+=-
  389. :set iskeyword
  390. < iskeyword=@,48-57,_,192-255,- ~
  391. If you look at the new value, you will see that Vim has added a comma for you.
  392. To remove a character use "-=". For example, to remove the underscore: >
  393. :set iskeyword-=_
  394. :set iskeyword
  395. < iskeyword=@,48-57,192-255,- ~
  396. This time a comma is automatically deleted.
  397. ROOM FOR MESSAGES
  398. When Vim starts there is one line at the bottom that is used for messages.
  399. When a message is long, it is either truncated, thus you can only see part of
  400. it, or the text scrolls and you have to press <Enter> to continue.
  401. You can set the 'cmdheight' option to the number of lines used for
  402. messages. Example: >
  403. :set cmdheight=3
  404. This does mean there is less room to edit text, thus it's a compromise.
  405. ==============================================================================
  406. Next chapter: |usr_06.txt| Using syntax highlighting
  407. Copyright: see |manual-copyright| vim:tw=78:ts=8:noet:ft=help:norl: