Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/adriaanzon/vim-textobj-matchit

Vim text object for linewise matchit pairs
https://github.com/adriaanzon/vim-textobj-matchit

elixir laravel-blade latex lua ruby text-object vim

Last synced: 11 days ago
JSON representation

Vim text object for linewise matchit pairs

Awesome Lists containing this project

README

        

# vim-textobj-matchit

A Vim plugin that creates text objects from matchit pairs, to be used with:

* Ruby (`if…end`, `def…end`)
* Blade (`@section…@endsection`)
* Shell (`if…fi`, `for…done`)
* Vim script (`if…endif`, `for…endfor`)
* :man_shrugging: Any other filetype that defines similar matchit pairs

## :package: Installation

Depends on [vim-textobj-user][textobj-user] and [matchit][matchit].

```vim
Plug 'kana/vim-textobj-user'
Plug 'adriaanzon/vim-textobj-matchit'

runtime macros/matchit.vim
```

It's likely that matchit is already enabled. You can check so by running
`:echo g:loaded_matchit`. It will return `1` when it's enabled.

## :sparkles: Usage

Textobj-matchit maps 2 keystrokes: `am` and `im`. They work like any other text
object: `am` selects the _all_ of the matchit pair, `im` the _inner_ portion of
the matchit pair.

See [`:h textobj-matchit`](doc/textobj-matchit.txt) for more details, including
instructions on how to define your own key mappings.

## :man_teacher: History

This plugin derives from [vim-textobj-rubyblock][textobj-rubyblock] and
[vim-textobj-blade-directive][textobj-blade-directive]. I wanted something
similar that works for every filetype, so that is why I created this plugin.

## :page_facing_up: License

Copyright © Adriaan Zonnenberg. Distributed under the same terms as Vim itself.
See `:help license`.

[matchit]: http://www.vim.org/scripts/script.php?script_id=39
[textobj-blade-directive]: https://github.com/adriaanzon/vim-textobj-blade-directive
[textobj-rubyblock]: https://github.com/nelstrom/vim-textobj-rubyblock
[textobj-user]: https://github.com/kana/vim-textobj-user