Merge remote-tracking branch 'greenfork/update-pony'
This commit is contained in:
commit
218f7ba0e0
|
@ -16,10 +16,12 @@ hook global WinSetOption filetype=pony %{
|
||||||
|
|
||||||
set-option window static_words %opt{pony_static_words}
|
set-option window static_words %opt{pony_static_words}
|
||||||
|
|
||||||
hook window InsertChar \n -group pony-insert pony-insert-on-new-line
|
|
||||||
hook window InsertChar \n -group pony-indent pony-indent-on-new-line
|
|
||||||
# cleanup trailing whitespaces on current line insert end
|
# cleanup trailing whitespaces on current line insert end
|
||||||
hook window ModeChange pop:insert:.* -group pony-trim-indent %{ try %{ execute-keys -draft <semicolon> x s ^\h+$ <ret> d } }
|
hook window ModeChange pop:insert:.* -group pony-trim-indent %{ try %{ execute-keys -draft <semicolon> x s ^\h+$ <ret> d } }
|
||||||
|
hook window InsertChar \n -group pony-indent pony-indent-on-new-line
|
||||||
|
hook window InsertChar \n -group pony-insert pony-insert-on-new-line
|
||||||
|
|
||||||
|
set-option buffer extra_word_chars '_' "'"
|
||||||
|
|
||||||
hook -once -always window WinSetOption filetype=.* %{ remove-hooks window pony-.+ }
|
hook -once -always window WinSetOption filetype=.* %{ remove-hooks window pony-.+ }
|
||||||
}
|
}
|
||||||
|
@ -29,47 +31,78 @@ hook -group pony-highlight global WinSetOption filetype=pony %{
|
||||||
hook -once -always window WinSetOption filetype=.* %{ remove-highlighter pony }
|
hook -once -always window WinSetOption filetype=.* %{ remove-highlighter pony }
|
||||||
}
|
}
|
||||||
|
|
||||||
provide-module pony %{
|
provide-module pony %§
|
||||||
|
|
||||||
# Highlighters & Completion
|
# Highlighters & Completion
|
||||||
# ‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾
|
# ‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾
|
||||||
|
|
||||||
add-highlighter shared/pony regions
|
add-highlighter shared/pony regions
|
||||||
add-highlighter shared/pony/code default-region group
|
add-highlighter shared/pony/code default-region group
|
||||||
add-highlighter shared/pony/triple_string region '"""' '"""' fill string
|
|
||||||
add-highlighter shared/pony/double_string region '"' (?<!\\)(\\\\)*" fill string
|
|
||||||
add-highlighter shared/pony/comment region '/\*' '\*/' fill comment
|
|
||||||
add-highlighter shared/pony/line_comment region '//' '$' fill comment
|
|
||||||
|
|
||||||
|
add-highlighter shared/pony/comment region '/\*' '\*/' fill comment
|
||||||
|
add-highlighter shared/pony/line_comment region '//' '$' fill comment
|
||||||
|
|
||||||
|
# String literals
|
||||||
|
add-highlighter shared/pony/string region -match-capture '("""|")' '(?<!\\)(?:\\\\)*("""|")' group
|
||||||
|
add-highlighter shared/pony/string/ fill string
|
||||||
|
add-highlighter shared/pony/string/ regex '(?:\\a|\\b|\\e|\\f|\\n|\\r|\\t||\\v|\\\\|\\''|\\0|\\x[0-9a-fA-F]{2}|\\u[0-9a-fA-F]{4}|\\u[0-9a-fA-F]{6})' 0:meta
|
||||||
|
|
||||||
|
# Character literals
|
||||||
|
# negative lookbehind to account for variables with prime such as myvar' or myvar''
|
||||||
|
add-highlighter shared/pony/character region "(?<![a-z0-9'])'" (?<!\\)(\\\\)*' group
|
||||||
|
add-highlighter shared/pony/character/ fill string
|
||||||
|
add-highlighter shared/pony/character/ regex '(?:\\a|\\b|\\e|\\f|\\n|\\r|\\t||\\v|\\\\|\\''|\\0|\\x[0-9a-fA-F]{2})' 0:meta
|
||||||
|
|
||||||
|
# Operators
|
||||||
|
add-highlighter shared/pony/code/ regex '=|\+|-|\*|/|%|%%|<<|>>|==|!=|<|<=|>=|>|=>|;' 0:operator
|
||||||
|
add-highlighter shared/pony/code/ regex '(\+|-|\*|/|%|%%|<<|>>|==|!=|<|<=|>=|>)~' 0:operator
|
||||||
|
add-highlighter shared/pony/code/ regex '(\+|-|\*|/|%|%%)\?' 0:operator
|
||||||
|
add-highlighter shared/pony/code/ regex '^\h*|' 0:operator
|
||||||
|
add-highlighter shared/pony/code/ regex '\b_\b' 0:operator
|
||||||
|
|
||||||
|
# Integer literals
|
||||||
|
add-highlighter shared/pony/code/ regex '\b[0-9](_?[0-9])*\b' 0:value
|
||||||
|
add-highlighter shared/pony/code/ regex '\b0x[0-9a-fA-F](_?[0-9a-fA-F])*\b' 0:value
|
||||||
|
add-highlighter shared/pony/code/ regex '\b0b[01](_?[01])*\b' 0:value
|
||||||
|
|
||||||
|
# Float literals
|
||||||
|
add-highlighter shared/pony/code/ regex '\b[0-9]+\.[0-9]+(?:[eE][-+]?[0-9]+)?\b' 0:value
|
||||||
|
add-highlighter shared/pony/code/ regex '\b[0-9]+[eE][-+]?[0-9]+\b' 0:value
|
||||||
|
|
||||||
|
# Type literals
|
||||||
|
add-highlighter shared/pony/code/ regex '\b_?[A-Z][A-Za-z0-9]*\b' 0:type
|
||||||
|
|
||||||
|
# Literal words are highlighted below to also allow for autocompletion by appending
|
||||||
|
# them to static_words.
|
||||||
evaluate-commands %sh{
|
evaluate-commands %sh{
|
||||||
# Grammar
|
# Grammar
|
||||||
values="true|false|None|this"
|
values="true|false|this"
|
||||||
meta='use'
|
meta='use'
|
||||||
# Keyword list is collected using `keyword.kwlist` from `keyword`
|
# Keyword list is collected using `keyword.kwlist` from `keyword`
|
||||||
keywords="and|as|or|break|match|continue|else|try|in|return|end|for|is"
|
keywords="as|break|match|continue|else|elseif|try|in|return|end|for|is"
|
||||||
keywords="${keywords}|recover|consume|error|do|then|if|while"
|
keywords="${keywords}|recover|consume|error|do|then|if|while|where|with"
|
||||||
func_decl="new|fun|be|lambda"
|
keywords="${keywords}|class|struct|object|actor|interface|trait|primitive"
|
||||||
|
keywords="${keywords}|type|var|let|embed|repeat|until|addressof"
|
||||||
|
func_decl="new|fun|be"
|
||||||
capabilities="iso|ref|box|tag|val|trn"
|
capabilities="iso|ref|box|tag|val|trn"
|
||||||
struct="class|actor|interface|trait|primitive|type|var|let|embed"
|
operators="and|or|xor|not"
|
||||||
|
builtin_types="String|None|Any|Array"
|
||||||
|
|
||||||
# Add the language's grammar to the static completion list
|
# Add the language's grammar to the static completion list
|
||||||
static_words="${values} ${meta} ${keywords} ${types_decl} ${capabilities}"
|
static_words="${values} ${meta} ${keywords} ${types_decl} ${capabilities}"
|
||||||
static_words="${static_words} ${struct}"
|
static_words="${static_words} ${operators} ${builtin_types}"
|
||||||
printf %s\\n "declare-option str-list pony_static_words ${static_words}" | tr '|' ' '
|
printf %s\\n "declare-option str-list pony_static_words ${static_words}" | tr '|' ' '
|
||||||
|
|
||||||
# Highlight keywords
|
# Highlight keywords
|
||||||
|
# The (?!') ensures that keywords with prime are highlighted as usual, for example try'
|
||||||
printf %s "
|
printf %s "
|
||||||
add-highlighter shared/pony/code/ regex '\b(${values})\b' 0:value
|
add-highlighter shared/pony/code/ regex \b(${values})\b(?!') 0:value
|
||||||
add-highlighter shared/pony/code/ regex '\b(${meta})\b' 0:meta
|
add-highlighter shared/pony/code/ regex \b(${operators})\b(?!') 0:operator
|
||||||
add-highlighter shared/pony/code/ regex '\b(${func_decl})(\s+(${capabilities}))?(\s+\w+)\(' 1:type 3:builtin 4:builtin
|
add-highlighter shared/pony/code/ regex \b(${meta})\b(?!') 0:meta
|
||||||
add-highlighter shared/pony/code/ regex '\b(${func_decl})\b' 0:type
|
add-highlighter shared/pony/code/ regex \b(${func_decl})(\s+(${capabilities}))?(\s+\w+)[\[(] 1:keyword 3:attribute 4:function
|
||||||
add-highlighter shared/pony/code/ regex '=>' 0:type
|
add-highlighter shared/pony/code/ regex \b(${func_decl})\b(?!') 0:keyword
|
||||||
add-highlighter shared/pony/code/ regex '\b(${keywords})\b' 0:keyword
|
add-highlighter shared/pony/code/ regex \b(${keywords})\b(?!') 0:keyword
|
||||||
add-highlighter shared/pony/code/ regex ';' 0:keyword
|
add-highlighter shared/pony/code/ regex \b(${capabilities})\b(?!')(!|\\^)? 1:attribute 2:attribute
|
||||||
add-highlighter shared/pony/code/ regex '^\s*|' 0:keyword
|
|
||||||
add-highlighter shared/pony/code/ regex '\b(${struct})\b' 0:variable
|
|
||||||
add-highlighter shared/pony/code/ regex '\b(${capabilities})\b(!|^)?' 1:builtin 2:builtin
|
|
||||||
"
|
"
|
||||||
|
|
||||||
# Highlight types and attributes
|
# Highlight types and attributes
|
||||||
|
@ -81,24 +114,42 @@ evaluate-commands %sh{
|
||||||
# Commands
|
# Commands
|
||||||
# ‾‾‾‾‾‾‾‾
|
# ‾‾‾‾‾‾‾‾
|
||||||
|
|
||||||
define-command -hidden pony-insert-on-new-line %{
|
define-command -hidden pony-insert-on-new-line %<
|
||||||
evaluate-commands -draft -itersel %{
|
evaluate-commands -no-hooks -draft -itersel %<
|
||||||
# copy // comments prefix and following white spaces
|
# copy // comments prefix and following white spaces
|
||||||
try %{ execute-keys -draft k x s ^\h*//\h* <ret> y jgh P }
|
try %{ execute-keys -draft k x s ^\h*\K//\h* <ret> y jgi P }
|
||||||
}
|
|
||||||
}
|
# wisely add `end` keyword
|
||||||
|
evaluate-commands -save-regs x %<
|
||||||
|
try %{ execute-keys -draft k x s ^ \h + <ret> \" x y } catch %{ reg x '' }
|
||||||
|
try %<
|
||||||
|
evaluate-commands -draft %<
|
||||||
|
# Check if previous line opens a block
|
||||||
|
execute-keys -draft kx <a-k>^<c-r>x(try|match|recover|repeat|object|.+\bdo$|.+\bthen$)[^0-9A-Za-z_']<ret>
|
||||||
|
# Check that we didn't put an end on the previous line that closes the block
|
||||||
|
execute-keys -draft kx <a-K> \bend$<ret>
|
||||||
|
# Check that we do not already have an end for this indent level which is first set via `pony-indent-on-new-line` hook
|
||||||
|
execute-keys -draft }i J x <a-K> ^<c-r>x(end|else|elseif|until)[^0-9A-Za-z_']<ret>
|
||||||
|
>
|
||||||
|
execute-keys -draft o<c-r>xend<esc> # insert a new line with containing end
|
||||||
|
>
|
||||||
|
>
|
||||||
|
>
|
||||||
|
>
|
||||||
|
|
||||||
define-command -hidden pony-indent-on-new-line %{
|
define-command -hidden pony-indent-on-new-line %{
|
||||||
evaluate-commands -draft -itersel %{
|
evaluate-commands -no-hooks -draft -itersel %{
|
||||||
# preserve previous line indent
|
# preserve previous line indent
|
||||||
try %{ execute-keys -draft , K <a-&> }
|
try %{ execute-keys -draft , K <a-&> }
|
||||||
# cleanup trailing whitespaces from previous line
|
# cleanup trailing whitespaces from previous line
|
||||||
try %{ execute-keys -draft k x s \h+$ <ret> d }
|
try %{ execute-keys -draft k x s \h+$ <ret> d }
|
||||||
# indent after line ending with :
|
# indent after line ending with: =>, do, try, then, else, =; or
|
||||||
try %{ execute-keys -draft , k x <a-k> (\b(?:do|try|then|else)|:|=>)$ <ret> j <a-gt> }
|
# starting with: actor, class, struct, trait, interface, if, elseif, recover, repeat
|
||||||
|
# excluding: primitive, type -- because they are often written in a single line
|
||||||
|
try %{ execute-keys -draft , k x <a-k> (\b(?:do|try|then|else|recover|repeat)|=>|=)$ | ^\h*(actor|class|struct|trait|interface|object)\b <ret> j <a-gt> }
|
||||||
# else, end are always de-indented
|
# else, end are always de-indented
|
||||||
try %{ execute-keys -draft , k x <a-k> \b(else|end):$ <ret> k x s ^\h* <ret> y j x <a-k> ^<c-r>" <ret> J <a-lt> }
|
try %{ execute-keys -draft , k x <a-k> \b(else|end):$ <ret> k x s ^\h* <ret> y j x <a-k> ^<c-r>" <ret> J <a-lt> }
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
§
|
||||||
|
|
|
@ -16,7 +16,7 @@ hook global BufSetOption filetype=asciidoc %{
|
||||||
set-option buffer comment_block_end '////'
|
set-option buffer comment_block_end '////'
|
||||||
}
|
}
|
||||||
|
|
||||||
hook global BufSetOption filetype=(c|cpp|dart|gluon|go|java|javascript|objc|odin|php|protobuf|rust|sass|scala|scss|swift|typescript|groovy) %{
|
hook global BufSetOption filetype=(c|cpp|dart|gluon|go|java|javascript|objc|odin|php|pony|protobuf|rust|sass|scala|scss|swift|typescript|groovy) %{
|
||||||
set-option buffer comment_line '//'
|
set-option buffer comment_line '//'
|
||||||
set-option buffer comment_block_begin '/*'
|
set-option buffer comment_block_begin '/*'
|
||||||
set-option buffer comment_block_end '*/'
|
set-option buffer comment_block_end '*/'
|
||||||
|
|
Loading…
Reference in New Issue
Block a user