wildfire.vim

Smart selection of the closest text object

  • 所有者: gcmt/wildfire.vim
  • 平台:
  • 許可證: MIT License
  • 分類:
  • 主題:
  • 喜歡:
    0
      比較:

Github星跟蹤圖

wildfire.vim

With Wildfire you can quickly select the closest text object among a group of candidates. By default candidates are i', i", i), i], i}, ip and it.

Learn more about text objects with :help text-objects.

Preview

Installation

Install either with Pathogen, Vundle, NeoBundle, or your favorite plugin manager.

Usage

Press <ENTER> in normal mode to select the closest text object. Keep pressing <ENTER> for selecting the next closest text object. To go the other way round, that is, to select the previously selected text object, press <BS>.

To speed things up, if you want to select the nth closest text object you can press a number followed by <ENTER> (e.g. pressing 2<ENTER> will select the second closest text object).

You can change default mappings with:

" This selects the next closest text object.
map <SPACE> <Plug>(wildfire-fuel)

" This selects the previous closest text object.
vmap <C-SPACE> <Plug>(wildfire-water)

By default, Wildfire selects any of the text objects i', i", i), i], i}, ip and it. You can decide the ones to consider with the following option:

let g:wildfire_objects = ["i'", 'i"', "i)", "i]", "i}", "ip", "it"]

Advanced usage

Sometimes considering certain kinds of text objects can be quite annoying. This is the case of Html, where, for example, you may want to select just tag objects.

Wildfire allows you to be selective about which text objects are considered with different filetypes:

" use '*' to mean 'all other filetypes'
" in this example, html and xml share the same text objects
let g:wildfire_objects = {
    \ "*" : ["i'", 'i"', "i)", "i]", "i}"],
    \ "html,xml" : ["at", "it"],
\ }

One problem with the solution above is that with html and xml files we loose the ability to select the text objects i', i", i), i] and i}. To solve this problem, Wildfire allows you to use different mappings for different text object candidates:

map <SPACE> <Plug>(wildfire-fuel)
let g:wildfire_objects = {
    \ "*" : ["i'", 'i"', "i)", "i]", "i}"]
\ }

cal wildfire#triggers#Add("<ENTER>", {
    \ "html,xml" : ["at", "it"],
\ })

Quick selection

A visual explanation often works far better than plain old words.

Preview

Wildfire does not set a default mapping for quick selection. Be sure to put something like the following line in your .vimrc:

nmap <leader>s <Plug>(wildfire-quick-select)

By default, quick selection use text objects in g:wildfire_objects to set "selection marks". Have a look at the example below if you want to use different text object without having to change g:wildfire_objects.

cal wildfire#triggers#AddQs("<leader>s", {
    \ "*" : ["i)", "i]"],
\ })

Similar plugins

Wildfire is not the only plugin who can smartly select text object. Be sure to have a look at the following plugins if Wildfire doesn't suit your needs:

主要指標

概覽
名稱與所有者gcmt/wildfire.vim
主編程語言Vim Script
編程語言Vim script (語言數: 1)
平台
許可證MIT License
所有者活动
創建於2014-01-08 17:43:32
推送於2023-07-22 04:40:37
最后一次提交2023-07-22 06:40:37
發布數8
最新版本名稱v2.0 (發布於 )
第一版名稱v1.0 (發布於 )
用户参与
星數612
關注者數6
派生數19
提交數141
已啟用問題?
問題數23
打開的問題數0
拉請求數10
打開的拉請求數0
關閉的拉請求數0
项目设置
已啟用Wiki?
已存檔?
是復刻?
已鎖定?
是鏡像?
是私有?