diff options
| author | Adam Stankiewicz <sheerun@sher.pl> | 2017-09-27 20:43:42 +0200 | 
|---|---|---|
| committer | Adam Stankiewicz <sheerun@sher.pl> | 2017-09-27 20:43:42 +0200 | 
| commit | 5b77877888162f4e415fe9a7b8c5e9fb5dfb6ee1 (patch) | |
| tree | 965ae5128797f3d42d78d02692e62d24a4596e19 /ftplugin/debcontrol.vim | |
| parent | 8148255ef1c416f414c3a78405eff08fe149d16e (diff) | |
| download | vim-polyglot-5b77877888162f4e415fe9a7b8c5e9fb5dfb6ee1.tar.gz vim-polyglot-5b77877888162f4e415fe9a7b8c5e9fb5dfb6ee1.zip | |
Add syntax files from upstream vim repository
Diffstat (limited to '')
| -rw-r--r-- | ftplugin/debcontrol.vim | 74 | 
1 files changed, 74 insertions, 0 deletions
| diff --git a/ftplugin/debcontrol.vim b/ftplugin/debcontrol.vim new file mode 100644 index 00000000..8b55189b --- /dev/null +++ b/ftplugin/debcontrol.vim @@ -0,0 +1,74 @@ +if !exists('g:polyglot_disabled') || index(g:polyglot_disabled, 'vim') == -1 +   +" Vim filetype plugin file (GUI menu and folding) +" Language:     Debian control files +" Maintainer:   Debian Vim Maintainers <pkg-vim-maintainers@lists.alioth.debian.org> +" Former Maintainer:    Pierre Habouzit <madcoder@debian.org> +" Last Change:  2008-03-08 +" URL:          http://hg.debian.org/hg/pkg-vim/vim/raw-file/tip/runtime/ftplugin/debcontrol.vim + +" Do these settings once per buffer +if exists("b:did_ftplugin") +  finish +endif +let b:did_ftplugin=1 + +" {{{1 Local settings (do on every load) +if exists("g:debcontrol_fold_enable") +  setlocal foldmethod=expr +  setlocal foldexpr=DebControlFold(v:lnum) +  setlocal foldtext=DebControlFoldText() +endif +setlocal textwidth=0 + +" Clean unloading +let b:undo_ftplugin = "setlocal tw< foldmethod< foldexpr< foldtext<" + +" }}}1 + +" {{{1 folding + +function! s:getField(f, lnum) +  let line = getline(a:lnum) +  let fwdsteps = 0 +  while line !~ '^'.a:f.':' +    let fwdsteps += 1 +    let line = getline(a:lnum + fwdsteps) +    if line == '' +      return 'unknown' +    endif +  endwhile +  return substitute(line, '^'.a:f.': *', '', '') +endfunction + +function! DebControlFoldText() +  if v:folddashes == '-'  " debcontrol entry fold +    let type = substitute(getline(v:foldstart), ':.*', '', '') +    if type == 'Source' +      let ftext = substitute(foldtext(), ' *Source: *', ' ', '') +      return ftext . ' -- ' . s:getField('Maintainer', v:foldstart) . ' ' +    endif +    let arch  = s:getField('Architecture', v:foldstart) +    let ftext = substitute(foldtext(), ' *Package: *', ' [' . arch . '] ', '') +    return ftext . ': ' . s:getField('Description', v:foldstart) . ' ' +  endif +  return foldtext() +endfunction + +function! DebControlFold(l) + +  " This is for not merging blank lines around folds to them +  if getline(a:l) =~ '^Source:' +    return '>1' +  endif + +  if getline(a:l) =~ '^Package:' +    return '>1' +  endif + +  return '=' +endfunction + +" }}}1 + +endif | 
