mirror of
https://github.com/adambard/learnxinyminutes-docs.git
synced 2025-01-15 05:35:59 +00:00
20af61ee8d
Replacing new line character to new line character is not practical but an interesting example which shows the difference between representation of new line character in search and replace patterns.
263 lines
8.3 KiB
Markdown
263 lines
8.3 KiB
Markdown
---
|
|
category: tool
|
|
tool: vim
|
|
contributors:
|
|
- ["RadhikaG", "https://github.com/RadhikaG"]
|
|
filename: LearnVim.txt
|
|
---
|
|
|
|
|
|
[Vim](http://www.vim.org)
|
|
(Vi IMproved) is a clone of the popular vi editor for Unix. It is a text
|
|
editor designed for speed and increased productivity, and is ubiquitous in most
|
|
unix-based systems. It has numerous keybindings for speedy navigation to
|
|
specific points in the file, and for fast editing.
|
|
|
|
## Basics of navigating Vim
|
|
|
|
```
|
|
vim <filename> # Open <filename> in vim
|
|
:help <topic> # Open up built-in help docs about <topic> if any exists
|
|
:q # Quit vim
|
|
:w # Save current file
|
|
:wq # Save file and quit vim
|
|
ZZ # Save file and quit vim
|
|
:q! # Quit vim without saving file
|
|
# ! *forces* :q to execute, hence quiting vim without saving
|
|
:x # Save file and quit vim, shorter version of :wq
|
|
|
|
u # Undo
|
|
CTRL+R # Redo
|
|
|
|
h # Move left one character
|
|
j # Move down one line
|
|
k # Move up one line
|
|
l # Move right one character
|
|
|
|
# Moving within the line
|
|
|
|
0 # Move to beginning of line
|
|
$ # Move to end of line
|
|
^ # Move to first non-blank character in line
|
|
|
|
# Searching in the text
|
|
|
|
/word # Highlights all occurrences of word after cursor
|
|
?word # Highlights all occurrences of word before cursor
|
|
n # Moves cursor to next occurrence of word after search
|
|
N # Moves cursor to previous occerence of word
|
|
|
|
:%s/foo/bar/g # Change 'foo' to 'bar' on every line in the file
|
|
:s/foo/bar/g # Change 'foo' to 'bar' on the current line
|
|
:%s/\n/\r/g # Replace new line characters with new line characters
|
|
|
|
# Jumping to characters
|
|
|
|
f<character> # Jump forward and land on <character>
|
|
t<character> # Jump forward and land right before <character>
|
|
|
|
# For example,
|
|
f< # Jump forward and land on <
|
|
t< # Jump forward and land right before <
|
|
|
|
# Moving by word
|
|
|
|
w # Move forward by one word
|
|
b # Move back by one word
|
|
e # Move to end of current word
|
|
|
|
# Other characters for moving around
|
|
|
|
gg # Go to the top of the file
|
|
G # Go to the bottom of the file
|
|
:NUM # Go to line number NUM (NUM is any number)
|
|
H # Move to the top of the screen
|
|
M # Move to the middle of the screen
|
|
L # Move to the bottom of the screen
|
|
```
|
|
|
|
## Help docs:
|
|
|
|
Vim has built in help documentation that can accessed with `:help <topic>`.
|
|
For example `:help navigation` will pull up documentation about how to navigate
|
|
your workspace!
|
|
|
|
`:help` can also be used without an option. This will bring up a default help dialog
|
|
that aims to make getting started with vim more approachable!
|
|
|
|
## Modes:
|
|
|
|
Vim is based on the concept on **modes**.
|
|
|
|
Command Mode - vim starts up in this mode, used to navigate and write commands
|
|
Insert Mode - used to make changes in your file
|
|
Visual Mode - used to highlight text and do operations to them
|
|
Ex Mode - used to drop down to the bottom with the ':' prompt to enter commands
|
|
|
|
```
|
|
i # Puts vim into insert mode, before the cursor position
|
|
a # Puts vim into insert mode, after the cursor position
|
|
v # Puts vim into visual mode
|
|
: # Puts vim into ex mode
|
|
<esc> # 'Escapes' from whichever mode you're in, into Command mode
|
|
|
|
# Copying and pasting text
|
|
|
|
y # Yank whatever is selected
|
|
yy # Yank the current line
|
|
d # Delete whatever is selected
|
|
dd # Delete the current line
|
|
p # Paste the copied text after the current cursor position
|
|
P # Paste the copied text before the current cursor position
|
|
x # Deleting character under current cursor position
|
|
```
|
|
|
|
## The 'Grammar' of vim
|
|
|
|
Vim can be thought of as a set of commands in a
|
|
'Verb-Modifier-Noun' format, where:
|
|
|
|
Verb - your action
|
|
Modifier - how you're doing your action
|
|
Noun - the object on which your action acts on
|
|
|
|
A few important examples of 'Verbs', 'Modifiers', and 'Nouns':
|
|
|
|
```
|
|
# 'Verbs'
|
|
|
|
d # Delete
|
|
c # Change
|
|
y # Yank (copy)
|
|
v # Visually select
|
|
|
|
# 'Modifiers'
|
|
|
|
i # Inside
|
|
a # Around
|
|
NUM # Number (NUM is any number)
|
|
f # Searches for something and lands on it
|
|
t # Searches for something and stops before it
|
|
/ # Finds a string from cursor onwards
|
|
? # Finds a string before cursor
|
|
|
|
# 'Nouns'
|
|
|
|
w # Word
|
|
s # Sentence
|
|
p # Paragraph
|
|
b # Block
|
|
|
|
# Sample 'sentences' or commands
|
|
|
|
d2w # Delete 2 words
|
|
cis # Change inside sentence
|
|
yip # Yank inside paragraph (copy the para you're in)
|
|
ct< # Change to open bracket
|
|
# Change the text from where you are to the next open bracket
|
|
d$ # Delete till end of line
|
|
```
|
|
|
|
## Some shortcuts and tricks
|
|
|
|
<!--TODO: Add more!-->
|
|
```
|
|
> # Indent selection by one block
|
|
< # Dedent selection by one block
|
|
:earlier 15m # Reverts the document back to how it was 15 minutes ago
|
|
:later 15m # Reverse above command
|
|
ddp # Swap position of consecutive lines, dd then p
|
|
. # Repeat previous action
|
|
:w !sudo tee % # Save the current file as root
|
|
:set syntax=c # Set syntax highlighting to 'c'
|
|
:sort # Sort all lines
|
|
:sort! # Sort all lines in reverse
|
|
:sort u # Sort all lines and remove duplicates
|
|
~ # Toggle letter case of selected text
|
|
u # Selected text to lower case
|
|
U # Selected text to upper case
|
|
|
|
# Fold text
|
|
zf # Create fold from selected text
|
|
zo # Open current fold
|
|
zc # Close current fold
|
|
zR # Open all folds
|
|
zM # Close all folds
|
|
```
|
|
|
|
## Macros
|
|
|
|
Macros are basically recordable actions.
|
|
When you start recording a macro, it records **every** action and command
|
|
you use, until you stop recording. On invoking a macro, it applies the exact
|
|
same sequence of actions and commands again on the text selection.
|
|
|
|
```
|
|
qa # Start recording a macro named 'a'
|
|
q # Stop recording
|
|
@a # Play back the macro
|
|
```
|
|
|
|
### Configuring ~/.vimrc
|
|
|
|
The .vimrc file can be used to configure Vim on startup.
|
|
|
|
Here's a sample ~/.vimrc file:
|
|
|
|
```
|
|
" Example ~/.vimrc
|
|
" 2015.10
|
|
|
|
" Required for vim to be iMproved
|
|
set nocompatible
|
|
|
|
" Determines filetype from name to allow intelligent auto-indenting, etc.
|
|
filetype indent plugin on
|
|
|
|
" Enable syntax highlighting
|
|
syntax on
|
|
|
|
" Better command-line completion
|
|
set wildmenu
|
|
|
|
" Use case insensitive search except when using capital letters
|
|
set ignorecase
|
|
set smartcase
|
|
|
|
" When opening a new line and no file-specific indenting is enabled,
|
|
" keep same indent as the line you're currently on
|
|
set autoindent
|
|
|
|
" Display line numbers on the left
|
|
set number
|
|
|
|
" Indentation options, change according to personal preference
|
|
|
|
" Number of visual spaces per TAB
|
|
set tabstop=4
|
|
|
|
" Number of spaces in TAB when editing
|
|
set softtabstop=4
|
|
|
|
" Number of spaces indented when reindent operations (>> and <<) are used
|
|
set shiftwidth=4
|
|
|
|
" Convert TABs to spaces
|
|
set expandtab
|
|
|
|
" Enable intelligent tabbing and spacing for indentation and alignment
|
|
set smarttab
|
|
```
|
|
|
|
### References
|
|
|
|
[Vim | Home](http://www.vim.org/index.php)
|
|
|
|
`$ vimtutor`
|
|
|
|
[A vim Tutorial and Primer](https://danielmiessler.com/study/vim/)
|
|
|
|
[What are the dark corners of Vim your mom never told you about? (Stack Overflow thread)](http://stackoverflow.com/questions/726894/what-are-the-dark-corners-of-vim-your-mom-never-told-you-about)
|
|
|
|
[Arch Linux Wiki](https://wiki.archlinux.org/index.php/Vim)
|