diff options
| -rwxr-xr-x | build.sh | 2 | ||||
| -rw-r--r-- | ftdetect/puppet.vim | 3 | ||||
| -rw-r--r-- | ftplugin/puppet.vim | 137 | ||||
| -rw-r--r-- | indent/puppet.vim | 76 | ||||
| -rw-r--r-- | syntax/puppet.vim | 94 | 
5 files changed, 277 insertions, 35 deletions
| @@ -61,7 +61,7 @@ syntax 'briancollins/vim-jst' &  syntax 'derekwyatt/vim-scala' &  syntax 'derekwyatt/vim-sbt' &  syntax 'travitch/hasksyn' & -syntax 'vim-scripts/Puppet-Syntax-Highlighting' & +syntax 'ajf/puppet-vim' &  syntax 'beyondwords/vim-twig' &  syntax 'sudar/vim-arduino-syntax' &  syntax 'guns/vim-clojure-static' & diff --git a/ftdetect/puppet.vim b/ftdetect/puppet.vim index 8237f87f..c9d15ea5 100644 --- a/ftdetect/puppet.vim +++ b/ftdetect/puppet.vim @@ -1 +1,2 @@ -au BufRead,BufNewFile *.pp setfiletype puppet +" detect puppet filetype +au BufRead,BufNewFile *.pp              set filetype=puppet diff --git a/ftplugin/puppet.vim b/ftplugin/puppet.vim new file mode 100644 index 00000000..1b008682 --- /dev/null +++ b/ftplugin/puppet.vim @@ -0,0 +1,137 @@ +" Vim filetype plugin +" Language:     Puppet +" Maintainer:   Todd Zullinger <tmz@pobox.com> +" Last Change:  2009 Aug 19 +" vim: set sw=4 sts=4: + +if exists("b:did_ftplugin") +    finish +endif +let b:did_ftplugin = 1 + +if !exists("no_plugin_maps") && !exists("no_puppet_maps") +    if !hasmapto("<Plug>AlignRange") +        map <buffer> <LocalLeader>= <Plug>AlignRange +    endif +endif + +noremap <buffer> <unique> <script> <Plug>AlignArrows :call <SID>AlignArrows()<CR> +noremap <buffer> <unique> <script> <Plug>AlignRange :call <SID>AlignRange()<CR> + +iabbrev => =><C-R>=<SID>AlignArrows('=>')<CR> +iabbrev +> +><C-R>=<SID>AlignArrows('+>')<CR> + +if exists('*s:AlignArrows') +    finish +endif + +let s:arrow_re = '[=+]>' +let s:selector_re = '[=+]>\s*\$.*\s*?\s*{\s*$' + +" set keywordprg to 'pi' (alias for puppet describe) +" this lets K invoke pi for word under cursor +setlocal keywordprg=puppet\ describe + +function! s:AlignArrows(op) +    let cursor_pos = getpos('.') +    let lnum = line('.') +    let line = getline(lnum) +    if line !~ s:arrow_re +        return +    endif +    let pos = stridx(line, a:op) +    let start = lnum +    let end = lnum +    let pnum = lnum - 1 +    while 1 +        let pline = getline(pnum) +        if pline !~ s:arrow_re || pline =~ s:selector_re +            break +        endif +        let start = pnum +        let pnum -= 1 +    endwhile +    let cnum = end +    while 1 +        let cline = getline(cnum) +        if cline !~ s:arrow_re || +                \ (indent(cnum) != indent(cnum+1) && getline(cnum+1) !~ '\s*}') +            break +        endif +        let end = cnum +        let cnum += 1 +    endwhile +    call s:AlignSection(start, end) +    let cursor_pos[2] = stridx(getline('.'), a:op) + strlen(a:op) + 1 +    call setpos('.', cursor_pos) +    return '' +endfunction + +function! s:AlignRange() range +    call s:AlignSection(a:firstline, a:lastline) +endfunction + +" AlignSection and AlignLine are from the vim wiki: +" http://vim.wikia.com/wiki/Regex-based_text_alignment +function! s:AlignSection(start, end) +    let extra = 1 +    let sep = s:arrow_re +    let maxpos = 0 +    let section = getline(a:start, a:end) +    for line in section +        let pos = match(line, ' *'.sep) +        if maxpos < pos +            let maxpos = pos +        endif +    endfor +    call map(section, 's:AlignLine(v:val, sep, maxpos, extra)') +    call setline(a:start, section) +endfunction + +function! s:AlignLine(line, sep, maxpos, extra) +    let m = matchlist(a:line, '\(.\{-}\) \{-}\('.a:sep.'.*\)') +    if empty(m) +        return a:line +    endif +    let spaces = repeat(' ', a:maxpos - strlen(m[1]) + a:extra) +    return m[1] . spaces . m[2] +endfunction + +" detect if we are in a module and set variables for classpath (autoloader), +" modulename, modulepath, and classname +" useful to use in templates +function! s:SetModuleVars() + +  " set these to any dirs you want to stop searching on +  " useful to stop vim from spinning disk looking all over for init.pp +  " probably only a macosx problem with /tmp since it's really /private/tmp +  " but it's here if you find vim spinning on new files in certain places +  if !exists("g:puppet_stop_dirs") +    let g:puppet_stop_dirs = '/tmp;/private/tmp' +  endif + +  " search path for init.pp +  let b:search_path = './**' +  let b:search_path = b:search_path . ';' . getcwd() . ';' . g:puppet_stop_dirs +   +  " find what we assume to be our module dir +  let b:initpp = findfile("init.pp", b:search_path) " find an init.pp up or down +  let b:module_path = fnamemodify(b:initpp, ":p:h:h") " full path to module name +  let b:module_name = fnamemodify(b:module_path, ":t") " just the module name + +  " sub out the full path to the module with the name and replace slashes with :: +  let b:classpath = fnamemodify(expand("%:p:r"), ':s#' . b:module_path . '/manifests#' . b:module_name . '#'. ":gs?/?::?") +  let b:classname = expand("%:t:r") + +  " if we don't start with a word we didn't replace the module_path  +  " probably b/c we couldn't find an init.pp / not a module +  " so we assume that root of the filename is the class (sane for throwaway +  " manifests +  if b:classpath =~ '^::' +    let b:classpath = b:classname +  endif +endfunction + +if exists("g:puppet_module_detect") +  call s:SetModuleVars() +endif diff --git a/indent/puppet.vim b/indent/puppet.vim new file mode 100644 index 00000000..689e0687 --- /dev/null +++ b/indent/puppet.vim @@ -0,0 +1,76 @@ +" Vim indent file +" Language:	Puppet +" Maintainer:	Todd Zullinger <tmz@pobox.com> +" Last Change:	2009 Aug 19 +" vim: set sw=4 sts=4: + +if exists("b:did_indent") +    finish +endif +let b:did_indent = 1 + +setlocal autoindent smartindent +setlocal indentexpr=GetPuppetIndent() +setlocal indentkeys+=0],0) + +if exists("*GetPuppetIndent") +    finish +endif + +" Check if a line is part of an include 'block', e.g.: +"   include foo, +"       bar, +"       baz +function! s:PartOfInclude(lnum) +    let lnum = a:lnum +    while lnum +        let lnum = lnum - 1 +        let line = getline(lnum) +        if line !~ ',$' +            break +        endif +        if line =~ '^\s*include\s\+[^,]\+,$' +            return 1 +        endif +    endwhile +    return 0 +endfunction + +function! s:OpenBrace(lnum) +    call cursor(a:lnum, 1) +    return searchpair('{\|\[\|(', '', '}\|\]\|)', 'nbW') +endfunction + +function! GetPuppetIndent() +    let pnum = prevnonblank(v:lnum - 1) +    if pnum == 0 +       return 0 +    endif + +    let line = getline(v:lnum) +    let pline = getline(pnum) +    let ind = indent(pnum) + +    if pline =~ '^\s*#' +        return ind +    endif + +    if pline =~ '\({\|\[\|(\|:\)$' +        let ind += &sw +    elseif pline =~ ';$' && pline !~ '[^:]\+:.*[=+]>.*' +        let ind -= &sw +    elseif pline =~ '^\s*include\s\+.*,$' +        let ind += &sw +    endif + +    if pline !~ ',$' && s:PartOfInclude(pnum) +        let ind -= &sw +    endif + +    " Match } }, }; ] ]: ) +    if line =~ '^\s*\(}\(,\|;\)\?$\|]:\?$\|)\)' +        let ind = indent(s:OpenBrace(v:lnum)) +    endif + +    return ind +endfunction diff --git a/syntax/puppet.vim b/syntax/puppet.vim index 698fc803..8cdada18 100644 --- a/syntax/puppet.vim +++ b/syntax/puppet.vim @@ -2,9 +2,9 @@  " Filename:     puppet.vim  " Language:     puppet configuration file  " Maintainer:   Luke Kanies <luke@madstop.com> -" URL:          +" URL:  " Last Change: -" Version:      +" Version:  "  " Copied from the cfengine, ruby, and perl syntax files @@ -16,40 +16,66 @@ elseif exists("b:current_syntax")    finish  endif -syn region  puppetDefine        start="^\s*\(class\|define\|site\|node\)" end="{" contains=puppetDefType,puppetDefName,puppetDefArguments -syn keyword puppetDefType       class define site node inherits contained -syn keyword puppetInherits      inherits contained -syn region  puppetDefArguments  start="(" end=")" contains=puppetArgument +" match class/definition/node declarations +syn region  puppetDefine        start="^\s*\(class\|define\|node\)\s" end="{" contains=puppetDefType,puppetDefName,puppetDefArguments,puppetNodeRe +syn keyword puppetDefType       class define node inherits contained +syn region  puppetDefArguments  start="(" end=")" contained contains=puppetArgument,puppetString  syn match   puppetArgument      "\w\+" contained  syn match   puppetArgument      "\$\w\+" contained  syn match   puppetArgument      "'[^']+'" contained  syn match   puppetArgument      '"[^"]+"' contained -syn match   puppetDefName     "\w\+" contained +syn match   puppetDefName       "\w\+" contained +syn match   puppetNodeRe        "/.*/" contained -syn match   puppetInstance           "\w\+\s*{" contains=puppetTypeBrace,puppetTypeName,puppetTypeDefault -syn match   puppetTypeBrace       "{" contained -syn match   puppetTypeName       "[a-z]\w*" contained -syn match   puppetTypeDefault    "[A-Z]\w*" contained +" match 'foo' in 'class foo { ...' +" match 'foo::bar' in 'class foo::bar { ...' +" match 'Foo::Bar' in 'Foo::Bar["..."] +"FIXME: "Foo-bar" doesn't get highlighted as expected, although "foo-bar" does. +syn match   puppetInstance      "[A-Za-z0-9_-]\+\(::[A-Za-z0-9_-]\+\)*\s*{" contains=puppetTypeName,puppetTypeDefault +syn match   puppetInstance      "[A-Z][a-z_-]\+\(::[A-Z][a-z_-]\+\)*\s*[[{]" contains=puppetTypeName,puppetTypeDefault +syn match   puppetInstance      "[A-Z][a-z_-]\+\(::[A-Z][a-z_-]\+\)*\s*<\?<|" contains=puppetTypeName,puppetTypeDefault +syn match   puppetTypeName      "[a-z]\w*" contained +syn match   puppetTypeDefault   "[A-Z]\w*" contained -syn match   puppetParam           "\w\+\s*=>" contains=puppetTypeRArrow,puppetParamName -syn match   puppetParamRArrow       "=>" contained -syn match   puppetParamName       "\w\+" contained -syn match   puppetVariable           "$\w\+" -syn match   puppetVariable           "${\w\+}" -syn match   puppetParen           "(" -syn match   puppetParen           ")" -syn match   puppetBrace           "{" -syn match   puppetBrace           "}" +" match 'foo' in 'foo => "bar"' +syn match   puppetParam         "\w\+\s*[=+]>" contains=puppetParamName +syn match   puppetParamName     "\w\+" contained -syn region  puppetString start=+"+ skip=+\\\\\|\\"+ end=+"+ contains=puppetVariable +" match 'present' in 'ensure => present' +" match '2755' in 'mode => 2755' +" don't match 'bar' in 'foo => bar' +syn match   puppetParam         "\w\+\s*[=+]>\s*[a-z0-9]\+" contains=puppetParamString,puppetParamName +syn match   puppetParamString   "[=+]>\s*\w\+" contains=puppetParamKeyword,puppetParamSpecial,puppetParamDigits contained +syn keyword puppetParamKeyword  present absent purged latest installed running stopped mounted unmounted role configured file directory link contained +syn keyword puppetParamSpecial  true false undef contained +syn match   puppetParamDigits   "[0-9]\+" -syn keyword puppetBoolean    true false -syn keyword puppetKeyword    import inherits include -syn keyword puppetControl    case default +" match 'template' in 'content => template("...")' +syn match   puppetParam         "\w\+\s*[=+]>\s*\w\+\s*(" contains=puppetFunction,puppetParamName +" statements +syn region  puppetFunction      start="^\s*\(alert\|crit\|debug\|emerg\|err\|fail\|include\|info\|notice\|realize\|require\|search\|tag\|warning\)\s*(" end=")" contained contains=puppetString +" rvalues +syn region  puppetFunction      start="^\s*\(defined\|file\|fqdn_rand\|generate\|inline_template\|regsubst\|sha1\|shellquote\|split\|sprintf\|tagged\|template\|versioncmp\)\s*(" end=")" contained contains=puppetString + +syn match   puppetVariable      "$[a-zA-Z0-9_:]\+" +syn match   puppetVariable      "${[a-zA-Z0-9_:]\+}" + +" match anything between simple/double quotes. +" don't match variables if preceded by a backslash. +syn region  puppetString        start=+'+ skip=+\\\\\|\\'+ end=+'+ +syn region  puppetString        start=+"+ skip=+\\\\\|\\"+ end=+"+ contains=puppetVariable,puppetNotVariable +syn match   puppetString        "/[^/]*/" +syn match   puppetNotVariable   "\\$\w\+" contained +syn match   puppetNotVariable   "\\${\w\+}" contained + +syn keyword puppetKeyword       import inherits include +syn keyword puppetControl       case default if else elsif +syn keyword puppetSpecial       true false undef  " comments last overriding everything else -syn match   puppetComment            "\s*#.*$" contains=puppetTodo -syn keyword puppetTodo               TODO NOTE FIXME XXX contained +syn match   puppetComment       "\s*#.*$" contains=puppetTodo +syn region  puppetComment       start="/\*" end="\*/" contains=puppetTodo extend +syn keyword puppetTodo          TODO NOTE FIXME XXX BUG HACK contained  " Define the default highlighting.  " For version 5.7 and earlier: only when not done already @@ -63,27 +89,29 @@ if version >= 508 || !exists("did_puppet_syn_inits")    endif    HiLink puppetVariable             Identifier -  HiLink puppetBoolean              Boolean    HiLink puppetType                 Identifier -  HiLink puppetDefault              Identifier    HiLink puppetKeyword              Define -  HiLink puppetTypeDefs             Define    HiLink puppetComment              Comment    HiLink puppetString               String +  HiLink puppetParamKeyword         String +  HiLink puppetParamDigits          String +  HiLink puppetNotVariable          String +  HiLink puppetParamSpecial         Special +  HiLink puppetSpecial              Special    HiLink puppetTodo                 Todo -"  HiLink puppetBrace                Delimiter -"  HiLink puppetTypeBrace            Delimiter -"  HiLink puppetParen                Delimiter -  HiLink puppetDelimiter            Delimiter    HiLink puppetControl              Statement    HiLink puppetDefType              Define    HiLink puppetDefName              Type +  HiLink puppetNodeRe               Type    HiLink puppetTypeName             Statement    HiLink puppetTypeDefault          Type    HiLink puppetParamName            Identifier    HiLink puppetArgument             Identifier +  HiLink puppetFunction             Function    delcommand HiLink  endif  let b:current_syntax = "puppet" +set iskeyword=-,:,@,48-57,_,192-255 + | 
