home *** CD-ROM | disk | FTP | other *** search
/ vim.ftp.fu-berlin.de / 2015-02-03.vim.ftp.fu-berlin.de.tar / vim.ftp.fu-berlin.de / unix / vim-6.2.tar.bz2 / vim-6.2.tar / vim62 / runtime / doc / usr_21.txt < prev    next >
Encoding:
Text File  |  2003-06-01  |  16.9 KB  |  461 lines

  1. *usr_21.txt*    For Vim version 6.2.  Last change: 2002 Oct 29
  2.  
  3.              VIM USER MANUAL - by Bram Moolenaar
  4.  
  5.                Go away and come back
  6.  
  7.  
  8. This chapter goes into mixing the use of other programs with Vim.  Either by
  9. executing program from inside Vim or by leaving Vim and coming back later.
  10. Furthermore, this is about the ways to remember the state of Vim and restore
  11. it later.
  12.  
  13. |21.1|    Suspend and resume
  14. |21.2|    Executing shell commands
  15. |21.3|    Remembering information; viminfo
  16. |21.4|    Sessions
  17. |21.5|    Views
  18. |21.6|    Modelines
  19.  
  20.      Next chapter: |usr_22.txt|  Finding the file to edit
  21.  Previous chapter: |usr_20.txt|  Typing command-line commands quickly
  22. Table of contents: |usr_toc.txt|
  23.  
  24. ==============================================================================
  25. *21.1*    Suspend and resume
  26.  
  27. Like most Unix programs Vim can be suspended by pressing CTRL-Z.  This stops
  28. Vim and takes you back to the shell it was started in.  You can then do any
  29. other commands until you are bored with them.  Then bring back Vim with the
  30. "fg" command. >
  31.  
  32.     CTRL-Z
  33.     {any sequence of shell commands}
  34.     fg
  35.  
  36. You are right back where you left Vim, nothing has changed.
  37.    In case pressing CTRL-Z doesn't work, you can also use ":suspend".
  38. Don't forget to bring Vim back to the foreground, you would lose any changes
  39. that you made!
  40.  
  41. Only Unix has support for this.  On other systems Vim will start a shell for
  42. you.  This also has the functionality of being able to execute shell commands.
  43. But it's a new shell, not the one that you started Vim from.
  44.    When you are running the GUI you can't go back to the shell where Vim was
  45. started.  CTRL-Z will minimize the Vim window instead.
  46.  
  47. ==============================================================================
  48. *21.2*    Executing shell commands
  49.  
  50. To execute a single shell command from Vim use ":!{command}".  For example, to
  51. see a directory listing: >
  52.  
  53.     :!ls
  54.     :!dir
  55.  
  56. The first one is for Unix, the second one for MS-Windows.
  57.    Vim will execute the program.  When it ends you will get a prompt to hit
  58. <Enter>.  This allows you to have a look at the output from the command before
  59. returning to the text you were editing.
  60.    The "!" is also used in other places where a program is run.  Let's take
  61. a look at an overview:
  62.  
  63.     :!{program}        execute {program}
  64.     :r !{program}        execute {program} and read its output
  65.     :w !{program}        execute {program} and send text to its input
  66.     :[range]!{program}    filter text through {program}
  67.  
  68. Notice that the precense of a range before "!{program}" makes a big
  69. difference.  Without it executes the program normally, with the range a number
  70. of text lines is filtered through the program.
  71.  
  72. Executing a whole row of programs this way is possible.  But a shell is much
  73. better at it.  You can start a new shell this way: >
  74.  
  75.     :shell
  76.  
  77. This is similar to using CTRL-Z to suspend Vim.  The difference is that a new
  78. shell is started.
  79.  
  80. When using the GUI the shell will be using the Vim window for its input and
  81. output.  Since Vim is not a terminal emulator, this will not work perfectly.
  82. If you have trouble, try toggling the 'guipty' option.  If this still doesn't
  83. work well enough, start a new terminal to run the shell in.  For example with:
  84. >
  85.     :!xterm&
  86.  
  87. ==============================================================================
  88. *21.3*    Remembering information; viminfo
  89.  
  90. After editing for a while you will have text in registers, marks in various
  91. files, a command line history filled with carefully crafted commands.  When
  92. you exit Vim all of this is lost.  But you can get it back!
  93.  
  94. The viminfo file is designed to store status information:
  95.  
  96.     Command-line and Search pattern history
  97.     Text in registers
  98.     Marks for various files
  99.     The buffer list
  100.     Global variables
  101.  
  102. Each time you exit Vim it will store this information in a file, the viminfo
  103. file.  When Vim starts again, the viminfo file is read and the information
  104. restored.
  105.  
  106. The 'viminfo' option is set by default to restore a limited number of items.
  107. You might want to set it to remember more information.  This is done through
  108. the following command: >
  109.  
  110.     :set viminfo=string
  111.  
  112. The string specifies what to save.  The syntax of this string is an option
  113. character followed by an argument.  The option/argument pairs are separated by
  114. commas.
  115.    Take a look at how you can build up your own viminfo string.  First, the '
  116. option is used to specify how many files for which you save marks (a-z).  Pick
  117. a nice even number for this option (1000, for instance).  Your command now
  118. looks like this: >
  119.  
  120.     :set viminfo='1000
  121.  
  122. The f option controls whether global marks (A-Z and 0-9) are stored.  If this
  123. option is 0, none are stored. If it is 1 or you do not specify an f option,
  124. the marks are stored.  You want this feature, so now you have this: >
  125.  
  126.     :set viminfo='1000,f1
  127.  
  128. The " option controls how many lines are saved for each of the registers.  By
  129. default, all the lines are saved.  If 0, nothing is saved.  To avoid adding
  130. thousands of lines to your viminfo file (which might never get used and makes
  131. starting Vim slower) you use a maximum of 500 lines: >
  132.  
  133.     :set viminfo='1000,f1,\"500
  134. <
  135.     Note:
  136.     Since the " character starts a comment, it must be preceded with a
  137.     backslash.
  138.  
  139. Other options you might want to use:
  140.     :    number of lines to save from the command line history
  141.     @    number of lines to save from the input line history
  142.     /    number of lines to save from the search history
  143.     r    removable media, for which no marks will be stored (can be
  144.         used several times)
  145.     !    global variables that start with an uppercase letter and
  146.         don't contain lowercase letters
  147.     h    disable 'hlsearch' highlighting when starting
  148.     %    the buffer list (only restored when starting Vim without file
  149.         arguments)
  150.     c    convert the text using 'encoding'
  151.     n    name used for the viminfo file (must be the last option)
  152.  
  153. See the 'viminfo' option and |viminfo-file| for more information.
  154.  
  155. When you run Vim multiple times, the last one exiting will store its
  156. information.  This may cause information that previously exiting Vims stored
  157. to be lost.  Each item can be remembered only once.
  158.  
  159.  
  160. GETTING BACK TO WHERE YOU WERE
  161.  
  162. You are halfway editing a file and it's time to leave for holidays.  You exit
  163. Vim and go enjoy yourselves, forgetting all about your work.  After a couple
  164. of weeks you start Vim, and type:
  165. >
  166.     '0
  167.  
  168. And you are right back where you left Vim.  So you can get on with your work.
  169.    Vim creates a mark each time you exit Vim.  The last one is '0.  The
  170. position that '0 pointed to is made '1.  And '1 is made to '2, and so forth.
  171. Mark '9 is lost.
  172.    The ":marks" command is useful to find out where '0 to '9 will take you.
  173.  
  174.  
  175. MOVE INFO FROM ONE VIM TO ANOTHER
  176.  
  177. You can use the ":wviminfo" and ":rviminfo" commands to save and restore the
  178. information while still running Vim.  This is useful for exchanging register
  179. contents between two instances of Vim, for example.  In the first Vim do: >
  180.  
  181.     :wviminfo! ~/tmp/viminfo
  182.  
  183. And in the second Vim do: >
  184.  
  185.     :rviminfo! ~/tmp/viminfo
  186.  
  187. Obviously, the "w" stands for "write" and the "r" for "read".
  188.    The ! character is used by ":wviminfo" to forcefully overwrite an existing
  189. file.  When it is omitted, and the file exists, the information is merged into
  190. the file.
  191.    The ! character used for ":rviminfo" means that all the information is
  192. used, this may overwrite existing information.  Without the ! only information
  193. that wasn't set is used.
  194.    These commands can also be used to store info and use it again later.  You
  195. could make a directory full of viminfo files, each containing info for a
  196. different purpose.
  197.  
  198. ==============================================================================
  199. *21.4*    Sessions
  200.  
  201. Suppose you are editing along, and it is the end of the day.  You want to quit
  202. work and pick up where you left off the next day.  You can do this by saving
  203. your editing session and restoring it the next day.
  204.    A Vim session contains all the information about what you are editing.
  205. This includes things such as the file list, window layout, global variables,
  206. options and other information. (Exactly what is remembered is controlled by
  207. the 'sessionoptions' option, described below.)
  208.    The following command creates a session file: >
  209.  
  210.     :mksession vimbook.vim
  211.  
  212. Later if you want to restore this session, you can use this command: >
  213.  
  214.     :source vimbook.vim
  215.  
  216. If you want to start Vim and restore a specific session, you can use the
  217. following command: >
  218.  
  219.     vim -S vimbook.vim
  220.  
  221. This tells Vim to read a specific file on startup.  The 'S' stands for
  222. session (actually, you can source any Vim script with -S, thus it might as
  223. well stand for "source").
  224.  
  225. The windows that were open are restored, with the same position and size as
  226. before.  Mappings and option values are like before.
  227.    What exactly is restored depends on the 'sessionoptions' option.  The
  228. default value is "blank,buffers,curdir,folds,help,options,winsize".
  229.  
  230.     blank        keep empty windows
  231.     buffers        all buffers, not only the ones in a window
  232.     curdir        the current directory
  233.     folds        folds, also manually created ones
  234.     help        the help window
  235.     options        all options and mappings
  236.     winsize        window sizes
  237.  
  238. Change this to your liking.  To also restore the size of the Vim window, for
  239. example, use: >
  240.  
  241.     :set sessionoptions+=resize
  242.  
  243.  
  244. SESSION HERE, SESSION THERE
  245.  
  246. The obvious way to use sessions is when working on different projects.
  247. Suppose you store you session files in the directory "~/.vim".  You are
  248. currently working on the "secret" project and have to switch to the "boring"
  249. project: >
  250.  
  251.     :wall
  252.     :mksession! ~/.vim/secret.vim
  253.     :source ~/.vim/boring.vim
  254.  
  255. This first uses ":wall" to write all modified files.  Then the current session
  256. is saved, using ":mksession!".  This overwrites the previous session.  The
  257. next time you load the secret session you can continue where you were at this
  258. point.  And finally you load the new "boring" session.
  259.  
  260. If you open help windows, split and close various window, and generally mess
  261. up the window layout, you can go back to the last saved session: >
  262.  
  263.     :source ~/.vim/boring.vim
  264.  
  265. Thus you have complete control over whether you want to continue next time
  266. where you are now, by saving the current setup in a session, or keep the
  267. session file as a starting point.
  268.    Another way of using sessions is to create a window layout that you like to
  269. use, and save this in a session.  Then you can go back to this layout whenever
  270. you want.
  271.    For example, this is a nice layout to use:
  272.  
  273.     +----------------------------------------+
  274.     |           VIM - main help file  |
  275.     |                     |
  276.     |Move around:  Use the cursor keys, or "h|
  277.     |help.txt================================|
  278.     |explorer   |                 |
  279.     |dir        |~                 |
  280.     |dir        |~                 |
  281.     |file        |~                 |
  282.     |file        |~                 |
  283.     |file        |~                 |
  284.     |file        |~                 |
  285.     |~/=========|[No File]===================|
  286.     |                     |
  287.     +----------------------------------------+
  288.  
  289. This has a help window at the top, so that you can read this text.  The narrow
  290. vertical window on the left contains a file explorer.  This is a Vim plugin
  291. that lists the contents of a directory.  You can select files to edit there.
  292. More about this in the next chapter.
  293.    Create this from a just started Vim with: >
  294.  
  295.     :help
  296.     CTRL-W w
  297.     :vertical split ~/
  298.  
  299. You can resize the windows a bit to your liking.  Then save the session with:
  300. >
  301.     :mksession ~/.vim/mine.vim
  302.  
  303. Now you can start Vim with this layout: >
  304.  
  305.     vim -S ~/.vim/mine.vim
  306.  
  307. Hint: To open a file you see listed in the explorer window in the empty
  308. window, move the cursor to the filename and press "O".  Double clicking with
  309. the mouse will also do this.
  310.  
  311.  
  312. UNIX AND MS-WINDOWS
  313.  
  314. Some people have to do work on MS-Windows systems one day and on Unix another
  315. day.  If you are one of them, consider adding "slash" and "unix" to
  316. 'sessionoptions'.  The session files will then be written in a format that can
  317. be used on both systems.  This is the command to put in your vimrc file: >
  318.  
  319.     :set sessionoptions+=unix,slash
  320.  
  321. Vim will use the Unix format then, because the MS-Windows Vim can read and
  322. write Unix files, but Unix Vim can't read MS-Windows format session files.
  323. Similarly, MS-Windows Vim understands file names with / to separate names, but
  324. Unix Vim doesn't understand \.
  325.  
  326.  
  327. SESSIONS AND VIMINFO
  328.  
  329. Sessions store many things, but not the position of marks, contents of
  330. registers and the command line history.  You need to use the viminfo feature
  331. for these things.
  332.    In most situations you will want to use sessions separately from viminfo.
  333. This can be used to switch to another session, but keep the command line
  334. history.  And yank text into registers in one session, and paste it back in
  335. another session.
  336.    You might prefer to keep the info with the session.  You will have to do
  337. this yourself then.  Example: >
  338.  
  339.     :mksession! ~/.vim/secret.vim
  340.     :wviminfo! ~/.vim/secret.viminfo
  341.  
  342. And to restore this again: >
  343.  
  344.     :source ~/.vim/secret.vim
  345.     :rviminfo! ~/.vim/secret.viminfo
  346.  
  347. ==============================================================================
  348. *21.5*    Views
  349.  
  350. A session stores the looks of the whole of Vim.  When you want to store the
  351. properties for one window only, use a view.
  352.    The use of a view is for when you want to edit a file in a specific way.
  353. For example, you have line numbers enabled with the 'number' option and
  354. defined a few folds.  Just like with sessions, you can remember this view on
  355. the file and restore it later.  Actually, when you store a session, it stores
  356. the view of each window.
  357.    There are two basic ways to use views.  The first is to let Vim pick a name
  358. for the view file.  You can restore the view when you later edit the same
  359. file.  To store the view for the current window: >
  360.  
  361.     :mkview
  362.  
  363. Vim will decide where to store the view.  When you later edit the same file
  364. you get the view back with this command: >
  365.  
  366.     :loadview
  367.  
  368. That's easy, isn't it?
  369.    Now you want to view the file without the 'number' option on, or with all
  370. folds open, you can set the options to make the window look that way.  Then
  371. store this view with: >
  372.  
  373.     :mkview 1
  374.  
  375. Obviously, you can get this back with: >
  376.  
  377.     :loadview 1
  378.  
  379. Now you can switch between the two views on the file by using ":loadview" with
  380. and without the "1" argument.
  381.    You can store up to ten views for the same file this way, one unnumbered
  382. and nine numbered 1 to 9.
  383.  
  384.  
  385. A VIEW WITH A NAME
  386.  
  387. The second basic way to use views is by storing the view in a file with a name
  388. you chose.  This view can be loaded while editing another file.  Vim will then
  389. switch to editing the file specified in the view.  Thus you can use this to
  390. quickly switch to editing another file, with all its options set as you saved
  391. them.
  392.    For example, to save the view of the current file: >
  393.  
  394.     :mkview ~/.vim/main.vim
  395.  
  396. You can restore it with: >
  397.  
  398.     :source ~/.vim/main.vim
  399.  
  400. ==============================================================================
  401. *21.6*    Modelines
  402.  
  403. When editing a specific file, you might set options specifically for that
  404. file.  Typing these commands each time is boring.  Using a session or view for
  405. editing a file doesn't work when sharing the file between several people.
  406.    The solution for this situation is adding a modeline to the file.  This is
  407. a line of text that tells Vim the values of options, to be used in this file
  408. only.
  409.    A typical example is a C program where you make indents by a multiple of 4
  410. spaces.  This requires setting the 'shiftwidth' option to 4.  This modeline
  411. will do that:
  412.  
  413.     /* vim:set shiftwidth=4: */ ~
  414.  
  415. Put this line as one of the first or last five lines in the file.  When
  416. editing the file, you will notice that 'shiftwidth' will have been set to
  417. four.  When editing another file, it's set back to the default value of eight.
  418.    For some files the modeline fits well in the header, thus it can be put at
  419. the top of the file.  For text files and other files where the modeline gets
  420. in the way of the normal contents, put it at the end of the file.
  421.  
  422. The 'modelines' option specifies how many lines at the start and end of the
  423. file are inspected for containing a modeline.  To inspect ten lines: >
  424.  
  425.     :set modelines=10
  426.  
  427. The 'modeline' option can be used to switch this off.  Do this when you are
  428. working as root or don't trust the files you are editing: >
  429.  
  430.     :set nomodeline
  431.  
  432. Use this format for the modeline:
  433.  
  434.     any-text vim:set {option}={value} ... : any-text ~
  435.  
  436. The "any-text" indicates that you can put any text before and after the part
  437. that Vim will use.  This allows making it look like a comment, like what was
  438. done above with /* and */.
  439.    The " vim:" part is what makes Vim recognize this line.  The must be white
  440. space before "vim", or "vim" must be at the start of the line.  Thus using
  441. something like "gvim:" will not work.
  442.    The part between the colons is a ":set" command.  It works the same way as
  443. typing the ":set" command, except that you need to insert a backslash before a
  444. colon (otherwise it would be seen as the end of the modeline).
  445.  
  446. Another example:
  447.  
  448.     // vim:set textwidth=72 dir=c\:\tmp:  use c:\tmp here ~
  449.  
  450. There is an extra backslash before the first colon, so that it's included in
  451. the ":set" command.  The text after the second colon is ignored, thus a remark
  452. can be placed there.
  453.  
  454. For more details see |modeline|.
  455.  
  456. ==============================================================================
  457.  
  458. Next chapter: |usr_22.txt|  Finding the file to edit
  459.  
  460. Copyright: see |manual-copyright|  vim:tw=78:ts=8:ft=help:norl:
  461.