1
0
Fork 0
mirror of synced 2024-11-15 21:48:57 -05:00
ultimate-vim/sources_forked/zencoding/autoload/zencoding.vim

1487 lines
56 KiB
VimL
Raw Normal View History

"=============================================================================
" zencoding.vim
" Author: Yasuhiro Matsumoto <mattn.jp@gmail.com>
" Last Change: 09-Apr-2013.
let s:save_cpo = &cpo
set cpo&vim
function! zencoding#getExpandos(type, key)
let expandos = zencoding#getResource(a:type, 'expandos', {})
if has_key(expandos, a:key)
return expandos[a:key]
endif
return a:key
endfunction
function! zencoding#splitFilterArg(filters)
for f in a:filters
if f =~ '^/'
return f[1:]
endif
endfor
return ''
endfunction
function! zencoding#useFilter(filters, filter)
for f in a:filters
if a:filter == '/' && f =~ '^/'
return 1
elseif f == a:filter
return 1
endif
endfor
return 0
endfunction
function! zencoding#getIndentation(...)
if a:0 > 0
let type = a:1
else
let type = zencoding#getFileType()
endif
if has_key(s:zen_settings, type) && has_key(s:zen_settings[type], 'indentation')
let indent = s:zen_settings[type].indentation
elseif has_key(s:zen_settings, 'indentation')
let indent = s:zen_settings.indentation
else
let indent = (&l:expandtab || &l:tabstop != &l:shiftwidth) ? repeat(' ', &l:shiftwidth) : "\t"
endif
return indent
endfunction
function! zencoding#getBaseType(type)
if !has_key(s:zen_settings, a:type)
return ''
endif
if !has_key(s:zen_settings[a:type], 'extends')
return a:type
endif
let extends = s:zen_settings[a:type].extends
if type(extends) == 1
let tmp = split(extends, '\s*,\s*')
let ext = tmp[0]
else
let ext = extends[0]
endif
if a:type != ext
return zencoding#getBaseType(ext)
endif
return ''
endfunction
function! zencoding#isExtends(type, extend)
if a:type == a:extend
return 1
endif
if !has_key(s:zen_settings, a:type)
return 0
endif
if !has_key(s:zen_settings[a:type], 'extends')
return 0
endif
let extends = s:zen_settings[a:type].extends
if type(extends) == 1
let tmp = split(extends, '\s*,\s*')
unlet! extends
let extends = tmp
endif
for ext in extends
if a:extend == ext
return 1
endif
endfor
return 0
endfunction
function! zencoding#parseIntoTree(abbr, type)
let abbr = a:abbr
let type = a:type
let rtype = zencoding#lang#exists(type) ? type : 'html'
return zencoding#lang#{rtype}#parseIntoTree(abbr, type)
endfunction
function! s:mergeConfig(lhs, rhs)
if type(a:lhs) == 3 && type(a:rhs) == 3
let a:lhs += a:rhs
if len(a:lhs)
call remove(a:lhs, 0, len(a:lhs)-1)
endif
for rhi in a:rhs
call add(a:lhs, a:rhs[rhi])
endfor
elseif type(a:lhs) == 4 && type(a:rhs) == 4
for key in keys(a:rhs)
if type(a:rhs[key]) == 3
if !has_key(a:lhs, key)
let a:lhs[key] = []
endif
let a:lhs[key] += a:rhs[key]
elseif type(a:rhs[key]) == 4
if has_key(a:lhs, key)
call s:mergeConfig(a:lhs[key], a:rhs[key])
else
let a:lhs[key] = a:rhs[key]
endif
else
let a:lhs[key] = a:rhs[key]
endif
endfor
endif
endfunction
function! zencoding#toString(...)
let current = a:1
if a:0 > 1
let type = a:2
else
let type = &ft
endif
if len(type) == 0 | let type = 'html' | endif
if a:0 > 2
let inline = a:3
else
let inline = 0
endif
if a:0 > 3
if type(a:4) == 1
let filters = split(a:4, '\s*,\s*')
else
let filters = a:4
endif
else
let filters = ['html']
endif
if a:0 > 4
let group_itemno = a:5
else
let group_itemno = 0
endif
let dollar_expr = zencoding#getResource(type, 'dollar_expr', 1)
let indent = zencoding#getIndentation(type)
let itemno = 0
let str = ''
let use_pipe_for_cursor = zencoding#getResource(type, 'use_pipe_for_cursor', 1)
let rtype = zencoding#lang#exists(type) ? type : 'html'
while itemno < current.multiplier
if len(current.name)
if group_itemno != 0
let inner = zencoding#lang#{rtype}#toString(s:zen_settings, current, type, inline, filters, group_itemno, indent)
else
let inner = zencoding#lang#{rtype}#toString(s:zen_settings, current, type, inline, filters, itemno, indent)
endif
if current.multiplier > 1
let inner = substitute(inner, '\$#', '$line'.(itemno+1).'$', 'g')
endif
let str .= inner
else
let snippet = current.snippet
if len(current.snippet) == 0
let snippets = zencoding#getResource(type, 'snippets', {})
if !empty(snippets) && has_key(snippets, 'zensnippet')
let snippet = snippets['zensnippet']
endif
endif
if len(snippet) > 0
let tmp = snippet
if use_pipe_for_cursor
let tmp = substitute(tmp, '|', '${cursor}', 'g')
endif
let tmp = substitute(tmp, '\${zenname}', current.name, 'g')
let snippet_node = { 'name': '', 'attr': {}, 'child': [], 'snippet': '', 'multiplier': 0, 'parent': {}, 'value': '{'.tmp.'}', 'pos': 0, 'important': current.important }
let str = zencoding#lang#{rtype}#toString(s:zen_settings, snippet_node, type, inline, filters, group_itemno, indent)
else
if len(current.name)
let str .= current.name
endif
if len(current.value)
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')
endif
let str .= text
endif
endif
let inner = ''
if len(current.child)
let render_type = zencoding#getFileType(1)
for n in current.child
let inner .= zencoding#toString(n, type, inline, filters, group_itemno)
endfor
endif
let spaces = matchstr(str, '\s*\ze\${child}')
let inner = substitute(inner, "\n", "\n" . spaces, 'g')
let str = substitute(str, '\${child}', inner, '')
endif
let itemno = itemno + 1
endwhile
return str
endfunction
function! zencoding#getSettings()
return s:zen_settings
endfunction
function! zencoding#getResource(type, name, default)
if !has_key(s:zen_settings, a:type)
return a:default
endif
let ret = a:default
if has_key(s:zen_settings[a:type], 'extends')
let extends = s:zen_settings[a:type].extends
if type(extends) == 1
let tmp = split(extends, '\s*,\s*')
unlet! extends
let extends = tmp
endif
for ext in extends
if has_key(s:zen_settings, ext) && has_key(s:zen_settings[ext], a:name)
call s:mergeConfig(ret, s:zen_settings[ext][a:name])
endif
endfor
endif
if has_key(s:zen_settings[a:type], a:name)
let v = s:zen_settings[a:type][a:name]
if type(ret) == 3 || type(ret) == 4
call s:mergeConfig(ret, s:zen_settings[a:type][a:name])
else
let ret = s:zen_settings[a:type][a:name]
endif
endif
return ret
endfunction
function! zencoding#getFileType(...)
let flg = get(a:000, 0, 0)
let type = &ft
if zencoding#lang#exists(&ft)
let type = &ft
else
let base = zencoding#getBaseType(type)
if base != ""
if flg
let type = &ft
else
let type = base
endif
endif
endif
if type == 'html'
let type = synIDattr(synID(line("."), col("."), 1), "name")
if type =~ '^css\w'
let type = 'css'
endif
if type =~ '^html\w'
let type = 'html'
endif
if type =~ '^javaScript'
let type = 'javascript'
endif
if len(type) == 0 && type =~ '^xml'
let type = 'xml'
endif
endif
if len(type) == 0 | let type = 'html' | endif
return type
endfunction
function! zencoding#expandAbbr(mode, abbr) range
let type = zencoding#getFileType()
let rtype = zencoding#getFileType(1)
let expand = ''
let filters = ['html']
let line = ''
let part = ''
let rest = ''
if has_key(s:zen_settings, type) && has_key(s:zen_settings[type], 'filters')
let filters = split(s:zen_settings[type].filters, '\s*,\s*')
endif
if a:mode == 2
let leader = substitute(input('Tag: ', ''), '^\s*\(.*\)\s*$', '\1', 'g')
if len(leader) == 0
return
endif
let mx = '|\(\%(html\|haml\|slim\|e\|c\|fc\|xsl\|t\|\/[^ ]\+\)\s*,\{0,1}\s*\)*$'
if leader =~ mx
let filters = map(split(matchstr(leader, mx)[1:], '\s*[^\\]\zs,\s*'), 'substitute(v:val, "\\\\\\\\zs.\\\\ze", "&", "g")')
let leader = substitute(leader, mx, '', '')
endif
if leader =~ '\*'
let query = substitute(leader, '*', '*' . (a:lastline - a:firstline + 1), '')
if query !~ '}\s*$'
let query .= '>{$#}'
endif
if zencoding#useFilter(filters, '/')
let spl = zencoding#splitFilterArg(filters)
let fline = getline(a:firstline)
let query = substitute(query, '>\{0,1}{\$#}\s*$', '{\\$column\\$}*' . len(split(fline, spl)), '')
endif
let items = zencoding#parseIntoTree(query, type).child
for item in items
let expand .= zencoding#toString(item, type, 0, filters)
endfor
if zencoding#useFilter(filters, 'e')
let expand = substitute(expand, '&', '\&amp;', 'g')
let expand = substitute(expand, '<', '\&lt;', 'g')
let expand = substitute(expand, '>', '\&gt;', 'g')
endif
let line = getline(a:firstline)
let part = substitute(line, '^\s*', '', '')
for n in range(a:firstline, a:lastline)
let lline = getline(n)
let lpart = substitute(lline, '^\s\+', '', '')
if zencoding#useFilter(filters, 't')
let lpart = substitute(lpart, '^[0-9.-]\+\s\+', '', '')
let lpart = substitute(lpart, '\s\+$', '', '')
endif
if zencoding#useFilter(filters, '/')
for column in split(lpart, spl)
let expand = substitute(expand, '\$column\$', '\=column', '')
endfor
else
let expand = substitute(expand, '\$line'.(n-a:firstline+1).'\$', '\=lpart', 'g')
endif
endfor
let expand = substitute(expand, '\$line\d*\$', '', 'g')
let expand = substitute(expand, '\$column\$', '', 'g')
let content = join(getline(a:firstline, a:lastline), "\n")
if stridx(expand, '$#') < len(expand)-2
let expand = substitute(expand, '^\(.*\)\$#\s*$', '\1', '')
endif
let expand = substitute(expand, '\$#', '\=content', 'g')
else
let str = ''
if visualmode() ==# 'V'
let line = getline(a:firstline)
let part = substitute(line, '^\s*', '', '')
for n in range(a:firstline, a:lastline)
if len(leader) > 0
let str .= getline(n) . "\n"
else
let lpart = substitute(getline(n), '^\s*', '', '')
let str .= lpart . "\n"
endif
endfor
let leader .= (str =~ "\n" ? ">{\n" : "{") . str . "}"
let items = zencoding#parseIntoTree(leader, type).child
else
let save_regcont = @"
let save_regtype = getregtype('"')
silent! normal! gvygv
let str = @"
call setreg('"', save_regcont, save_regtype)
let items = zencoding#parseIntoTree(leader . "{".str."}", type).child
endif
for item in items
let expand .= zencoding#toString(item, type, 0, filters)
endfor
if zencoding#useFilter(filters, 'e')
let expand = substitute(expand, '&', '\&amp;', 'g')
let expand = substitute(expand, '<', '\&lt;', 'g')
let expand = substitute(expand, '>', '\&gt;', 'g')
endif
endif
elseif a:mode == 4
let line = getline('.')
let spaces = matchstr(line, '^\s*')
if line !~ '^\s*$'
put =spaces.a:abbr
else
call setline('.', spaces.a:abbr)
endif
normal! $
call zencoding#expandAbbr(0, "")
return
else
let line = getline('.')
if col('.') < len(line)
let line = matchstr(line, '^\(.*\%'.col('.').'c.\)')
endif
if a:mode == 1
let part = matchstr(line, '\([a-zA-Z0-9:_\-\@|]\+\)$')
else
let part = matchstr(line, '\(\S.*\)$')
let ftype = zencoding#lang#exists(type) ? type : 'html'
let part = zencoding#lang#{ftype}#findTokens(part)
endif
let rest = getline('.')[len(line):]
let str = part
let mx = '|\(\%(html\|haml\|slim\|e\|c\|fc\|xsl\|t\|\/[^ ]\+\)\s*,\{0,1}\s*\)*$'
if str =~ mx
let filters = split(matchstr(str, mx)[1:], '\s*,\s*')
let str = substitute(str, mx, '', '')
endif
let items = zencoding#parseIntoTree(str, rtype).child
for item in items
let expand .= zencoding#toString(item, rtype, 0, filters)
endfor
if zencoding#useFilter(filters, 'e')
let expand = substitute(expand, '&', '\&amp;', 'g')
let expand = substitute(expand, '<', '\&lt;', 'g')
let expand = substitute(expand, '>', '\&gt;', 'g')
endif
let expand = substitute(expand, '\$line\([0-9]\+\)\$', '\=submatch(1)', 'g')
endif
if len(expand)
if expand !~ '\${cursor}'
if a:mode == 2 |
let expand = '${cursor}' . expand
else
let expand .= '${cursor}'
endif
endif
let expand = substitute(expand, '${lang}', s:zen_settings.lang, 'g')
let expand = substitute(expand, '${charset}', s:zen_settings.charset, 'g')
if has_key(s:zen_settings, 'timezone') && len(s:zen_settings.timezone)
let expand = substitute(expand, '${datetime}', strftime("%Y-%m-%dT%H:%M:%S") . s:zen_settings.timezone, 'g')
else
" TODO: on windows, %z/%Z is 'Tokyo(Standard)'
let expand = substitute(expand, '${datetime}', strftime("%Y-%m-%dT%H:%M:%S %z"), 'g')
endif
if a:mode == 2 && visualmode() ==# 'v'
if a:firstline == a:lastline
let expand = substitute(expand, '\n\s*', '', 'g')
else
let expand = substitute(expand, '\n$', '', 'g')
endif
let expand = substitute(expand, '\${cursor}', '$cursor$', '')
let expand = substitute(expand, '\${cursor}', '', 'g')
silent! normal! gv
let col = col("'<")
silent! normal! c
let line = getline('.')
let lhs = matchstr(line, '.*\%<'.col.'c.')
let rhs = matchstr(line, '\%>'.(col-1).'c.*')
let expand = lhs.expand.rhs
let lines = split(expand, '\n')
call setline(line('.'), lines[0])
if len(lines) > 1
call append(line('.'), lines[1:])
endif
else
let expand = substitute(expand, '\${cursor}', '$cursor$', '')
let expand = substitute(expand, '\${cursor}', '', 'g')
if line[:-len(part)-1] =~ '^\s\+$'
let indent = line[:-len(part)-1]
else
let indent = ''
endif
let expand = substitute(expand, '\n\s*$', '', 'g')
let expand = line[:-len(part)-1] . substitute(expand, "\n", "\n" . indent, 'g') . rest
let lines = split(expand, '\n')
if a:mode == 2
silent! exe "normal! gvc"
endif
call setline(line('.'), lines[0])
if len(lines) > 1
call append(line('.'), lines[1:])
endif
endif
endif
if search('\$cursor\$', 'e')
let oldselection = &selection
let &selection = 'inclusive'
silent! foldopen
silent! exe "normal! v7h\"_s"
let &selection = oldselection
endif
if g:zencoding_debug > 1
call getchar()
endif
endfunction
function! zencoding#moveNextPrev(flag)
let type = zencoding#getFileType()
let rtype = zencoding#lang#exists(type) ? type : 'html'
return zencoding#lang#{rtype}#moveNextPrev(a:flag)
endfunction
function! zencoding#imageSize()
let type = zencoding#getFileType()
let rtype = zencoding#lang#exists(type) ? type : 'html'
return zencoding#lang#{rtype}#imageSize()
endfunction
function! zencoding#encodeImage()
let type = zencoding#getFileType()
let rtype = zencoding#lang#exists(type) ? type : 'html'
return zencoding#lang#{rtype}#encodeImage()
endfunction
function! zencoding#toggleComment()
let type = zencoding#getFileType()
let rtype = zencoding#lang#exists(type) ? type : 'html'
return zencoding#lang#{rtype}#toggleComment()
endfunction
function! zencoding#balanceTag(flag) range
let type = zencoding#getFileType()
let rtype = zencoding#lang#exists(type) ? type : 'html'
return zencoding#lang#{rtype}#balanceTag(a:flag)
endfunction
function! zencoding#splitJoinTag()
let type = zencoding#getFileType()
let rtype = zencoding#lang#exists(type) ? type : 'html'
return zencoding#lang#{rtype}#splitJoinTag()
endfunction
function! zencoding#mergeLines() range
let lines = join(map(getline(a:firstline, a:lastline), 'matchstr(v:val, "^\\s*\\zs.*\\ze\\s*$")'), '')
let indent = substitute(getline('.'), '^\(\s*\).*', '\1', '')
silent! exe "normal! gvc"
call setline('.', indent . lines)
endfunction
function! zencoding#removeTag()
let type = zencoding#getFileType()
let rtype = zencoding#lang#exists(type) ? type : 'html'
return zencoding#lang#{rtype}#removeTag()
endfunction
function! zencoding#anchorizeURL(flag)
let mx = 'https\=:\/\/[-!#$%&*+,./:;=?@0-9a-zA-Z_~]\+'
let pos1 = searchpos(mx, 'bcnW')
let url = matchstr(getline(pos1[0])[pos1[1]-1:], mx)
let block = [pos1, [pos1[0], pos1[1] + len(url) - 1]]
if !zencoding#util#cursorInRegion(block)
return
endif
let mx = '.*<title[^>]*>\s*\zs\([^<]\+\)\ze\s*<\/title[^>]*>.*'
let content = zencoding#util#getContentFromURL(url)
let content = substitute(content, '\r', '', 'g')
let content = substitute(content, '[ \n]\+', ' ', 'g')
let content = substitute(content, '<!--.\{-}-->', '', 'g')
let title = matchstr(content, mx)
let type = zencoding#getFileType()
let rtype = zencoding#lang#exists(type) ? type : 'html'
if a:flag == 0
let a = zencoding#lang#html#parseTag('<a>')
let a.attr.href = url
let a.value = '{' . title . '}'
let expand = zencoding#toString(a, rtype, 0, [])
let expand = substitute(expand, '\${cursor}', '', 'g')
else
let body = zencoding#util#getTextFromHTML(content)
let body = '{' . substitute(body, '^\(.\{0,100}\).*', '\1', '') . '...}'
let blockquote = zencoding#lang#html#parseTag('<blockquote class="quote">')
let a = zencoding#lang#html#parseTag('<a>')
let a.attr.href = url
let a.value = '{' . title . '}'
call add(blockquote.child, a)
call add(blockquote.child, zencoding#lang#html#parseTag('<br/>'))
let p = zencoding#lang#html#parseTag('<p>')
let p.value = body
call add(blockquote.child, p)
let cite = zencoding#lang#html#parseTag('<cite>')
let cite.value = '{' . url . '}'
call add(blockquote.child, cite)
let expand = zencoding#toString(blockquote, rtype, 0, [])
let expand = substitute(expand, '\${cursor}', '', 'g')
endif
let indent = substitute(getline('.'), '^\(\s*\).*', '\1', '')
let expand = substitute(expand, "\n", "\n" . indent, 'g')
call zencoding#util#setContent(block, expand)
endfunction
function! zencoding#codePretty() range
let type = input('FileType: ', &ft, 'filetype')
if len(type) == 0
return
endif
let block = zencoding#util#getVisualBlock()
let content = zencoding#util#getContent(block)
silent! 1new
let &l:filetype = type
call setline(1, split(content, "\n"))
let old_lazyredraw = &lazyredraw
set lazyredraw
silent! TOhtml
let &lazyredraw = old_lazyredraw
let content = join(getline(1, '$'), "\n")
silent! bw!
silent! bw!
let content = matchstr(content, '<body[^>]*>[\s\n]*\zs.*\ze</body>')
call zencoding#util#setContent(block, content)
endfunction
function! zencoding#ExpandWord(abbr, type, orig)
let mx = '|\(\%(html\|haml\|slim\|e\|c\|fc\|xsl\|t\|\/[^ ]\+\)\s*,\{0,1}\s*\)*$'
let str = a:abbr
let type = a:type
if len(type) == 0 | let type = 'html' | endif
if str =~ mx
let filters = split(matchstr(str, mx)[1:], '\s*,\s*')
let str = substitute(str, mx, '', '')
elseif has_key(s:zen_settings[a:type], 'filters')
let filters = split(s:zen_settings[a:type].filters, '\s*,\s*')
else
let filters = ['html']
endif
let items = zencoding#parseIntoTree(str, a:type).child
let expand = ''
for item in items
let expand .= zencoding#toString(item, a:type, 0, filters)
endfor
if zencoding#useFilter(filters, 'e')
let expand = substitute(expand, '&', '\&amp;', 'g')
let expand = substitute(expand, '<', '\&lt;', 'g')
let expand = substitute(expand, '>', '\&gt;', 'g')
endif
if a:orig == 0
let expand = substitute(expand, '\${lang}', s:zen_settings.lang, 'g')
let expand = substitute(expand, '\${charset}', s:zen_settings.charset, 'g')
let expand = substitute(expand, '\${cursor}', '', 'g')
endif
return expand
endfunction
function! zencoding#getSnippets(type)
let type = a:type
if len(type) == 0 || !has_key(s:zen_settings, type)
let type = 'html'
endif
return zencoding#getResource(type, 'snippets', {})
endfunction
function! zencoding#CompleteTag(findstart, base)
if a:findstart
let line = getline('.')
let start = col('.') - 1
while start > 0 && line[start - 1] =~ '[a-zA-Z0-9:_\@\-]'
let start -= 1
endwhile
return start
else
let type = zencoding#getFileType()
let res = []
let snippets = zencoding#getResource(type, 'snippets', {})
for item in keys(snippets)
if stridx(item, a:base) != -1
call add(res, substitute(item, '\${cursor}\||', '', 'g'))
endif
endfor
let aliases = zencoding#getResource(type, 'aliases', {})
for item in values(aliases)
if stridx(item, a:base) != -1
call add(res, substitute(item, '\${cursor}\||', '', 'g'))
endif
endfor
return res
endif
endfunction
unlet! s:zen_settings
let s:zen_settings = {
\ 'lang': "en",
\ 'charset': "UTF-8",
\ 'css': {
\ 'snippets': {
\ '@i': '@import url(|);',
\ '@m': "@media print {\n\t|\n}",
\ '@f': "@font-face {\n\tfont-family:|;\n\tsrc:url(|);\n}",
\ '!': '!important',
\ 'pos': 'position:|;',
\ 'pos:s': 'position:static;',
\ 'pos:a': 'position:absolute;',
\ 'pos:r': 'position:relative;',
\ 'pos:f': 'position:fixed;',
\ 't': 'top:|;',
\ 't:a': 'top:auto;',
\ 'r': 'right:|;',
\ 'r:a': 'right:auto;',
\ 'b': 'bottom:|;',
\ 'b:a': 'bottom:auto;',
\ 'l': 'left:|;',
\ 'l:a': 'left:auto;',
\ 'z': 'z-index:|;',
\ 'z:a': 'z-index:auto;',
\ 'fl': 'float:|;',
\ 'fl:n': 'float:none;',
\ 'fl:l': 'float:left;',
\ 'fl:r': 'float:right;',
\ 'cl': 'clear:|;',
\ 'cl:n': 'clear:none;',
\ 'cl:l': 'clear:left;',
\ 'cl:r': 'clear:right;',
\ 'cl:b': 'clear:both;',
\ 'd': 'display:|;',
\ 'd:n': 'display:none;',
\ 'd:b': 'display:block;',
\ 'd:i': 'display:inline;',
\ 'd:ib': 'display:inline-block;',
\ 'd:li': 'display:list-item;',
\ 'd:ri': 'display:run-in;',
\ 'd:cp': 'display:compact;',
\ 'd:tb': 'display:table;',
\ 'd:itb': 'display:inline-table;',
\ 'd:tbcp': 'display:table-caption;',
\ 'd:tbcl': 'display:table-column;',
\ 'd:tbclg': 'display:table-column-group;',
\ 'd:tbhg': 'display:table-header-group;',
\ 'd:tbfg': 'display:table-footer-group;',
\ 'd:tbr': 'display:table-row;',
\ 'd:tbrg': 'display:table-row-group;',
\ 'd:tbc': 'display:table-cell;',
\ 'd:rb': 'display:ruby;',
\ 'd:rbb': 'display:ruby-base;',
\ 'd:rbbg': 'display:ruby-base-group;',
\ 'd:rbt': 'display:ruby-text;',
\ 'd:rbtg': 'display:ruby-text-group;',
\ 'v': 'visibility:|;',
\ 'v:v': 'visibility:visible;',
\ 'v:h': 'visibility:hidden;',
\ 'v:c': 'visibility:collapse;',
\ 'ov': 'overflow:|;',
\ 'ov:v': 'overflow:visible;',
\ 'ov:h': 'overflow:hidden;',
\ 'ov:s': 'overflow:scroll;',
\ 'ov:a': 'overflow:auto;',
\ 'ovx': 'overflow-x:|;',
\ 'ovx:v': 'overflow-x:visible;',
\ 'ovx:h': 'overflow-x:hidden;',
\ 'ovx:s': 'overflow-x:scroll;',
\ 'ovx:a': 'overflow-x:auto;',
\ 'ovy': 'overflow-y:|;',
\ 'ovy:v': 'overflow-y:visible;',
\ 'ovy:h': 'overflow-y:hidden;',
\ 'ovy:s': 'overflow-y:scroll;',
\ 'ovy:a': 'overflow-y:auto;',
\ 'ovs': 'overflow-style:|;',
\ 'ovs:a': 'overflow-style:auto;',
\ 'ovs:s': 'overflow-style:scrollbar;',
\ 'ovs:p': 'overflow-style:panner;',
\ 'ovs:m': 'overflow-style:move;',
\ 'ovs:mq': 'overflow-style:marquee;',
\ 'zoo': 'zoom:1;',
\ 'cp': 'clip:|;',
\ 'cp:a': 'clip:auto;',
\ 'cp:r': 'clip:rect(|);',
\ 'bxz': 'box-sizing:|;',
\ 'bxz:cb': 'box-sizing:content-box;',
\ 'bxz:bb': 'box-sizing:border-box;',
\ 'bxsh': 'box-shadow:|;',
\ 'bxsh:n': 'box-shadow:none;',
\ 'bxsh:w': '-webkit-box-shadow:0 0 0 #000;',
\ 'bxsh:m': '-moz-box-shadow:0 0 0 0 #000;',
\ 'm': 'margin:|;',
\ 'm:a': 'margin:auto;',
\ 'm:0': 'margin:0;',
\ 'm:2': 'margin:0 0;',
\ 'm:3': 'margin:0 0 0;',
\ 'm:4': 'margin:0 0 0 0;',
\ 'mt': 'margin-top:|;',
\ 'mt:a': 'margin-top:auto;',
\ 'mr': 'margin-right:|;',
\ 'mr:a': 'margin-right:auto;',
\ 'mb': 'margin-bottom:|;',
\ 'mb:a': 'margin-bottom:auto;',
\ 'ml': 'margin-left:|;',
\ 'ml:a': 'margin-left:auto;',
\ 'p': 'padding:|;',
\ 'p:0': 'padding:0;',
\ 'p:2': 'padding:0 0;',
\ 'p:3': 'padding:0 0 0;',
\ 'p:4': 'padding:0 0 0 0;',
\ 'pt': 'padding-top:|;',
\ 'pr': 'padding-right:|;',
\ 'pb': 'padding-bottom:|;',
\ 'pl': 'padding-left:|;',
\ 'w': 'width:|;',
\ 'w:a': 'width:auto;',
\ 'h': 'height:|;',
\ 'h:a': 'height:auto;',
\ 'maw': 'max-width:|;',
\ 'maw:n': 'max-width:none;',
\ 'mah': 'max-height:|;',
\ 'mah:n': 'max-height:none;',
\ 'miw': 'min-width:|;',
\ 'mih': 'min-height:|;',
\ 'o': 'outline:|;',
\ 'o:n': 'outline:none;',
\ 'oo': 'outline-offset:|;',
\ 'ow': 'outline-width:|;',
\ 'os': 'outline-style:|;',
\ 'oc': 'outline-color:#000;',
\ 'oc:i': 'outline-color:invert;',
\ 'bd': 'border:|;',
\ 'bd+': 'border:1px solid #000;',
\ 'bd:n': 'border:none;',
\ 'bdbk': 'border-break:|;',
\ 'bdbk:c': 'border-break:close;',
\ 'bdcl': 'border-collapse:|;',
\ 'bdcl:c': 'border-collapse:collapse;',
\ 'bdcl:s': 'border-collapse:separate;',
\ 'bdc': 'border-color:#000;',
\ 'bdi': 'border-image:url(|);',
\ 'bdi:n': 'border-image:none;',
\ 'bdi:w': '-webkit-border-image:url(|) 0 0 0 0 stretch stretch;',
\ 'bdi:m': '-moz-border-image:url(|) 0 0 0 0 stretch stretch;',
\ 'bdti': 'border-top-image:url(|);',
\ 'bdti:n': 'border-top-image:none;',
\ 'bdri': 'border-right-image:url(|);',
\ 'bdri:n': 'border-right-image:none;',
\ 'bdbi': 'border-bottom-image:url(|);',
\ 'bdbi:n': 'border-bottom-image:none;',
\ 'bdli': 'border-left-image:url(|);',
\ 'bdli:n': 'border-left-image:none;',
\ 'bdci': 'border-corner-image:url(|);',
\ 'bdci:n': 'border-corner-image:none;',
\ 'bdci:c': 'border-corner-image:continue;',
\ 'bdtli': 'border-top-left-image:url(|);',
\ 'bdtli:n': 'border-top-left-image:none;',
\ 'bdtli:c': 'border-top-left-image:continue;',
\ 'bdtri': 'border-top-right-image:url(|);',
\ 'bdtri:n': 'border-top-right-image:none;',
\ 'bdtri:c': 'border-top-right-image:continue;',
\ 'bdbri': 'border-bottom-right-image:url(|);',
\ 'bdbri:n': 'border-bottom-right-image:none;',
\ 'bdbri:c': 'border-bottom-right-image:continue;',
\ 'bdbli': 'border-bottom-left-image:url(|);',
\ 'bdbli:n': 'border-bottom-left-image:none;',
\ 'bdbli:c': 'border-bottom-left-image:continue;',
\ 'bdf': 'border-fit:|;',
\ 'bdf:c': 'border-fit:clip;',
\ 'bdf:r': 'border-fit:repeat;',
\ 'bdf:sc': 'border-fit:scale;',
\ 'bdf:st': 'border-fit:stretch;',
\ 'bdf:ow': 'border-fit:overwrite;',
\ 'bdf:of': 'border-fit:overflow;',
\ 'bdf:sp': 'border-fit:space;',
\ 'bdl': 'border-left:|;',
\ 'bdl:a': 'border-length:auto;',
\ 'bdsp': 'border-spacing:|;',
\ 'bds': 'border-style:|;',
\ 'bds:n': 'border-style:none;',
\ 'bds:h': 'border-style:hidden;',
\ 'bds:dt': 'border-style:dotted;',
\ 'bds:ds': 'border-style:dashed;',
\ 'bds:s': 'border-style:solid;',
\ 'bds:db': 'border-style:double;',
\ 'bds:dtds': 'border-style:dot-dash;',
\ 'bds:dtdtds': 'border-style:dot-dot-dash;',
\ 'bds:w': 'border-style:wave;',
\ 'bds:g': 'border-style:groove;',
\ 'bds:r': 'border-style:ridge;',
\ 'bds:i': 'border-style:inset;',
\ 'bds:o': 'border-style:outset;',
\ 'bdw': 'border-width:|;',
\ 'bdt': 'border-top:|;',
\ 'bdt+': 'border-top:1px solid #000;',
\ 'bdt:n': 'border-top:none;',
\ 'bdtw': 'border-top-width:|;',
\ 'bdts': 'border-top-style:|;',
\ 'bdts:n': 'border-top-style:none;',
\ 'bdtc': 'border-top-color:#000;',
\ 'bdr': 'border-right:|;',
\ 'bdr+': 'border-right:1px solid #000;',
\ 'bdr:n': 'border-right:none;',
\ 'bdrw': 'border-right-width:|;',
\ 'bdrt': 'border-right-style:|;',
\ 'bdrs:n': 'border-right-style:none;',
\ 'bdrc': 'border-right-color:#000;',
\ 'bdb': 'border-bottom:|;',
\ 'bdb+': 'border-bottom:1px solid #000;',
\ 'bdb:n': 'border-bottom:none;',
\ 'bdbw': 'border-bottom-width:|;',
\ 'bdbs': 'border-bottom-style:|;',
\ 'bdbs:n': 'border-bottom-style:none;',
\ 'bdbc': 'border-bottom-color:#000;',
\ 'bdln': 'border-length:|;',
\ 'bdl+': 'border-left:1px solid #000;',
\ 'bdl:n': 'border-left:none;',
\ 'bdlw': 'border-left-width:|;',
\ 'bdls': 'border-left-style:|;',
\ 'bdls:n': 'border-left-style:none;',
\ 'bdlc': 'border-left-color:#000;',
\ 'bdrs': 'border-radius:|;',
\ 'bdtrrz': 'border-top-right-radius:|;',
\ 'bdtlrz': 'border-top-left-radius:|;',
\ 'bdbrrz': 'border-bottom-right-radius:|;',
\ 'bdblrz': 'border-bottom-left-radius:|;',
\ 'bdrz:w': '-webkit-border-radius:|;',
\ 'bdrz:m': '-moz-border-radius:|;',
\ 'bg': 'background:|;',
\ 'bg+': 'background:#FFF url(|) 0 0 no-repeat;',
\ 'bg:n': 'background:none;',
\ 'bg:ie': 'filter:progid:DXImageTransform.Microsoft.AlphaImageLoader(src=''|x.png'');',
\ 'bgc': 'background-color:#FFF;',
\ 'bgi': 'background-image:url(|);',
\ 'bgi:n': 'background-image:none;',
\ 'bgr': 'background-repeat:|;',
\ 'bgr:n': 'background-repeat:no-repeat;',
\ 'bgr:x': 'background-repeat:repeat-x;',
\ 'bgr:y': 'background-repeat:repeat-y;',
\ 'bga': 'background-attachment:|;',
\ 'bga:f': 'background-attachment:fixed;',
\ 'bga:s': 'background-attachment:scroll;',
\ 'bgp': 'background-position:0 0;',
\ 'bgpx': 'background-position-x:|;',
\ 'bgpy': 'background-position-y:|;',
\ 'bgbk': 'background-break:|;',
\ 'bgbk:bb': 'background-break:bounding-box;',
\ 'bgbk:eb': 'background-break:each-box;',
\ 'bgbk:c': 'background-break:continuous;',
\ 'bgcp': 'background-clip:|;',
\ 'bgcp:bb': 'background-clip:border-box;',
\ 'bgcp:pb': 'background-clip:padding-box;',
\ 'bgcp:cb': 'background-clip:content-box;',
\ 'bgcp:nc': 'background-clip:no-clip;',
\ 'bgo': 'background-origin:|;',
\ 'bgo:pb': 'background-origin:padding-box;',
\ 'bgo:bb': 'background-origin:border-box;',
\ 'bgo:cb': 'background-origin:content-box;',
\ 'bgz': 'background-size:|;',
\ 'bgz:a': 'background-size:auto;',
\ 'bgz:ct': 'background-size:contain;',
\ 'bgz:cv': 'background-size:cover;',
\ 'c': 'color:#000;',
\ 'tbl': 'table-layout:|;',
\ 'tbl:a': 'table-layout:auto;',
\ 'tbl:f': 'table-layout:fixed;',
\ 'cps': 'caption-side:|;',
\ 'cps:t': 'caption-side:top;',
\ 'cps:b': 'caption-side:bottom;',
\ 'ec': 'empty-cells:|;',
\ 'ec:s': 'empty-cells:show;',
\ 'ec:h': 'empty-cells:hide;',
\ 'lis': 'list-style:|;',
\ 'lis:n': 'list-style:none;',
\ 'lisp': 'list-style-position:|;',
\ 'lisp:i': 'list-style-position:inside;',
\ 'lisp:o': 'list-style-position:outside;',
\ 'list': 'list-style-type:|;',
\ 'list:n': 'list-style-type:none;',
\ 'list:d': 'list-style-type:disc;',
\ 'list:c': 'list-style-type:circle;',
\ 'list:s': 'list-style-type:square;',
\ 'list:dc': 'list-style-type:decimal;',
\ 'list:dclz': 'list-style-type:decimal-leading-zero;',
\ 'list:lr': 'list-style-type:lower-roman;',
\ 'list:ur': 'list-style-type:upper-roman;',
\ 'lisi': 'list-style-image:|;',
\ 'lisi:n': 'list-style-image:none;',
\ 'q': 'quotes:|;',
\ 'q:n': 'quotes:none;',
\ 'q:ru': 'quotes:''\00AB'' ''\00BB'' ''\201E'' ''\201C'';',
\ 'q:en': 'quotes:''\201C'' ''\201D'' ''\2018'' ''\2019'';',
\ 'ct': 'content:|;',
\ 'ct:n': 'content:normal;',
\ 'ct:oq': 'content:open-quote;',
\ 'ct:noq': 'content:no-open-quote;',
\ 'ct:cq': 'content:close-quote;',
\ 'ct:ncq': 'content:no-close-quote;',
\ 'ct:a': 'content:attr(|);',
\ 'ct:c': 'content:counter(|);',
\ 'ct:cs': 'content:counters(|);',
\ 'coi': 'counter-increment:|;',
\ 'cor': 'counter-reset:|;',
\ 'va': 'vertical-align:|;',
\ 'va:sup': 'vertical-align:super;',
\ 'va:t': 'vertical-align:top;',
\ 'va:tt': 'vertical-align:text-top;',
\ 'va:m': 'vertical-align:middle;',
\ 'va:bl': 'vertical-align:baseline;',
\ 'va:b': 'vertical-align:bottom;',
\ 'va:tb': 'vertical-align:text-bottom;',
\ 'va:sub': 'vertical-align:sub;',
\ 'ta': 'text-align:|;',
\ 'ta:l': 'text-align:left;',
\ 'ta:c': 'text-align:center;',
\ 'ta:r': 'text-align:right;',
\ 'tal': 'text-align-last:|;',
\ 'tal:a': 'text-align-last:auto;',
\ 'tal:l': 'text-align-last:left;',
\ 'tal:c': 'text-align-last:center;',
\ 'tal:r': 'text-align-last:right;',
\ 'td': 'text-decoration:|;',
\ 'td:n': 'text-decoration:none;',
\ 'td:u': 'text-decoration:underline;',
\ 'td:o': 'text-decoration:overline;',
\ 'td:l': 'text-decoration:line-through;',
\ 'te': 'text-emphasis:|;',
\ 'te:n': 'text-emphasis:none;',
\ 'te:ac': 'text-emphasis:accent;',
\ 'te:dt': 'text-emphasis:dot;',
\ 'te:c': 'text-emphasis:circle;',
\ 'te:ds': 'text-emphasis:disc;',
\ 'te:b': 'text-emphasis:before;',
\ 'te:a': 'text-emphasis:after;',
\ 'th': 'text-height:|;',
\ 'th:a': 'text-height:auto;',
\ 'th:f': 'text-height:font-size;',
\ 'th:t': 'text-height:text-size;',
\ 'th:m': 'text-height:max-size;',
\ 'ti': 'text-indent:|;',
\ 'ti:-': 'text-indent:-9999px;',
\ 'tj': 'text-justify:|;',
\ 'tj:a': 'text-justify:auto;',
\ 'tj:iw': 'text-justify:inter-word;',
\ 'tj:ii': 'text-justify:inter-ideograph;',
\ 'tj:ic': 'text-justify:inter-cluster;',
\ 'tj:d': 'text-justify:distribute;',
\ 'tj:k': 'text-justify:kashida;',
\ 'tj:t': 'text-justify:tibetan;',
\ 'to': 'text-outline:|;',
\ 'to+': 'text-outline:0 0 #000;',
\ 'to:n': 'text-outline:none;',
\ 'tr': 'text-replace:|;',
\ 'tr:n': 'text-replace:none;',
\ 'tt': 'text-transform:|;',
\ 'tt:n': 'text-transform:none;',
\ 'tt:c': 'text-transform:capitalize;',
\ 'tt:u': 'text-transform:uppercase;',
\ 'tt:l': 'text-transform:lowercase;',
\ 'tw': 'text-wrap:|;',
\ 'tw:n': 'text-wrap:normal;',
\ 'tw:no': 'text-wrap:none;',
\ 'tw:u': 'text-wrap:unrestricted;',
\ 'tw:s': 'text-wrap:suppress;',
\ 'tsh': 'text-shadow:|;',
\ 'tsh+': 'text-shadow:0 0 0 #000;',
\ 'tsh:n': 'text-shadow:none;',
\ 'lh': 'line-height:|;',
\ 'whs': 'white-space:|;',
\ 'whs:n': 'white-space:normal;',
\ 'whs:p': 'white-space:pre;',
\ 'whs:nw': 'white-space:nowrap;',
\ 'whs:pw': 'white-space:pre-wrap;',
\ 'whs:pl': 'white-space:pre-line;',
\ 'whsc': 'white-space-collapse:|;',
\ 'whsc:n': 'white-space-collapse:normal;',
\ 'whsc:k': 'white-space-collapse:keep-all;',
\ 'whsc:l': 'white-space-collapse:loose;',
\ 'whsc:bs': 'white-space-collapse:break-strict;',
\ 'whsc:ba': 'white-space-collapse:break-all;',
\ 'wob': 'word-break:|;',
\ 'wob:n': 'word-break:normal;',
\ 'wob:k': 'word-break:keep-all;',
\ 'wob:l': 'word-break:loose;',
\ 'wob:bs': 'word-break:break-strict;',
\ 'wob:ba': 'word-break:break-all;',
\ 'wos': 'word-spacing:|;',
\ 'wow': 'word-wrap:|;',
\ 'wow:nm': 'word-wrap:normal;',
\ 'wow:n': 'word-wrap:none;',
\ 'wow:u': 'word-wrap:unrestricted;',
\ 'wow:s': 'word-wrap:suppress;',
\ 'lts': 'letter-spacing:|;',
\ 'f': 'font:|;',
\ 'f+': 'font:1em Arial,sans-serif;',
\ 'fw': 'font-weight:|;',
\ 'fw:n': 'font-weight:normal;',
\ 'fw:b': 'font-weight:bold;',
\ 'fw:br': 'font-weight:bolder;',
\ 'fw:lr': 'font-weight:lighter;',
\ 'fs': 'font-style:|;',
\ 'fs:n': 'font-style:normal;',
\ 'fs:i': 'font-style:italic;',
\ 'fs:o': 'font-style:oblique;',
\ 'fv': 'font-variant:|;',
\ 'fv:n': 'font-variant:normal;',
\ 'fv:sc': 'font-variant:small-caps;',
\ 'fz': 'font-size:|;',
\ 'fza': 'font-size-adjust:|;',
\ 'fza:n': 'font-size-adjust:none;',
\ 'ff': 'font-family:|;',
\ 'ff:s': 'font-family:serif;',
\ 'ff:ss': 'font-family:sans-serif;',
\ 'ff:c': 'font-family:cursive;',
\ 'ff:f': 'font-family:fantasy;',
\ 'ff:m': 'font-family:monospace;',
\ 'fef': 'font-effect:|;',
\ 'fef:n': 'font-effect:none;',
\ 'fef:eg': 'font-effect:engrave;',
\ 'fef:eb': 'font-effect:emboss;',
\ 'fef:o': 'font-effect:outline;',
\ 'fem': 'font-emphasize:|;',
\ 'femp': 'font-emphasize-position:|;',
\ 'femp:b': 'font-emphasize-position:before;',
\ 'femp:a': 'font-emphasize-position:after;',
\ 'fems': 'font-emphasize-style:|;',
\ 'fems:n': 'font-emphasize-style:none;',
\ 'fems:ac': 'font-emphasize-style:accent;',
\ 'fems:dt': 'font-emphasize-style:dot;',
\ 'fems:c': 'font-emphasize-style:circle;',
\ 'fems:ds': 'font-emphasize-style:disc;',
\ 'fsm': 'font-smooth:|;',
\ 'fsm:a': 'font-smooth:auto;',
\ 'fsm:n': 'font-smooth:never;',
\ 'fsm:aw': 'font-smooth:always;',
\ 'fst': 'font-stretch:|;',
\ 'fst:n': 'font-stretch:normal;',
\ 'fst:uc': 'font-stretch:ultra-condensed;',
\ 'fst:ec': 'font-stretch:extra-condensed;',
\ 'fst:c': 'font-stretch:condensed;',
\ 'fst:sc': 'font-stretch:semi-condensed;',
\ 'fst:se': 'font-stretch:semi-expanded;',
\ 'fst:e': 'font-stretch:expanded;',
\ 'fst:ee': 'font-stretch:extra-expanded;',
\ 'fst:ue': 'font-stretch:ultra-expanded;',
\ 'op': 'opacity:|;',
\ 'op:ie': 'filter:progid:DXImageTransform.Microsoft.Alpha(Opacity=100);',
\ 'op:ms': '-ms-filter:''progid:DXImageTransform.Microsoft.Alpha(Opacity=100)'';',
\ 'rz': 'resize:|;',
\ 'rz:n': 'resize:none;',
\ 'rz:b': 'resize:both;',
\ 'rz:h': 'resize:horizontal;',
\ 'rz:v': 'resize:vertical;',
\ 'cur': 'cursor:|;',
\ 'cur:a': 'cursor:auto;',
\ 'cur:d': 'cursor:default;',
\ 'cur:c': 'cursor:crosshair;',
\ 'cur:ha': 'cursor:hand;',
\ 'cur:he': 'cursor:help;',
\ 'cur:m': 'cursor:move;',
\ 'cur:p': 'cursor:pointer;',
\ 'cur:t': 'cursor:text;',
\ 'pgbb': 'page-break-before:|;',
\ 'pgbb:au': 'page-break-before:auto;',
\ 'pgbb:al': 'page-break-before:always;',
\ 'pgbb:l': 'page-break-before:left;',
\ 'pgbb:r': 'page-break-before:right;',
\ 'pgbi': 'page-break-inside:|;',
\ 'pgbi:au': 'page-break-inside:auto;',
\ 'pgbi:av': 'page-break-inside:avoid;',
\ 'pgba': 'page-break-after:|;',
\ 'pgba:au': 'page-break-after:auto;',
\ 'pgba:al': 'page-break-after:always;',
\ 'pgba:l': 'page-break-after:left;',
\ 'pgba:r': 'page-break-after:right;',
\ 'orp': 'orphans:|;',
\ 'wid': 'widows:|;'
\ },
\ 'filters': 'fc'
\ },
\ 'sass': {
\ 'extends': 'css',
\ 'snippets': {
\ '@if': "@if {\n\t|\n}",
\ '@e': "@else {\n\t|\n}",
\ '@in': "@include |",
\ '@ex': "@extend |",
\ '@mx': "@mixin {\n\t|\n}",
\ '@fn': "@function {\n\t|\n}",
\ '@r': "@return |",
\ },
\ },
\ 'scss': {
\ 'extends': 'css',
\ },
\ 'less': {
\ 'extends': 'css',
\ },
\ 'css.drupal': {
\ 'extends': 'css',
\ },
\ 'html': {
\ 'snippets': {
\ 'cc:ie6': "<!--[if lte IE 6]>\n\t${child}|\n<![endif]-->",
\ 'cc:ie': "<!--[if IE]>\n\t${child}|\n<![endif]-->",
\ 'cc:noie': "<!--[if !IE]><!-->\n\t${child}|\n<!--<![endif]-->",
\ 'html:4t': "<!DOCTYPE HTML PUBLIC \"-//W3C//DTD HTML 4.01 Transitional//EN\" \"http://www.w3.org/TR/html4/loose.dtd\">\n"
\ ."<html lang=\"${lang}\">\n"
\ ."<head>\n"
\ ."\t<meta http-equiv=\"Content-Type\" content=\"text/html;charset=${charset}\">\n"
\ ."\t<title></title>\n"
\ ."</head>\n"
\ ."<body>\n\t${child}|\n</body>\n"
\ ."</html>",
\ 'html:4s': "<!DOCTYPE HTML PUBLIC \"-//W3C//DTD HTML 4.01//EN\" \"http://www.w3.org/TR/html4/strict.dtd\">\n"
\ ."<html lang=\"${lang}\">\n"
\ ."<head>\n"
\ ."\t<meta http-equiv=\"Content-Type\" content=\"text/html;charset=${charset}\">\n"
\ ."\t<title></title>\n"
\ ."</head>\n"
\ ."<body>\n\t${child}|\n</body>\n"
\ ."</html>",
\ 'html:xt': "<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n"
\ ."<html xmlns=\"http://www.w3.org/1999/xhtml\" xml:lang=\"${lang}\">\n"
\ ."<head>\n"
\ ."\t<meta http-equiv=\"Content-Type\" content=\"text/html;charset=${charset}\" />\n"
\ ."\t<title></title>\n"
\ ."</head>\n"
\ ."<body>\n\t${child}|\n</body>\n"
\ ."</html>",
\ 'html:xs': "<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Strict//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd\">\n"
\ ."<html xmlns=\"http://www.w3.org/1999/xhtml\" xml:lang=\"${lang}\">\n"
\ ."<head>\n"
\ ."\t<meta http-equiv=\"Content-Type\" content=\"text/html;charset=${charset}\" />\n"
\ ."\t<title></title>\n"
\ ."</head>\n"
\ ."<body>\n\t${child}|\n</body>\n"
\ ."</html>",
\ 'html:xxs': "<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.1//EN\" \"http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd\">\n"
\ ."<html xmlns=\"http://www.w3.org/1999/xhtml\" xml:lang=\"${lang}\">\n"
\ ."<head>\n"
\ ."\t<meta http-equiv=\"Content-Type\" content=\"text/html;charset=${charset}\" />\n"
\ ."\t<title></title>\n"
\ ."</head>\n"
\ ."<body>\n\t${child}|\n</body>\n"
\ ."</html>",
\ 'html:5': "<!DOCTYPE html>\n"
\ ."<html lang=\"${lang}\">\n"
\ ."<head>\n"
\ ."\t<meta charset=\"${charset}\">\n"
\ ."\t<title></title>\n"
\ ."</head>\n"
\ ."<body>\n\t${child}|\n</body>\n"
\ ."</html>"
\ },
\ 'default_attributes': {
\ 'a': {'href': ''},
\ 'a:link': {'href': 'http://|'},
\ 'a:mail': {'href': 'mailto:|'},
\ 'abbr': {'title': ''},
\ 'acronym': {'title': ''},
\ 'base': {'href': ''},
\ 'bdo': {'dir': ''},
\ 'bdo:r': {'dir': 'rtl'},
\ 'bdo:l': {'dir': 'ltr'},
\ 'del': {'datetime': '${datetime}'},
\ 'ins': {'datetime': '${datetime}'},
\ 'link:css': [{'rel': 'stylesheet'}, {'type': 'text/css'}, {'href': '|style.css'}, {'media': 'all'}],
\ 'link:print': [{'rel': 'stylesheet'}, {'type': 'text/css'}, {'href': '|print.css'}, {'media': 'print'}],
\ 'link:favicon': [{'rel': 'shortcut icon'}, {'type': 'image/x-icon'}, {'href': '|favicon.ico'}],
\ 'link:touch': [{'rel': 'apple-touch-icon'}, {'href': '|favicon.png'}],
\ 'link:rss': [{'rel': 'alternate'}, {'type': 'application/rss+xml'}, {'title': 'RSS'}, {'href': '|rss.xml'}],
\ 'link:atom': [{'rel': 'alternate'}, {'type': 'application/atom+xml'}, {'title': 'Atom'}, {'href': 'atom.xml'}],
\ 'meta:utf': [{'http-equiv': 'Content-Type'}, {'content': 'text/html;charset=UTF-8'}],
\ 'meta:win': [{'http-equiv': 'Content-Type'}, {'content': 'text/html;charset=Win-1251'}],
\ 'meta:compat': [{'http-equiv': 'X-UA-Compatible'}, {'content': 'IE=7'}],
\ 'style': {'type': 'text/css'},
\ 'script': {'type': 'text/javascript'},
\ 'script:src': [{'type': 'text/javascript'}, {'src': ''}],
\ 'img': [{'src': ''}, {'alt': ''}],
\ 'iframe': [{'src': ''}, {'frameborder': '0'}],
\ 'embed': [{'src': ''}, {'type': ''}],
\ 'object': [{'data': ''}, {'type': ''}],
\ 'param': [{'name': ''}, {'value': ''}],
\ 'map': {'name': ''},
\ 'area': [{'shape': ''}, {'coords': ''}, {'href': ''}, {'alt': ''}],
\ 'area:d': [{'shape': 'default'}, {'href': ''}, {'alt': ''}],
\ 'area:c': [{'shape': 'circle'}, {'coords': ''}, {'href': ''}, {'alt': ''}],
\ 'area:r': [{'shape': 'rect'}, {'coords': ''}, {'href': ''}, {'alt': ''}],
\ 'area:p': [{'shape': 'poly'}, {'coords': ''}, {'href': ''}, {'alt': ''}],
\ 'link': [{'rel': 'stylesheet'}, {'href': ''}],
\ 'form': {'action': ''},
\ 'form:get': {'action': '', 'method': 'get'},
\ 'form:post': {'action': '', 'method': 'post'},
\ 'form:upload': {'action': '', 'method': 'post', 'enctype': 'multipart/form-data'},
\ 'label': {'for': ''},
\ 'input': {'type': ''},
\ 'input:hidden': [{'type': 'hidden'}, {'name': ''}],
\ 'input:h': [{'type': 'hidden'}, {'name': ''}],
\ 'input:text': [{'type': 'text'}, {'name': ''}, {'id': ''}],
\ 'input:t': [{'type': 'text'}, {'name': ''}, {'id': ''}],
\ 'input:search': [{'type': 'search'}, {'name': ''}, {'id': ''}],
\ 'input:email': [{'type': 'email'}, {'name': ''}, {'id': ''}],
\ 'input:url': [{'type': 'url'}, {'name': ''}, {'id': ''}],
\ 'input:password': [{'type': 'password'}, {'name': ''}, {'id': ''}],
\ 'input:p': [{'type': 'password'}, {'name': ''}, {'id': ''}],
\ 'input:datetime': [{'type': 'datetime'}, {'name': ''}, {'id': ''}],
\ 'input:date': [{'type': 'date'}, {'name': ''}, {'id': ''}],
\ 'input:datetime-local': [{'type': 'datetime-local'}, {'name': ''}, {'id': ''}],
\ 'input:month': [{'type': 'month'}, {'name': ''}, {'id': ''}],
\ 'input:week': [{'type': 'week'}, {'name': ''}, {'id': ''}],
\ 'input:time': [{'type': 'time'}, {'name': ''}, {'id': ''}],
\ 'input:number': [{'type': 'number'}, {'name': ''}, {'id': ''}],
\ 'input:color': [{'type': 'color'}, {'name': ''}, {'id': ''}],
\ 'input:checkbox': [{'type': 'checkbox'}, {'name': ''}, {'id': ''}],
\ 'input:c': [{'type': 'checkbox'}, {'name': ''}, {'id': ''}],
\ 'input:radio': [{'type': 'radio'}, {'name': ''}, {'id': ''}],
\ 'input:r': [{'type': 'radio'}, {'name': ''}, {'id': ''}],
\ 'input:range': [{'type': 'range'}, {'name': ''}, {'id': ''}],
\ 'input:file': [{'type': 'file'}, {'name': ''}, {'id': ''}],
\ 'input:f': [{'type': 'file'}, {'name': ''}, {'id': ''}],
\ 'input:submit': [{'type': 'submit'}, {'value': ''}],
\ 'input:s': [{'type': 'submit'}, {'value': ''}],
\ 'input:image': [{'type': 'image'}, {'src': ''}, {'alt': ''}],
\ 'input:i': [{'type': 'image'}, {'src': ''}, {'alt': ''}],
\ 'input:reset': [{'type': 'reset'}, {'value': ''}],
\ 'input:button': [{'type': 'button'}, {'value': ''}],
\ 'input:b': [{'type': 'button'}, {'value': ''}],
\ 'select': [{'name': ''}, {'id': ''}],
\ 'option': {'value': ''},
\ 'textarea': [{'name': ''}, {'id': ''}, {'cols': '30'}, {'rows': '10'}],
\ 'menu:context': {'type': 'context'},
\ 'menu:c': {'type': 'context'},
\ 'menu:toolbar': {'type': 'toolbar'},
\ 'menu:t': {'type': 'toolbar'},
\ 'video': {'src': ''},
\ 'audio': {'src': ''},
\ 'html:xml': [{'xmlns': 'http://www.w3.org/1999/xhtml'}, {'xml:lang': '${lang}'}]
\ },
\ 'aliases': {
\ 'link:*': 'link',
\ 'meta:*': 'meta',
\ 'area:*': 'area',
\ 'bdo:*': 'bdo',
\ 'form:*': 'form',
\ 'input:*': 'input',
\ 'script:*': 'script',
\ 'html:*': 'html',
\ 'a:*': 'a',
\ 'menu:*': 'menu',
\ 'bq': 'blockquote',
\ 'acr': 'acronym',
\ 'fig': 'figure',
\ 'ifr': 'iframe',
\ 'emb': 'embed',
\ 'obj': 'object',
\ 'src': 'source',
\ 'cap': 'caption',
\ 'colg': 'colgroup',
\ 'fst': 'fieldset',
\ 'btn': 'button',
\ 'optg': 'optgroup',
\ 'opt': 'option',
\ 'tarea': 'textarea',
\ 'leg': 'legend',
\ 'sect': 'section',
\ 'art': 'article',
\ 'hdr': 'header',
\ 'ftr': 'footer',
\ 'adr': 'address',
\ 'dlg': 'dialog',
\ 'str': 'strong',
\ 'sty': 'style',
\ 'prog': 'progress',
\ 'fset': 'fieldset',
\ 'datag': 'datagrid',
\ 'datal': 'datalist',
\ 'kg': 'keygen',
\ 'out': 'output',
\ 'det': 'details',
\ 'cmd': 'command'
\ },
\ 'expandos': {
\ 'ol': 'ol>li',
\ 'ul': 'ul>li',
\ 'dl': 'dl>dt+dd',
\ 'map': 'map>area',
\ 'table': 'table>tr>td',
\ 'colgroup': 'colgroup>col',
\ 'colg': 'colgroup>col',
\ 'tr': 'tr>td',
\ 'select': 'select>option',
\ 'optgroup': 'optgroup>option',
\ 'optg': 'optgroup>option'
\ },
\ 'empty_elements': 'area,base,basefont,br,col,frame,hr,img,input,isindex,link,meta,param,embed,keygen,command',
\ 'block_elements': 'address,applet,blockquote,button,center,dd,del,dir,div,dl,dt,fieldset,form,frameset,hr,iframe,ins,isindex,li,link,map,menu,noframes,noscript,object,ol,p,pre,script,table,tbody,td,tfoot,th,thead,tr,ul,h1,h2,h3,h4,h5,h6',
\ 'inline_elements': 'a,abbr,acronym,applet,b,basefont,bdo,big,br,button,cite,code,del,dfn,em,font,i,iframe,img,input,ins,kbd,label,map,object,q,s,samp,script,select,small,span,strike,strong,sub,sup,textarea,tt,u,var',
\ 'empty_element_suffix': ' />'
\ },
\ 'htmldjango': {
\ 'extends': 'html',
\ },
\ 'html.django_template': {
\ 'extends': 'html',
\ },
\ 'xsl': {
\ 'extends': 'html',
\ 'default_attributes': {
\ 'tmatch': [{'match': ''}, {'mode': ''}],
\ 'tname': [{'name': ''}],
\ 'xsl:when': {'test': ''},
\ 'var': [{'name': ''}, {'select': ''}],
\ 'vari': {'name': ''},
\ 'if': {'test': ''},
\ 'call': {'name': ''},
\ 'attr': {'name': ''},
\ 'wp': [{'name': ''}, {'select': ''}],
\ 'par': [{'name': ''}, {'select': ''}],
\ 'val': {'select': ''},
\ 'co': {'select': ''},
\ 'each': {'select': ''},
\ 'ap': [{'select': ''}, {'mode': ''}]
\ },
\ 'aliases': {
\ 'tmatch': 'xsl:template',
\ 'tname': 'xsl:template',
\ 'var': 'xsl:variable',
\ 'vari': 'xsl:variable',
\ 'if': 'xsl:if',
\ 'choose': 'xsl:choose',
\ 'call': 'xsl:call-template',
\ 'wp': 'xsl:with-param',
\ 'par': 'xsl:param',
\ 'val': 'xsl:value-of',
\ 'attr': 'xsl:attribute',
\ 'co' : 'xsl:copy-of',
\ 'each' : 'xsl:for-each',
\ 'ap' : 'xsl:apply-templates'
\ },
\ 'expandos': {
\ 'choose': 'xsl:choose>xsl:when+xsl:otherwise'
\ }
\ },
\ 'xslt': {
\ 'extends': 'xsl',
\ },
\ 'haml': {
\ 'indentation': ' ',
\ 'extends': 'html',
\ 'snippets': {
\ 'html:5': "!!! 5\n"
\ ."%html{:lang => \"${lang}\"}\n"
\ ."\t%head\n"
\ ."\t\t%meta{:charset => \"${charset}\"}\n"
\ ."\t\t%title\n"
\ ."\t%body\n"
\ ."\t\t${child}|\n"
\ },
\ },
\ 'slim': {
\ 'indentation': ' ',
\ 'extends': 'html',
\ 'snippets': {
\ 'html:5': "doctype 5\n"
\ ."html lang=\"${lang}\"\n"
\ ."\thead\n"
\ ."\t\tmeta charset=\"${charset}\"\n"
\ ."\t\ttitle\n"
\ ."\tbody\n"
\ ."\t\t${child}|\n"
\ },
\ },
\ 'xhtml': {
\ 'extends': 'html'
\ },
\ 'mustache': {
\ 'extends': 'html'
\ },
\ 'xsd': {
\ 'extends': 'html',
\ 'snippets': {
\ 'xsd:w3c': "<?xml version=\"1.0\"?>\n"
\ ."<xsd:schema xmlns:xsd=\"http://www.w3.org/2001/XMLSchema\">\n"
\ ."\t<xsd:element name=\"\" type=\"\"/>\n"
\ ."</xsd:schema>\n"
\ }
\ }
\}
if exists('g:user_zen_settings')
call s:mergeConfig(s:zen_settings, g:user_zen_settings)
endif
let &cpo = s:save_cpo
unlet s:save_cpo
" vim:set et: