updated documents and added SelectPhrasePaste function

This commit is contained in:
haya14busa 2013-10-05 02:34:48 +09:00
parent 630484d7b6
commit 80255e41c9
3 changed files with 149 additions and 61 deletions

View File

@ -3,6 +3,8 @@
2. Added forward-backward search (bidirectional) search. You can jump forward or backward at the same time. `<Leader>s`. One useful trick is to map `nmap <SPACE> <leader>s` and `vmap <SPACE> <leader>s` to use space bar instead and save one keystroke! 2. Added forward-backward search (bidirectional) search. You can jump forward or backward at the same time. `<Leader>s`. One useful trick is to map `nmap <SPACE> <leader>s` and `vmap <SPACE> <leader>s` to use space bar instead and save one keystroke!
3. Added SelectLines function which allows you to select any range of lines using two consecutive easymotion calls. Default mappings are `c<Leader>l, d<Leader>l, v<Leader>l, y<Leader>l`. To yank a single line you can either type the same character(s) twice, or use '.' character. E.g. `vlb.` will select the line with character 'b'. Note: to promote good Vim habits, you should learn standard movement commands like `}}, vi(, va(, %, ][, ]], [(, etc.` before resorting to this function. 3. Added SelectLines function which allows you to select any range of lines using two consecutive easymotion calls. Default mappings are `c<Leader>l, d<Leader>l, v<Leader>l, y<Leader>l`. To yank a single line you can either type the same character(s) twice, or use '.' character. E.g. `vlb.` will select the line with character 'b'. Note: to promote good Vim habits, you should learn standard movement commands like `}}, vi(, va(, %, ][, ]], [(, etc.` before resorting to this function.
4. (Experimental) Added SelectPhrase function which allows you to make selection between any two characters. Default mapping are `c<Leader>p, d<Leader>p, v<Leader>p, y<Leader>p`. Example usage: type `v<Leader>p` then press two input characters. Now the two input characters will be highlight on the same screen, and you can then type two combos to make selection. 4. (Experimental) Added SelectPhrase function which allows you to make selection between any two characters. Default mapping are `c<Leader>p, d<Leader>p, v<Leader>p, y<Leader>p`. Example usage: type `v<Leader>p` then press two input characters. Now the two input characters will be highlight on the same screen, and you can then type two combos to make selection.
5. Added matching target keys by smartcase option.
6. Added keep cursor column option when JK motion.
## Animated demonstration ## Animated demonstration
@ -12,10 +14,16 @@ Two-key combo
Select lines using `v<Leader>l` Select lines using `v<Leader>l`
let g:EasyMotion_special_select_line = 1 " Default:0
let g:EasyMotion_special_mapping_l = '{anykeys}' " Customize keymap
![two-character key](http://homes.cs.washington.edu/~supasorn/easymotion2.gif) ![two-character key](http://homes.cs.washington.edu/~supasorn/easymotion2.gif)
Yank lines using `y<Leader>l`. You can copy lines without moving cursor back and forth between line you want to yank and line you want to paste. Yank lines using `y<Leader>l`. You can copy lines without moving cursor back and forth between line you want to yank and line you want to paste.
let g:EasyMotion_special_select_phrase = 1 " Default:0
let g:EasyMotion_special_mapping_p = '{anykeys}' " Customize keymap
![two-character key](http://homes.cs.washington.edu/~supasorn/easymotion3.gif) ![two-character key](http://homes.cs.washington.edu/~supasorn/easymotion3.gif)
This is an alpha version, which breaks multi-byte support, and others. This is an alpha version, which breaks multi-byte support, and others.
@ -71,3 +79,31 @@ about EasyMotion.
## Animated demonstration ## Animated demonstration
![Animated demonstration](http://oi54.tinypic.com/2yysefm.jpg) ![Animated demonstration](http://oi54.tinypic.com/2yysefm.jpg)
## Vim-Lazymotion!
Matching target keys by smartcase. You can type targets more lazily.
Type `<Leader><Leader>sv`, and all "v" and "V" characters are highlighted:
<cursor>V{a}im v{b}im V{c}IM.
Press `b` to jump to the second "v":
Vim <cursor>vim VIM.
Type `<Leader><Leader>sV`, and all "V" characters are highlighted, not "v":
<cursor>V{a}im vim V{b}IM.
Press `b` to jump to the second "V":
Vim vim <cursor>VIM.
Add following description in your vimrc:
let g:EasyMotion_smartcase = 1
Default:0

View File

@ -72,6 +72,7 @@
if g:EasyMotion_special_{fn.flag} if g:EasyMotion_special_{fn.flag}
silent exec 'onoremap <silent> ' . g:EasyMotion_special_mapping_{motion} . ' :call EasyMotion#' . fn.name . '()<CR>' silent exec 'onoremap <silent> ' . g:EasyMotion_special_mapping_{motion} . ' :call EasyMotion#' . fn.name . '()<CR>'
silent exec 'nnoremap <silent> v' . g:EasyMotion_special_mapping_{motion} . ' :call EasyMotion#' . fn.name . '()<CR>' silent exec 'nnoremap <silent> v' . g:EasyMotion_special_mapping_{motion} . ' :call EasyMotion#' . fn.name . '()<CR>'
silent exec 'nnoremap <silent> p' . g:EasyMotion_special_mapping_{motion} . ' :call EasyMotion#' . fn.name . 'Paste()<CR>'
silent exec 'nnoremap <silent> y' . g:EasyMotion_special_mapping_{motion} . ' :call EasyMotion#' . fn.name . 'Yank()<CR>' silent exec 'nnoremap <silent> y' . g:EasyMotion_special_mapping_{motion} . ' :call EasyMotion#' . fn.name . 'Yank()<CR>'
endif endif
endfor endfor
@ -81,25 +82,7 @@
" }}} " }}}
" Motion functions {{{ " Motion functions {{{
function! EasyMotion#SelectLinesPaste() function! EasyMotion#SelectLines() "{{{
let orig_pos = [line('.'), col('.')]
call EasyMotion#SelectLines()
normal y
keepjumps call cursor(orig_pos[0], orig_pos[1])
if !g:EasyMotion_cancelled
normal p
endif
endfunction
function! EasyMotion#SelectLinesYank()
let orig_pos = [line('.'), col('.')]
call EasyMotion#SelectLines()
normal y
keepjumps call cursor(orig_pos[0], orig_pos[1])
"normal p
endfunction
function! EasyMotion#SelectLines()
let orig_pos = [line('.'), col('.')] let orig_pos = [line('.'), col('.')]
call s:EasyMotion('^\(\w\|\s*\zs\|$\)', 2, '', '', 0, 0, 1) call s:EasyMotion('^\(\w\|\s*\zs\|$\)', 2, '', '', 0, 0, 1)
@ -118,9 +101,25 @@
keepjumps call cursor(pos1[0], pos1[1]) keepjumps call cursor(pos1[0], pos1[1])
endif endif
endif endif
endfunction endfunction "}}}
function! EasyMotion#SelectLinesYank() "{{{
let orig_pos = [line('.'), col('.')]
call EasyMotion#SelectLines()
normal y
keepjumps call cursor(orig_pos[0], orig_pos[1])
"normal p
endfunction "}}}
function! EasyMotion#SelectLinesPaste() "{{{
let orig_pos = [line('.'), col('.')]
call EasyMotion#SelectLines()
normal y
keepjumps call cursor(orig_pos[0], orig_pos[1])
if !g:EasyMotion_cancelled
normal p
endif
endfunction "}}}
function! EasyMotion#SelectPhrase() function! EasyMotion#SelectPhrase() "{{{
let chars = s:GetSearchChar2(0) let chars = s:GetSearchChar2(0)
if empty(chars) if empty(chars)
return return
@ -151,15 +150,23 @@
keepjumps call cursor(pos1[0], pos1[1]) keepjumps call cursor(pos1[0], pos1[1])
endif endif
endif endif
endfunction endfunction "}}}
function! EasyMotion#SelectPhraseYank() "{{{
function! EasyMotion#SelectPhraseYank()
let orig_pos = [line('.'), col('.')] let orig_pos = [line('.'), col('.')]
call EasyMotion#SelectPhrase() call EasyMotion#SelectPhrase()
normal y normal y
keepjumps call cursor(orig_pos[0], orig_pos[1]) keepjumps call cursor(orig_pos[0], orig_pos[1])
endfunction endfunction "}}}
function! EasyMotion#SelectPhrasePaste() "{{{
let orig_pos = [line('.'), col('.')]
call EasyMotion#SelectPhrase()
normal y
keepjumps call cursor(orig_pos[0], orig_pos[1])
if !g:EasyMotion_cancelled
normal p
endif
endfunction "}}}
function! EasyMotion#F(visualmode, direction) " {{{ function! EasyMotion#F(visualmode, direction) " {{{

View File

@ -1,4 +1,4 @@
*easymotion.txt* Version 1.3. Last change: 2011 Nov 7 *easymotion.txt* Version 1.3. Last change: 2013 Oct 5
______ __ ___ __ _ ______ __ ___ __ _
@ -23,13 +23,15 @@ CONTENTS *easymotion-contents*
4.3 EasyMotion_do_mapping .......... |EasyMotion_do_mapping| 4.3 EasyMotion_do_mapping .......... |EasyMotion_do_mapping|
4.4 EasyMotion_grouping ............ |EasyMotion_grouping| 4.4 EasyMotion_grouping ............ |EasyMotion_grouping|
4.5 EasyMotion_startofline ......... |EasyMotion_startofline| 4.5 EasyMotion_startofline ......... |EasyMotion_startofline|
4.6 Custom highlighting ............ |easymotion-custom-hl| 4.6 EasyMotion_smartcase ........... |EasyMotion_smartcase|
4.7 Custom mappings ................ |easymotion-custom-mappings| 4.7 Custom highlighting ............ |easymotion-custom-hl|
4.7.1 Leader key ............... |easymotion-leader-key| 4.8 Custom mappings ................ |easymotion-custom-mappings|
4.7.2 Custom keys .............. |easymotion-custom-keys| 4.8.1 Leader key ............... |easymotion-leader-key|
4.8 Easymotion other functions ..... |easymotion-other-mappings| 4.8.2 Custom keys .............. |easymotion-custom-keys|
4.8.1 Select Line .............. |easymotion-select-line| 4.8.3 Special Custom keys ...... |easymotion-special-custom-keys|
4.8.2 Select Phrase ............ |easymotion-select-phrase| 4.9 Easymotion special functions ... |easymotion-special-mappings|
4.9.1 Select Line .............. |easymotion-select-line|
4.9.2 Select Phrase ............ |easymotion-select-phrase|
5. License ............................ |easymotion-license| 5. License ............................ |easymotion-license|
6. Known bugs ......................... |easymotion-known-bugs| 6. Known bugs ......................... |easymotion-known-bugs|
7. Contributing ....................... |easymotion-contributing| 7. Contributing ....................... |easymotion-contributing|
@ -83,26 +85,30 @@ And that's it!
The default configuration defines the following mappings in normal, The default configuration defines the following mappings in normal,
visual and operator-pending mode: visual and operator-pending mode:
Mapping | Details Mapping | Details
------------------|---------------------------------------------- ---------------------|----------------------------------------------
<Leader>f{char} | Find {char} to the right. See |f|. <Leader>f{char} | Find {char} to the right. See |f|.
<Leader>F{char} | Find {char} to the left. See |F|. <Leader>F{char} | Find {char} to the left. See |F|.
<Leader>t{char} | Till before the {char} to the right. See |t|. <Leader>t{char} | Till before the {char} to the right. See |t|.
<Leader>T{char} | Till after the {char} to the left. See |T|. <Leader>T{char} | Till after the {char} to the left. See |T|.
<Leader>w | Beginning of word forward. See |w|. <Leader>w | Beginning of word forward. See |w|.
<Leader>W | Beginning of WORD forward. See |W|. <Leader>W | Beginning of WORD forward. See |W|.
<Leader>b | Beginning of word backward. See |b|. <Leader>b | Beginning of word backward. See |b|.
<Leader>B | Beginning of WORD backward. See |B|. <Leader>B | Beginning of WORD backward. See |B|.
<Leader>e | End of word forward. See |e|. <Leader>e | End of word forward. See |e|.
<Leader>E | End of WORD forward. See |E|. <Leader>E | End of WORD forward. See |E|.
<Leader>ge | End of word backward. See |ge|. <Leader>ge | End of word backward. See |ge|.
<Leader>gE | End of WORD backward. See |gE|. <Leader>gE | End of WORD backward. See |gE|.
<Leader>j | Line downward. See |j|. <Leader>j | Line downward. See |j|.
<Leader>k | Line upward. See |k|. <Leader>k | Line upward. See |k|.
<Leader>n | Jump to latest "/" or "?" forward. See |n|. <Leader>n | Jump to latest "/" or "?" forward. See |n|.
<Leader>N | Jump to latest "/" or "?" backward. See |N|. <Leader>N | Jump to latest "/" or "?" backward. See |N|.
<Leader>s | Find(Search) {char} forward and backward. See |f| and |F|. <Leader>s | Find(Search) {char} forward and backward. See |f| and |F|.
<Leader>S | Beginning of word forward and backward. See |w| and |b|. <Leader>S | Beginning of word forward and backward. See |w| and |b|.
|
|
{operator}<Leader>l | Select, yank, paste, delete, or other operation of lines. See |easymotion-special-function|.
{operator}<Leader>p | Select, yank, paste, delete, or other operation of phrase. See |easymotion-special-function|.
See |easymotion-leader-key| and |mapleader| for details about the leader key. See |easymotion-leader-key| and |mapleader| for details about the leader key.
See |easymotion-custom-mappings| for customizing the default mappings. See |easymotion-custom-mappings| for customizing the default mappings.
@ -211,7 +217,16 @@ current column (by setting this option to 0) or to move along the first column
Default: 1 Default: 1
------------------------------------------------------------------------------ ------------------------------------------------------------------------------
4.6 Custom highlighting *easymotion-custom-hl* 4.6 Start of Line *EasyMotion_startofline*
When using the |j| or |k| motion, the cursor can be configured to stay in the
current column (by setting this option to 0) or to move along the first column
(by setting this option to 1).
Default: 1
------------------------------------------------------------------------------
4.7 Custom highlighting *easymotion-custom-hl*
The default EasyMotion configuration uses two highlighting groups that link The default EasyMotion configuration uses two highlighting groups that link
to groups with default values. The highlighting groups are: to groups with default values. The highlighting groups are:
@ -262,14 +277,14 @@ There are two ways to override the default colors:
hi link EasyMotionTarget2Second MatchParen hi link EasyMotionTarget2Second MatchParen
< <
------------------------------------------------------------------------------ ------------------------------------------------------------------------------
4.7 Custom mappings *easymotion-custom-mappings* 4.8 Custom mappings *easymotion-custom-mappings*
EasyMotion allows you to customize all default mappings to avoid conflicts EasyMotion allows you to customize all default mappings to avoid conflicts
with existing mappings. It is possible to change the default leader key with existing mappings. It is possible to change the default leader key
of all mappings to another key or sequence. It is also possible to fine of all mappings to another key or sequence. It is also possible to fine
tune the plugin to your need by changing every single sequence. tune the plugin to your need by changing every single sequence.
4.7.1 Leader key *EasyMotion_leader_key* *easymotion-leader-key* 4.8.1 Leader key *EasyMotion_leader_key* *easymotion-leader-key*
The default leader key can be changed with the configuration option The default leader key can be changed with the configuration option
|EasyMotion_leader_key|. |EasyMotion_leader_key|.
@ -285,7 +300,7 @@ leader by setting this option in your vimrc: >
< <
Default: '<Leader><Leader>' Default: '<Leader><Leader>'
4.7.2 Custom Keys *easymotion-custom-keys* 4.8.2 Custom Keys *easymotion-custom-keys*
All custom mappings follow the same variable format: > All custom mappings follow the same variable format: >
@ -303,10 +318,28 @@ Note: The leader key defined by |EasyMotion_leader_key| is not prepended to
your customized mappings! You have to provide full key sequences when setting your customized mappings! You have to provide full key sequences when setting
these options. these options.
------------------------------------------------------------------------------ 4.8.3 Custom Keys for Special Function *easymotion-special-custom-keys*
4.8 Easymotion other functions *easymotion-other-mappings*
4.8.1 Select Line *easymotion-select-line* All special custom mappings follow the same variable format: >
EasyMotion_special_mapping_{motion} = {mapping}
<
Example: >
let g:EasyMotion_special_mapping_l = 'L'
let g:EasyMotion_special_mapping_p = 'p'
<
See |easymotion-default-mappings| for a table of motions that can be mapped
and their default values.
Note: The leader key defined by |EasyMotion_leader_key| is not prepended to
your customized mappings! You have to provide full key sequences when setting
these options.
------------------------------------------------------------------------------
4.9 Easymotion special functions *easymotion-special-function*
4.9.1 Select Line *easymotion-select-line*
Default: Disabled Default: Disabled
@ -330,7 +363,7 @@ Example: >
Default: 0 Default: 0
4.8.2 Select Phrase *easymotion-select-phrase* 4.9.2 Select Phrase *easymotion-select-phrase*
(Experimental) SelectPhrase function which allows you to make selection (Experimental) SelectPhrase function which allows you to make selection
between any two characters. between any two characters.
@ -385,5 +418,17 @@ can be downloaded here:
http://www.vim.org/scripts/script.php?script_id=3437 http://www.vim.org/scripts/script.php?script_id=3437
------------------------------------------------------------------------------
Forked and modified by haya14busa
Author: haya14busa <hayabusa1419@gmail.com>
Source repository: https://github.com/haya14busa/vim-easymotion
Ref:
- supasorn : two key combos and special function
- mtth : startofline(keep column)
- bootleq : fixed bufname bug
============================================================================== ==============================================================================
vim:tw=78:sw=4:ts=8:ft=help:norl: vim:tw=78:sw=4:ts=8:ft=help:norl: