mirror of
https://github.com/Raimondi/delimitMate.git
synced 2026-02-16 15:12:01 +08:00
441 lines
20 KiB
Plaintext
441 lines
20 KiB
Plaintext
*delimitMate.txt* Trying to keep those beasts at bay! v.1.6
|
||
|
||
|
||
REFERENCE MANUAL *delimitMate*
|
||
|
||
|
||
==============================================================================
|
||
0.- CONTENTS *delimitMate-contents*
|
||
|
||
1. Introduction____________________________|delimitMateIntro|
|
||
2. Functionality___________________________|delimitMateFunctionality|
|
||
2.1 Automatic closing & exiting________|delimitMateAutoClose|
|
||
2.2 Expansion of space and CR__________|delimitMateExpansion|
|
||
2.3 Deletion of empty pairs____________|delimitMateBackspace|
|
||
2.4 Visual wrapping____________________|delimitMateVisualWrapping|
|
||
3. Customization___________________________|delimitMateOptions|
|
||
3.1 Option summary_____________________|delimitMateOptionSummary|
|
||
3.2 Options details____________________|delimitMateOptionDetails|
|
||
4. Commands________________________________|delimitMateCommands|
|
||
5. TODO list_______________________________|delimitMateTodo|
|
||
6. Maintainer______________________________|delimitMateMaintainer|
|
||
7. Credits_________________________________|delimitMateCredits|
|
||
8. History_________________________________|delimitMateHistory|
|
||
|
||
==============================================================================
|
||
1.- INTRODUCTION *delimitMateIntro*
|
||
|
||
The delimitMate plugin tries to provide some not so dumb help in the work with
|
||
delimiters (brackets, quotes, etc.), with some optional auto-completions and
|
||
expansions.
|
||
|
||
When automatic closing is enabled, if an opening delimiter is inserted
|
||
delimitMate inserts the closing pair and places the cursor between them. When
|
||
automatic closing is disabled, no closing delimiters is inserted by
|
||
delimitMate, but if a pair of delimiters is typed, the cursor is placed in the
|
||
middle. Also, to get out of a pair of delimiters just type the right delimiter
|
||
and the cursor will jump to the right.
|
||
|
||
If the cursor is inside an empty pair of delimiters <Space> and <CR> can be
|
||
expanded to follow your coding style, you just need to define a couple of
|
||
options with the desired mappings for them.
|
||
|
||
==============================================================================
|
||
2. FUNCTIONALITY *delimitMateFunctionality*
|
||
|
||
------------------------------------------------------------------------------
|
||
2.1 AUTOMATIC CLOSING AND EXITING *delimitMateAutoClose*
|
||
|
||
With automatic closing enabled, if an opening delimiter is inserted the plugin
|
||
inserts the closing delimiter and places the cursor between the pair. With
|
||
automatic closing disabled, no closing delimiters is inserted by delimitMate,
|
||
but when a pair of delimiters is typed, the cursor is placed in the middle.
|
||
|
||
When the cursor is inside an empty pair or located next to the left of a
|
||
closing delimiter, the cursor is placed outside the pair to the right of the
|
||
closing delimiter.
|
||
|
||
Unless |'b:delimitMate_matchpairs'| and |'b:delimitMate_quotes'|is set, this
|
||
script uses the values in '&matchpairs' to identify the pairs, and ", ' and `
|
||
for quotes respectively.
|
||
|
||
The following table shows the behaviour, this applies to quotes too (the final
|
||
position of the cursor is represented by a "|"):
|
||
|
||
With auto-close: >
|
||
Type | You get
|
||
====================
|
||
( | (|)
|
||
–––––––––|––––––––––
|
||
() | ()|
|
||
<
|
||
Without auto-close: >
|
||
|
||
Type | You get
|
||
====================
|
||
() | (|)
|
||
–––––––––|––––––––––
|
||
()) | ()|
|
||
<
|
||
------------------------------------------------------------------------------
|
||
2.2 EXPANSION OF SPACE AND CAR RETURN *delimitMateExpansion*
|
||
|
||
When the cursor is inside an empty pair of delimiters, <Space> and <CR> can be
|
||
expanded to follow your coding style with |'b:delimitMate_expand_space'| and
|
||
|'b:delimitMate_expand_cr'|. e.g. (cursor represented by a "|"):
|
||
|
||
Expand <Space> to: >
|
||
|
||
<Space><Space><Left> | You get
|
||
====================================
|
||
(|) | ( | )
|
||
<
|
||
Expand <CR> to: >
|
||
|
||
<CR><CR><Up> | You get
|
||
============================
|
||
(|) | (
|
||
| |
|
||
| )
|
||
<
|
||
|
||
------------------------------------------------------------------------------
|
||
2.3 DELETION OF EMPTY PAIR *delimitMateBackspace*
|
||
|
||
If you press backspace inside an empty pair, both delimiters are deleted.
|
||
|
||
e.g.: >
|
||
|
||
Before | After
|
||
====================================
|
||
call expand(|) | call expand|
|
||
<
|
||
|
||
------------------------------------------------------------------------------
|
||
2.4 WRAPPING OF VISUAL SELECTION *delimitMateVisualWrapping*
|
||
|
||
When visual mode is active this script allows for the selection to be enclosed
|
||
with delimiters. But, since brackets have special meaning in visual mode, a
|
||
leader (the value of 'mapleader' by default) should precede the delimiter.
|
||
This feature doesn't currently work on blockwise visual mode, any suggestions
|
||
will be welcome.
|
||
|
||
e.g. (selection represented between square brackets): >
|
||
|
||
Selected text | After \"
|
||
=============================================
|
||
An [absurd] example! | An "absurd" example!
|
||
<
|
||
==============================================================================
|
||
3. CUSTOMIZATION *delimitMateOptions*
|
||
|
||
------------------------------------------------------------------------------
|
||
3.1 OPTIONS SUMMARY *delimitMateOptionSummary*
|
||
|
||
The behaviour of this script can be customized setting the following options
|
||
in your vimrc file. You can use local options to set the configuration for
|
||
specific file types, see |delimitMateOptionDetails| for examples.
|
||
|
||
|'loaded_delimitMate'| Turns off the script.
|
||
|
||
|'delimitMate_autoclose'| Tells delimitMate whether to automagically
|
||
insert the closing delimiter.
|
||
|
||
|'delimitMate_matchpairs'| Tells delimitMate which characters are
|
||
matching pairs.
|
||
|
||
|'delimitMate_quotes'| Tells delimitMate which quotes should be
|
||
used.
|
||
|
||
|'delimitMate_visual_leader'| Sets the leader to be used in visual mode.
|
||
|
||
|'delimitMate_expand_cr'| Sets the expansion for <CR> inside an empty
|
||
pair of matching delimiters or quotes.
|
||
|
||
|'delimitMate_expand_space'| Sets the expansion for <Space> inside an
|
||
empty pair of matching delimiters or quotes.
|
||
|
||
|'delimitMate_excluded_ft'| Turns off the script for the given file types.
|
||
|
||
|'delimitMate_apostrophes'| Tells delimitMate how it should "fix"
|
||
balancing of single quotes when used as
|
||
apostrophes.
|
||
|
||
------------------------------------------------------------------------------
|
||
3.2 OPTIONS DETAILS *delimitMateOptionDetails*
|
||
|
||
Add the shown lines to your vimrc file in order to set the below options.
|
||
Local options take precedence over global ones and can be used along with
|
||
autocmd to modify delimitMate's behavior for specific file types.
|
||
|
||
*'loaded_delimitMate'*
|
||
*'b:loaded_delimitMate'*
|
||
This option prevents delimitMate from loading.
|
||
e.g.: >
|
||
let loaded_delimitMate = 1
|
||
au FileType mail let b:loaded_delimitMate = 1
|
||
<
|
||
------------------------------------------------------------------------------
|
||
*'delimitMate_autoclose'*
|
||
*'b:delimitMate_autoclose'*
|
||
Values: 0 or 1. ~
|
||
Default: 1 ~
|
||
|
||
If this option is set to 0, delimitMate will not add a closing delimiter
|
||
automagically. See |delimitMateAutoClose| for details.
|
||
e.g.: >
|
||
let delimitMate_autoclose = 0
|
||
au FileType mail let b:delimitMate_autoclose = 0
|
||
<
|
||
------------------------------------------------------------------------------
|
||
*'delimitMate_matchpairs'*
|
||
*'b:delimitMate_matchpairs'*
|
||
Values: A string with |matchpairs| syntax. ~
|
||
Default: &matchpairs ~
|
||
|
||
Use this option to tell delimitMate which characters should be considered
|
||
matching pairs. Read |delimitMateAutoClose| for details.
|
||
e.g: >
|
||
let delimitMate = "(:),[:],{:},<:>"
|
||
au FileType vim,html let b:delimitMate_matchpairs = "(:),[:],{:},<:>"
|
||
<
|
||
------------------------------------------------------------------------------
|
||
*'delimitMate_quotes'*
|
||
*'b:delimitMate_quotes'*
|
||
Values: A string of characters separated by spaces. ~
|
||
Default: "\" ' `" ~
|
||
|
||
Use this option to tell delimitMate which characters should be considered as
|
||
quotes. Read |delimitMateAutoClose| for details.
|
||
e.g.: >
|
||
let b:delimitMate_quotes = "\" ' ` *"
|
||
au FileType html let b:delimitMate_quotes = "\" '"
|
||
<
|
||
------------------------------------------------------------------------------
|
||
*'delimitMate_visual_leader'*
|
||
*'b:delimitMate_visual_leader'*
|
||
Values: Any character. ~
|
||
Default: q ~
|
||
|
||
The value of this option will be used to wrap the selection in visual mode
|
||
when followed by a delimiter. Read |delimitMateVisualWrap| for details.
|
||
e.g: >
|
||
let delimitMate_visual_leader = "f"
|
||
au FileType html let b:delimitMate_visual_leader = "f"
|
||
<
|
||
------------------------------------------------------------------------------
|
||
*'delimitMate_expand_cr'*
|
||
*'b:delimitMate_expand_cr'*
|
||
Values: A key mapping. ~
|
||
Default: "\<CR>" ~
|
||
|
||
The value of this option will be used to expand the car return character when
|
||
typed inside an empty delimiter pair. Read |delimitMateExpansion| for details.
|
||
e.g.: >
|
||
let b:delimitMate_expand_cr = "\<CR>\<CR>\<Up>"
|
||
au FileType mail let b:delimitMate_expand_cr = "\<CR>
|
||
<
|
||
------------------------------------------------------------------------------
|
||
*'delimitMate_expand_space'*
|
||
*'b:delimitMate_expand_space'*
|
||
Values: A key mapping. ~
|
||
Default: "\<Space>" ~
|
||
|
||
The value of this option will be used to expand the space character when typed
|
||
inside an empty delimiter pair. Read |delimitMateExpansion| for details.
|
||
e.g.: >
|
||
let delimitMate_expand_space = "\<Space>\<Space>\<Left>"
|
||
au FileType tcl let b:delimitMate_expand_space = "\<Space>"
|
||
<
|
||
------------------------------------------------------------------------------
|
||
*'delimitMate_excluded_ft'*
|
||
Values: A string of file type names separated by single commas. ~
|
||
Default: Empty. ~
|
||
|
||
This options turns delimitMate off for the listed file types, use this option
|
||
only if don't want any of the features it provides.
|
||
e.g.: >
|
||
let delimitMate_excluded_ft = "mail,txt"
|
||
<
|
||
------------------------------------------------------------------------------
|
||
*'delimitMate_apostrophes'*
|
||
Values: Strings separated by ":". ~
|
||
Default: "n't:'s:'re:'d:'ll:'ve:s'" ~
|
||
|
||
If auto-close is enabled, this option tells delimitMate how to try to fix the
|
||
balancing of single quotes when used as apostrophes. The values of this option
|
||
are strings of text where a single quote would be used as an apostrophe (e.g.:
|
||
the "n't" of wouldn't or can't) separated by ":". Set it to an empty string to
|
||
disable this feature.
|
||
e.g.: >
|
||
let delimitMate_apostrophes = ""
|
||
au FileType tcl let delimitMate_apostrophes = ""
|
||
<
|
||
==============================================================================
|
||
4. COMMANDS *delimitMateCommands*
|
||
|
||
------------------------------------------------------------------------------
|
||
:DelimitMateReload *:DelimitMateReload*
|
||
|
||
Re-sets all the mappings used for this script, use it if any option has been
|
||
changed or if the filetype option hasn't been set yet.
|
||
|
||
------------------------------------------------------------------------------
|
||
:DelimitMateTest *:DelimitMateTest*
|
||
|
||
This command tests every mapping set-up for this script, useful for testing
|
||
custom configurations.
|
||
|
||
The following output corresponds to the default values, it will be different
|
||
depending on your configuration. "Open & close:" represents the final result
|
||
when the closing delimiter has been inserted, either manually or
|
||
automatically, see |delimitMateExpansion|. "Delete:" typing backspace in an
|
||
empty pair, see |delimitMateBackspace|. "Exit:" typing a closing delimiter
|
||
inside a pair of delimiters, see |delimitMateAutoclose|. "Space:" the
|
||
expansion, if any, of space, see |delimitMateExpansion|. "Visual-L",
|
||
"Visual-R" and "Visual" shows visual wrapping, see
|
||
|delimitMateVisualWrapping|. "Car return:" the expansion of car return, see
|
||
|delimitMateExpansion|. The cursor's position at the end of every test is
|
||
represented by an "|": >
|
||
|
||
* AUTOCLOSE:
|
||
Open & close: (|)
|
||
Delete: |
|
||
Exit: ()|
|
||
Space: ( |)
|
||
Visual-L: (v)
|
||
Visual-R: (v)
|
||
Car return: (
|
||
|)
|
||
|
||
Open & close: {|}
|
||
Delete: |
|
||
Exit: {}|
|
||
Space: { |}
|
||
Visual-L: {v}
|
||
Visual-R: {v}
|
||
Car return: {
|
||
|}
|
||
|
||
Open & close: [|]
|
||
Delete: |
|
||
Exit: []|
|
||
Space: [ |]
|
||
Visual-L: [v]
|
||
Visual-R: [v]
|
||
Car return: [
|
||
|]
|
||
|
||
Open & close: "|"
|
||
Delete: |
|
||
Exit: ""|
|
||
Space: " |"
|
||
Visual: "v"
|
||
Car return: "
|
||
|"
|
||
|
||
Open & close: '|'
|
||
Delete: |
|
||
Exit: ''|
|
||
Space: ' |'
|
||
Visual: 'v'
|
||
Car return: '
|
||
|'
|
||
|
||
Open & close: `|`
|
||
Delete: |
|
||
Exit: ``|
|
||
Space: ` |`
|
||
Visual: `v`
|
||
Car return: `
|
||
|`
|
||
<
|
||
|
||
==============================================================================
|
||
5. TODO LIST *delimitMateTodo*
|
||
|
||
- Automatic set-up by file type.
|
||
- Make visual wrapping work on blockwise visual mode.
|
||
- Limit behaviour by region.
|
||
|
||
==============================================================================
|
||
6. MAINTAINER *delimitMateMaintainer*
|
||
|
||
Hi there! My name is Israel Chauca F. and I can be reached at:
|
||
mailto:israelchauca@gmail.com
|
||
|
||
Feel free to send me any suggestions and/or comments about this plugin, I'll
|
||
be very pleased to read them.
|
||
|
||
==============================================================================
|
||
7. CREDITS *delimitMateCredits*
|
||
|
||
Some of the code that make this script is modified or just shamelessly copied
|
||
from the following sources:
|
||
|
||
- Ian McCracken
|
||
Post titled: Vim, Part II: Matching Pairs:
|
||
http://concisionandconcinnity.blogspot.com/
|
||
|
||
- Aristotle Pagaltzis
|
||
From the comments on the previous blog post and from:
|
||
http://gist.github.com/144619
|
||
|
||
- Vim Scripts:
|
||
http://www.vim.org/scripts
|
||
|
||
This script was inspired by the auto-completion of delimiters of TextMate.
|
||
|
||
==============================================================================
|
||
8. HISTORY *delimitMateHistory*
|
||
|
||
Version Date Release notes ~
|
||
|---------|------------|-----------------------------------------------------|
|
||
1.6 2009-10-10 Now delimitMate tries to fix the balancing of single
|
||
quotes when used as apostrophes. You can read
|
||
|delimitMate_apostrophes| for details.
|
||
Fixed an error when |b:delimitMate_expand_space|
|
||
wasn't set but |delimitMate_expand_space| wasn't.
|
||
|
||
|---------|------------|-----------------------------------------------------|
|
||
1.5 2009-10-05 Fix: delimitMate should work correctly for files
|
||
passed as arguments to Vim. Thanks to Ben Beuchler
|
||
for helping to nail this bug.
|
||
|
||
|---------|------------|-----------------------------------------------------|
|
||
1.4 2009-09-27 Fix: delimitMate is now enabled on new buffers even
|
||
if they don't have set the file type option or were
|
||
opened directly from the terminal.
|
||
|
||
|---------|------------|-----------------------------------------------------|
|
||
1.3 2009-09-24 Now local options can be used along with autocmd
|
||
for specific file type configurations.
|
||
Fixes:
|
||
- Unnamed register content is not lost on visual
|
||
mode.
|
||
- Use noremap where appropiate.
|
||
- Wrapping a single empty line works as expected.
|
||
|
||
|---------|------------|-----------------------------------------------------|
|
||
1.2 2009-09-07 Fixes:
|
||
- When inside nested empty pairs, deleting the
|
||
innermost left delimiter would delete all right
|
||
contiguous delimiters.
|
||
- When inside an empty pair, inserting a left
|
||
delimiter wouldn't insert the right one, instead
|
||
the cursor would jump to the right.
|
||
- New buffer inside the current window wouldn't
|
||
have the mappings set.
|
||
|
||
|---------|------------|-----------------------------------------------------|
|
||
1.1 2009-08-25 Fixed an error that ocurred when mapleader wasn't
|
||
set and added support for GetLatestScripts
|
||
auto-detection.
|
||
|
||
|---------|------------|-----------------------------------------------------|
|
||
1.0 2009-08-23 Initial upload.
|
||
|
||
|---------|------------|-----------------------------------------------------|
|
||
|
||
vim:tw=78:ts=8:ft=help:norl:formatoptions+=tcroqn:autoindent:
|