scratch/content/html/en/blog/Learn-Vim-Progressively.md

318 lines
10 KiB
Markdown
Raw Normal View History

2011-08-26 13:48:47 +00:00
-----
isHidden: false
menupriority: 1
kind: article
created_at: 2011-08-25T19:28:20+02:00
title: Learn Vim Progressively
author_name: Yann Esposito
author_uri: yannesposito.com
tags:
- vi
- vim
- editor
- tutorial
-----
<%= blogimage("uber_leet_use_vim.jpg","Über leet use vim!") %>
begindiv(intro)
<%= tldr %> Want to learn vim (the best text editor known to human kind) the fastest way possible. I suggest you a way. Start by learning the minimal to survive, then integrate slowly all tricks.
enddiv
[Vim] the Six Billion Dollar editor
> Better, Stronger, Faster.
Learn [vim] and it will be your last text editor.
There isn't any better text editor I know.
Hard to learn, but incredible to use.
I suggest you to learn it in 4 steps:
1. Survive
2. Feel comfortable
3. Feel Better, Stronger, Faster
4. Use vim superpowers
By the end of this journey, you'll become a vim superstar.
But before we start, just a warning.
Learning vim will be painful at first.
2011-08-26 14:32:49 +00:00
It will take time.
It will be a lot like playing a music instrument.
2011-08-26 13:48:47 +00:00
Don't expect to be more efficient with vim than with another editor in less than 3 days.
In fact it will certainly take 2 weeks instead of 3 days.
[Vim]: http://www.vim.org
[vim]: http://www.vim.org
## 1st Level -- Survive
0. Install [vim]
1. Launch vim
2. DO NOTHING! Read.
In a standard editor, typing on the keyboard is enough to write something and see it on the screen.
Not this time.
2011-08-29 13:14:17 +00:00
Vim is in _Normal_ mode.
2011-08-29 13:05:28 +00:00
Lets get in _Insert_ mode.
2011-08-26 13:48:47 +00:00
Type on the letter `i`.
2011-08-26 14:32:49 +00:00
You should feel a bit better.
2011-08-26 13:48:47 +00:00
You can type letters like in a standard notepad.
2011-08-29 13:14:17 +00:00
To get back in _Normal_ mode just tap the `ESC` key.
2011-08-26 13:48:47 +00:00
2011-08-29 13:14:17 +00:00
You know how to switch between _Insert_ and _Normal_ mode.
And now, the list of command you can use in _Normal_ mode to survive:
2011-08-26 13:48:47 +00:00
2011-08-29 13:14:17 +00:00
> - `i`: _Insert_ mode. Type `ESC` to return to Normal mode.
2011-08-26 13:48:47 +00:00
> - `x`: Delete the char under the cursor
> - `:wq`: Save and Quit (`:w` save, `:q` quit)
> - `dd`: Delete (and copy) current line
2011-08-29 13:05:28 +00:00
> - `p`: Paste
2011-08-26 14:32:49 +00:00
>
> Recommended:
>
> - `hjkl` (recommended but not mandatory): basic cursor move (<-&darr;&uarr;→). Hint: `j` look like a down arrow.
2011-08-26 13:48:47 +00:00
> - `:help <command>`: Show help about <command>, you can start using `:help` without anything else.
Only 5 commands. This is very few to start.
Once these command start to become natural (may be after a complete day), you should go on level 2.
2011-08-29 13:14:17 +00:00
But before, just a little remark on _Normal mode_.
2011-08-26 14:32:49 +00:00
In standard editors, to copy you have to use the `Ctrl` key (`Ctrl-c` generally).
2011-08-26 13:48:47 +00:00
In fact, when you press `Ctrl`, it is a bit like if all your key change meaning.
2011-08-29 13:14:17 +00:00
With vim in Normal mode, it is a bit like if your `Ctrl` key is always pushed down.
2011-08-26 13:48:47 +00:00
2011-08-29 13:05:28 +00:00
A last word about notation: instead of writing `Ctrl-λ`, I'll write `<C-λ>`.
2011-08-26 13:48:47 +00:00
## 2nd Level -- Feel comfortable
2011-08-29 13:31:54 +00:00
You know the commands required for survival.
It's time to learn a few more commands.
2011-08-26 13:48:47 +00:00
I suggest:
2011-08-29 13:14:17 +00:00
1. Insert mode variations:
2011-08-26 13:48:47 +00:00
2011-08-26 14:39:45 +00:00
> - `a` → insert after the cursor
2011-08-26 13:48:47 +00:00
> - `o` → insert a new line after the current one
> - `O` → insert a new line before the current one
2011-08-29 13:14:17 +00:00
> - `cw` → replace from the cursor to the end the word
2011-08-26 13:48:47 +00:00
2. Basic moves
> - `0` → go to first column
> - `^` → go to first character of the line
> - `$` → go to the end of line
> - `/pattern` → search for `pattern`
3. Copy/Paste
2011-08-29 11:39:13 +00:00
> - `P` → paste before, remember `p` is paste after current position.
2011-08-26 13:48:47 +00:00
> - `yy` → copy current line, easier but equivalent to `ddP`
4. Undo/Redo
2011-08-29 12:03:03 +00:00
> - `u` → undo
2011-08-29 13:05:28 +00:00
> - `<C-r>` → redo
2011-08-26 13:48:47 +00:00
5. Load/Save/Quit/Change File (Buffer)
2011-08-29 12:03:03 +00:00
> - `:e <path/to/file>` → open
> - `:w` → save
> - `:saveas <path/to/file>` → save to `<path/to/file>`
> - `ZZ` or `:wq` → save and quit
> - `:q!` → quit without saving, also `:qa!` to even if there are some modified hidden buffers.
> - `:bn` (resp. `:bp`) → show next (resp. previous) file (buffer)
2011-08-26 13:48:47 +00:00
Take the time to integrate all of these command.
Once done, you should be able to do every thing you are able to do on other editors.
But until now, it is a bit awkward. But follow me to the next level and you'll see why.
## 3rd Level -- Better. Stronger. Faster.
2011-08-29 13:31:54 +00:00
Congratulation reaching this far!
We can start the interesting stuff.
2011-08-26 13:48:47 +00:00
At level 3, we'll only talk about command which are compatible with the old vi.
### Better
Lets look at how vim could help you to repeat yourself:
1. `.` → (dot) will repeat the last command,
2. N&lt;command&gt; → will do the command N times.
Some examples, open a file and type:
> - `2dd` → will delete 2 lines
> - `3p` → will paste the text 3 times
> - `100idesu [ESC]` → will write "desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu "
> - `.` → Just after the last command will write again the 100 "desu ".
> - `3.` → Will write 3 "desu" (and not 300, how clever).
### Stronger
Knowing how to move efficiently with vim is _very_ important.
Don't skip this section.
1. N`G` → Go to line N
2. `gg` → shortcut for `1G`, go to the start of the file
3. `G` → Go to last line
4. Word moves:
> 1. `w` → go to the start of the following word,
> 2. `e` → go to the end of this word.
>
> By default, word are composed of letter and the underscore character.
> If you want to use word in the meaning of group of letter separated by spaces, just use uppercases:
>
> 1. `W` → go to the start of the following "extended" word,
> 2. `E` → go to the end of this "extended" word.
>
> <%= blogimage("word_moves.jpg","Word moves example") %>
Now lets talk about very efficient moves:
> - `%` : Go to corresponding `(`, `{`, `[`.
> - `*` (resp. `#`) : go to next (resp. previous) occurrence of the word under the cursor
2011-08-29 13:31:54 +00:00
Believe me, the last three commands are gold.
2011-08-26 13:48:47 +00:00
### Faster
Remember about the importance of vi moves?
Here is the reason.
Most commands can be used using the following general format:
`<start position><command><end position>`
For example : `0y$` means
- `0` → go to the beginning of this line
- `y` → yank from here
- `$` → up to the end of this line
We also can do things like `ye`, yank from here to the end of the word.
But also `y2/foo` yank up to the second occurrence of "foo".
But what was true for `y` (yank),
is also true for `d` (delete), `v` (visual select), `gU` (uppercase), `gu` (lowercase), etc...
## 4th Level -- Vim Superpowers
With all preceding commands you should be comfortable to use vim.
But now, here are the killer features.
Some of these features were the reason I started to use vim.
### Move on current line: `0` `^` `$` `f` `F` `t` `T` `,` `;`
> - `0` → go to column 0
> - `^` → go to first character on the line
> - `$` → go to the last character on the line
> - `fa` → go to next occurrence of the letter `a` on the line. `,` (resp. `;`) will seek for the next (resp. previous) occurrence.
2011-08-29 13:05:28 +00:00
> - `t,` → go just before the character `,`.
2011-08-26 13:48:47 +00:00
> - `3fa` → search the 3rd occurrence of `a` on this line.
> - `F` and `T` → like `f` and `t` but backward.
> <%= blogimage("line_moves.jpg","Line moves") %>
_Some Useful Tips_
> - `dt"` → remove everything until the `"`.
> - `vi"` → select everything inside two `"`.
2011-08-29 13:41:15 +00:00
### Select rectangular blocs: `<C-v>`.
2011-08-26 13:48:47 +00:00
Rectangular blocks are very useful to comment many lines of code.
2011-08-29 13:41:15 +00:00
Typically: `0<C-v><C-d>I// [ESC]`
2011-08-26 13:48:47 +00:00
- `^` → go to start of the line
2011-08-29 13:41:15 +00:00
- `<C-v>` → Start block selection
2011-08-29 13:05:28 +00:00
- `<C-d>` → move down (could also be `jjj` or `%`, etc...)
2011-08-26 13:48:47 +00:00
- `I// [ESC]` → write `// ` to comment each line
<%= blogimage("rectangular-blocks.gif","Rectangular blocks") %>
2011-08-29 13:41:15 +00:00
Not on windows you might have to use `<C-q>` instead of `<C-v>` if your clipboard is not empty.
2011-08-29 13:05:28 +00:00
### Completion: `<C-n>` and `<C-p>`.
2011-08-26 13:48:47 +00:00
2011-08-29 13:05:28 +00:00
In Insert mode, just type the start of a word, then type `<C-p>`, magic...
2011-08-26 13:48:47 +00:00
<%= blogimage("completion.gif","Completion") %>
### Macros : `qa` do something `q`, `@a`, `@@`
`qa` record your actions in the _register_ `a`.
Then `@a` will replay the macro saved into the register `a` as if you typed it.
`@@` is a shortcut to replay the last executed macro.
> *Example*
>
> On a line containing only the number 1, type this:
>
2011-08-29 13:05:28 +00:00
> - `qaYp<C-a>q` →
2011-08-26 13:48:47 +00:00
>
> - `qa` start recording.
> - `Yp` duplicate this line.
2011-08-29 13:05:28 +00:00
> - `<C-a>` increment the number.
2011-08-26 13:48:47 +00:00
> - `q` stop recording.
>
> - `@a` → write 2 under the 1
> - `@@` → write 3 under the 2
> - Now do `100@@` will create a list of increasing numbers until 103.
<%= blogimage("macros.gif","Macros") %>
2011-08-29 13:05:28 +00:00
### Visual selection: `v`,`V`,`<C-v>`
2011-08-26 13:48:47 +00:00
2011-08-29 13:41:15 +00:00
We saw an example with `<C-v>`.
2011-08-26 13:48:47 +00:00
There is also `v` and `V`.
Once the selection made, you can:
- `J` → join all lines together.
- `<` (resp. `>`) → indent to the left (resp. to the right).
- `=` → auto indent
<%= blogimage("autoindent.gif","Autoindent") %>
2011-08-29 13:31:54 +00:00
Add something at the end of all visually selected lines:
2011-08-26 13:48:47 +00:00
2011-08-29 13:05:28 +00:00
- `<C-v>`
- go to desired line (`jjj` or `<C-d>` or `/pattern` or `%` etc...)
2011-08-26 13:48:47 +00:00
- `$` go to the end of line
2011-08-29 13:31:54 +00:00
- `A`, write text, `ESC`.
2011-08-26 13:48:47 +00:00
<%= blogimage("append-to-many-lines.gif","Append to many lines") %>
2011-08-26 14:39:45 +00:00
### Splits: `:split` and `vsplit`.
2011-08-26 13:48:47 +00:00
Here are the main commands, but you should look at `:help split`.
> - `:split` → create a split (`:vsplit` create a vertical split)
2011-08-29 13:05:28 +00:00
> - `<C-w><dir>` : where dir is any of `hjkl` or <-&darr;&uarr;→ to change split.
> - `<C-w>_` (resp. `<C-w>|`) : maximise size of split (resp. vertical split)
> - `<C-w>+` (resp. `<C-w>-`) : Grow (resp. shrink) split
2011-08-26 13:48:47 +00:00
<%= blogimage("split.gif","Split") %>
## Conclusion
That was 90% of commands I use every day.
I suggest you to learn no more than one or two new command per day.
After two to three weeks you'll start to feel the power of vim in your hands.
2011-08-26 14:39:45 +00:00
Then, you will learn about `!`, folds, registers, the plugins and many other features.
Learn vim like you'd learn piano and all should be fine.
2011-08-26 13:48:47 +00:00
<script>
// Style the keywords
$(document).ready(function() {
$('code').css({ 'border': 'solid 1px #CCC', 'padding':'3px'});
});
</script>