diff options
| author | Adam Stankiewicz <sheerun@sher.pl> | 2019-06-14 16:11:54 +0200 | 
|---|---|---|
| committer | Adam Stankiewicz <sheerun@sher.pl> | 2019-06-14 16:11:54 +0200 | 
| commit | 15727e7eb005a0eef76941e09d993754b86cb81d (patch) | |
| tree | e014def7673da03559b2597cff9601ed0fd72006 | |
| parent | 6b169212f82cbe81d1fbf3ae7f7dcea14bc5bec4 (diff) | |
| download | vim-polyglot-15727e7eb005a0eef76941e09d993754b86cb81d.tar.gz vim-polyglot-15727e7eb005a0eef76941e09d993754b86cb81d.zip | |
Add zephir support
| -rw-r--r-- | README.md | 3 | ||||
| -rwxr-xr-x | build | 1 | ||||
| -rw-r--r-- | ftdetect/polyglot.vim | 7 | ||||
| -rw-r--r-- | syntax/zephir.vim | 137 | 
4 files changed, 147 insertions, 1 deletions
| @@ -10,7 +10,7 @@ A collection of language packs for Vim.  > One to rule them all, one to find them, one to bring them all and in the darkness bind them.  - It **won't affect your startup time**, as scripts are loaded only on demand\*. -- It **installs and updates 120+ times faster** than the <!--Package Count-->144<!--/Package Count--> packages it consists of. +- It **installs and updates 120+ times faster** than the <!--Package Count-->145<!--/Package Count--> packages it consists of.  - Solid syntax and indentation support (other features skipped). Only the best language packs.  - All unnecessary files are ignored (like enormous documentation from php support).  - No support for esoteric languages, only most popular ones (modern too, like `slim`). @@ -188,6 +188,7 @@ If you need full functionality of any plugin, please use it directly with your p  - [xml](https://github.com/amadeus/vim-xml) (syntax)  - [yaml](https://github.com/stephpy/vim-yaml) (syntax, ftplugin)  - [yard](https://github.com/sheerun/vim-yardoc) (syntax) +- [zephir](https://github.com/xwsoul/vim-zephir) (syntax)  - [zig](https://github.com/ziglang/zig.vim) (syntax, autoload, ftplugin)  <!--/Language Packs--> @@ -298,6 +298,7 @@ PACKS="    xls:vim-scripts/XSLT-syntax    yaml:stephpy/vim-yaml    yard:sheerun/vim-yardoc +  zephir:xwsoul/vim-zephir    zig:ziglang/zig.vim  " diff --git a/ftdetect/polyglot.vim b/ftdetect/polyglot.vim index 6854f34f..b080cfd9 100644 --- a/ftdetect/polyglot.vim +++ b/ftdetect/polyglot.vim @@ -1471,6 +1471,13 @@ autocmd BufNewFile,BufRead *.xdc setfiletype xdc    augroup end  endif +if !exists('g:polyglot_disabled') || index(g:polyglot_disabled, 'zephir') == -1 +  augroup filetypedetect +  " zephir, from zephir.vim in xwsoul/vim-zephir +autocmd BufNewFile,BufReadPost *.zep set filetype=zephir +  augroup end +endif +  if !exists('g:polyglot_disabled') || index(g:polyglot_disabled, 'zig') == -1    augroup filetypedetect    " zig, from zig.vim in ziglang/zig.vim diff --git a/syntax/zephir.vim b/syntax/zephir.vim new file mode 100644 index 00000000..bfd3ef09 --- /dev/null +++ b/syntax/zephir.vim @@ -0,0 +1,137 @@ +if exists('g:polyglot_disabled') && index(g:polyglot_disabled, 'zephir') != -1 +  finish +endif + +" Copyright 2009 The Go Authors. All rights reserved. +if exists("b:current_syntax") +  finish +endif + +syn case match + +" Comments; their contents +syn keyword     zepTodo              contained TODO FIXME XXX +syn cluster     zepCommentGroup      contains=zepTodo +syn region      zepComment           start="/\*" end="\*/" contains=@zepCommentGroup,@Spell +syn region      zepComment           start="//" end="$" contains=@zepCommentGroup,@Spell + +hi def link     zepComment           Comment +hi def link     zepTodo              Todo + +syn keyword     zepDirective         namespace extends implements return +syn keyword     zepDeclaration       var let new const +syn keyword     zepDeclType          abstract class interface +syn keyword     zepDeclFun           function +syn keyword     zepDeclMore          public private protected static final +syn keyword     zepExceptionOperator throw try catch + +hi def link     zepDirective         Statement +hi def link     zepDeclaration       Keyword +hi def link     zepDeclFun           Keyword +hi def link     zepDeclType          Keyword +hi def link     zepDeclMore          Keyword +hi def link     zepExceptionOperator Keyword + +syn keyword     zepCond              if else elseif switch +syn keyword     zepRepeat            for in while loop +syn keyword     zepLabel             case default continue require this parent self +syn match       zepTypeHits          "\<\w+\>"me=e+1,me=e-1 contained display + +hi def link     zepCond              Conditional +hi def link     zepRepeat            Repeat +hi def link     zepLabel             Label + +syn match       zepOperator          "[-=+%^&|*!.~?:]" contained display +syn match       zepOperator          "[-+*/%^&|.]="  contained display +syn match       zepOperator          "/[^*/]"me=e-1  contained display +syn match       zepOperator          "\$"  contained display +syn match       zepOperator          "&&\|\<and\>" contained display +syn match       zepOperator          "||\|\<x\=or\>" contained display +syn match       zepRelation          "[!=<>]=" contained display +syn match       zepRelation          "[<>]"  contained display +syn match       zepMemberSelector    "->"  contained display + +hi def link     zepOperator          Operator +hi def link     zepRelation          Operator +hi def link     zepMemberSelector    Operator + +syn keyword     zepType              array string char void void +syn keyword     zepType              bool[ean] true false +syn keyword     zepType              unsigned int uint long ulong + +hi def link     zepType              Type + +syn match       zepGlobalVar         "_(SERVER|POST|GET|COOKIE|SESSION)\["me=e-1 contained display + +hi def link     zepGlobalVar         Statement + +syn keyword     zepSpecialOperator   empty isset fetch +syn keyword     zepBuildIns          global_set global_get +syn keyword     zepBuildIns          echo count typeof range reverse +syn keyword     zepBuildIns          set get toString +"for string +syn keyword     zepBuildIns          length trim trimleft trimright index lower upper lowerfirst upperfirst format +"for array +syn keyword     zepBuildIns          join reverse +"for char +syn keyword     zepBuildIns          toHex +"for integer +syn keyword     zepBuildIns          abs + +hi def link     zepSpecialOperator   Function +hi def link     zepBuildIns          Function + +" zep escapes +syn match       zepEscapeOctal       display contained "\\[0-7]\{3}" +syn match       zepEscapeC           display contained +\\[abfnrtv\\'"]+ +syn match       zepEscapeX           display contained "\\x\x\{2}" +syn match       zepEscapeU           display contained "\\u\x\{4}" +syn match       zepEscapeBigU        display contained "\\U\x\{8}" +syn match       zepEscapeError       display contained +\\[^0-7xuUabfnrtv\\'"]+ + +hi def link     zepEscapeOctal       zepSpecialString +hi def link     zepEscapeC           zepSpecialString +hi def link     zepEscapeX           zepSpecialString +hi def link     zepEscapeU           zepSpecialString +hi def link     zepEscapeBigU        zepSpecialString +hi def link     zepSpecialString     Special +hi def link     zepEscapeError       Error + +" Strings and their contents +syn cluster     zepStringGroup       contains=zepEscapeOctal,zepEscapeC,zepEscapeX,zepEscapeU,zepEscapeBigU,zepEscapeError +syn region      zepString            start=+"+ skip=+\\\\\|\\"+ end=+"+ contains=@zepStringGroup +syn region      zepString            start=+'+ skip=+\\\\\|\\'+ end=+'+ contains=@zepStringGroup + +hi def link     zepString            String + +" Integers +syn match       zepDecimalInt        "\<\d\+\([Ee]\d\+\)\?\>" +syn match       zepHexadecimalInt    "\<0x\x\+\>" +syn match       zepOctalInt          "\<0\o\+\>" +syn match       zepOctalError        "\<0\o*[89]\d*\>" + +hi def link     zepDecimalInt        Integer +hi def link     zepHexadecimalInt    Integer +hi def link     zepOctalInt          Integer +hi def link     Integer              Number + +" Floating point +syn match       zepFloat             "\<\d\+\.\d*\([Ee][-+]\d\+\)\?\>" +syn match       zepFloat             "\<\.\d\+\([Ee][-+]\d\+\)\?\>" +syn match       zepFloat             "\<\d\+[Ee][-+]\d\+\>" + +hi def link     zepFloat             Float + +" Imaginary literals +syn match       zepImaginary         "\<\d\+i\>" +syn match       zepImaginary         "\<\d\+\.\d*\([Ee][-+]\d\+\)\?i\>" +syn match       zepImaginary         "\<\.\d\+\([Ee][-+]\d\+\)\?i\>" +syn match       zepImaginary         "\<\d\+[Ee][-+]\d\+i\>" + +hi def link     zepImaginary         Number + + +syn sync minlines=500 + +let b:current_syntax = "zephir" +syn match       zepTypeHits          "<\w+>" contained display | 
