forked from VimPlug/emmet-vim
Merge branch 'master' of github.com:mattn/emmet-vim
This commit is contained in:
@@ -237,7 +237,11 @@ function! emmet#toString(...) abort
|
|||||||
let snippet_node = emmet#newNode()
|
let snippet_node = emmet#newNode()
|
||||||
let snippet_node.value = '{'.tmp.'}'
|
let snippet_node.value = '{'.tmp.'}'
|
||||||
let snippet_node.important = current.important
|
let snippet_node.important = current.important
|
||||||
let str = emmet#lang#{rtype}#toString(s:emmet_settings, snippet_node, type, inline, filters, s:itemno(group_itemno, current), indent)
|
let snippet_node.multiplier = current.multiplier
|
||||||
|
let str .= emmet#lang#{rtype}#toString(s:emmet_settings, snippet_node, type, inline, filters, s:itemno(group_itemno, current), indent)
|
||||||
|
if current.multiplier > 1
|
||||||
|
let str .= "\n"
|
||||||
|
endif
|
||||||
else
|
else
|
||||||
if len(current.name)
|
if len(current.name)
|
||||||
let str .= current.name
|
let str .= current.name
|
||||||
@@ -646,7 +650,7 @@ function! emmet#expandAbbr(mode, abbr) range abort
|
|||||||
endif
|
endif
|
||||||
let expand = substitute(expand, '[\r\n]\s*$', '', 'g')
|
let expand = substitute(expand, '[\r\n]\s*$', '', 'g')
|
||||||
if emmet#useFilter(filters, 's')
|
if emmet#useFilter(filters, 's')
|
||||||
let epart = substitute(expand, '[\r\n]\s\*', '', 'g')
|
let epart = substitute(expand, '[\r\n]\s*', '', 'g')
|
||||||
else
|
else
|
||||||
let epart = substitute(expand, '[\r\n]', "\n" . indent, 'g')
|
let epart = substitute(expand, '[\r\n]', "\n" . indent, 'g')
|
||||||
endif
|
endif
|
||||||
|
|||||||
@@ -31,7 +31,7 @@ function! emmet#lang#css#parseIntoTree(abbr, type) abort
|
|||||||
else
|
else
|
||||||
for n in range(len(tokens))
|
for n in range(len(tokens))
|
||||||
let token = tokens[n]
|
let token = tokens[n]
|
||||||
let prop = matchlist(token, '^\(-\{0,1}[a-zA-Z]\+\|[a-zA-Z0-9]\++\{0,1}\|([a-zA-Z0-9]\++\{0,1})\)\(\%([0-9.-]\+[pe]\{0,1}-\{0,1}\|-auto\)*\)$')
|
let prop = matchlist(token, '^\(-\{0,1}[a-zA-Z]\+\|[a-zA-Z0-9]\++\{0,1}\|([a-zA-Z0-9]\++\{0,1})\)\(\%([0-9.-]\+\%(p\|e\|em\|re\|rem\|%\)\{0,1}-\{0,1}\|-auto\)*\)$')
|
||||||
if len(prop)
|
if len(prop)
|
||||||
let token = substitute(prop[1], '^(\(.*\))', '\1', '')
|
let token = substitute(prop[1], '^(\(.*\))', '\1', '')
|
||||||
if token =~# '^-'
|
if token =~# '^-'
|
||||||
@@ -48,8 +48,16 @@ function! emmet#lang#css#parseIntoTree(abbr, type) abort
|
|||||||
let value .= substitute(v, '[^0-9.]*$', '', '')
|
let value .= substitute(v, '[^0-9.]*$', '', '')
|
||||||
elseif v =~# 'p$'
|
elseif v =~# 'p$'
|
||||||
let value .= substitute(v, 'p$', '%', '')
|
let value .= substitute(v, 'p$', '%', '')
|
||||||
|
elseif v =~# '%$'
|
||||||
|
let value .= v
|
||||||
elseif v =~# 'e$'
|
elseif v =~# 'e$'
|
||||||
let value .= substitute(v, 'e$', 'em', '')
|
let value .= substitute(v, 'e$', 'em', '')
|
||||||
|
elseif v =~# 'em$'
|
||||||
|
let value .= v
|
||||||
|
elseif v =~# 're$'
|
||||||
|
let value .= substitute(v, 're$', 'rem', '')
|
||||||
|
elseif v =~# 'rem$'
|
||||||
|
let value .= v
|
||||||
elseif v =~# '\.'
|
elseif v =~# '\.'
|
||||||
let value .= v . 'em'
|
let value .= v . 'em'
|
||||||
elseif v ==# 'auto'
|
elseif v ==# 'auto'
|
||||||
|
|||||||
332
autoload/emmet/lang/jade.vim
Normal file
332
autoload/emmet/lang/jade.vim
Normal file
@@ -0,0 +1,332 @@
|
|||||||
|
function! emmet#lang#jade#findTokens(str) abort
|
||||||
|
return emmet#lang#html#findTokens(a:str)
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
function! emmet#lang#jade#parseIntoTree(abbr, type) abort
|
||||||
|
return emmet#lang#html#parseIntoTree(a:abbr, a:type)
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
function! emmet#lang#jade#toString(settings, current, type, inline, filters, itemno, indent) abort
|
||||||
|
let settings = a:settings
|
||||||
|
let current = a:current
|
||||||
|
let type = a:type
|
||||||
|
let inline = a:inline
|
||||||
|
let filters = a:filters
|
||||||
|
let itemno = a:itemno
|
||||||
|
let indent = emmet#getIndentation(type)
|
||||||
|
let dollar_expr = emmet#getResource(type, 'dollar_expr', 1)
|
||||||
|
let attribute_style = emmet#getResource('jade', 'attribute_style', 'hash')
|
||||||
|
let str = ''
|
||||||
|
|
||||||
|
let current_name = current.name
|
||||||
|
if dollar_expr
|
||||||
|
let current_name = substitute(current.name, '\$$', itemno+1, '')
|
||||||
|
endif
|
||||||
|
if len(current.name) > 0
|
||||||
|
let str .= '' . current_name
|
||||||
|
let tmp = ''
|
||||||
|
for attr in emmet#util#unique(current.attrs_order + keys(current.attr))
|
||||||
|
if !has_key(current.attr, attr)
|
||||||
|
continue
|
||||||
|
endif
|
||||||
|
let Val = current.attr[attr]
|
||||||
|
if type(Val) == 2 && Val == function('emmet#types#true')
|
||||||
|
if attribute_style ==# 'hash'
|
||||||
|
let tmp .= ' ' . attr . ' = true'
|
||||||
|
elseif attribute_style ==# 'html'
|
||||||
|
let tmp .= attr . '=true'
|
||||||
|
end
|
||||||
|
else
|
||||||
|
if dollar_expr
|
||||||
|
while Val =~# '\$\([^#{]\|$\)'
|
||||||
|
let Val = substitute(Val, '\(\$\+\)\([^{]\|$\)', '\=printf("%0".len(submatch(1))."d", itemno+1).submatch(2)', 'g')
|
||||||
|
endwhile
|
||||||
|
let attr = substitute(attr, '\$$', itemno+1, '')
|
||||||
|
endif
|
||||||
|
let valtmp = substitute(Val, '\${cursor}', '', '')
|
||||||
|
if attr ==# 'id' && len(valtmp) > 0
|
||||||
|
let str .= '#' . Val
|
||||||
|
elseif attr ==# 'class' && len(valtmp) > 0
|
||||||
|
let str .= '.' . substitute(Val, ' ', '.', 'g')
|
||||||
|
else
|
||||||
|
if len(tmp) > 0
|
||||||
|
if attribute_style ==# 'hash'
|
||||||
|
let tmp .= ', '
|
||||||
|
elseif attribute_style ==# 'html'
|
||||||
|
let tmp .= ' '
|
||||||
|
endif
|
||||||
|
endif
|
||||||
|
let Val = substitute(Val, '\${cursor}', '', '')
|
||||||
|
if attribute_style ==# 'hash'
|
||||||
|
let tmp .= '' . attr . '="' . Val . '"'
|
||||||
|
elseif attribute_style ==# 'html'
|
||||||
|
let tmp .= attr . '="' . Val . '"'
|
||||||
|
end
|
||||||
|
endif
|
||||||
|
endif
|
||||||
|
endfor
|
||||||
|
if len(tmp)
|
||||||
|
if attribute_style ==# 'hash'
|
||||||
|
let str .= '(' . tmp . ')'
|
||||||
|
elseif attribute_style ==# 'html'
|
||||||
|
let str .= '(' . tmp . ')'
|
||||||
|
end
|
||||||
|
endif
|
||||||
|
|
||||||
|
let inner = ''
|
||||||
|
if len(current.value) > 0
|
||||||
|
let text = current.value[1:-2]
|
||||||
|
if dollar_expr
|
||||||
|
let text = substitute(text, '\%(\\\)\@\<!\(\$\+\)\([^{#]\|$\)', '\=printf("%0".len(submatch(1))."d", itemno+1).submatch(2)', 'g')
|
||||||
|
let text = substitute(text, '\${nr}', "\n", 'g')
|
||||||
|
let text = substitute(text, '\\\$', '$', 'g')
|
||||||
|
let str = substitute(str, '\$#', text, 'g')
|
||||||
|
endif
|
||||||
|
let lines = split(text, "\n")
|
||||||
|
if len(lines) == 1
|
||||||
|
let str .= ' ' . text
|
||||||
|
else
|
||||||
|
for line in lines
|
||||||
|
let str .= "\n" . indent . line . ' |'
|
||||||
|
endfor
|
||||||
|
endif
|
||||||
|
elseif len(current.child) == 0
|
||||||
|
let str .= '${cursor}'
|
||||||
|
endif
|
||||||
|
if len(current.child) == 1 && len(current.child[0].name) == 0
|
||||||
|
let text = current.child[0].value[1:-2]
|
||||||
|
if dollar_expr
|
||||||
|
let text = substitute(text, '\%(\\\)\@\<!\(\$\+\)\([^{#]\|$\)', '\=printf("%0".len(submatch(1))."d", itemno+1).submatch(2)', 'g')
|
||||||
|
let text = substitute(text, '\${nr}', "\n", 'g')
|
||||||
|
let text = substitute(text, '\\\$', '$', 'g')
|
||||||
|
endif
|
||||||
|
let lines = split(text, "\n")
|
||||||
|
if len(lines) == 1
|
||||||
|
let str .= ' ' . text
|
||||||
|
else
|
||||||
|
for line in lines
|
||||||
|
let str .= "\n" . indent . line . ' |'
|
||||||
|
endfor
|
||||||
|
endif
|
||||||
|
elseif len(current.child) > 0
|
||||||
|
for child in current.child
|
||||||
|
let inner .= emmet#toString(child, type, inline, filters, itemno, indent)
|
||||||
|
endfor
|
||||||
|
let inner = substitute(inner, "\n", "\n" . escape(indent, '\'), 'g')
|
||||||
|
let inner = substitute(inner, "\n" . escape(indent, '\') . '$', '', 'g')
|
||||||
|
let str .= "\n" . indent . inner
|
||||||
|
endif
|
||||||
|
else
|
||||||
|
let str = current.value[1:-2]
|
||||||
|
if dollar_expr
|
||||||
|
let str = substitute(str, '\%(\\\)\@\<!\(\$\+\)\([^{#]\|$\)', '\=printf("%0".len(submatch(1))."d", itemno+1).submatch(2)', 'g')
|
||||||
|
let str = substitute(str, '\${nr}', "\n", 'g')
|
||||||
|
let str = substitute(str, '\\\$', '$', 'g')
|
||||||
|
endif
|
||||||
|
endif
|
||||||
|
let str .= "\n"
|
||||||
|
return str
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
function! emmet#lang#jade#imageSize() abort
|
||||||
|
let line = getline('.')
|
||||||
|
let current = emmet#lang#jade#parseTag(line)
|
||||||
|
if empty(current) || !has_key(current.attr, 'src')
|
||||||
|
return
|
||||||
|
endif
|
||||||
|
let fn = current.attr.src
|
||||||
|
if fn =~# '^\s*$'
|
||||||
|
return
|
||||||
|
elseif fn !~# '^\(/\|http\)'
|
||||||
|
let fn = simplify(expand('%:h') . '/' . fn)
|
||||||
|
endif
|
||||||
|
|
||||||
|
let [width, height] = emmet#util#getImageSize(fn)
|
||||||
|
if width == -1 && height == -1
|
||||||
|
return
|
||||||
|
endif
|
||||||
|
let current.attr.width = width
|
||||||
|
let current.attr.height = height
|
||||||
|
let current.attrs_order += ['width', 'height']
|
||||||
|
let jade = emmet#toString(current, 'jade', 1)
|
||||||
|
let jade = substitute(jade, '\${cursor}', '', '')
|
||||||
|
call setline('.', substitute(matchstr(line, '^\s*') . jade, "\n", '', 'g'))
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
function! emmet#lang#jade#encodeImage() abort
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
function! emmet#lang#jade#parseTag(tag) abort
|
||||||
|
let current = emmet#newNode()
|
||||||
|
let mx = '%\([a-zA-Z][a-zA-Z0-9]*\)\s*\%({\(.*\)}\)'
|
||||||
|
let match = matchstr(a:tag, mx)
|
||||||
|
let current.name = substitute(match, mx, '\1', '')
|
||||||
|
let attrs = substitute(match, mx, '\2', '')
|
||||||
|
let mx = '\([a-zA-Z0-9]\+\)\s*=>\s*\%(\([^"'' \t]\+\)\|"\([^"]\{-}\)"\|''\([^'']\{-}\)''\)'
|
||||||
|
while len(attrs) > 0
|
||||||
|
let match = matchstr(attrs, mx)
|
||||||
|
if len(match) ==# 0
|
||||||
|
break
|
||||||
|
endif
|
||||||
|
let attr_match = matchlist(match, mx)
|
||||||
|
let name = attr_match[1]
|
||||||
|
let value = len(attr_match[2]) ? attr_match[2] : attr_match[3]
|
||||||
|
let current.attr[name] = value
|
||||||
|
let current.attrs_order += [name]
|
||||||
|
let attrs = attrs[stridx(attrs, match) + len(match):]
|
||||||
|
endwhile
|
||||||
|
return current
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
function! emmet#lang#jade#toggleComment() abort
|
||||||
|
let line = getline('.')
|
||||||
|
let space = matchstr(line, '^\s*')
|
||||||
|
if line =~# '^\s*-#'
|
||||||
|
call setline('.', space . matchstr(line[len(space)+2:], '^\s*\zs.*'))
|
||||||
|
elseif line =~# '^\s*%[a-z]'
|
||||||
|
call setline('.', space . '-# ' . line[len(space):])
|
||||||
|
endif
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
function! emmet#lang#jade#balanceTag(flag) range abort
|
||||||
|
let block = emmet#util#getVisualBlock()
|
||||||
|
if a:flag == -2 || a:flag == 2
|
||||||
|
let curpos = [0, line("'<"), col("'<"), 0]
|
||||||
|
else
|
||||||
|
let curpos = emmet#util#getcurpos()
|
||||||
|
endif
|
||||||
|
let n = curpos[1]
|
||||||
|
let ml = len(matchstr(getline(n), '^\s*'))
|
||||||
|
|
||||||
|
if a:flag > 0
|
||||||
|
if a:flag == 1 || !emmet#util#regionIsValid(block)
|
||||||
|
let n = line('.')
|
||||||
|
else
|
||||||
|
while n > 0
|
||||||
|
let l = len(matchstr(getline(n), '^\s*\ze%[a-z]'))
|
||||||
|
if l > 0 && l < ml
|
||||||
|
let ml = l
|
||||||
|
break
|
||||||
|
endif
|
||||||
|
let n -= 1
|
||||||
|
endwhile
|
||||||
|
endif
|
||||||
|
let sn = n
|
||||||
|
if n == 0
|
||||||
|
let ml = 0
|
||||||
|
endif
|
||||||
|
while n < line('$')
|
||||||
|
let l = len(matchstr(getline(n), '^\s*%[a-z]'))
|
||||||
|
if l > 0 && l <= ml
|
||||||
|
let n -= 1
|
||||||
|
break
|
||||||
|
endif
|
||||||
|
let n += 1
|
||||||
|
endwhile
|
||||||
|
call setpos('.', [0, n, 1, 0])
|
||||||
|
normal! V
|
||||||
|
call setpos('.', [0, sn, 1, 0])
|
||||||
|
else
|
||||||
|
while n > 0
|
||||||
|
let l = len(matchstr(getline(n), '^\s*\ze[a-z]'))
|
||||||
|
if l > 0 && l > ml
|
||||||
|
let ml = l
|
||||||
|
break
|
||||||
|
endif
|
||||||
|
let n += 1
|
||||||
|
endwhile
|
||||||
|
let sn = n
|
||||||
|
if n == 0
|
||||||
|
let ml = 0
|
||||||
|
endif
|
||||||
|
while n < line('$')
|
||||||
|
let l = len(matchstr(getline(n), '^\s*%[a-z]'))
|
||||||
|
if l > 0 && l <= ml
|
||||||
|
let n -= 1
|
||||||
|
break
|
||||||
|
endif
|
||||||
|
let n += 1
|
||||||
|
endwhile
|
||||||
|
call setpos('.', [0, n, 1, 0])
|
||||||
|
normal! V
|
||||||
|
call setpos('.', [0, sn, 1, 0])
|
||||||
|
endif
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
function! emmet#lang#jade#moveNextPrevItem(flag) abort
|
||||||
|
return emmet#lang#jade#moveNextPrev(a:flag)
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
function! emmet#lang#jade#moveNextPrev(flag) abort
|
||||||
|
let pos = search('""', a:flag ? 'Wb' : 'W')
|
||||||
|
if pos != 0
|
||||||
|
silent! normal! l
|
||||||
|
startinsert
|
||||||
|
endif
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
function! emmet#lang#jade#splitJoinTag() abort
|
||||||
|
let n = line('.')
|
||||||
|
let sml = len(matchstr(getline(n), '^\s*%[a-z]'))
|
||||||
|
while n > 0
|
||||||
|
if getline(n) =~# '^\s*\ze%[a-z]'
|
||||||
|
if len(matchstr(getline(n), '^\s*%[a-z]')) < sml
|
||||||
|
break
|
||||||
|
endif
|
||||||
|
let line = getline(n)
|
||||||
|
call setline(n, substitute(line, '^\s*%\w\+\%(\s*{[^}]*}\|\s\)\zs.*', '', ''))
|
||||||
|
let sn = n
|
||||||
|
let n += 1
|
||||||
|
let ml = len(matchstr(getline(n), '^\s*%[a-z]'))
|
||||||
|
if len(matchstr(getline(n), '^\s*')) > ml
|
||||||
|
while n <= line('$')
|
||||||
|
let l = len(matchstr(getline(n), '^\s*'))
|
||||||
|
if l <= ml
|
||||||
|
break
|
||||||
|
endif
|
||||||
|
exe n 'delete'
|
||||||
|
endwhile
|
||||||
|
call setpos('.', [0, sn, 1, 0])
|
||||||
|
else
|
||||||
|
let tag = matchstr(getline(sn), '^\s*%\zs\(\w\+\)')
|
||||||
|
let spaces = matchstr(getline(sn), '^\s*')
|
||||||
|
let settings = emmet#getSettings()
|
||||||
|
if stridx(','.settings.html.inline_elements.',', ','.tag.',') == -1
|
||||||
|
call append(sn, spaces . ' ')
|
||||||
|
call setpos('.', [0, sn+1, 1, 0])
|
||||||
|
else
|
||||||
|
call setpos('.', [0, sn, 1, 0])
|
||||||
|
endif
|
||||||
|
startinsert!
|
||||||
|
endif
|
||||||
|
break
|
||||||
|
endif
|
||||||
|
let n -= 1
|
||||||
|
endwhile
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
function! emmet#lang#jade#removeTag() abort
|
||||||
|
let n = line('.')
|
||||||
|
let ml = 0
|
||||||
|
while n > 0
|
||||||
|
if getline(n) =~# '^\s*\ze[a-z]'
|
||||||
|
let ml = len(matchstr(getline(n), '^\s*%[a-z]'))
|
||||||
|
break
|
||||||
|
endif
|
||||||
|
let n -= 1
|
||||||
|
endwhile
|
||||||
|
let sn = n
|
||||||
|
while n < line('$')
|
||||||
|
let l = len(matchstr(getline(n), '^\s*%[a-z]'))
|
||||||
|
if l > 0 && l <= ml
|
||||||
|
let n -= 1
|
||||||
|
break
|
||||||
|
endif
|
||||||
|
let n += 1
|
||||||
|
endwhile
|
||||||
|
if sn == n
|
||||||
|
exe 'delete'
|
||||||
|
else
|
||||||
|
exe sn ',' (n-1) 'delete'
|
||||||
|
endif
|
||||||
|
endfunction
|
||||||
@@ -906,7 +906,7 @@ inside generated tree and elements' attributes.
|
|||||||
<
|
<
|
||||||
Other examples:
|
Other examples:
|
||||||
>
|
>
|
||||||
.wrapper -> <div class="wraper"></div>
|
.wrapper -> <div class="wrapper"></div>
|
||||||
#popup -> <div id="popup"></div>
|
#popup -> <div id="popup"></div>
|
||||||
<
|
<
|
||||||
When you expand abbreviation, Emmet tries to grab parent context,
|
When you expand abbreviation, Emmet tries to grab parent context,
|
||||||
|
|||||||
@@ -114,6 +114,10 @@ function! s:install_plugin(mode, buffer)
|
|||||||
\ {'mode': 'n', 'var': 'user_emmet_next_key', 'key': 'n', 'plug': 'emmet-move-next', 'func': ':call emmet#moveNextPrev(0)<cr>'},
|
\ {'mode': 'n', 'var': 'user_emmet_next_key', 'key': 'n', 'plug': 'emmet-move-next', 'func': ':call emmet#moveNextPrev(0)<cr>'},
|
||||||
\ {'mode': 'i', 'var': 'user_emmet_prev_key', 'key': 'N', 'plug': 'emmet-move-prev', 'func': '<esc>:call emmet#moveNextPrev(1)<cr>'},
|
\ {'mode': 'i', 'var': 'user_emmet_prev_key', 'key': 'N', 'plug': 'emmet-move-prev', 'func': '<esc>:call emmet#moveNextPrev(1)<cr>'},
|
||||||
\ {'mode': 'n', 'var': 'user_emmet_prev_key', 'key': 'N', 'plug': 'emmet-move-prev', 'func': ':call emmet#moveNextPrev(1)<cr>'},
|
\ {'mode': 'n', 'var': 'user_emmet_prev_key', 'key': 'N', 'plug': 'emmet-move-prev', 'func': ':call emmet#moveNextPrev(1)<cr>'},
|
||||||
|
\ {'mode': 'i', 'var': '', 'key': '', 'plug': 'emmet-move-next-item', 'func': '<esc>:call emmet#moveNextPrevItem(0)<cr>'},
|
||||||
|
\ {'mode': 'n', 'var': '', 'key': '', 'plug': 'emmet-move-next-item', 'func': ':call emmet#moveNextPrevItem(0)<cr>'},
|
||||||
|
\ {'mode': 'i', 'var': '', 'key': '', 'plug': 'emmet-move-prev-item', 'func': '<esc>:call emmet#moveNextPrevItem(1)<cr>'},
|
||||||
|
\ {'mode': 'n', 'var': '', 'key': '', 'plug': 'emmet-move-prev-item', 'func': ':call emmet#moveNextPrevItem(1)<cr>'},
|
||||||
\ {'mode': 'i', 'var': 'user_emmet_imagesize_key', 'key': 'i', 'plug': 'emmet-image-size', 'func': '<c-r>=emmet#util#closePopup()<cr><c-r>=emmet#imageSize()<cr>'},
|
\ {'mode': 'i', 'var': 'user_emmet_imagesize_key', 'key': 'i', 'plug': 'emmet-image-size', 'func': '<c-r>=emmet#util#closePopup()<cr><c-r>=emmet#imageSize()<cr>'},
|
||||||
\ {'mode': 'n', 'var': 'user_emmet_imagesize_key', 'key': 'i', 'plug': 'emmet-image-size', 'func': ':call emmet#imageSize()<cr>'},
|
\ {'mode': 'n', 'var': 'user_emmet_imagesize_key', 'key': 'i', 'plug': 'emmet-image-size', 'func': ':call emmet#imageSize()<cr>'},
|
||||||
\ {'mode': 'i', 'var': 'user_emmet_togglecomment_key', 'key': '/', 'plug': 'emmet-toggle-comment', 'func': '<c-r>=emmet#util#closePopup()<cr><c-r>=emmet#toggleComment()<cr>'},
|
\ {'mode': 'i', 'var': 'user_emmet_togglecomment_key', 'key': '/', 'plug': 'emmet-toggle-comment', 'func': '<c-r>=emmet#util#closePopup()<cr><c-r>=emmet#toggleComment()<cr>'},
|
||||||
@@ -130,11 +134,13 @@ function! s:install_plugin(mode, buffer)
|
|||||||
\ {'mode': 'v', 'var': 'user_emmet_codepretty_key', 'key': 'c', 'plug': 'emmet-code-pretty', 'func': ':call emmet#codePretty()<cr>'},
|
\ {'mode': 'v', 'var': 'user_emmet_codepretty_key', 'key': 'c', 'plug': 'emmet-code-pretty', 'func': ':call emmet#codePretty()<cr>'},
|
||||||
\]
|
\]
|
||||||
|
|
||||||
|
let only_plug = get(g:, 'emmet_install_only_plug', 0)
|
||||||
for item in items
|
for item in items
|
||||||
if a:mode !=# 'a' && stridx(a:mode, item.mode) == -1
|
if a:mode !=# 'a' && stridx(a:mode, item.mode) == -1
|
||||||
continue
|
continue
|
||||||
endif
|
endif
|
||||||
exe item.mode . 'noremap '. buffer .' <plug>(' . item.plug . ') ' . item.func
|
exe item.mode . 'noremap '. buffer .' <plug>(' . item.plug . ') ' . item.func
|
||||||
|
if item.var != '' && !only_plug
|
||||||
if exists('g:' . item.var)
|
if exists('g:' . item.var)
|
||||||
let key = eval('g:' . item.var)
|
let key = eval('g:' . item.var)
|
||||||
else
|
else
|
||||||
@@ -143,6 +149,7 @@ function! s:install_plugin(mode, buffer)
|
|||||||
if !hasmapto('<plug>(' . item.plug . ')', item.mode) && !len(maparg(key, item.mode))
|
if !hasmapto('<plug>(' . item.plug . ')', item.mode) && !len(maparg(key, item.mode))
|
||||||
exe item.mode . 'map ' . buffer . ' <unique> ' . key . ' <plug>(' . item.plug . ')'
|
exe item.mode . 'map ' . buffer . ' <unique> ' . key . ' <plug>(' . item.plug . ')'
|
||||||
endif
|
endif
|
||||||
|
endif
|
||||||
endfor
|
endfor
|
||||||
|
|
||||||
if exists('g:user_emmet_complete_tag') && g:user_emmet_complete_tag
|
if exists('g:user_emmet_complete_tag') && g:user_emmet_complete_tag
|
||||||
|
|||||||
24
unittest.vim
24
unittest.vim
@@ -738,6 +738,30 @@ finish
|
|||||||
'query': "{dn$$$$}",
|
'query': "{dn$$$$}",
|
||||||
'result': "{display: none;}",
|
'result': "{display: none;}",
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
'query': "{p10%$$$$}",
|
||||||
|
'result': "{padding: 10%;}",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
'query': "{p10p$$$$}",
|
||||||
|
'result': "{padding: 10%;}",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
'query': "{p10e$$$$}",
|
||||||
|
'result': "{padding: 10em;}",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
'query': "{p10em$$$$}",
|
||||||
|
'result': "{padding: 10em;}",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
'query': "{p10re$$$$}",
|
||||||
|
'result': "{padding: 10rem;}",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
'query': "{p10rem$$$$}",
|
||||||
|
'result': "{padding: 10rem;}",
|
||||||
|
},
|
||||||
],
|
],
|
||||||
},
|
},
|
||||||
],
|
],
|
||||||
|
|||||||
Reference in New Issue
Block a user