diff --git a/rc/base/autowrap.kak b/rc/base/autowrap.kak index d723c93e..1f8ef8be 100644 --- a/rc/base/autowrap.kak +++ b/rc/base/autowrap.kak @@ -1,23 +1,23 @@ -decl -docstring "maximum amount of characters per line, after which a newline character will be inserted" \ +declare-option -docstring "maximum amount of characters per line, after which a newline character will be inserted" \ int autowrap_column 80 -decl -docstring %{when enabled, paragraph formatting will reformat the whole paragraph in which characters are being inserted +declare-option -docstring %{when enabled, paragraph formatting will reformat the whole paragraph in which characters are being inserted This can potentially break formatting of documents containing markup (e.g. markdown)} \ bool autowrap_format_paragraph no -decl -docstring %{command to which the paragraphs to wrap will be passed +declare-option -docstring %{command to which the paragraphs to wrap will be passed all occurences of '%c' are replaced with `autowrap_column`} \ str autowrap_fmtcmd 'fold -s -w %c' -def -hidden autowrap-cursor %{ eval -save-regs '/"|^@m' %{ +define-command -hidden autowrap-cursor %{ evaluate-commands -save-regs '/"|^@m' %{ try %{ ## if the line isn't too long, do nothing - exec -draft "^[^\n]{%opt{autowrap_column},}[^\n]" + execute-keys -draft "^[^\n]{%opt{autowrap_column},}[^\n]" try %{ reg m "%val{selections_desc}" ## if we're adding characters past the limit, just wrap them around - exec -draft ".{%opt{autowrap_column}}\h*[^\s]*1s(\h+)[^\h]*\zc" + execute-keys -draft ".{%opt{autowrap_column}}\h*[^\s]*1s(\h+)[^\h]*\zc" } catch %{ ## if we're adding characters in the middle of a sentence, use ## the `fmtcmd` command to wrap the entire paragraph @@ -27,9 +27,9 @@ def -hidden autowrap-cursor %{ eval -save-regs '/"|^@m' %{ format_cmd=$(printf %s "${kak_opt_autowrap_fmtcmd}" \ | sed "s/%c/${kak_opt_autowrap_column}/g") printf %s " - eval -draft %{ - exec 'p|${format_cmd}' - try %{ exec s\h+$ d } + evaluate-commands -draft %{ + execute-keys 'p|${format_cmd}' + try %{ execute-keys s\h+$ d } } select '${kak_reg_m}' " @@ -39,10 +39,10 @@ def -hidden autowrap-cursor %{ eval -save-regs '/"|^@m' %{ } } } -def autowrap-enable -docstring "Automatically wrap the lines in which characters are inserted" %{ +define-command autowrap-enable -docstring "Automatically wrap the lines in which characters are inserted" %{ hook -group autowrap window InsertChar [^\n] autowrap-cursor } -def autowrap-disable -docstring "Disable automatic line wrapping" %{ +define-command autowrap-disable -docstring "Disable automatic line wrapping" %{ remove-hooks window autowrap } diff --git a/rc/base/clojure.kak b/rc/base/clojure.kak index 77f58681..00c7ca46 100644 --- a/rc/base/clojure.kak +++ b/rc/base/clojure.kak @@ -7,7 +7,7 @@ # ‾‾‾‾‾‾‾‾‾ hook global BufCreate .*[.](cljs?) %{ - set buffer filetype clojure + set-option buffer filetype clojure } # Highlighters @@ -22,8 +22,8 @@ add-highlighter shared/clojure regex \b(clojure.core/['/\w]+)\b 0:keyword # Commands # ‾‾‾‾‾‾‾‾ -def -hidden clojure-filter-around-selections lisp-filter-around-selections -def -hidden clojure-indent-on-new-line lisp-indent-on-new-line +define-command -hidden clojure-filter-around-selections lisp-filter-around-selections +define-command -hidden clojure-indent-on-new-line lisp-indent-on-new-line # Initialization # ‾‾‾‾‾‾‾‾‾‾‾‾‾‾ diff --git a/rc/base/css.kak b/rc/base/css.kak index c6a0d7e2..73695397 100644 --- a/rc/base/css.kak +++ b/rc/base/css.kak @@ -5,7 +5,7 @@ # ‾‾‾‾‾‾‾‾‾ hook global BufCreate .*[.](css) %{ - set buffer filetype css + set-option buffer filetype css } # Highlighters @@ -38,26 +38,26 @@ add-highlighter shared/css/selector regex [*]|[#.][A-Za-z][A-Za-z0-9_-]* 0:varia # Commands # ‾‾‾‾‾‾‾‾ -def -hidden css-filter-around-selections %{ +define-command -hidden css-filter-around-selections %{ # remove trailing white spaces - try %{ exec -draft -itersel s \h+$ d } + try %{ execute-keys -draft -itersel s \h+$ d } } -def -hidden css-indent-on-new-line %[ - eval -draft -itersel %[ +define-command -hidden css-indent-on-new-line %[ + evaluate-commands -draft -itersel %[ # preserve previous line indent - try %[ exec -draft \; K ] + try %[ execute-keys -draft \; K ] # filter previous line - try %[ exec -draft k : css-filter-around-selections ] + try %[ execute-keys -draft k : css-filter-around-selections ] # indent after lines ending with with { - try %[ exec -draft k \{$ j ] + try %[ execute-keys -draft k \{$ j ] ] ] -def -hidden css-indent-on-closing-curly-brace %[ - eval -draft -itersel %[ +define-command -hidden css-indent-on-closing-curly-brace %[ + evaluate-commands -draft -itersel %[ # align to opening curly brace when alone on a line - try %[ exec -draft ^\h+\}$ m s \A|.\z 1 ] + try %[ execute-keys -draft ^\h+\}$ m s \A|.\z 1 ] ] ] diff --git a/rc/base/ctags.kak b/rc/base/ctags.kak index 4c5c193e..1e68fc30 100644 --- a/rc/base/ctags.kak +++ b/rc/base/ctags.kak @@ -3,10 +3,10 @@ # This script requires the readtags command available in ctags source but # not installed by default -decl -docstring "colon separated list of paths to tag files to parse when looking up a symbol" \ +declare-option -docstring "colon separated list of paths to tag files to parse when looking up a symbol" \ str-list ctagsfiles 'tags' -def -params ..1 \ +define-command -params ..1 \ -shell-candidates ' printf %s\\n "$kak_opt_ctagsfiles" | tr \':\' \'\n\' | while read -r candidate; do @@ -37,47 +37,47 @@ If no symbol is passed then the current selection is used as symbol name} \ re=$0; sub(".*\t/\\^", "", re); sub("\\$?/$", "", re); gsub("(\\{|\\}|\\\\E).*$", "", re); keys=re; gsub(/", keys); gsub(/\t/, "", keys); - out = out " %{" $2 " {MenuInfo}" re "} %{eval -collapse-jumps %{ try %{ edit %{" tagroot $2 "}; exec %{/\\Q" keys "vc} } catch %{ echo %{unable to find tag} } } }" + out = out " %{" $2 " {MenuInfo}" re "} %{evaluate-commands -collapse-jumps %{ try %{ edit %{" tagroot $2 "}; execute-keys %{/\\Q" keys "vc} } catch %{ echo %{unable to find tag} } } }" } - /[^\t]+\t[^\t]+\t[0-9]+/ { out = out " %{" $2 ":" $3 "} %{eval -collapse-jumps %{ edit %{" tagroot $2 "} %{" $3 "}}}" } + /[^\t]+\t[^\t]+\t[0-9]+/ { out = out " %{" $2 ":" $3 "} %{evaluate-commands -collapse-jumps %{ edit %{" tagroot $2 "} %{" $3 "}}}" } END { print ( length(out) == 0 ? "echo -markup %{{Error}no such tag " ENVIRON["tagname"] "}" : "menu -markup -auto-single " out ) }' }} -def ctags-complete -docstring "Insert completion candidates for the current selection into the buffer's local variables" %{ eval -draft %{ - exec hb^\w+$ +define-command ctags-complete -docstring "Insert completion candidates for the current selection into the buffer's local variables" %{ evaluate-commands -draft %{ + execute-keys hb^\w+$ %sh{ { compl=$(readtags -p "$kak_selection" | cut -f 1 | sort | uniq | sed -e 's/:/\\:/g' | sed -e 's/\n/:/g' ) compl="${kak_cursor_line}.${kak_cursor_column}+${#kak_selection}@${kak_timestamp}:${compl}" - printf %s\\n "set buffer=$kak_bufname ctags_completions '${compl}'" | kak -p ${kak_session} + printf %s\\n "set-option buffer=$kak_bufname ctags_completions '${compl}'" | kak -p ${kak_session} } > /dev/null 2>&1 < /dev/null & } }} -def ctags-funcinfo -docstring "Display ctags information about a selected function" %{ - eval -draft %{ +define-command ctags-funcinfo -docstring "Display ctags information about a selected function" %{ + evaluate-commands -draft %{ try %{ - exec -no-hooks '[(;B[a-zA-Z_]+\(' + execute-keys -no-hooks '[(;B[a-zA-Z_]+\(' %sh{ sigs=$(readtags -e ${kak_selection%(} | grep kind:f | sed -re 's/^(\S+).*((class|struct|namespace):(\S+))?.*signature:(.*)$/\5 [\4::\1]/') if [ -n "$sigs" ]; then - printf %s\\n "eval -client ${kak_client} %{info -anchor $kak_cursor_line.$kak_cursor_column -placement above '$sigs'}" + printf %s\\n "evaluate-commands -client ${kak_client} %{info -anchor $kak_cursor_line.$kak_cursor_column -placement above '$sigs'}" fi } } } } -def ctags-enable-autoinfo -docstring "Automatically display ctags information about function" %{ +define-command ctags-enable-autoinfo -docstring "Automatically display ctags information about function" %{ hook window -group ctags-autoinfo NormalIdle .* ctags-funcinfo hook window -group ctags-autoinfo InsertIdle .* ctags-funcinfo } -def ctags-disable-autoinfo -docstring "Disable automatic ctags information displaying" %{ remove-hooks window ctags-autoinfo } +define-command ctags-disable-autoinfo -docstring "Disable automatic ctags information displaying" %{ remove-hooks window ctags-autoinfo } -decl -docstring "options to pass to the `ctags` shell command" \ +declare-option -docstring "options to pass to the `ctags` shell command" \ str ctagsopts "-R" -decl -docstring "path to the directory in which the tags file will be generated" str ctagspaths "." +declare-option -docstring "path to the directory in which the tags file will be generated" str ctagspaths "." -def ctags-generate -docstring 'Generate tag file asynchronously' %{ +define-command ctags-generate -docstring 'Generate tag file asynchronously' %{ echo -markup "{Information}launching tag generation in the background" %sh{ { while ! mkdir .tags.kaklock 2>/dev/null; do sleep 1; done @@ -90,11 +90,11 @@ def ctags-generate -docstring 'Generate tag file asynchronously' %{ msg="tags generation failed" fi - printf %s\\n "eval -client $kak_client echo -markup '{Information}${msg}'" | kak -p ${kak_session} + printf %s\\n "evaluate-commands -client $kak_client echo -markup '{Information}${msg}'" | kak -p ${kak_session} } > /dev/null 2>&1 < /dev/null & } } -def ctags-update-tags -docstring 'Update tags for the given file' %{ +define-command ctags-update-tags -docstring 'Update tags for the given file' %{ %sh{ { while ! mkdir .tags.kaklock 2>/dev/null; do sleep 1; done trap 'rmdir .tags.kaklock' EXIT @@ -110,6 +110,6 @@ def ctags-update-tags -docstring 'Update tags for the given file' %{ msg="tags update failed for $kak_bufname" fi - printf %s\\n "eval -client $kak_client echo -markup '{Information}${msg}'" | kak -p ${kak_session} + printf %s\\n "evaluate-commands -client $kak_client echo -markup '{Information}${msg}'" | kak -p ${kak_session} } > /dev/null 2>&1 < /dev/null & } } diff --git a/rc/base/d.kak b/rc/base/d.kak index 8fd86b76..4f245f8e 100644 --- a/rc/base/d.kak +++ b/rc/base/d.kak @@ -5,7 +5,7 @@ # ‾‾‾‾‾‾‾‾‾ hook global BufCreate .*\.di? %{ - set buffer filetype d + set-option buffer filetype d } # Highlighters @@ -63,7 +63,7 @@ add-highlighter shared/d/code regex "\b(this)\b\s*[^(]" 1:value # Add the language's grammar to the static completion list printf %s\\n "hook global WinSetOption filetype=d %{ - set window static_words '${keywords}:${attributes}:${types}:${values}:${decorators}:${properties}' + set-option window static_words '${keywords}:${attributes}:${types}:${values}:${decorators}:${properties}' }" | sed 's,|,:,g' # Highlight keywords @@ -81,33 +81,33 @@ add-highlighter shared/d/code regex "\b(this)\b\s*[^(]" 1:value # Commands # ‾‾‾‾‾‾‾‾ -def -hidden d-indent-on-new-line %~ - eval -draft -itersel %= +define-command -hidden d-indent-on-new-line %~ + evaluate-commands -draft -itersel %= # preserve previous line indent - try %{ exec -draft \;K } + try %{ execute-keys -draft \;K } # indent after lines ending with { or ( - try %[ exec -draft k [{(]\h*$ j ] + try %[ execute-keys -draft k [{(]\h*$ j ] # cleanup trailing white spaces on the previous line - try %{ exec -draft k s \h+$ d } + try %{ execute-keys -draft k s \h+$ d } # align to opening paren of previous line - try %{ exec -draft [( \A\([^\n]+\n[^\n]*\n?\z s \A\(\h*.|.\z '' & } + try %{ execute-keys -draft [( \A\([^\n]+\n[^\n]*\n?\z s \A\(\h*.|.\z '' & } # copy // comments prefix - try %{ exec -draft \;k s ^\h*\K/{2,} yP } + try %{ execute-keys -draft \;k s ^\h*\K/{2,} yP } # indent after a switch's case/default statements - try %[ exec -draft k ^\h*(case|default).*:$ j ] + try %[ execute-keys -draft k ^\h*(case|default).*:$ j ] # indent after if|else|while|for - try %[ exec -draft \;)MB \A(if|else|while|for)\h*\(.*\)\h*\n\h*\n?\z s \A|.\z 11 ] + try %[ execute-keys -draft \;)MB \A(if|else|while|for)\h*\(.*\)\h*\n\h*\n?\z s \A|.\z 11 ] = ~ -def -hidden d-indent-on-opening-curly-brace %[ +define-command -hidden d-indent-on-opening-curly-brace %[ # align indent with opening paren when { is entered on a new line after the closing paren - try %[ exec -draft -itersel h)M \A\(.*\)\h*\n\h*\{\z s \A|.\z 1 ] + try %[ execute-keys -draft -itersel h)M \A\(.*\)\h*\n\h*\{\z s \A|.\z 1 ] ] -def -hidden d-indent-on-closing-curly-brace %[ +define-command -hidden d-indent-on-closing-curly-brace %[ # align to opening curly brace when alone on a line - try %[ exec -itersel -draft ^\h+\}$hms\A|.\z1 ] + try %[ execute-keys -itersel -draft ^\h+\}$hms\A|.\z1 ] ] # Initialization @@ -117,7 +117,7 @@ hook -group d-highlight global WinSetOption filetype=d %{ add-highlighter window hook global WinSetOption filetype=d %{ # cleanup trailing whitespaces when exiting insert mode - hook window InsertEnd .* -group d-hooks %{ try %{ exec -draft s^\h+$d } } + hook window InsertEnd .* -group d-hooks %{ try %{ execute-keys -draft s^\h+$d } } hook window InsertChar \n -group d-indent d-indent-on-new-line hook window InsertChar \{ -group d-indent d-indent-on-opening-curly-brace hook window InsertChar \} -group d-indent d-indent-on-closing-curly-brace diff --git a/rc/base/etc.kak b/rc/base/etc.kak index 5947bc62..6a0ecf0f 100644 --- a/rc/base/etc.kak +++ b/rc/base/etc.kak @@ -1,15 +1,15 @@ # Highlighting for common files in /etc -hook global BufCreate .*/etc/(hosts|networks|services) %{ set buffer filetype etc-hosts } -hook global BufCreate .*/etc/resolv.conf %{ set buffer filetype etc-resolv-conf } -hook global BufCreate .*/etc/shadow %{ set buffer filetype etc-shadow } -hook global BufCreate .*/etc/passwd %{ set buffer filetype etc-passwd } -hook global BufCreate .*/etc/gshadow %{ set buffer filetype etc-gshadow } -hook global BufCreate .*/etc/group %{ set buffer filetype etc-group } -hook global BufCreate .*/etc/(fs|m)tab %{ set buffer filetype etc-fstab } -hook global BufCreate .*/etc/environment %{ set buffer filetype sh } -hook global BufCreate .*/etc/env.d/.* %{ set buffer filetype sh } -hook global BufCreate .*/etc/profile(\.(csh|env))? %{ set buffer filetype sh } -hook global BufCreate .*/etc/profile\.d/.* %{ set buffer filetype sh } +hook global BufCreate .*/etc/(hosts|networks|services) %{ set-option buffer filetype etc-hosts } +hook global BufCreate .*/etc/resolv.conf %{ set-option buffer filetype etc-resolv-conf } +hook global BufCreate .*/etc/shadow %{ set-option buffer filetype etc-shadow } +hook global BufCreate .*/etc/passwd %{ set-option buffer filetype etc-passwd } +hook global BufCreate .*/etc/gshadow %{ set-option buffer filetype etc-gshadow } +hook global BufCreate .*/etc/group %{ set-option buffer filetype etc-group } +hook global BufCreate .*/etc/(fs|m)tab %{ set-option buffer filetype etc-fstab } +hook global BufCreate .*/etc/environment %{ set-option buffer filetype sh } +hook global BufCreate .*/etc/env.d/.* %{ set-option buffer filetype sh } +hook global BufCreate .*/etc/profile(\.(csh|env))? %{ set-option buffer filetype sh } +hook global BufCreate .*/etc/profile\.d/.* %{ set-option buffer filetype sh } # Highlighters ## /etc/resolv.conf diff --git a/rc/base/file.kak b/rc/base/file.kak index 770db29f..65d5b982 100644 --- a/rc/base/file.kak +++ b/rc/base/file.kak @@ -10,7 +10,7 @@ hook global BufOpenFile .* %{ %sh{ text/*) filetype="${mime#text/}" ;; esac if [ -n "${filetype}" ]; then - printf "set buffer filetype '%s'\n" "${filetype}" + printf "set-option buffer filetype '%s'\n" "${filetype}" fi fi } } diff --git a/rc/base/fish.kak b/rc/base/fish.kak index d7d77e99..4eb82b79 100644 --- a/rc/base/fish.kak +++ b/rc/base/fish.kak @@ -5,7 +5,7 @@ # ‾‾‾‾‾‾‾‾‾ hook global BufCreate .*[.](fish) %{ - set buffer filetype fish + set-option buffer filetype fish } # Highlighters @@ -29,41 +29,41 @@ add-highlighter shared/fish/code regex \b(and|begin|bg|bind|block|break|breakpoi # Commands # ‾‾‾‾‾‾‾‾ -def -hidden fish-filter-around-selections %{ - eval -no-hooks -draft -itersel %{ +define-command -hidden fish-filter-around-selections %{ + evaluate-commands -no-hooks -draft -itersel %{ # remove trailing white spaces - try %{ exec -draft s\h+$d } + try %{ execute-keys -draft s\h+$d } } } -def -hidden fish-indent-on-char %{ - eval -no-hooks -draft -itersel %{ +define-command -hidden fish-indent-on-char %{ + evaluate-commands -no-hooks -draft -itersel %{ # align middle and end structures to start and indent when necessary - try %{ exec -draft ^\h*(else)$^\h*(if)s\A|\z' } - try %{ exec -draft ^\h*(end)$^\h*(begin|for|function|if|switch|while)s\A|\z' } - try %{ exec -draft ^\h*(case)$^\h*(switch)s\A|\z'' } + try %{ execute-keys -draft ^\h*(else)$^\h*(if)s\A|\z' } + try %{ execute-keys -draft ^\h*(end)$^\h*(begin|for|function|if|switch|while)s\A|\z' } + try %{ execute-keys -draft ^\h*(case)$^\h*(switch)s\A|\z'' } } } -def -hidden fish-indent-on-new-line %{ - eval -no-hooks -draft -itersel %{ +define-command -hidden fish-indent-on-new-line %{ + evaluate-commands -no-hooks -draft -itersel %{ # preserve previous line indent - try %{ exec -draft K } + try %{ execute-keys -draft K } # filter previous line - try %{ exec -draft k:fish-filter-around-selections } + try %{ execute-keys -draft k:fish-filter-around-selections } # indent after start structure - try %{ exec -draft k^\h*(begin|case|else|for|function|if|switch|while)\bj } + try %{ execute-keys -draft k^\h*(begin|case|else|for|function|if|switch|while)\bj } } } -def -hidden fish-insert-on-new-line %{ - eval -no-hooks -draft -itersel %{ +define-command -hidden fish-insert-on-new-line %{ + evaluate-commands -no-hooks -draft -itersel %{ # copy _#_ comment prefix and following white spaces - try %{ exec -draft ks^\h*\K#\h*yjp } + try %{ execute-keys -draft ks^\h*\K#\h*yjp } # wisely add end structure - eval -save-regs x %{ - try %{ exec -draft ks^\h+"xy } catch %{ reg x '' } - try %{ exec -draft k^x(begin|for|function|if|switch|while)jiXK^x(begin|for|function|if|switch|while).*\nxend$jxypjaend } + evaluate-commands -save-regs x %{ + try %{ execute-keys -draft ks^\h+"xy } catch %{ reg x '' } + try %{ execute-keys -draft k^x(begin|for|function|if|switch|while)jiXK^x(begin|for|function|if|switch|while).*\nxend$jxypjaend } } } } diff --git a/rc/base/gas.kak b/rc/base/gas.kak index d6f0aba7..8c4dcef6 100644 --- a/rc/base/gas.kak +++ b/rc/base/gas.kak @@ -1,7 +1,7 @@ # Detection # --------- hook global BufCreate .*\.(s|S|asm)$ %{ - set buffer filetype gas + set-option buffer filetype gas } @@ -66,22 +66,22 @@ add-highlighter shared/gas/code regex \ ^\h*(cvttp[ds]2dq|cvttp[ds]2pi|cvtts[ds]2si)\b|\ ^\h*(vxorp[sd]|vandp[sd]|ucomis[sd])\b 0:keyword -def -hidden gas-filter-around-selections %{ - eval -draft -itersel %{ - exec +define-command -hidden gas-filter-around-selections %{ + evaluate-commands -draft -itersel %{ + execute-keys # remove trailing white spaces - try %{ exec -draft s \h+$ d } + try %{ execute-keys -draft s \h+$ d } } } -def -hidden gas-indent-on-new-line %~ - eval -draft -itersel %< +define-command -hidden gas-indent-on-new-line %~ + evaluate-commands -draft -itersel %< # preserve previous line indent - try %{ exec -draft \; K } + try %{ execute-keys -draft \; K } # filter previous line - try %{ exec -draft k : gas-filter-around-selections } + try %{ execute-keys -draft k : gas-filter-around-selections } # indent after label - try %[ exec -draft k :$ j ] + try %[ execute-keys -draft k :$ j ] > ~ diff --git a/rc/base/git.kak b/rc/base/git.kak index dbf956cf..c3e82ef8 100644 --- a/rc/base/git.kak +++ b/rc/base/git.kak @@ -1,5 +1,5 @@ hook global BufCreate .*(COMMIT_EDITMSG|MERGE_MSG) %{ - set buffer filetype git-commit + set-option buffer filetype git-commit } hook -group git-commit-highlight global WinSetOption filetype=git-commit %{ @@ -12,7 +12,7 @@ hook -group git-commit-highlight global WinSetOption filetype=git-commit %{ hook -group git-commit-highlight global WinSetOption filetype=(?!git-commit).* %{ remove-highlighter window/git-commit-highlight } hook global BufCreate .*git-rebase-todo %{ - set buffer filetype git-rebase + set-option buffer filetype git-rebase } hook -group git-rebase-highlight global WinSetOption filetype=git-rebase %{ diff --git a/rc/base/go.kak b/rc/base/go.kak index 24060882..b37d813b 100644 --- a/rc/base/go.kak +++ b/rc/base/go.kak @@ -5,7 +5,7 @@ # ‾‾‾‾‾‾‾‾‾ hook global BufCreate .*\.go %{ - set buffer filetype go + set-option buffer filetype go } # Highlighters @@ -37,7 +37,7 @@ add-highlighter shared/go/code regex %{-?([0-9]*\.(?!0[xX]))?\b([0-9]+|0[xX][0-9 # Add the language's grammar to the static completion list printf %s\\n "hook global WinSetOption filetype=go %{ - set window static_words '${keywords}:${attributes}:${types}:${values}:${functions}' + set-option window static_words '${keywords}:${attributes}:${types}:${values}:${functions}' }" | sed 's,|,:,g' # Highlight keywords @@ -53,33 +53,33 @@ add-highlighter shared/go/code regex %{-?([0-9]*\.(?!0[xX]))?\b([0-9]+|0[xX][0-9 # Commands # ‾‾‾‾‾‾‾‾ -def -hidden go-indent-on-new-line %~ - eval -draft -itersel %= +define-command -hidden go-indent-on-new-line %~ + evaluate-commands -draft -itersel %= # preserve previous line indent - try %{ exec -draft \;K } + try %{ execute-keys -draft \;K } # indent after lines ending with { or ( - try %[ exec -draft k [{(]\h*$ j ] + try %[ execute-keys -draft k [{(]\h*$ j ] # cleanup trailing white spaces on the previous line - try %{ exec -draft k s \h+$ d } + try %{ execute-keys -draft k s \h+$ d } # align to opening paren of previous line - try %{ exec -draft [( \A\([^\n]+\n[^\n]*\n?\z s \A\(\h*.|.\z '' & } + try %{ execute-keys -draft [( \A\([^\n]+\n[^\n]*\n?\z s \A\(\h*.|.\z '' & } # copy // comments prefix - try %{ exec -draft \;k s ^\h*\K/{2,} yP } + try %{ execute-keys -draft \;k s ^\h*\K/{2,} yP } # indent after a switch's case/default statements - try %[ exec -draft k ^\h*(case|default).*:$ j ] + try %[ execute-keys -draft k ^\h*(case|default).*:$ j ] # indent after if|else|while|for - try %[ exec -draft \;)MB \A(if|else|while|for)\h*\(.*\)\h*\n\h*\n?\z s \A|.\z 11 ] + try %[ execute-keys -draft \;)MB \A(if|else|while|for)\h*\(.*\)\h*\n\h*\n?\z s \A|.\z 11 ] = ~ -def -hidden go-indent-on-opening-curly-brace %[ +define-command -hidden go-indent-on-opening-curly-brace %[ # align indent with opening paren when { is entered on a new line after the closing paren - try %[ exec -draft -itersel h)M \A\(.*\)\h*\n\h*\{\z s \A|.\z 1 ] + try %[ execute-keys -draft -itersel h)M \A\(.*\)\h*\n\h*\{\z s \A|.\z 1 ] ] -def -hidden go-indent-on-closing-curly-brace %[ +define-command -hidden go-indent-on-closing-curly-brace %[ # align to opening curly brace when alone on a line - try %[ exec -itersel -draft ^\h+\}$hms\A|.\z1 ] + try %[ execute-keys -itersel -draft ^\h+\}$hms\A|.\z1 ] ] # Initialization @@ -89,7 +89,7 @@ hook -group go-highlight global WinSetOption filetype=go %{ add-highlighter wind hook global WinSetOption filetype=go %{ # cleanup trailing whitespaces when exiting insert mode - hook window InsertEnd .* -group go-hooks %{ try %{ exec -draft s^\h+$d } } + hook window InsertEnd .* -group go-hooks %{ try %{ execute-keys -draft s^\h+$d } } hook window InsertChar \n -group go-indent go-indent-on-new-line hook window InsertChar \{ -group go-indent go-indent-on-opening-curly-brace hook window InsertChar \} -group go-indent go-indent-on-closing-curly-brace diff --git a/rc/base/haskell.kak b/rc/base/haskell.kak index 2253c2a9..b5e60c30 100644 --- a/rc/base/haskell.kak +++ b/rc/base/haskell.kak @@ -5,7 +5,7 @@ # ‾‾‾‾‾‾‾‾‾ hook global BufCreate .*[.](hs) %{ - set buffer filetype haskell + set-option buffer filetype haskell } # Highlighters @@ -72,23 +72,23 @@ add-highlighter shared/haskell/code regex \B'([^\\]|[\\]['"\w\d\\])' 0:string # http://en.wikibooks.org/wiki/Haskell/Indentation -def -hidden haskell-filter-around-selections %{ +define-command -hidden haskell-filter-around-selections %{ # remove trailing white spaces - try %{ exec -draft -itersel s \h+$ d } + try %{ execute-keys -draft -itersel s \h+$ d } } -def -hidden haskell-indent-on-new-line %{ - eval -draft -itersel %{ +define-command -hidden haskell-indent-on-new-line %{ + evaluate-commands -draft -itersel %{ # copy -- comments prefix and following white spaces - try %{ exec -draft k s ^\h*\K--\h* y gh j P } + try %{ execute-keys -draft k s ^\h*\K--\h* y gh j P } # preserve previous line indent - try %{ exec -draft \; K } + try %{ execute-keys -draft \; K } # align to first clause - try %{ exec -draft \; k x X s ^\h*(if|then|else)?\h*(([\w']+\h+)+=)?\h*(case\h+[\w']+\h+of|do|let|where)\h+\K.* s \A|.\z & } + try %{ execute-keys -draft \; k x X s ^\h*(if|then|else)?\h*(([\w']+\h+)+=)?\h*(case\h+[\w']+\h+of|do|let|where)\h+\K.* s \A|.\z & } # filter previous line - try %{ exec -draft k : haskell-filter-around-selections } + try %{ execute-keys -draft k : haskell-filter-around-selections } # indent after lines beginning with condition or ending with expression or =( - try %{ exec -draft \; k x ^\h*(if)|(case\h+[\w']+\h+of|do|let|where|[=(])$ j } + try %{ execute-keys -draft \; k x ^\h*(if)|(case\h+[\w']+\h+of|do|let|where|[=(])$ j } } } @@ -98,7 +98,7 @@ def -hidden haskell-indent-on-new-line %{ hook -group haskell-highlight global WinSetOption filetype=haskell %{ add-highlighter window ref haskell } hook global WinSetOption filetype=haskell %{ - set window extra_word_chars "'" + set-option window extra_word_chars "'" hook window InsertEnd .* -group haskell-hooks haskell-filter-around-selections hook window InsertChar \n -group haskell-indent haskell-indent-on-new-line } diff --git a/rc/base/html.kak b/rc/base/html.kak index cd43e66d..e4f465ca 100644 --- a/rc/base/html.kak +++ b/rc/base/html.kak @@ -5,11 +5,11 @@ # ‾‾‾‾‾‾‾‾‾ hook global BufCreate .*\.html %{ - set buffer filetype html + set-option buffer filetype html } hook global BufCreate .*\.xml %{ - set buffer filetype xml + set-option buffer filetype xml } # Highlighters @@ -39,26 +39,26 @@ add-highlighter shared/html/tag/content/string fill string # Commands # ‾‾‾‾‾‾‾‾ -def -hidden html-filter-around-selections %{ +define-command -hidden html-filter-around-selections %{ # remove trailing white spaces - try %{ exec -draft -itersel s \h+$ d } + try %{ execute-keys -draft -itersel s \h+$ d } } -def -hidden html-indent-on-greater-than %[ - eval -draft -itersel %[ +define-command -hidden html-indent-on-greater-than %[ + evaluate-commands -draft -itersel %[ # align closing tag to opening when alone on a line - try %[ exec -draft s ^\h+/(\w+)$ {c1,/1 s \A|.\z 1 ] + try %[ execute-keys -draft s ^\h+/(\w+)$ {c1,/1 s \A|.\z 1 ] ] ] -def -hidden html-indent-on-new-line %{ - eval -draft -itersel %{ +define-command -hidden html-indent-on-new-line %{ + evaluate-commands -draft -itersel %{ # preserve previous line indent - try %{ exec -draft \; K } + try %{ execute-keys -draft \; K } # filter previous line - try %{ exec -draft k : html-filter-around-selections } + try %{ execute-keys -draft k : html-filter-around-selections } # indent after lines ending with opening tag - try %{ exec -draft k <[^/][^>]+>$ j } + try %{ execute-keys -draft k <[^/][^>]+>$ j } } } diff --git a/rc/base/ini.kak b/rc/base/ini.kak index 3da27982..7f64e87c 100644 --- a/rc/base/ini.kak +++ b/rc/base/ini.kak @@ -1,5 +1,5 @@ hook global BufCreate .*\.(repo|service|target|socket|ini|cfg) %{ - set buffer filetype ini + set-option buffer filetype ini } add-highlighter shared/ regions -default code ini \ diff --git a/rc/base/java.kak b/rc/base/java.kak index 3256bfa9..2d107e43 100644 --- a/rc/base/java.kak +++ b/rc/base/java.kak @@ -1,5 +1,5 @@ hook global BufCreate .*\.java %{ - set buffer filetype java + set-option buffer filetype java } add-highlighter shared/ regions -default code java \ @@ -18,40 +18,40 @@ add-highlighter shared/java/code regex "\b(final|public|protected|private|abstra # Commands # ‾‾‾‾‾‾‾‾ -def -hidden java-indent-on-new-line %~ - eval -draft -itersel %= +define-command -hidden java-indent-on-new-line %~ + evaluate-commands -draft -itersel %= # preserve previous line indent - try %{ exec -draft \;K } + try %{ execute-keys -draft \;K } # indent after lines ending with { or ( - try %[ exec -draft k [{(]\h*$ j ] + try %[ execute-keys -draft k [{(]\h*$ j ] # cleanup trailing white spaces on the previous line - try %{ exec -draft k s \h+$ d } + try %{ execute-keys -draft k s \h+$ d } # align to opening paren of previous line - try %{ exec -draft [( \A\([^\n]+\n[^\n]*\n?\z s \A\(\h*.|.\z '' & } + try %{ execute-keys -draft [( \A\([^\n]+\n[^\n]*\n?\z s \A\(\h*.|.\z '' & } # copy // comments prefix - try %{ exec -draft \;k s ^\h*\K/{2,} yP } + try %{ execute-keys -draft \;k s ^\h*\K/{2,} yP } # indent after a switch's case/default statements - try %[ exec -draft k ^\h*(case|default).*:$ j ] + try %[ execute-keys -draft k ^\h*(case|default).*:$ j ] # indent after keywords - try %[ exec -draft \;)MB \A(if|else|while|for|try|catch)\h*\(.*\)\h*\n\h*\n?\z s \A|.\z 11 ] + try %[ execute-keys -draft \;)MB \A(if|else|while|for|try|catch)\h*\(.*\)\h*\n\h*\n?\z s \A|.\z 11 ] = ~ -def -hidden java-indent-on-opening-curly-brace %[ +define-command -hidden java-indent-on-opening-curly-brace %[ # align indent with opening paren when { is entered on a new line after the closing paren - try %[ exec -draft -itersel h)M \A\(.*\)\h*\n\h*\{\z s \A|.\z 1 ] + try %[ execute-keys -draft -itersel h)M \A\(.*\)\h*\n\h*\{\z s \A|.\z 1 ] ] -def -hidden java-indent-on-closing-curly-brace %[ +define-command -hidden java-indent-on-closing-curly-brace %[ # align to opening curly brace when alone on a line - try %[ exec -itersel -draft ^\h+\}$hms\A|.\z1 ] + try %[ execute-keys -itersel -draft ^\h+\}$hms\A|.\z1 ] ] # Initialization # ‾‾‾‾‾‾‾‾‾‾‾‾‾‾ hook global WinSetOption filetype=java %{ # cleanup trailing whitespaces when exiting insert mode - hook window InsertEnd .* -group java-hooks %{ try %{ exec -draft s^\h+$d } } + hook window InsertEnd .* -group java-hooks %{ try %{ execute-keys -draft s^\h+$d } } hook window InsertChar \n -group java-indent java-indent-on-new-line hook window InsertChar \{ -group java-indent java-indent-on-opening-curly-brace hook window InsertChar \} -group java-indent java-indent-on-closing-curly-brace diff --git a/rc/base/javascript.kak b/rc/base/javascript.kak index a8092707..6f4a7a2b 100644 --- a/rc/base/javascript.kak +++ b/rc/base/javascript.kak @@ -2,7 +2,7 @@ # ‾‾‾‾‾‾‾‾‾ hook global BufCreate .*[.](js) %{ - set buffer filetype javascript + set-option buffer filetype javascript } # Highlighters @@ -39,28 +39,28 @@ add-highlighter shared/javascript/code regex \b(async|await|break|case|catch|cla # Commands # ‾‾‾‾‾‾‾‾ -def -hidden javascript-filter-around-selections %{ +define-command -hidden javascript-filter-around-selections %{ # remove trailing white spaces - try %{ exec -draft -itersel s \h+$ d } + try %{ execute-keys -draft -itersel s \h+$ d } } -def -hidden javascript-indent-on-char %< - eval -draft -itersel %< +define-command -hidden javascript-indent-on-char %< + evaluate-commands -draft -itersel %< # align closer token to its opener when alone on a line - try %/ exec -draft ^\h+[]}]$ m s \A|.\z 1 / + try %/ execute-keys -draft ^\h+[]}]$ m s \A|.\z 1 / > > -def -hidden javascript-indent-on-new-line %< - eval -draft -itersel %< +define-command -hidden javascript-indent-on-new-line %< + evaluate-commands -draft -itersel %< # copy // comments prefix and following white spaces - try %{ exec -draft k s ^\h*\K#\h* y gh j P } + try %{ execute-keys -draft k s ^\h*\K#\h* y gh j P } # preserve previous line indent - try %{ exec -draft \; K } + try %{ execute-keys -draft \; K } # filter previous line - try %{ exec -draft k : javascript-filter-around-selections } + try %{ execute-keys -draft k : javascript-filter-around-selections } # indent after lines beginning / ending with opener token - try %_ exec -draft k ^\h*[[{]|[[{]$ j _ + try %_ execute-keys -draft k ^\h*[[{]|[[{]$ j _ > > diff --git a/rc/base/json.kak b/rc/base/json.kak index 848373fe..c53193d0 100644 --- a/rc/base/json.kak +++ b/rc/base/json.kak @@ -5,7 +5,7 @@ # ‾‾‾‾‾‾‾‾‾ hook global BufCreate .*[.](json) %{ - set buffer filetype json + set-option buffer filetype json } # Highlighters @@ -21,26 +21,26 @@ add-highlighter shared/json/code regex \b(true|false|null|\d+(?:\.\d+)?(?:[eE][+ # Commands # ‾‾‾‾‾‾‾‾ -def -hidden json-filter-around-selections %{ +define-command -hidden json-filter-around-selections %{ # remove trailing white spaces - try %{ exec -draft -itersel s \h+$ d } + try %{ execute-keys -draft -itersel s \h+$ d } } -def -hidden json-indent-on-char %< - eval -draft -itersel %< +define-command -hidden json-indent-on-char %< + evaluate-commands -draft -itersel %< # align closer token to its opener when alone on a line - try %< exec -draft ^\h+[]}]$ m s \A|.\z 1 > + try %< execute-keys -draft ^\h+[]}]$ m s \A|.\z 1 > > > -def -hidden json-indent-on-new-line %< - eval -draft -itersel %< +define-command -hidden json-indent-on-new-line %< + evaluate-commands -draft -itersel %< # preserve previous line indent - try %{ exec -draft \; K } + try %{ execute-keys -draft \; K } # filter previous line - try %{ exec -draft k : json-filter-around-selections } + try %{ execute-keys -draft k : json-filter-around-selections } # indent after lines beginning with opener token - try %< exec -draft k ^\h*[[{] j > + try %< execute-keys -draft k ^\h*[[{] j > > > diff --git a/rc/base/julia.kak b/rc/base/julia.kak index d04b086f..19219830 100644 --- a/rc/base/julia.kak +++ b/rc/base/julia.kak @@ -5,7 +5,7 @@ # ‾‾‾‾‾‾‾‾‾ hook global BufCreate .*\.(jl) %{ - set buffer filetype julia + set-option buffer filetype julia } # Highlighters diff --git a/rc/base/lint.kak b/rc/base/lint.kak index 55be2b0e..51afd2e2 100644 --- a/rc/base/lint.kak +++ b/rc/base/lint.kak @@ -1,21 +1,21 @@ -decl -docstring %{shell command to which the path of a copy of the current buffer will be passed +declare-option -docstring %{shell command to which the path of a copy of the current buffer will be passed The output returned by this command is expected to comply with the following format: {filename}:{line}:{column}: {kind}: {message}} \ str lintcmd -decl -hidden line-specs lint_flags -decl -hidden range-specs lint_errors +declare-option -hidden line-specs lint_flags +declare-option -hidden range-specs lint_errors -def lint -docstring 'Parse the current buffer with a linter' %{ +define-command lint -docstring 'Parse the current buffer with a linter' %{ %sh{ dir=$(mktemp -d "${TMPDIR:-/tmp}"/kak-lint.XXXXXXXX) mkfifo "$dir"/fifo - printf '%s\n' "eval -no-hooks write $dir/buf" + printf '%s\n' "evaluate-commands -no-hooks write $dir/buf" - printf '%s\n' "eval -draft %{ + printf '%s\n' "evaluate-commands -draft %{ edit! -fifo $dir/fifo -debug *lint-output* - set buffer filetype make - set buffer make_current_error_line 0 + set-option buffer filetype make + set-option buffer make_current_error_line 0 hook -group fifo buffer BufCloseFifo .* %{ nop %sh{ rm -r '$dir' } remove-hooks buffer fifo @@ -24,8 +24,8 @@ def lint -docstring 'Parse the current buffer with a linter' %{ { # do the parsing in the background and when ready send to the session - eval "$kak_opt_lintcmd '$dir'/buf" | sort -t: -k2,2 -n > "$dir"/stderr - printf '%s\n' "eval -client $kak_client echo 'linting done'" | kak -p "$kak_session" + evaluate-commands "$kak_opt_lintcmd '$dir'/buf" | sort -t: -k2,2 -n > "$dir"/stderr + printf '%s\n' "evaluate-commands -client $kak_client echo 'linting done'" | kak -p "$kak_session" # Flags for the gutter: # line3|{red}:line11|{yellow} @@ -48,10 +48,10 @@ def lint -docstring 'Parse the current buffer with a linter' %{ errors = substr(errors, 1, length(errors)-1) " (col " $3 ")" } END { - print "set \"buffer=" file "\" lint_flags %{" stamp ":" substr(flags, 1, length(flags)-1) "}" + print "set-option \"buffer=" file "\" lint_flags %{" stamp ":" substr(flags, 1, length(flags)-1) "}" errors = substr(errors, 1, length(errors)-1) gsub("~", "\\~", errors) - print "set \"buffer=" file "\" lint_errors %~" stamp errors "~" + print "set-option \"buffer=" file "\" lint_errors %~" stamp errors "~" } ' "$dir"/stderr | kak -p "$kak_session" @@ -61,7 +61,7 @@ def lint -docstring 'Parse the current buffer with a linter' %{ } } -def -hidden lint-show %{ +define-command -hidden lint-show %{ update-option buffer lint_errors %sh{ desc=$(printf '%s\n' "$kak_opt_lint_errors" | sed -e 's/\([^\\]\):/\1\n/g' | tail -n +2 | @@ -71,17 +71,17 @@ def -hidden lint-show %{ fi } } -def lint-enable -docstring "Activate automatic diagnostics of the code" %{ +define-command lint-enable -docstring "Activate automatic diagnostics of the code" %{ add-highlighter window flag_lines default lint_flags hook window -group lint-diagnostics NormalIdle .* %{ lint-show } } -def lint-disable -docstring "Disable automatic diagnostics of the code" %{ +define-command lint-disable -docstring "Disable automatic diagnostics of the code" %{ remove-highlighter window/hlflags_lint_flags remove-hooks window lint-diagnostics } -def lint-next-error -docstring "Jump to the next line that contains an error" %{ +define-command lint-next-error -docstring "Jump to the next line that contains an error" %{ update-option buffer lint_errors %sh{ printf '%s\n' "$kak_opt_lint_errors" | sed -e 's/\([^\\]\):/\1\n/g' | tail -n +2 | { @@ -102,7 +102,7 @@ def lint-next-error -docstring "Jump to the next line that contains an error" %{ } }} -def lint-previous-error -docstring "Jump to the previous line that contains an error" %{ +define-command lint-previous-error -docstring "Jump to the previous line that contains an error" %{ update-option buffer lint_errors %sh{ printf '%s\n' "$kak_opt_lint_errors" | sed -e 's/\([^\\]\):/\1\n/g' | tail -n +2 | sort -t. -k1,1 -rn | { diff --git a/rc/base/lisp.kak b/rc/base/lisp.kak index 427713c9..c85b39bf 100644 --- a/rc/base/lisp.kak +++ b/rc/base/lisp.kak @@ -5,7 +5,7 @@ # ‾‾‾‾‾‾‾‾‾ hook global BufCreate .*[.](lisp) %{ - set buffer filetype lisp + set-option buffer filetype lisp } # Highlighters @@ -26,17 +26,17 @@ add-highlighter shared/lisp/code regex \b(def[a-z]+|if|do|let|lambda|catch|and|a # Commands # ‾‾‾‾‾‾‾‾ -def -hidden lisp-filter-around-selections %{ +define-command -hidden lisp-filter-around-selections %{ # remove trailing white spaces - try %{ exec -draft -itersel s \h+$ d } + try %{ execute-keys -draft -itersel s \h+$ d } } -def -hidden lisp-indent-on-new-line %{ - eval -draft -itersel %{ +define-command -hidden lisp-indent-on-new-line %{ + evaluate-commands -draft -itersel %{ # preserve previous line indent - try %{ exec -draft \; K } + try %{ execute-keys -draft \; K } # indent when matches opening paren - try %{ exec -draft [( \A\([^\n]+\n[^\n]*\n?\z \; } + try %{ execute-keys -draft [( \A\([^\n]+\n[^\n]*\n?\z \; } } } diff --git a/rc/base/lua.kak b/rc/base/lua.kak index 46979484..9ec31b93 100644 --- a/rc/base/lua.kak +++ b/rc/base/lua.kak @@ -5,7 +5,7 @@ # ‾‾‾‾‾‾‾‾‾ hook global BufCreate .*[.](lua) %{ - set buffer filetype lua + set-option buffer filetype lua } # Highlighters @@ -26,7 +26,7 @@ add-highlighter shared/lua/code regex \b(and|break|do|else|elseif|end|false|for| # Commands # ‾‾‾‾‾‾‾‾ -def lua-alternative-file -docstring 'Jump to the alternate file (implementation ↔ test)' %{ %sh{ +define-command lua-alternative-file -docstring 'Jump to the alternate file (implementation ↔ test)' %{ %sh{ case $kak_buffile in *spec/*_spec.lua) altfile=$(eval printf %s\\n $(printf %s\\n $kak_buffile | sed s+spec/+'*'/+';'s/_spec//)) @@ -51,40 +51,40 @@ def lua-alternative-file -docstring 'Jump to the alternate file (implementation printf %s\\n "edit $altfile" }} -def -hidden lua-filter-around-selections %{ - eval -no-hooks -draft -itersel %{ +define-command -hidden lua-filter-around-selections %{ + evaluate-commands -no-hooks -draft -itersel %{ # remove trailing white spaces - try %{ exec -draft s\h+$d } + try %{ execute-keys -draft s\h+$d } } } -def -hidden lua-indent-on-char %{ - eval -no-hooks -draft -itersel %{ +define-command -hidden lua-indent-on-char %{ + evaluate-commands -no-hooks -draft -itersel %{ # align middle and end structures to start and indent when necessary, elseif is already covered by else - try %{ exec -draft ^\h*(else)$^\h*(if)s\A|\z' } - try %{ exec -draft ^\h*(end)$^\h*(for|function|if|while)s\A|\z' } + try %{ execute-keys -draft ^\h*(else)$^\h*(if)s\A|\z' } + try %{ execute-keys -draft ^\h*(end)$^\h*(for|function|if|while)s\A|\z' } } } -def -hidden lua-indent-on-new-line %{ - eval -no-hooks -draft -itersel %{ +define-command -hidden lua-indent-on-new-line %{ + evaluate-commands -no-hooks -draft -itersel %{ # preserve previous line indent - try %{ exec -draft K } + try %{ execute-keys -draft K } # filter previous line - try %{ exec -draft k:lua-filter-around-selections } + try %{ execute-keys -draft k:lua-filter-around-selections } # indent after start structure - try %{ exec -draft k^\h*(else|elseif|for|function|if|while)\bj } + try %{ execute-keys -draft k^\h*(else|elseif|for|function|if|while)\bj } } } -def -hidden lua-insert-on-new-line %{ - eval -no-hooks -draft -itersel %{ +define-command -hidden lua-insert-on-new-line %{ + evaluate-commands -no-hooks -draft -itersel %{ # copy -- comment prefix and following white spaces - try %{ exec -draft ks^\h*\K--\h*yghjP } + try %{ execute-keys -draft ks^\h*\K--\h*yghjP } # wisely add end structure - eval -save-regs x %{ - try %{ exec -draft ks^\h+"xy } catch %{ reg x '' } - try %{ exec -draft k^x(for|function|if|while)jiXK^x(for|function|if|while).*\nx(else|end|elseif[^\n]*)$jxypjaend } + evaluate-commands -save-regs x %{ + try %{ execute-keys -draft ks^\h+"xy } catch %{ reg x '' } + try %{ execute-keys -draft k^x(for|function|if|while)jiXK^x(for|function|if|while).*\nx(else|end|elseif[^\n]*)$jxypjaend } } } } diff --git a/rc/base/mail.kak b/rc/base/mail.kak index 63839e0e..86b76193 100644 --- a/rc/base/mail.kak +++ b/rc/base/mail.kak @@ -1,5 +1,5 @@ hook global BufCreate .+\.eml %{ - set buffer filetype mail + set-option buffer filetype mail } add-highlighter shared/ group mail diff --git a/rc/base/markdown.kak b/rc/base/markdown.kak index d1cbec9b..0aa09719 100644 --- a/rc/base/markdown.kak +++ b/rc/base/markdown.kak @@ -5,7 +5,7 @@ # ‾‾‾‾‾‾‾‾‾ hook global BufCreate .*[.](markdown|md|mkd) %{ - set buffer filetype markdown + set-option buffer filetype markdown } # Highlighters @@ -123,14 +123,14 @@ add-highlighter shared/markdown/content regex \H\K\h\h$ 0:PrimarySelection # Commands # ‾‾‾‾‾‾‾‾ -def -hidden markdown-indent-on-new-line %{ - eval -draft -itersel %{ +define-command -hidden markdown-indent-on-new-line %{ + evaluate-commands -draft -itersel %{ # copy block quote(s), list item prefix and following white spaces - try %{ exec -draft k s ^\h*\K((>\h*)+([*+-]\h)?|(>\h*)*[*+-]\h)\h* y gh j P } + try %{ execute-keys -draft k s ^\h*\K((>\h*)+([*+-]\h)?|(>\h*)*[*+-]\h)\h* y gh j P } # preserve previous line indent - try %{ exec -draft \; K } + try %{ execute-keys -draft \; K } # remove trailing white spaces - try %{ exec -draft -itersel %{ k s \h+$ d } } + try %{ execute-keys -draft -itersel %{ k s \h+$ d } } } } diff --git a/rc/base/mercurial.kak b/rc/base/mercurial.kak index 3e2a3eac..c626e883 100644 --- a/rc/base/mercurial.kak +++ b/rc/base/mercurial.kak @@ -4,13 +4,13 @@ # Faces # ‾‾‾‾‾ -face MercurialCommitComment cyan +set-face MercurialCommitComment cyan # Detection # ‾‾‾‾‾‾‾‾‾ hook global BufCreate .*hg-editor-\w+\.txt$ %{ - set buffer filetype hg-commit + set-option buffer filetype hg-commit } hook -group hg-commit-highlight global WinSetOption filetype=(?!hg-commit).* %{ diff --git a/rc/base/ocaml.kak b/rc/base/ocaml.kak index e6e29dc5..2e81f20d 100644 --- a/rc/base/ocaml.kak +++ b/rc/base/ocaml.kak @@ -7,7 +7,7 @@ # ‾‾‾‾‾‾‾‾‾ hook global BufCreate .*\.mli? %{ - set buffer filetype ocaml + set-option buffer filetype ocaml } # Highlighters @@ -23,9 +23,9 @@ add-highlighter shared/ocaml/comment fill comment # Commands # ‾‾‾‾‾‾‾‾ -def -hidden ocaml-indent-on-char %{ - eval -no-hooks -draft -itersel %{ - exec ";iGg|ocp-indent --config base=%opt{indentwidth} --indent-empty --lines %val{cursor_line}" +define-command -hidden ocaml-indent-on-char %{ + evaluate-commands -no-hooks -draft -itersel %{ + execute-keys ";iGg|ocp-indent --config base=%opt{indentwidth} --indent-empty --lines %val{cursor_line}" } } @@ -52,7 +52,7 @@ hook global WinSetOption filetype=(?!ocaml).* %{ echo " add-highlighter shared/ocaml/code regex \b($(printf $keywords | tr : '|'))\b 0:keyword hook global WinSetOption filetype=ocaml %{ - set window static_words $keywords + set-option window static_words $keywords } hook global WinSetOption filetype=(?!ocaml).* %{ unset window static_words diff --git a/rc/base/perl.kak b/rc/base/perl.kak index 89e3b890..04dc9ec4 100644 --- a/rc/base/perl.kak +++ b/rc/base/perl.kak @@ -5,7 +5,7 @@ # ‾‾‾‾‾‾‾‾‾ hook global BufCreate .*\.p[lm] %{ - set buffer filetype perl + set-option buffer filetype perl } # Highlighters @@ -41,7 +41,7 @@ add-highlighter shared/perl/comment fill comment # Add the language's grammar to the static completion list printf %s\\n "hook global WinSetOption filetype=perl %{ - set window static_words '${keywords}:${attributes}:${values}' + set-option window static_words '${keywords}:${attributes}:${values}' }" | sed 's,|,:,g' # Highlight keywords @@ -70,33 +70,33 @@ add-highlighter shared/perl/code regex \$(LAST_REGEXP_CODE_RESULT|LIST_SEPARATOR # Commands # ‾‾‾‾‾‾‾‾ -def -hidden perl-indent-on-new-line %~ - eval -draft -itersel %= +define-command -hidden perl-indent-on-new-line %~ + evaluate-commands -draft -itersel %= # preserve previous line indent - try %{ exec -draft \;K } + try %{ execute-keys -draft \;K } # indent after lines ending with { or ( - try %[ exec -draft k [{(]\h*$ j ] + try %[ execute-keys -draft k [{(]\h*$ j ] # cleanup trailing white spaces on the previous line - try %{ exec -draft k s \h+$ d } + try %{ execute-keys -draft k s \h+$ d } # align to opening paren of previous line - try %{ exec -draft [( \A\([^\n]+\n[^\n]*\n?\z s \A\(\h*.|.\z '' & } + try %{ execute-keys -draft [( \A\([^\n]+\n[^\n]*\n?\z s \A\(\h*.|.\z '' & } # copy // comments prefix - try %{ exec -draft \;k s ^\h*\K/{2,} yP } + try %{ execute-keys -draft \;k s ^\h*\K/{2,} yP } # indent after a switch's case/default statements - try %[ exec -draft k ^\h*(case|default).*:$ j ] + try %[ execute-keys -draft k ^\h*(case|default).*:$ j ] # indent after if|else|while|for - try %[ exec -draft \;)MB \A(if|else|while|for)\h*\(.*\)\h*\n\h*\n?\z s \A|.\z 11 ] + try %[ execute-keys -draft \;)MB \A(if|else|while|for)\h*\(.*\)\h*\n\h*\n?\z s \A|.\z 11 ] = ~ -def -hidden perl-indent-on-opening-curly-brace %[ +define-command -hidden perl-indent-on-opening-curly-brace %[ # align indent with opening paren when { is entered on a new line after the closing paren - try %[ exec -draft -itersel h)M \A\(.*\)\h*\n\h*\{\' s \A|.\z 1 ] + try %[ execute-keys -draft -itersel h)M \A\(.*\)\h*\n\h*\{\' s \A|.\z 1 ] ] -def -hidden perl-indent-on-closing-curly-brace %[ +define-command -hidden perl-indent-on-closing-curly-brace %[ # align to opening curly brace when alone on a line - try %[ exec -itersel -draft ^\h+\}$hms\A|.\z1 ] + try %[ execute-keys -itersel -draft ^\h+\}$hms\A|.\z1 ] ] # Initialization @@ -106,7 +106,7 @@ hook -group perl-highlight global WinSetOption filetype=perl %{ add-highlighter hook global WinSetOption filetype=perl %{ # cleanup trailing whitespaces when exiting insert mode - hook window InsertEnd .* -group perl-hooks %{ try %{ exec -draft s^\h+$d } } + hook window InsertEnd .* -group perl-hooks %{ try %{ execute-keys -draft s^\h+$d } } hook window InsertChar \n -group perl-indent perl-indent-on-new-line hook window InsertChar \{ -group perl-indent perl-indent-on-opening-curly-brace hook window InsertChar \} -group perl-indent perl-indent-on-closing-curly-brace diff --git a/rc/base/ruby.kak b/rc/base/ruby.kak index eb8bf01a..edd11633 100644 --- a/rc/base/ruby.kak +++ b/rc/base/ruby.kak @@ -5,7 +5,7 @@ # ‾‾‾‾‾‾‾‾‾ hook global BufCreate .*(([.](rb))|(irbrc)|(pryrc)|(Capfile|[.]cap)|(Gemfile)|(Guardfile)|(Rakefile|[.]rake)|(Thorfile|[.]thor)|(Vagrantfile)) %{ - set buffer filetype ruby + set-option buffer filetype ruby } # Highlighters @@ -60,7 +60,7 @@ add-highlighter shared/ruby/code regex \b([A-Za-z]\w*:(?!:))|([$@][A-Za-z]\w*)|( # Add the language's grammar to the static completion list printf %s\\n "hook global WinSetOption filetype=ruby %{ - set window static_words '${keywords}:${attributes}:${values}:${meta}' + set-option window static_words '${keywords}:${attributes}:${values}:${meta}' }" | sed 's,|,:,g' # Highlight keywords @@ -75,7 +75,7 @@ add-highlighter shared/ruby/code regex \b([A-Za-z]\w*:(?!:))|([$@][A-Za-z]\w*)|( # Commands # ‾‾‾‾‾‾‾‾ -def ruby-alternative-file -docstring 'Jump to the alternate file (implementation ↔ test)' %{ %sh{ +define-command ruby-alternative-file -docstring 'Jump to the alternate file (implementation ↔ test)' %{ %sh{ case $kak_buffile in *spec/*_spec.rb) altfile=$(eval echo $(echo $kak_buffile | sed s+spec/+'*'/+';'s/_spec//)) @@ -100,43 +100,43 @@ def ruby-alternative-file -docstring 'Jump to the alternate file (implementation echo "edit $altfile" }} -def -hidden ruby-filter-around-selections %{ - eval -no-hooks -draft -itersel %{ - exec +define-command -hidden ruby-filter-around-selections %{ + evaluate-commands -no-hooks -draft -itersel %{ + execute-keys # remove trailing white spaces - try %{ exec -draft s \h + $ d } + try %{ execute-keys -draft s \h + $ d } } } -def -hidden ruby-indent-on-char %{ - eval -no-hooks -draft -itersel %{ +define-command -hidden ruby-indent-on-char %{ + evaluate-commands -no-hooks -draft -itersel %{ # align middle and end structures to start - try %{ exec -draft ^ \h * (else|elsif) $ ^ \h * (if) s \A | \z \' } - try %{ exec -draft ^ \h * (when) $ ^ \h * (case) s \A | \z \' } - try %{ exec -draft ^ \h * (rescue) $ ^ \h * (begin) s \A | \z \' } - try %{ exec -draft ^ \h * (end) $ ^ \h * (begin|case|class|def|do|for|if|module|unless|until|while) s \A | \z \' } + try %{ execute-keys -draft ^ \h * (else|elsif) $ ^ \h * (if) s \A | \z \' } + try %{ execute-keys -draft ^ \h * (when) $ ^ \h * (case) s \A | \z \' } + try %{ execute-keys -draft ^ \h * (rescue) $ ^ \h * (begin) s \A | \z \' } + try %{ execute-keys -draft ^ \h * (end) $ ^ \h * (begin|case|class|def|do|for|if|module|unless|until|while) s \A | \z \' } } } -def -hidden ruby-indent-on-new-line %{ - eval -no-hooks -draft -itersel %{ +define-command -hidden ruby-indent-on-new-line %{ + evaluate-commands -no-hooks -draft -itersel %{ # preserve previous line indent - try %{ exec -draft K } + try %{ execute-keys -draft K } # filter previous line - try %{ exec -draft k : ruby-filter-around-selections } + try %{ execute-keys -draft k : ruby-filter-around-selections } # indent after start structure - try %{ exec -draft k ^ \h * (begin|case|class|def|do|else|elsif|ensure|for|if|module|rescue|unless|until|when|while) \b j } + try %{ execute-keys -draft k ^ \h * (begin|case|class|def|do|else|elsif|ensure|for|if|module|rescue|unless|until|when|while) \b j } } } -def -hidden ruby-insert-on-new-line %{ - eval -no-hooks -draft -itersel %{ +define-command -hidden ruby-insert-on-new-line %{ + evaluate-commands -no-hooks -draft -itersel %{ # copy _#_ comment prefix and following white spaces - try %{ exec -draft k s '^\h*\K#\h*' y gh j P } + try %{ execute-keys -draft k s '^\h*\K#\h*' y gh j P } # wisely add end structure - eval -save-regs x %{ - try %{ exec -draft k s ^ \h + \" x y } catch %{ reg x '' } - try %{ exec -draft k ^ x (begin|case|class|def|do|for|if|module|unless|until|while) j i X K ^ x (begin|case|class|def|do|for|if|module|unless|until|while) . * \n x end $ j x y p j a end } + evaluate-commands -save-regs x %{ + try %{ execute-keys -draft k s ^ \h + \" x y } catch %{ reg x '' } + try %{ execute-keys -draft k ^ x (begin|case|class|def|do|for|if|module|unless|until|while) j i X K ^ x (begin|case|class|def|do|for|if|module|unless|until|while) . * \n x end $ j x y p j a end } } } } diff --git a/rc/base/rust.kak b/rc/base/rust.kak index 0b766f00..d5e7ded0 100644 --- a/rc/base/rust.kak +++ b/rc/base/rust.kak @@ -5,7 +5,7 @@ # ‾‾‾‾‾‾‾‾‾ hook global BufCreate .*[.](rust|rs) %{ - set buffer filetype rust + set-option buffer filetype rust } # Highlighters @@ -34,37 +34,37 @@ add-highlighter shared/rust/code regex \b(?:u8|u16|u32|u64|usize|i8|i16|i32|i64| # Commands # ‾‾‾‾‾‾‾‾ -def -hidden rust-filter-around-selections %{ +define-command -hidden rust-filter-around-selections %{ # remove trailing white spaces - try %{ exec -draft -itersel s \h+$ d } + try %{ execute-keys -draft -itersel s \h+$ d } } -def -hidden rust-indent-on-new-line %~ - eval -draft -itersel %< +define-command -hidden rust-indent-on-new-line %~ + evaluate-commands -draft -itersel %< # copy // comments prefix and following white spaces - try %{ exec -draft k s ^\h*\K//\h* y gh j P } + try %{ execute-keys -draft k s ^\h*\K//\h* y gh j P } # preserve previous line indent - try %{ exec -draft \; K } + try %{ execute-keys -draft \; K } # filter previous line - try %{ exec -draft k : rust-filter-around-selections } + try %{ execute-keys -draft k : rust-filter-around-selections } # indent after lines ending with { or ( - try %[ exec -draft k [{(]\h*$ j ] + try %[ execute-keys -draft k [{(]\h*$ j ] # align to opening paren of previous line - try %{ exec -draft [( \A\([^\n]+\n[^\n]*\n?\z s \A\(\h*.|.\z & } + try %{ execute-keys -draft [( \A\([^\n]+\n[^\n]*\n?\z s \A\(\h*.|.\z & } > ~ -def -hidden rust-indent-on-opening-curly-brace %[ - eval -draft -itersel %_ +define-command -hidden rust-indent-on-opening-curly-brace %[ + evaluate-commands -draft -itersel %_ # align indent with opening paren when { is entered on a new line after the closing paren - try %[ exec -draft h ) M \A\(.*\)\h*\n\h*\{\z s \A|.\z 1 ] + try %[ execute-keys -draft h ) M \A\(.*\)\h*\n\h*\{\z s \A|.\z 1 ] _ ] -def -hidden rust-indent-on-closing-curly-brace %[ - eval -draft -itersel %_ +define-command -hidden rust-indent-on-closing-curly-brace %[ + evaluate-commands -draft -itersel %_ # align to opening curly brace when alone on a line - try %[ exec -draft ^\h+\}$ h m s \A|.\z 1 ] + try %[ execute-keys -draft ^\h+\}$ h m s \A|.\z 1 ] _ ] diff --git a/rc/base/scala.kak b/rc/base/scala.kak index c080f88d..559e58f2 100644 --- a/rc/base/scala.kak +++ b/rc/base/scala.kak @@ -5,7 +5,7 @@ # ‾‾‾‾‾‾‾‾‾ hook global BufCreate .*[.](scala) %{ - set buffer filetype scala + set-option buffer filetype scala } # Highlighters @@ -34,28 +34,28 @@ add-highlighter shared/scala/code regex "'[_A-Za-z0-9$]+" 0:variable # Commands # ‾‾‾‾‾‾‾‾ -def -hidden scala-filter-around-selections %{ +define-command -hidden scala-filter-around-selections %{ # remove trailing white spaces - try %{ exec -draft -itersel s \h+$ d } + try %{ execute-keys -draft -itersel s \h+$ d } } -def -hidden scala-indent-on-new-line %[ - eval -draft -itersel %[ +define-command -hidden scala-indent-on-new-line %[ + evaluate-commands -draft -itersel %[ # copy // comments prefix and following white spaces - try %[ exec -draft k s ^\h*\K#\h* y gh j P ] + try %[ execute-keys -draft k s ^\h*\K#\h* y gh j P ] # preserve previous line indent - try %[ exec -draft \; K ] + try %[ execute-keys -draft \; K ] # filter previous line - try %[ exec -draft k : scala-filter-around-selections ] + try %[ execute-keys -draft k : scala-filter-around-selections ] # indent after lines ending with { - try %[ exec -draft k \{$ j ] + try %[ execute-keys -draft k \{$ j ] ] ] -def -hidden scala-indent-on-closing-curly-brace %[ - eval -draft -itersel %[ +define-command -hidden scala-indent-on-closing-curly-brace %[ + evaluate-commands -draft -itersel %[ # align to opening curly brace when alone on a line - try %[ exec -draft ^\h+\}$ m s \A|.\z 1 ] + try %[ execute-keys -draft ^\h+\}$ m s \A|.\z 1 ] ] ] diff --git a/rc/base/spell.kak b/rc/base/spell.kak index 5fbe56c0..a1811a9b 100644 --- a/rc/base/spell.kak +++ b/rc/base/spell.kak @@ -1,8 +1,8 @@ -decl -hidden range-specs spell_regions -decl -hidden str spell_lang -decl -hidden str spell_tmp_file +declare-option -hidden range-specs spell_regions +declare-option -hidden str spell_lang +declare-option -hidden str spell_tmp_file -def -params ..1 \ +define-command -params ..1 \ -docstring %{spell []: spell check the current buffer The first optional argument is the language against which the check will be performed Formats of language supported: @@ -13,7 +13,7 @@ Formats of language supported: %sh{ file=$(mktemp -d "${TMPDIR:-/tmp}"/kak-spell.XXXXXXXX)/buffer printf 'eval -no-hooks write %s\n' "${file}" - printf 'set buffer spell_tmp_file %s\n' "${file}" + printf 'set-option buffer spell_tmp_file %s\n' "${file}" } %sh{ if [ $# -ge 1 ]; then @@ -23,7 +23,7 @@ Formats of language supported: exit 1 else options="-l '$1'" - printf 'set buffer spell_lang %s\n' "$1" + printf 'set-option buffer spell_lang %s\n' "$1" fi fi @@ -49,7 +49,7 @@ Formats of language supported: *) printf 'echo -markup %%{{Error}%s}\n' "${line}" | kak -p "${kak_session}";; esac done - printf 'set "buffer=%s" spell_regions %%{%s}' "${kak_bufname}" "${regions}" \ + printf 'set-option "buffer=%s" spell_regions %%{%s}' "${kak_bufname}" "${regions}" \ | kak -p "${kak_session}" } rm -rf $(dirname "$kak_opt_spell_tmp_file") @@ -57,7 +57,7 @@ Formats of language supported: } } -def spell-next %{ %sh{ +define-command spell-next %{ %sh{ anchor_line="${kak_selection_desc%%.*}" anchor_col="${kak_selection_desc%%,*}" anchor_col="${anchor_col##*.}" @@ -101,7 +101,7 @@ def spell-next %{ %sh{ fi } } -def spell-replace %{ %sh{ +define-command spell-replace %{ %sh{ if [ -n "$kak_opt_spell_lang" ]; then options="-l '$kak_opt_spell_lang'" fi @@ -109,7 +109,7 @@ def spell-replace %{ %sh{ menu=$(printf %s "${suggestions#?}" | awk -F', ' ' { for (i=1; i<=NF; i++) - printf "%s", "%{"$i"}" "%{exec -itersel c"$i"be}" + printf "%s", "%{"$i"}" "%{execute-keys -itersel c"$i"be}" } ') printf 'try %%{ menu -auto-single %s }' "${menu}" diff --git a/rc/base/sql.kak b/rc/base/sql.kak index ab92e28e..f8360be8 100644 --- a/rc/base/sql.kak +++ b/rc/base/sql.kak @@ -5,7 +5,7 @@ # ‾‾‾‾‾‾‾‾‾ hook global BufCreate .*/?(?i)sql %{ - set buffer filetype sql + set-option buffer filetype sql } # Highlighters @@ -80,7 +80,7 @@ add-highlighter shared/ regions -default code sql \ # Add the language's grammar to the static completion list printf %s\\n "hook global WinSetOption filetype=sql %{ - set window static_words '${keywords}:${operators}:${functions}:${data_types}:${data_types_fn}:NULL' + set-option window static_words '${keywords}:${operators}:${functions}:${data_types}:${data_types_fn}:NULL' }" | sed 's,|,:,g' # Highlight keywords diff --git a/rc/base/swift.kak b/rc/base/swift.kak index ca768bb2..4cdaa09f 100644 --- a/rc/base/swift.kak +++ b/rc/base/swift.kak @@ -1,5 +1,5 @@ hook global BufCreate .*\.(swift) %{ - set buffer filetype swift + set-option buffer filetype swift } add-highlighter shared/ regions -default code swift \ diff --git a/rc/base/tmux.kak b/rc/base/tmux.kak index 34ece586..068492b4 100644 --- a/rc/base/tmux.kak +++ b/rc/base/tmux.kak @@ -14,7 +14,7 @@ hook global KakBegin .* %{ } ## Temporarily override the default client creation command -def -hidden -params 1.. tmux-new-impl %{ +define-command -hidden -params 1.. tmux-new-impl %{ %sh{ tmux=${kak_client_env_TMUX:-$TMUX} if [ -z "$tmux" ]; then @@ -28,24 +28,24 @@ def -hidden -params 1.. tmux-new-impl %{ } } -def tmux-new-vertical -params .. -command-completion -docstring "Create a new vertical pane" %{ +define-command tmux-new-vertical -params .. -command-completion -docstring "Create a new vertical pane" %{ tmux-new-impl 'split-window -v' %arg{@} } -def tmux-new-horizontal -params .. -command-completion -docstring "Create a new horizontal pane" %{ +define-command tmux-new-horizontal -params .. -command-completion -docstring "Create a new horizontal pane" %{ tmux-new-impl 'split-window -h' %arg{@} } -def tmux-new-window -params .. -command-completion -docstring "Create a new window" %{ +define-command tmux-new-window -params .. -command-completion -docstring "Create a new window" %{ tmux-new-impl 'new-window' %arg{@} } -def -docstring %{tmux-focus []: focus the given client +define-command -docstring %{tmux-focus []: focus the given client If no client is passed then the current one is used} \ -params ..1 -client-completion \ tmux-focus %{ %sh{ if [ $# -eq 1 ]; then - printf %s\\n "eval -client '$1' focus" + printf %s\\n "evaluate-commands -client '$1' focus" elif [ -n "${kak_client_env_TMUX}" ]; then TMUX="${kak_client_env_TMUX}" tmux select-pane -t "${kak_client_env_TMUX_PANE}" > /dev/null fi diff --git a/rc/base/x11.kak b/rc/base/x11.kak index 8c13dd4e..97cff767 100644 --- a/rc/base/x11.kak +++ b/rc/base/x11.kak @@ -1,7 +1,7 @@ -# termcmd should be set such as the next argument is the whole +# termcmd should be set-option such as the next argument is the whole # command line to execute -decl -docstring %{shell command run to spawn a new terminal -A shell command is appended to the one set in this option at runtime} \ +declare-option -docstring %{shell command run to spawn a new terminal +A shell command is appended to the one set-option in this option at runtime} \ str termcmd %sh{ for termcmd in 'alacritty -e sh -c' \ 'termite -e ' \ @@ -21,25 +21,25 @@ A shell command is appended to the one set in this option at runtime} \ done } -def -docstring %{x11-new []: create a new kak client for the current session +define-command -docstring %{x11-new []: create a new kak client for the current session The optional arguments will be passed as arguments to the new client} \ -params .. \ -command-completion \ x11-new %{ %sh{ if [ -z "${kak_opt_termcmd}" ]; then - echo "echo -markup '{Error}termcmd option is not set'" + echo "echo -markup '{Error}termcmd option is not set-option'" exit fi if [ $# -ne 0 ]; then kakoune_params="-e '$@'"; fi setsid ${kak_opt_termcmd} "kak -c ${kak_session} ${kakoune_params}" < /dev/null > /dev/null 2>&1 & }} -def -docstring %{x11-focus []: focus a given client's window +define-command -docstring %{x11-focus []: focus a given client's window If no client is passed, then the current client is used} \ -params ..1 -client-completion \ x11-focus %{ %sh{ if [ $# -eq 1 ]; then - printf %s\\n "eval -client '$1' focus" + printf %s\\n "evaluate-commands -client '$1' focus" else xdotool windowactivate $kak_client_env_WINDOWID > /dev/null fi diff --git a/rc/base/yaml.kak b/rc/base/yaml.kak index de682a01..82c683bb 100644 --- a/rc/base/yaml.kak +++ b/rc/base/yaml.kak @@ -5,7 +5,7 @@ # ‾‾‾‾‾‾‾‾‾ hook global BufCreate .*[.](ya?ml) %{ - set buffer filetype yaml + set-option buffer filetype yaml } # Highlighters @@ -28,21 +28,21 @@ add-highlighter shared/yaml/code regex ^\h*-?\h*(\S+): 1:attribute # Commands # ‾‾‾‾‾‾‾‾ -def -hidden yaml-filter-around-selections %{ +define-command -hidden yaml-filter-around-selections %{ # remove trailing white spaces - try %{ exec -draft -itersel s \h+$ d } + try %{ execute-keys -draft -itersel s \h+$ d } } -def -hidden yaml-indent-on-new-line %{ - eval -draft -itersel %{ +define-command -hidden yaml-indent-on-new-line %{ + evaluate-commands -draft -itersel %{ # copy '#' comment prefix and following white spaces - try %{ exec -draft k s ^\h*\K#\h* y gh j P } + try %{ execute-keys -draft k s ^\h*\K#\h* y gh j P } # preserve previous line indent - try %{ exec -draft \; K } + try %{ execute-keys -draft \; K } # filter previous line - try %{ exec -draft k : yaml-filter-around-selections } + try %{ execute-keys -draft k : yaml-filter-around-selections } # indent after : - try %{ exec -draft k x :$ j } + try %{ execute-keys -draft k x :$ j } } } diff --git a/rc/core/asciidoc.kak b/rc/core/asciidoc.kak index b0c50442..b2cc2ed9 100644 --- a/rc/core/asciidoc.kak +++ b/rc/core/asciidoc.kak @@ -5,7 +5,7 @@ # ‾‾‾‾‾‾‾‾‾ hook global BufCreate .+\.(a(scii)?doc|asc) %{ - set buffer filetype asciidoc + set-option buffer filetype asciidoc } # Highlighters diff --git a/rc/core/c-family.kak b/rc/core/c-family.kak index 67be6470..e9234400 100644 --- a/rc/core/c-family.kak +++ b/rc/core/c-family.kak @@ -1,125 +1,125 @@ hook global BufCreate .*\.(cc|cpp|cxx|C|hh|hpp|hxx|H)$ %{ - set buffer filetype cpp + set-option buffer filetype cpp } hook global BufSetOption filetype=c\+\+ %{ - set buffer filetype cpp + set-option buffer filetype cpp } hook global BufCreate .*\.c$ %{ - set buffer filetype c + set-option buffer filetype c } hook global BufCreate .*\.h$ %{ try %{ - exec -draft %{%s\b::\b|\btemplate\h*|\bclass\h+\w+|\b(typename|namespace)\b|\b(public|private|protected)\h*:} - set buffer filetype cpp + execute-keys -draft %{%s\b::\b|\btemplate\h*|\bclass\h+\w+|\b(typename|namespace)\b|\b(public|private|protected)\h*:} + set-option buffer filetype cpp } catch %{ - set buffer filetype c + set-option buffer filetype c } } hook global BufCreate .*\.m %{ - set buffer filetype objc + set-option buffer filetype objc } -def -hidden c-family-trim-autoindent %[ eval -draft -itersel %[ +define-command -hidden c-family-trim-autoindent %[ evaluate-commands -draft -itersel %[ # remove the line if it's empty when leaving the insert mode - try %[ exec 1s^(\h+)$ d ] + try %[ execute-keys 1s^(\h+)$ d ] ] ] -def -hidden c-family-indent-on-newline %< eval -draft -itersel %< - exec \; +define-command -hidden c-family-indent-on-newline %< evaluate-commands -draft -itersel %< + execute-keys \; try %< # if previous line closed a paren, copy indent of the opening paren line - exec -draft k 1s(\))(\h+\w+)*\h*(\;\h*)?$ mJ s\A|.\z 1 + execute-keys -draft k 1s(\))(\h+\w+)*\h*(\;\h*)?$ mJ s\A|.\z 1 > catch %< # else indent new lines with the same level as the previous one - exec -draft K + execute-keys -draft K > # remove previous empty lines resulting from the automatic indent - try %< exec -draft k ^\h+$ Hd > + try %< execute-keys -draft k ^\h+$ Hd > # indent after an opening brace - try %< exec -draft k s\{\h*$ j > + try %< execute-keys -draft k s\{\h*$ j > # indent after a label - try %< exec -draft k s[a-zA-Z0-9_-]+:\h*$ j > + try %< execute-keys -draft k s[a-zA-Z0-9_-]+:\h*$ j > # indent after a statement not followed by an opening brace - try %< exec -draft k \b(if|else|for|while)\h*\(.+?\)\h*$ j > + try %< execute-keys -draft k \b(if|else|for|while)\h*\(.+?\)\h*$ j > # align to the opening parenthesis or opening brace (whichever is first) # on a previous line if its followed by text on the same line - try %< eval -draft %< + try %< evaluate-commands -draft %< # Go to opening parenthesis and opening brace, then select the most nested one - try %< try %< exec [bZ[B > catch %< exec [B > > + try %< try %< execute-keys [bZ[B > catch %< execute-keys [B > > # Validate selection and get first and last char - exec \A[{(](\h*\S+)+\n L s\A|.\z + execute-keys \A[{(](\h*\S+)+\n L s\A|.\z # Remove eventual indent from new line - try %< exec -draft s\h+ d > + try %< execute-keys -draft s\h+ d > # Now align that new line with the opening parenthesis/brace - exec & + execute-keys & > > > > -def -hidden c-family-indent-on-opening-curly-brace %[ +define-command -hidden c-family-indent-on-opening-curly-brace %[ # align indent with opening paren when { is entered on a new line after the closing paren - try %[ exec -draft -itersel h)M \A\(.*\)\h*\n\h*\{\z s \A|.\z 1 ] + try %[ execute-keys -draft -itersel h)M \A\(.*\)\h*\n\h*\{\z s \A|.\z 1 ] ] -def -hidden c-family-indent-on-closing-curly-brace %[ +define-command -hidden c-family-indent-on-closing-curly-brace %[ # align to opening curly brace when alone on a line - try %[ exec -itersel -draft ^\h+\}$hms\A|.\z1 ] + try %[ execute-keys -itersel -draft ^\h+\}$hms\A|.\z1 ] ] -def -hidden c-family-insert-on-closing-curly-brace %[ +define-command -hidden c-family-insert-on-closing-curly-brace %[ # add a semicolon after a closing brace if part of a class, union or struct definition - try %[ exec -itersel -draft hmB\A\h*(class|struct|union|enum) a\; ] + try %[ execute-keys -itersel -draft hmB\A\h*(class|struct|union|enum) a\; ] ] -def -hidden c-family-insert-on-newline %[ eval -draft %[ - exec \; +define-command -hidden c-family-insert-on-newline %[ evaluate-commands -draft %[ + execute-keys \; try %[ - eval -draft %[ + evaluate-commands -draft %[ # copy the commenting prefix - exec -save-regs '' k 1s^\h*(//+\h*) y + execute-keys -save-regs '' k 1s^\h*(//+\h*) y try %[ # if the previous comment isn't empty, create a new one - exec ^\h*//+\h*$ js^\h*P + execute-keys ^\h*//+\h*$ js^\h*P ] catch %[ # if there is no text in the previous comment, remove it completely - exec d + execute-keys d ] ] ] try %[ # if the previous line isn't within a comment scope, break - exec -draft k ^(\h*/\*|\h+\*(?!/)) + execute-keys -draft k ^(\h*/\*|\h+\*(?!/)) # find comment opening, validate it was not closed, and check its using star prefixes - exec -draft /\* \*/ \A\h*/\*([^\n]*\n\h*\*)*[^\n]*\n\h*.\z + execute-keys -draft /\* \*/ \A\h*/\*([^\n]*\n\h*\*)*[^\n]*\n\h*.\z try %[ # if the previous line is opening the comment, insert star preceeded by space - exec -draft k^\h*/\* - exec -draft i* + execute-keys -draft k^\h*/\* + execute-keys -draft i* ] catch %[ try %[ # if the next line is a comment line insert a star - exec -draft j^\h+\* - exec -draft i* + execute-keys -draft j^\h+\* + execute-keys -draft i* ] catch %[ try %[ # if the previous line is an empty comment line, close the comment scope - exec -draft k^\h+\*\h+$ 1s\*(\h*)c/ + execute-keys -draft k^\h+\*\h+$ 1s\*(\h*)c/ ] catch %[ # if the previous line is a non-empty comment line, add a star - exec -draft i* + execute-keys -draft i* ] ] ] # trim trailing whitespace on the previous line - try %[ exec -draft 1s(\h+)$d ] + try %[ execute-keys -draft 1s(\h+)$d ] # align the new star with the previous one - exec J1s^[^*]*(\*)& + execute-keys J1s^[^*]*(\*)& ] ] ] @@ -161,7 +161,7 @@ add-highlighter shared/c/code regex %{\b-?(0x[0-9a-fA-F]+|\d+)[fdiu]?|'((\\.)?|[ # Add the language's grammar to the static completion list printf %s\\n "hook global WinSetOption filetype=c %{ - set window static_words '${keywords}:${attributes}:${types}:${values}' + set-option window static_words '${keywords}:${attributes}:${types}:${values}' }" | sed 's,|,:,g' # Highlight keywords @@ -192,7 +192,7 @@ add-highlighter shared/cpp/code regex %{\b-?(0x[0-9a-fA-F]+|\d+)[fdiu]?|'((\\.)? # Add the language's grammar to the static completion list printf %s\\n "hook global WinSetOption filetype=cpp %{ - set window static_words '${keywords}:${attributes}:${types}:${values}' + set-option window static_words '${keywords}:${attributes}:${types}:${values}' }" | sed 's,|,:,g' # Highlight keywords @@ -231,7 +231,7 @@ add-highlighter shared/objc/code regex %{\b-?\d+[fdiu]?|'((\\.)?|[^'\\])'} 0:val # Add the language's grammar to the static completion list printf %s\\n "hook global WinSetOption filetype=objc %{ - set window static_words '${keywords}:${attributes}:${types}:${values}:${decorators}' + set-option window static_words '${keywords}:${attributes}:${types}:${values}:${decorators}' }" | sed 's,|,:,g' # Highlight keywords @@ -278,20 +278,20 @@ hook -group cpp-highlight global WinSetOption filetype=(?!cpp).* %[ remove-highl hook -group objc-highlight global WinSetOption filetype=objc %[ add-highlighter window ref objc ] hook -group objc-highlight global WinSetOption filetype=(?!objc).* %[ remove-highlighter window/objc ] -decl -docstring %{control the type of include guard to be inserted in empty headers +declare-option -docstring %{control the type of include guard to be inserted in empty headers Can be one of the following: ifdef: old style ifndef/define guard pragma: newer type of guard using "pragma once"} \ str c_include_guard_style "ifdef" -def -hidden c-family-insert-include-guards %{ +define-command -hidden c-family-insert-include-guards %{ %sh{ case "${kak_opt_c_include_guard_style}" in ifdef) - echo 'exec ggi%ggxs\.c_A_INCLUDEDggxyppI#ifndefjI#definejI#endif//O' + echo 'execute-keys ggi%ggxs\.c_A_INCLUDEDggxyppI#ifndefjI#definejI#endif//O' ;; pragma) - echo 'exec ggi#pragmaonce' + echo 'execute-keys ggi#pragmaonce' ;; *);; esac @@ -300,10 +300,10 @@ def -hidden c-family-insert-include-guards %{ hook -group c-family-insert global BufNewFile .*\.(h|hh|hpp|hxx|H) c-family-insert-include-guards -decl -docstring "colon separated list of path in which header files will be looked for" \ +declare-option -docstring "colon separated list of path in which header files will be looked for" \ str-list alt_dirs ".:.." -def c-family-alternative-file -docstring "Jump to the alternate file (header/implementation)" %{ %sh{ +define-command c-family-alternative-file -docstring "Jump to the alternate file (header/implementation)" %{ %sh{ alt_dirs=$(printf %s\\n "${kak_opt_alt_dirs}" | tr ':' '\n') file="${kak_buffile##*/}" file_noext="${file%.*}" diff --git a/rc/core/comment.kak b/rc/core/comment.kak index eebb6ab3..acb96f89 100644 --- a/rc/core/comment.kak +++ b/rc/core/comment.kak @@ -1,102 +1,102 @@ ## Line comments -decl -docstring "characters inserted at the beginning of a commented line" \ +declare-option -docstring "characters inserted at the beginning of a commented line" \ str comment_line '#' ## Block comments -decl -docstring "colon separated tuple containing the characters inserted before/after a commented line" \ +declare-option -docstring "colon separated tuple containing the characters inserted before/after a commented line" \ str-list comment_block ## Default comments for all languages hook global BufSetOption filetype=asciidoc %{ - set buffer comment_block '///:///' + set-option buffer comment_block '///:///' } hook global BufSetOption filetype=(c|cpp|go|java|javascript|objc|php|sass|scala|scss|swift) %{ - set buffer comment_line '//' - set buffer comment_block '/*:*/' + set-option buffer comment_line '//' + set-option buffer comment_block '/*:*/' } hook global BufSetOption filetype=(cabal|haskell|moon) %{ - set buffer comment_line '--' - set buffer comment_block '{-:-}' + set-option buffer comment_line '--' + set-option buffer comment_block '{-:-}' } hook global BufSetOption filetype=clojure %{ - set buffer comment_line '#_ ' - set buffer comment_block '(comment :)' + set-option buffer comment_line '#_ ' + set-option buffer comment_block '(comment :)' } hook global BufSetOption filetype=coffee %{ - set buffer comment_block '###:###' + set-option buffer comment_block '###:###' } hook global BufSetOption filetype=css %{ - set buffer comment_line '' - set buffer comment_block '/*:*/' + set-option buffer comment_line '' + set-option buffer comment_block '/*:*/' } hook global BufSetOption filetype=d %{ - set buffer comment_line '//' - set buffer comment_block '/+:+/' + set-option buffer comment_line '//' + set-option buffer comment_block '/+:+/' } hook global BufSetOption filetype=(gas|ini) %{ - set buffer comment_line ';' + set-option buffer comment_line ';' } hook global BufSetOption filetype=haml %{ - set buffer comment_line '-#' + set-option buffer comment_line '-#' } hook global BufSetOption filetype=html %{ - set buffer comment_line '' - set buffer comment_block '' + set-option buffer comment_line '' + set-option buffer comment_block '' } hook global BufSetOption filetype=latex %{ - set buffer comment_line '%' + set-option buffer comment_line '%' } hook global BufSetOption filetype=lisp %{ - set buffer comment_line ';' - set buffer comment_block '#|:|#' + set-option buffer comment_line ';' + set-option buffer comment_block '#|:|#' } hook global BufSetOption filetype=lua %{ - set buffer comment_line '--' - set buffer comment_block '--[[:]]' + set-option buffer comment_line '--' + set-option buffer comment_block '--[[:]]' } hook global BufSetOption filetype=markdown %{ - set buffer comment_line '' - set buffer comment_block '[//]: # (:)' + set-option buffer comment_line '' + set-option buffer comment_block '[//]: # (:)' } hook global BufSetOption filetype=perl %{ - set buffer comment_block '#[:]' + set-option buffer comment_block '#[:]' } hook global BufSetOption filetype=(pug|rust) %{ - set buffer comment_line '//' + set-option buffer comment_line '//' } hook global BufSetOption filetype=python %{ - set buffer comment_block "''':'''" + set-option buffer comment_block "''':'''" } hook global BufSetOption filetype=ragel %{ - set buffer comment_line '%%' - set buffer comment_block '%%{:}%%' + set-option buffer comment_line '%%' + set-option buffer comment_block '%%{:}%%' } hook global BufSetOption filetype=ruby %{ - set buffer comment_block '^begin=:^=end' + set-option buffer comment_block '^begin=:^=end' } -def comment-block -docstring '(un)comment selected lines using block comments' %{ +define-command comment-block -docstring '(un)comment selected lines using block comments' %{ %sh{ exec_proof() { - ## Replace the '<' sign that is interpreted differently in `exec` + ## Replace the '<' sign that is interpreted differently in `execute-keys` printf %s\\n "$@" | sed 's,<,,g' } @@ -108,25 +108,25 @@ def comment-block -docstring '(un)comment selected lines using block comments' % exit fi - printf %s\\n "eval -draft %{ try %{ + printf %s\\n "evaluate-commands -draft %{ try %{ ## The selection is empty - exec \\A[\\h\\v\\n]*\\z + execute-keys \\A[\\h\\v\\n]*\\z try %{ ## The selection has already been commented - exec %{\\A\\Q${opening}\\E.*\\Q${closing}\\E\\n*\\z} + execute-keys %{\\A\\Q${opening}\\E.*\\Q${closing}\\E\\n*\\z} ## Comment the selection - exec -draft %{a${closing}i${opening}} + execute-keys -draft %{a${closing}i${opening}} } catch %{ ## Uncomment the commented selection - exec -draft %{s(\\A\\Q${opening}\\E)|(\\Q${closing}\\E\\n*\\z)d} + execute-keys -draft %{s(\\A\\Q${opening}\\E)|(\\Q${closing}\\E\\n*\\z)d} } } }" } } -def comment-line -docstring '(un)comment selected lines using line comments' %{ +define-command comment-line -docstring '(un)comment selected lines using line comments' %{ %sh{ readonly opening="${kak_opt_comment_line}" readonly opening_escaped="\\Q${opening}\\E" @@ -136,23 +136,23 @@ def comment-line -docstring '(un)comment selected lines using line comments' %{ exit fi - printf %s\\n "eval -draft %{ + printf %s\\n "evaluate-commands -draft %{ ## Select the content of the lines, without indentation - exec I + execute-keys I try %{ ## There’s no text on the line - exec \\A[\\h\\v\\n]*\\z + execute-keys \\A[\\h\\v\\n]*\\z try %{ ## The line has already been commented - exec %{\\A${opening_escaped}} + execute-keys %{\\A${opening_escaped}} ## Comment the line - exec -draft %{i${opening}} + execute-keys -draft %{i${opening}} } catch %{ ## Uncomment the line - exec -draft %{s\\A${opening_escaped}\\h*d} + execute-keys -draft %{s\\A${opening_escaped}\\h*d} } } }" diff --git a/rc/core/diff.kak b/rc/core/diff.kak index 18c934f7..425efaca 100644 --- a/rc/core/diff.kak +++ b/rc/core/diff.kak @@ -1,5 +1,5 @@ hook global BufCreate .*\.(diff|patch) %{ - set buffer filetype diff + set-option buffer filetype diff } add-highlighter shared/ group diff diff --git a/rc/core/doc.kak b/rc/core/doc.kak index c3a03bc9..f84192ac 100644 --- a/rc/core/doc.kak +++ b/rc/core/doc.kak @@ -1,33 +1,33 @@ -decl -docstring "name of the client in which documentation is to be displayed" \ +declare-option -docstring "name of the client in which documentation is to be displayed" \ str docsclient declare-option -hidden range-specs doc_render_ranges define-command -hidden -params 4 doc-render-regex %{ - eval -draft %{ try %{ - exec \%s %arg{1} - exec -draft s %arg{2} d - exec "%arg{3}" + evaluate-commands -draft %{ try %{ + execute-keys \%s %arg{1} + execute-keys -draft s %arg{2} d + execute-keys "%arg{3}" %sh{ ranges=$(echo "$kak_selections_desc" | sed -e "s/:/|$4:/g; s/\$/|$4/") echo "update-option buffer doc_render_ranges" - echo "set -add buffer doc_render_ranges '$ranges'" + echo "set-option -add buffer doc_render_ranges '$ranges'" } } } } define-command -params 1 -hidden doc-render %{ edit! -scratch *doc* - exec "!cat %arg{1}gg" + execute-keys "!cat %arg{1}gg" # Join paragraphs together - try %{ exec -draft \%S \n{2,}|(?<=\+)\n|^[^\n]+::\n ^-{2,}(\n|\z) S\n\z \n } + try %{ execute-keys -draft \%S \n{2,}|(?<=\+)\n|^[^\n]+::\n ^-{2,}(\n|\z) S\n\z \n } # Remove some line end markers - try %{ exec -draft \%s \h*(\+|:{2,})$ d } + try %{ execute-keys -draft \%s \h*(\+|:{2,})$ d } # Setup the doc_render_ranges option - set buffer doc_render_ranges %val{timestamp} + set-option buffer doc_render_ranges %val{timestamp} doc-render-regex \B(?.*? .*,| 'H' link # Remove escaping of * and ` - try %{ exec -draft \%s \\((?=\*)|(?=`)) d } + try %{ execute-keys -draft \%s \\((?=\*)|(?=`)) d } set-option buffer readonly true add-highlighter buffer ranges doc_render_ranges add-highlighter buffer wrap -word -indent } -def -params 1 \ +define-command -params 1 \ -shell-candidates %{ find "${kak_runtime}/doc/" -type f -name "*.asciidoc" | while read l; do basename "${l%.*}" @@ -57,7 +57,7 @@ An optional keyword argument can be passed to the function, which will be automa shift if [ -f "${page}" ]; then - printf %s\\n "eval -try-client %opt{docsclient} doc-render ${page}" + printf %s\\n "evaluate-commands -try-client %opt{docsclient} doc-render ${page}" else printf %s\\n "echo -markup '{Error}No such doc file: ${page}'" fi diff --git a/rc/core/formatter.kak b/rc/core/formatter.kak index b531a8a6..2439bd4a 100644 --- a/rc/core/formatter.kak +++ b/rc/core/formatter.kak @@ -1,7 +1,7 @@ -decl -docstring "shell command to which the contents of the current buffer is piped" \ +declare-option -docstring "shell command to which the contents of the current buffer is piped" \ str formatcmd -def format -docstring "Format the contents of the current buffer" %{ eval -draft %{ +define-command format -docstring "Format the contents of the current buffer" %{ evaluate-commands -draft %{ %sh{ if [ -n "${kak_opt_formatcmd}" ]; then path_file_tmp=$(mktemp "${TMPDIR:-/tmp}"/kak-formatter-XXXXXX) @@ -12,11 +12,11 @@ def format -docstring "Format the contents of the current buffer" %{ eval -draft readonly path_file_out=\$(mktemp \"${TMPDIR:-/tmp}\"/kak-formatter-XXXXXX) if cat \"${path_file_tmp}\" | eval \"${kak_opt_formatcmd}\" > \"\${path_file_out}\"; then - printf '%s\\n' \"exec \\%|cat'\${path_file_out}'\" + printf '%s\\n' \"execute-keys \\%|cat'\${path_file_out}'\" printf '%s\\n' \"%sh{ rm -f '\${path_file_out}' }\" else printf '%s\\n' \" - eval -client '${kak_client}' echo -markup '{Error}formatter returned an error (\$?)' + evaluate-commands -client '${kak_client}' echo -markup '{Error}formatter returned an error (\$?)' \" rm -f \"\${path_file_out}\" fi @@ -25,7 +25,7 @@ def format -docstring "Format the contents of the current buffer" %{ eval -draft } " else - printf '%s\n' "eval -client '${kak_client}' echo -markup '{Error}formatcmd option not specified'" + printf '%s\n' "evaluate-commands -client '${kak_client}' echo -markup '{Error}formatcmd option not specified'" fi } } } diff --git a/rc/core/grep.kak b/rc/core/grep.kak index ad6f60e3..4048c93c 100644 --- a/rc/core/grep.kak +++ b/rc/core/grep.kak @@ -1,10 +1,10 @@ -decl -docstring "shell command run to search for subtext in a file/directory" \ +declare-option -docstring "shell command run to search for subtext in a file/directory" \ str grepcmd 'grep -RHn' -decl -docstring "name of the client in which utilities display information" \ +declare-option -docstring "name of the client in which utilities display information" \ str toolsclient -decl -hidden int grep_current_line 0 +declare-option -hidden int grep_current_line 0 -def -params .. -file-completion \ +define-command -params .. -file-completion \ -docstring %{grep []: grep utility wrapper All the optional arguments are forwarded to the grep utility} \ grep %{ %sh{ @@ -16,10 +16,10 @@ All the optional arguments are forwarded to the grep utility} \ ( ${kak_opt_grepcmd} "${kak_selection}" | tr -d '\r' > ${output} 2>&1 ) > /dev/null 2>&1 < /dev/null & fi - printf %s\\n "eval -try-client '$kak_opt_toolsclient' %{ + printf %s\\n "evaluate-commands -try-client '$kak_opt_toolsclient' %{ edit! -fifo ${output} -scroll *grep* - set buffer filetype grep - set buffer grep_current_line 0 + set-option buffer filetype grep + set-option buffer grep_current_line 0 hook -group fifo buffer BufCloseFifo .* %{ nop %sh{ rm -r $(dirname ${output}) } remove-hooks buffer fifo @@ -43,38 +43,38 @@ hook global WinSetOption filetype=(?!grep).* %{ remove-hooks buffer grep-hooks } -decl -docstring "name of the client in which all source code jumps will be executed" \ +declare-option -docstring "name of the client in which all source code jumps will be executed" \ str jumpclient -def -hidden grep-jump %{ - eval -collapse-jumps %{ +define-command -hidden grep-jump %{ + evaluate-commands -collapse-jumps %{ try %{ - exec 's^((?:\w:)?[^:]+):(\d+):(\d+)?' - set buffer grep_current_line %val{cursor_line} - eval -try-client %opt{jumpclient} edit -existing %reg{1} %reg{2} %reg{3} + execute-keys 's^((?:\w:)?[^:]+):(\d+):(\d+)?' + set-option buffer grep_current_line %val{cursor_line} + evaluate-commands -try-client %opt{jumpclient} edit -existing %reg{1} %reg{2} %reg{3} try %{ focus %opt{jumpclient} } } } } -def grep-next-match -docstring 'Jump to the next grep match' %{ - eval -collapse-jumps -try-client %opt{jumpclient} %{ +define-command grep-next-match -docstring 'Jump to the next grep match' %{ + evaluate-commands -collapse-jumps -try-client %opt{jumpclient} %{ buffer '*grep*' # First jump to enf of buffer so that if grep_current_line == 0 # 0g will be a no-op and we'll jump to the first result. # Yeah, thats ugly... - exec "ge %opt{grep_current_line}g /^[^:]+:\d+:" + execute-keys "ge %opt{grep_current_line}g /^[^:]+:\d+:" grep-jump } - try %{ eval -client %opt{toolsclient} %{ exec gg %opt{grep_current_line}g } } + try %{ evaluate-commands -client %opt{toolsclient} %{ execute-keys gg %opt{grep_current_line}g } } } -def grep-previous-match -docstring 'Jump to the previous grep match' %{ - eval -collapse-jumps -try-client %opt{jumpclient} %{ +define-command grep-previous-match -docstring 'Jump to the previous grep match' %{ + evaluate-commands -collapse-jumps -try-client %opt{jumpclient} %{ buffer '*grep*' # See comment in grep-next-match - exec "ge %opt{grep_current_line}g ^[^:]+:\d+:" + execute-keys "ge %opt{grep_current_line}g ^[^:]+:\d+:" grep-jump } - try %{ eval -client %opt{toolsclient} %{ exec gg %opt{grep_current_line}g } } + try %{ evaluate-commands -client %opt{toolsclient} %{ execute-keys gg %opt{grep_current_line}g } } } diff --git a/rc/core/kakrc.kak b/rc/core/kakrc.kak index b954962d..95d07ef1 100644 --- a/rc/core/kakrc.kak +++ b/rc/core/kakrc.kak @@ -5,7 +5,7 @@ # ‾‾‾‾‾‾‾‾‾ hook global BufCreate (.*/)?(kakrc|.*.kak) %{ - set buffer filetype kak + set-option buffer filetype kak } # Highlighters & Completion @@ -29,8 +29,9 @@ add-highlighter shared/ regions -default code kakrc \ keywords="edit write write-all kill quit write-quit write-all-quit map unmap alias unalias buffer buffer-next buffer-previous delete-buffer add-highlighter remove-highlighter hook remove-hooks define-command echo debug source try fail - set-option unset-option update-option declare-option exec eval prompt menu on-key info - set-face rename-client set-register select change-directory rename-session colorscheme" + set-option unset-option update-option declare-option execute-keys evaluate-commands + prompt menu on-key info set-face rename-client set-register select change-directory + rename-session colorscheme" attributes="global buffer window current normal insert menu prompt goto view user object number_lines show_matching show_whitespaces fill regex dynregex group flag_lines @@ -42,8 +43,8 @@ add-highlighter shared/ regions -default code kakrc \ # Add the language's grammar to the static completion list printf '%s\n' "hook global WinSetOption filetype=kak %{ - set window static_words '$(join "${keywords}:${attributes}:${types}:${values}" ':')' - set -- window extra_word_chars '-' + set-option window static_words '$(join "${keywords}:${attributes}:${types}:${values}" ':')' + set-option -- window extra_word_chars '-' }" # Highlight keywords (which are always surrounded by whitespace) @@ -63,16 +64,16 @@ add-highlighter shared/kakrc/shell ref sh # Commands # ‾‾‾‾‾‾‾‾ -def -hidden kak-indent-on-new-line %{ - eval -draft -itersel %{ +define-command -hidden kak-indent-on-new-line %{ + evaluate-commands -draft -itersel %{ # copy '#' comment prefix and following white spaces - try %{ exec -draft k s ^\h*#\h* y jgh P } + try %{ execute-keys -draft k s ^\h*#\h* y jgh P } # preserve previous line indent - try %{ exec -draft \; K } + try %{ execute-keys -draft \; K } # cleanup trailing whitespaces from previous line - try %{ exec -draft k s \h+$ d } + try %{ execute-keys -draft k s \h+$ d } # indent after line ending with %[\W\S] - try %{ exec -draft k \%[\W\S]$ j } + try %{ execute-keys -draft k \%[\W\S]$ j } } } @@ -84,8 +85,8 @@ hook -group kak-highlight global WinSetOption filetype=kak %{ add-highlighter wi hook global WinSetOption filetype=kak %{ hook window InsertChar \n -group kak-indent kak-indent-on-new-line # cleanup trailing whitespaces on current line insert end - hook window InsertEnd .* -group kak-indent %{ try %{ exec -draft \; s ^\h+$ d } } - set buffer extra_word_chars '-' + hook window InsertEnd .* -group kak-indent %{ try %{ execute-keys -draft \; s ^\h+$ d } } + set-option buffer extra_word_chars '-' } hook -group kak-highlight global WinSetOption filetype=(?!kak).* %{ remove-highlighter window/kakrc } diff --git a/rc/core/make.kak b/rc/core/make.kak index 9aba90ba..34a1db0d 100644 --- a/rc/core/make.kak +++ b/rc/core/make.kak @@ -1,13 +1,13 @@ -decl -docstring "shell command run to build the project" \ +declare-option -docstring "shell command run to build the project" \ str makecmd make -decl -docstring "pattern that describes lines containing information about errors in the output of the `makecmd` command" \ +declare-option -docstring "pattern that describes lines containing information about errors in the output of the `makecmd` command" \ str make_error_pattern " (?:fatal )?error:" -decl -docstring "name of the client in which utilities display information" \ +declare-option -docstring "name of the client in which utilities display information" \ str toolsclient -decl -hidden int make_current_error_line +declare-option -hidden int make_current_error_line -def -params .. \ +define-command -params .. \ -docstring %{make []: make utility wrapper All the optional arguments are forwarded to the make utility} \ make %{ %sh{ @@ -15,10 +15,10 @@ All the optional arguments are forwarded to the make utility} \ mkfifo ${output} ( eval ${kak_opt_makecmd} "$@" > ${output} 2>&1 ) > /dev/null 2>&1 < /dev/null & - printf %s\\n "eval -try-client '$kak_opt_toolsclient' %{ + printf %s\\n "evaluate-commands -try-client '$kak_opt_toolsclient' %{ edit! -fifo ${output} -scroll *make* - set buffer filetype make - set buffer make_current_error_line 0 + set-option buffer filetype make + set-option buffer make_current_error_line 0 hook -group fifo buffer BufCloseFifo .* %{ nop %sh{ rm -r $(dirname ${output}) } remove-hooks buffer fifo @@ -43,39 +43,39 @@ hook global WinSetOption filetype=(?!make).* %{ remove-hooks buffer make-hooks } -decl -docstring "name of the client in which all source code jumps will be executed" \ +declare-option -docstring "name of the client in which all source code jumps will be executed" \ str jumpclient -def -hidden make-jump %{ - eval -collapse-jumps %{ +define-command -hidden make-jump %{ + evaluate-commands -collapse-jumps %{ try %{ - exec gl "Entering directory" + execute-keys gl "Entering directory" # Try to parse the error into capture groups, failing on absolute paths - exec s "Entering directory '([^']+)'.*\n([^:/][^:]*):(\d+):(?:(\d+):)?([^\n]+)\z" l - set buffer make_current_error_line %val{cursor_line} - eval -try-client %opt{jumpclient} "edit -existing %reg{1}/%reg{2} %reg{3} %reg{4}; echo -markup %{{Information}%reg{5}}; try %{ focus }" + execute-keys s "Entering directory '([^']+)'.*\n([^:/][^:]*):(\d+):(?:(\d+):)?([^\n]+)\z" l + set-option buffer make_current_error_line %val{cursor_line} + evaluate-commands -try-client %opt{jumpclient} "edit -existing %reg{1}/%reg{2} %reg{3} %reg{4}; echo -markup %{{Information}%reg{5}}; try %{ focus }" } catch %{ - exec s "((?:\w:)?[^:]+):(\d+):(?:(\d+):)?([^\n]+)\z" l - set buffer make_current_error_line %val{cursor_line} - eval -try-client %opt{jumpclient} "edit -existing %reg{1} %reg{2} %reg{3}; echo -markup %{{Information}%reg{4}}; try %{ focus }" + execute-keys s "((?:\w:)?[^:]+):(\d+):(?:(\d+):)?([^\n]+)\z" l + set-option buffer make_current_error_line %val{cursor_line} + evaluate-commands -try-client %opt{jumpclient} "edit -existing %reg{1} %reg{2} %reg{3}; echo -markup %{{Information}%reg{4}}; try %{ focus }" } } } -def make-next-error -docstring 'Jump to the next make error' %{ - eval -collapse-jumps -try-client %opt{jumpclient} %{ +define-command make-next-error -docstring 'Jump to the next make error' %{ + evaluate-commands -collapse-jumps -try-client %opt{jumpclient} %{ buffer '*make*' - exec "%opt{make_current_error_line}ggl" "/^(?:\w:)?[^:\n]+:\d+:(?:\d+:)?%opt{make_error_pattern}" + execute-keys "%opt{make_current_error_line}ggl" "/^(?:\w:)?[^:\n]+:\d+:(?:\d+:)?%opt{make_error_pattern}" make-jump } - try %{ eval -client %opt{toolsclient} %{ exec %opt{make_current_error_line}g } } + try %{ evaluate-commands -client %opt{toolsclient} %{ execute-keys %opt{make_current_error_line}g } } } -def make-previous-error -docstring 'Jump to the previous make error' %{ - eval -collapse-jumps -try-client %opt{jumpclient} %{ +define-command make-previous-error -docstring 'Jump to the previous make error' %{ + evaluate-commands -collapse-jumps -try-client %opt{jumpclient} %{ buffer '*make*' - exec "%opt{make_current_error_line}g" "^(?:\w:)?[^:\n]+:\d+:(?:\d+:)?%opt{make_error_pattern}" + execute-keys "%opt{make_current_error_line}g" "^(?:\w:)?[^:\n]+:\d+:(?:\d+:)?%opt{make_error_pattern}" make-jump } - try %{ eval -client %opt{toolsclient} %{ exec %opt{make_current_error_line}g } } + try %{ evaluate-commands -client %opt{toolsclient} %{ execute-keys %opt{make_current_error_line}g } } } diff --git a/rc/core/makefile.kak b/rc/core/makefile.kak index 06e93402..ab4dd2f7 100644 --- a/rc/core/makefile.kak +++ b/rc/core/makefile.kak @@ -2,7 +2,7 @@ # ‾‾‾‾‾‾‾‾‾ hook global BufCreate .*/?[mM]akefile %{ - set buffer filetype makefile + set-option buffer filetype makefile } # Highlighters @@ -10,10 +10,10 @@ hook global BufCreate .*/?[mM]akefile %{ add-highlighter shared/ regions -default content makefile \ comment '#' '$' '' \ - eval '\$\(' '\)' '\(' + evaluate-commands '\$\(' '\)' '\(' add-highlighter shared/makefile/comment fill comment -add-highlighter shared/makefile/eval fill value +add-highlighter shared/makefile/evaluate-commands fill value add-highlighter shared/makefile/content regex ^[\w.%-]+\h*:\s 0:variable add-highlighter shared/makefile/content regex [+?:]= 0:operator @@ -24,7 +24,7 @@ add-highlighter shared/makefile/content regex [+?:]= 0:operator # Add the language's grammar to the static completion list printf %s\\n "hook global WinSetOption filetype=makefile %{ - set window static_words '${keywords}' + set-option window static_words '${keywords}' }" | sed 's,|,:,g' # Highlight keywords @@ -34,16 +34,16 @@ add-highlighter shared/makefile/content regex [+?:]= 0:operator # Commands # ‾‾‾‾‾‾‾‾ -def -hidden makefile-indent-on-new-line %{ - eval -draft -itersel %{ +define-command -hidden makefile-indent-on-new-line %{ + evaluate-commands -draft -itersel %{ # preserve previous line indent - try %{ exec -draft \;K } + try %{ execute-keys -draft \;K } ## If the line above is a target indent with a tab - try %{ exec -draft Z k ^[^:]+:\s z i } + try %{ execute-keys -draft Z k ^[^:]+:\s z i } # cleanup trailing white space son previous line - try %{ exec -draft k s \h+$ d } + try %{ execute-keys -draft k s \h+$ d } # indent after some keywords - try %{ exec -draft Z k ^\h*(ifeq|ifneq|ifdef|ifndef|else|define)\b z } + try %{ execute-keys -draft Z k ^\h*(ifeq|ifneq|ifdef|ifndef|else|define)\b z } } } diff --git a/rc/core/man.kak b/rc/core/man.kak index fc0064be..77dd57fc 100644 --- a/rc/core/man.kak +++ b/rc/core/man.kak @@ -1,7 +1,7 @@ -decl -docstring "name of the client in which documentation is to be displayed" \ +declare-option -docstring "name of the client in which documentation is to be displayed" \ str docsclient -decl -hidden str manpage +declare-option -hidden str manpage hook -group man-highlight global WinSetOption filetype=man %{ add-highlighter window group man-highlight @@ -27,7 +27,7 @@ hook global WinSetOption filetype=(?!man).* %{ remove-hooks window man-hooks } -def -hidden -params 1..2 man-impl %{ %sh{ +define-command -hidden -params 1..2 man-impl %{ %sh{ manout=$(mktemp "${TMPDIR:-/tmp}"/kak-man-XXXXXX) colout=$(mktemp "${TMPDIR:-/tmp}"/kak-man-XXXXXX) MANWIDTH=${kak_window_width} man "$@" > $manout 2>/dev/null @@ -37,10 +37,10 @@ def -hidden -params 1..2 man-impl %{ %sh{ if [ "${retval}" -eq 0 ]; then printf %s\\n " edit -scratch '*man*' - exec '%|cat${colout}gk' + execute-keys '%|cat${colout}gk' nop %sh{rm ${colout}} - set buffer filetype man - set window manpage '$@' + set-option buffer filetype man + set-option window manpage '$@' " else printf %s\\n "echo -markup %{{Error}man '$@' failed: see *debug* buffer for details}" @@ -48,7 +48,7 @@ def -hidden -params 1..2 man-impl %{ %sh{ fi } } -def -params ..1 \ +define-command -params ..1 \ -shell-completion %{ prefix=$(printf %s\\n "$1" | cut -c1-${kak_pos_in_token} 2>/dev/null) for page in /usr/share/man/*/${prefix}*.[1-8]*; do @@ -75,5 +75,5 @@ The page can be a word, or a word directly followed by a section number between ;; esac - printf %s\\n "eval -collapse-jumps -try-client %opt{docsclient} man-impl $pagenum $subject" + printf %s\\n "evaluate-commands -collapse-jumps -try-client %opt{docsclient} man-impl $pagenum $subject" } } diff --git a/rc/core/python.kak b/rc/core/python.kak index 15e94806..8d145156 100644 --- a/rc/core/python.kak +++ b/rc/core/python.kak @@ -5,7 +5,7 @@ # ‾‾‾‾‾‾‾‾‾ hook global BufCreate .*[.](py) %{ - set buffer filetype python + set-option buffer filetype python } # Highlighters & Completion @@ -42,7 +42,7 @@ add-highlighter shared/python/comment fill comment # Add the language's grammar to the static completion list printf %s\\n "hook global WinSetOption filetype=python %{ - set window static_words '${values}:${meta}:${keywords}:${types}:${functions}' + set-option window static_words '${values}:${meta}:${keywords}:${types}:${functions}' }" | sed 's,|,:,g' # Highlight keywords @@ -63,16 +63,16 @@ add-highlighter shared/python/comment fill comment # Commands # ‾‾‾‾‾‾‾‾ -def -hidden python-indent-on-new-line %{ - eval -draft -itersel %{ +define-command -hidden python-indent-on-new-line %{ + evaluate-commands -draft -itersel %{ # copy '#' comment prefix and following white spaces - try %{ exec -draft k s ^\h*#\h* y jgh P } + try %{ execute-keys -draft k s ^\h*#\h* y jgh P } # preserve previous line indent - try %{ exec -draft \; K } + try %{ execute-keys -draft \; K } # cleanup trailing whitespaces from previous line - try %{ exec -draft k s \h+$ d } + try %{ execute-keys -draft k s \h+$ d } # indent after line ending with : - try %{ exec -draft k x :$ j } + try %{ execute-keys -draft k x :$ j } } } @@ -84,7 +84,7 @@ hook -group python-highlight global WinSetOption filetype=python %{ add-highligh hook global WinSetOption filetype=python %{ hook window InsertChar \n -group python-indent python-indent-on-new-line # cleanup trailing whitespaces on current line insert end - hook window InsertEnd .* -group python-indent %{ try %{ exec -draft \; s ^\h+$ d } } + hook window InsertEnd .* -group python-indent %{ try %{ execute-keys -draft \; s ^\h+$ d } } } hook -group python-highlight global WinSetOption filetype=(?!python).* %{ remove-highlighter window/python } diff --git a/rc/core/sh.kak b/rc/core/sh.kak index da65c818..232bf540 100644 --- a/rc/core/sh.kak +++ b/rc/core/sh.kak @@ -1,5 +1,5 @@ hook global BufCreate .*\.(z|ba|c|k|mk)?sh(rc|_profile)? %{ - set buffer filetype sh + set-option buffer filetype sh } add-highlighter shared/ regions -default code -match-capture sh \ @@ -23,7 +23,7 @@ add-highlighter shared/sh/heredoc fill string # Add the language's grammar to the static completion list printf %s\\n "hook global WinSetOption filetype=sh %{ - set window static_words '${keywords}' + set-option window static_words '${keywords}' }" | sed 's,|,:,g' # Highlight keywords diff --git a/rc/extra/autorestore.kak b/rc/extra/autorestore.kak index 0db6d3b8..e2709c50 100644 --- a/rc/extra/autorestore.kak +++ b/rc/extra/autorestore.kak @@ -1,8 +1,8 @@ -decl -docstring "remove backups once they've been restored" \ +declare-option -docstring "remove backups once they've been restored" \ bool autorestore_purge_restored true ## Insert the content of the backup file into the current buffer, if a suitable one is found -def autorestore-restore-buffer -docstring "Restore the backup for the current file if it exists" %{ +define-command autorestore-restore-buffer -docstring "Restore the backup for the current file if it exists" %{ %sh{ buffer_basename="${kak_buffile##*/}" buffer_dirname=$(dirname "${kak_buffile}") @@ -29,7 +29,7 @@ def autorestore-restore-buffer -docstring "Restore the backup for the current fi ## Replace the content of the buffer with the content of the backup file echo -debug Restoring file: ${newer} - exec -draft %{ %d!cat\"${newer}\"d } + execute-keys -draft %{ %d!cat\"${newer}\"d } ## If the backup file has to be removed, issue the command once ## the current buffer has been saved @@ -48,7 +48,7 @@ def autorestore-restore-buffer -docstring "Restore the backup for the current fi } ## Remove all the backups that have been created for the current buffer -def autorestore-purge-backups -docstring "Remove all the backups of the current buffer" %{ +define-command autorestore-purge-backups -docstring "Remove all the backups of the current buffer" %{ %sh{ [ ! -f "${kak_buffile}" ] && exit @@ -64,7 +64,7 @@ def autorestore-purge-backups -docstring "Remove all the backups of the current } ## If for some reason, backup files need to be ignored -def autorestore-disable -docstring "Disable automatic backup recovering" %{ +define-command autorestore-disable -docstring "Disable automatic backup recovering" %{ remove-hooks global autorestore } diff --git a/rc/extra/cabal.kak b/rc/extra/cabal.kak index 8e11b692..7500270c 100644 --- a/rc/extra/cabal.kak +++ b/rc/extra/cabal.kak @@ -5,7 +5,7 @@ # ‾‾‾‾‾‾‾‾‾ hook global BufCreate .*[.](cabal) %{ - set buffer filetype cabal + set-option buffer filetype cabal } # Highlighters @@ -24,35 +24,35 @@ add-highlighter shared/cabal/code regex ^\h*([A-Za-z][A-Za-z0-9_-]*)\h*: 1:varia # Commands # ‾‾‾‾‾‾‾‾ -def -hidden cabal-filter-around-selections %{ +define-command -hidden cabal-filter-around-selections %{ # remove trailing white spaces - try %{ exec -draft -itersel s \h+$ d } + try %{ execute-keys -draft -itersel s \h+$ d } } -def -hidden cabal-indent-on-new-line %[ - eval -draft -itersel %[ +define-command -hidden cabal-indent-on-new-line %[ + evaluate-commands -draft -itersel %[ # copy '#' comment prefix and following white spaces - try %[ exec -draft k s ^\h*\K#\h* y gh j P ] + try %[ execute-keys -draft k s ^\h*\K#\h* y gh j P ] # preserve previous line indent - try %[ exec -draft \; K ] + try %[ execute-keys -draft \; K ] # filter previous line - try %[ exec -draft k : cabal-filter-around-selections ] + try %[ execute-keys -draft k : cabal-filter-around-selections ] # indent after lines ending with { or : - try %[ exec -draft k [:{]$ j ] + try %[ execute-keys -draft k [:{]$ j ] ] ] -def -hidden cabal-indent-on-opening-curly-brace %[ - eval -draft -itersel %[ +define-command -hidden cabal-indent-on-opening-curly-brace %[ + evaluate-commands -draft -itersel %[ # align indent with opening paren when { is entered on a new line after the closing paren - try %[ exec -draft h ) M \A\(.*\)\h*\n\h*\{\z s \A|.\z 1 ] + try %[ execute-keys -draft h ) M \A\(.*\)\h*\n\h*\{\z s \A|.\z 1 ] ] ] -def -hidden cabal-indent-on-closing-curly-brace %[ - eval -draft -itersel %[ +define-command -hidden cabal-indent-on-closing-curly-brace %[ + evaluate-commands -draft -itersel %[ # align to opening curly brace when alone on a line - try %[ exec -draft ^\h+\}$ h m s \A|.\z 1 ] + try %[ execute-keys -draft ^\h+\}$ h m s \A|.\z 1 ] ] ] diff --git a/rc/extra/clang.kak b/rc/extra/clang.kak index 6396a6a0..6d6dd0a0 100644 --- a/rc/extra/clang.kak +++ b/rc/extra/clang.kak @@ -1,29 +1,29 @@ -decl -docstring "options to pass to the `clang` shell command" \ +declare-option -docstring "options to pass to the `clang` shell command" \ str clang_options -decl -hidden str clang_tmp_dir -decl -hidden completions clang_completions -decl -hidden line-specs clang_flags -decl -hidden line-specs clang_errors +declare-option -hidden str clang_tmp_dir +declare-option -hidden completions clang_completions +declare-option -hidden line-specs clang_flags +declare-option -hidden line-specs clang_errors -def -params ..1 \ +define-command -params ..1 \ -docstring %{Parse the contents of the current buffer The syntaxic errors detected during parsing are shown when auto-diagnostics are enabled} \ clang-parse %{ %sh{ dir=$(mktemp -d "${TMPDIR:-/tmp}"/kak-clang.XXXXXXXX) mkfifo ${dir}/fifo - printf %s\\n "set buffer clang_tmp_dir ${dir}" - printf %s\\n "eval -no-hooks write ${dir}/buf" + printf %s\\n "set-option buffer clang_tmp_dir ${dir}" + printf %s\\n "evaluate-commands -no-hooks write ${dir}/buf" } # end the previous %sh{} so that its output gets interpreted by kakoune # before launching the following as a background task. %sh{ dir=${kak_opt_clang_tmp_dir} - printf %s\\n "eval -draft %{ + printf %s\\n "evaluate-commands -draft %{ edit! -fifo ${dir}/fifo -debug *clang-output* - set buffer filetype make - set buffer make_current_error_line 0 + set-option buffer filetype make + set-option buffer make_current_error_line 0 hook -group fifo buffer BufCloseFifo .* %{ nop %sh{ rm -r ${dir} } remove-hooks buffer fifo @@ -75,11 +75,11 @@ The syntaxic errors detected during parsing are shown when auto-diagnostics are print id "|" docstrings[id] "|" menu } }' | paste -s -d ':' - | sed -e "s/\\\\n/\\n/g; s/'/\\\\'/g") - printf %s\\n "eval -client ${kak_client} echo 'clang completion done' - set 'buffer=${kak_buffile}' clang_completions '${header}:${compl}'" | kak -p ${kak_session} + printf %s\\n "evaluate-commands -client ${kak_client} echo 'clang completion done' + set-option 'buffer=${kak_buffile}' clang_completions '${header}:${compl}'" | kak -p ${kak_session} else clang++ -x ${ft} -fsyntax-only ${kak_opt_clang_options} - < ${dir}/buf 2> ${dir}/stderr - printf %s\\n "eval -client ${kak_client} echo 'clang parsing done'" | kak -p ${kak_session} + printf %s\\n "evaluate-commands -client ${kak_client} echo 'clang parsing done'" | kak -p ${kak_session} fi flags=$(cat ${dir}/stderr | sed -rne " @@ -95,30 +95,30 @@ The syntaxic errors detected during parsing are shown when auto-diagnostics are sed -e "s||${kak_bufname}|g" < ${dir}/stderr > ${dir}/fifo - printf %s\\n "set 'buffer=${kak_buffile}' clang_flags %{${kak_timestamp}:${flags}} - set 'buffer=${kak_buffile}' clang_errors '${kak_timestamp}:${errors}'" | kak -p ${kak_session} + printf %s\\n "set-option 'buffer=${kak_buffile}' clang_flags %{${kak_timestamp}:${flags}} + set-option 'buffer=${kak_buffile}' clang_errors '${kak_timestamp}:${errors}'" | kak -p ${kak_session} ) > /dev/null 2>&1 < /dev/null & } } -def clang-complete -docstring "Complete the current selection" %{ clang-parse -complete } +define-command clang-complete -docstring "Complete the current selection" %{ clang-parse -complete } -def -hidden clang-show-completion-info %[ try %[ - eval -draft %[ - exec {( ^\( b \A\w+\z +define-command -hidden clang-show-completion-info %[ try %[ + evaluate-commands -draft %[ + execute-keys {( ^\( b \A\w+\z %sh[ desc=$(printf %s\\n "${kak_opt_clang_completions}" | sed -e "{ s/\([^\\]\):/\1\n/g }" | sed -ne "/^${kak_selection}|/ { s/^[^|]\+|//; s/|.*$//; s/\\\:/:/g; p }") if [ -n "$desc" ]; then - printf %s\\n "eval -client $kak_client %{info -anchor ${kak_cursor_line}.${kak_cursor_column} -placement above %{${desc}}}" + printf %s\\n "evaluate-commands -client $kak_client %{info -anchor ${kak_cursor_line}.${kak_cursor_column} -placement above %{${desc}}}" fi ] ] ] ] -def clang-enable-autocomplete -docstring "Enable automatic clang completion" %{ - set window completers "option=clang_completions:%opt{completers}" +define-command clang-enable-autocomplete -docstring "Enable automatic clang completion" %{ + set-option window completers "option=clang_completions:%opt{completers}" hook window -group clang-autocomplete InsertIdle .* %{ try %{ - exec -draft (\.|->|::).\z + execute-keys -draft (\.|->|::).\z echo 'completing...' clang-complete } @@ -127,13 +127,13 @@ def clang-enable-autocomplete -docstring "Enable automatic clang completion" %{ alias window complete clang-complete } -def clang-disable-autocomplete -docstring "Disable automatic clang completion" %{ - set window completers %sh{ printf %s\\n "'${kak_opt_completers}'" | sed -e 's/option=clang_completions://g' } +define-command clang-disable-autocomplete -docstring "Disable automatic clang completion" %{ + set-option window completers %sh{ printf %s\\n "'${kak_opt_completers}'" | sed -e 's/option=clang_completions://g' } remove-hooks window clang-autocomplete unalias window complete clang-complete } -def -hidden clang-show-error-info %{ +define-command -hidden clang-show-error-info %{ update-option buffer clang_errors # Ensure we are up to date with buffer changes %sh{ desc=$(printf %s\\n "${kak_opt_clang_errors}" | @@ -144,7 +144,7 @@ def -hidden clang-show-error-info %{ fi } } -def clang-enable-diagnostics -docstring %{Activate automatic error reporting and diagnostics +define-command clang-enable-diagnostics -docstring %{Activate automatic error reporting and diagnostics Information about the analysis are showned after the buffer has been parsed with the clang-parse function} \ %{ add-highlighter window flag_lines default clang_flags @@ -152,12 +152,12 @@ Information about the analysis are showned after the buffer has been parsed with hook window -group clang-diagnostics WinSetOption ^clang_errors=.* %{ info; clang-show-error-info } } -def clang-disable-diagnostics -docstring "Disable automatic error reporting and diagnostics" %{ +define-command clang-disable-diagnostics -docstring "Disable automatic error reporting and diagnostics" %{ remove-highlighter window/hlflags_clang_flags remove-hooks window clang-diagnostics } -def clang-diagnostics-next -docstring "Jump to the next line that contains an error" %{ +define-command clang-diagnostics-next -docstring "Jump to the next line that contains an error" %{ update-option buffer clang_errors # Ensure we are up to date with buffer changes %sh{ printf "%s\n" "${kak_opt_clang_errors}" | sed -e 's/\([^\\]\):/\1\n/g' | tail -n +2 | ( @@ -170,7 +170,7 @@ def clang-diagnostics-next -docstring "Jump to the next line that contains an er done line=${line-$first_line} if [ -n "$line" ]; then - printf %s\\n "exec ${line} g" + printf %s\\n "execute-keys ${line} g" else echo "echo -markup '{Error}no next clang diagnostic'" fi diff --git a/rc/extra/coffee.kak b/rc/extra/coffee.kak index 25d9428c..91ddfdec 100644 --- a/rc/extra/coffee.kak +++ b/rc/extra/coffee.kak @@ -5,7 +5,7 @@ # ‾‾‾‾‾‾‾‾‾ hook global BufCreate .*[.](coffee) %{ - set buffer filetype coffee + set-option buffer filetype coffee } # Highlighters @@ -45,24 +45,24 @@ add-highlighter shared/coffee/code regex \b(break|case|catch|class|const|continu # Commands # ‾‾‾‾‾‾‾‾ -def -hidden coffee-filter-around-selections %{ - eval -draft -itersel %{ - exec +define-command -hidden coffee-filter-around-selections %{ + evaluate-commands -draft -itersel %{ + execute-keys # remove trailing white spaces - try %{ exec -draft s \h + $ d } + try %{ execute-keys -draft s \h + $ d } } } -def -hidden coffee-indent-on-new-line %{ - eval -draft -itersel %{ +define-command -hidden coffee-indent-on-new-line %{ + evaluate-commands -draft -itersel %{ # copy '#' comment prefix and following white spaces - try %{ exec -draft k s '^\h*\K#\h*' y gh j P } + try %{ execute-keys -draft k s '^\h*\K#\h*' y gh j P } # preserve previous line indent - try %{ exec -draft \; K } + try %{ execute-keys -draft \; K } # filter previous line - try %{ exec -draft k : coffee-filter-around-selections } + try %{ execute-keys -draft k : coffee-filter-around-selections } # indent after start structure - try %{ exec -draft k ^ \h * (case|catch|class|else|finally|for|function|if|switch|try|while|with) \b | (=|->) $ j } + try %{ execute-keys -draft k ^ \h * (case|catch|class|else|finally|for|function|if|switch|try|while|with) \b | (=|->) $ j } } } diff --git a/rc/extra/cucumber.kak b/rc/extra/cucumber.kak index b8dee97d..06a100aa 100644 --- a/rc/extra/cucumber.kak +++ b/rc/extra/cucumber.kak @@ -5,7 +5,7 @@ # ‾‾‾‾‾‾‾‾‾ hook global BufCreate .*[.](feature|story) %{ - set buffer filetype cucumber + set-option buffer filetype cucumber } # Highlighters @@ -56,21 +56,21 @@ add-highlighter shared/cucumber/code regex \b(Feature|Business\h+Need|Ability|Ba # Commands # ‾‾‾‾‾‾‾‾ -def -hidden cucumber-filter-around-selections %{ +define-command -hidden cucumber-filter-around-selections %{ # remove trailing white spaces - try %{ exec -draft -itersel s \h+$ d } + try %{ execute-keys -draft -itersel s \h+$ d } } -def -hidden cucumber-indent-on-new-line %{ - eval -draft -itersel %{ +define-command -hidden cucumber-indent-on-new-line %{ + evaluate-commands -draft -itersel %{ # copy '#' comment prefix and following white spaces - try %{ exec -draft k s ^\h*\K#\h* y gh j P } + try %{ execute-keys -draft k s ^\h*\K#\h* y gh j P } # preserve previous line indent - try %{ exec -draft \; K } + try %{ execute-keys -draft \; K } # filter previous line - try %{ exec -draft k : cucumber-filter-around-selections } + try %{ execute-keys -draft k : cucumber-filter-around-selections } # indent after lines containing : - try %{ exec -draft k x : j } + try %{ execute-keys -draft k x : j } } } diff --git a/rc/extra/dockerfile.kak b/rc/extra/dockerfile.kak index 11d0ed98..10f87c0e 100644 --- a/rc/extra/dockerfile.kak +++ b/rc/extra/dockerfile.kak @@ -7,7 +7,7 @@ # ‾‾‾‾‾‾‾‾‾ hook global BufCreate .*Dockerfile %{ - set buffer filetype dockerfile + set-option buffer filetype dockerfile } # Highlighters diff --git a/rc/extra/editorconfig.kak b/rc/extra/editorconfig.kak index 456eb623..767360bb 100644 --- a/rc/extra/editorconfig.kak +++ b/rc/extra/editorconfig.kak @@ -1,9 +1,9 @@ # http://editorconfig.org/#file-format-details # ‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾ -decl -hidden bool editorconfig_trim_trailing_whitespace false +declare-option -hidden bool editorconfig_trim_trailing_whitespace false -def editorconfig-load -params ..1 -docstring "editorconfig-load [file]: set formatting behavior according to editorconfig" %{ +define-command editorconfig-load -params ..1 -docstring "editorconfig-load [file]: set-option formatting behavior according to editorconfig" %{ remove-hooks buffer editorconfig-hooks %sh{ command -v editorconfig >/dev/null 2>&1 || { echo 'echo -markup "{Error}editorconfig could not be found"'; exit 1; } @@ -17,31 +17,31 @@ def editorconfig-load -params ..1 -docstring "editorconfig-load [file]: set form END { if (indent_style == "tab") { - print "set buffer indentwidth 0" - print "set buffer aligntab true" + print "set-option buffer indentwidth 0" + print "set-option buffer aligntab true" } if (indent_style == "space") { - print "set buffer indentwidth " (indent_size == "tab" ? 4 : indent_size) - print "set buffer aligntab false" + print "set-option buffer indentwidth " (indent_size == "tab" ? 4 : indent_size) + print "set-option buffer aligntab false" } if (indent_size || tab_width) { - print "set buffer tabstop " (tab_width ? tab_width : indent_size) + print "set-option buffer tabstop " (tab_width ? tab_width : indent_size) } if (end_of_line == "lf" || end_of_line == "crlf") { - print "set buffer eolformat " end_of_line + print "set-option buffer eolformat " end_of_line } if (charset == "utf-8-bom") { - print "set buffer BOM utf8" + print "set-option buffer BOM utf8" } if (trim_trailing_whitespace == "true") { - print "set buffer editorconfig_trim_trailing_whitespace true" + print "set-option buffer editorconfig_trim_trailing_whitespace true" } } ' } hook buffer BufWritePre %val{buffile} -group editorconfig-hooks %{ %sh{ if [ ${kak_opt_editorconfig_trim_trailing_whitespace} = "true" ]; then - printf %s\\n "try %{ exec -draft %{ %s\h+$d } }" + printf %s\\n "try %{ execute-keys -draft %{ %s\h+$d } }" fi } } } diff --git a/rc/extra/elixir.kak b/rc/extra/elixir.kak index b8651fcf..30927773 100644 --- a/rc/extra/elixir.kak +++ b/rc/extra/elixir.kak @@ -5,7 +5,7 @@ # ‾‾‾‾‾‾‾‾‾ hook global BufCreate .*[.](ex|exs) %{ - set buffer filetype elixir + set-option buffer filetype elixir } @@ -42,23 +42,23 @@ add-highlighter shared/elixir/code regex '\b\d+[\d_]*\b' 0:value # Commands # ‾‾‾‾‾‾‾‾ -def -hidden elixir-filter-around-selections %{ +define-command -hidden elixir-filter-around-selections %{ # remove trailing white spaces - try %{ exec -draft -itersel s \h+$ d } + try %{ execute-keys -draft -itersel s \h+$ d } } -def -hidden elixir-indent-on-new-line %{ - eval -draft -itersel %{ +define-command -hidden elixir-indent-on-new-line %{ + evaluate-commands -draft -itersel %{ # copy -- comments prefix and following white spaces - try %{ exec -draft k s ^\h*\K--\h* y gh j P } + try %{ execute-keys -draft k s ^\h*\K--\h* y gh j P } # preserve previous line indent - try %{ exec -draft \; K } + try %{ execute-keys -draft \; K } # indent after line ending with: - # try %{ exec -draft k x (do|else|->)$ & } + # try %{ execute-keys -draft k x (do|else|->)$ & } # filter previous line - try %{ exec -draft k : elixir-filter-around-selections } + try %{ execute-keys -draft k : elixir-filter-around-selections } # indent after lines ending with do or -> - try %{ exec -draft \\; k x ^.+(do|->)$ j } + try %{ execute-keys -draft \\; k x ^.+(do|->)$ j } } } diff --git a/rc/extra/elm.kak b/rc/extra/elm.kak index 4764a9a6..5ab8eade 100644 --- a/rc/extra/elm.kak +++ b/rc/extra/elm.kak @@ -5,7 +5,7 @@ # ‾‾‾‾‾‾‾‾‾ hook global BufCreate .*[.](elm) %{ - set buffer filetype elm + set-option buffer filetype elm } # Highlighters @@ -29,25 +29,25 @@ add-highlighter shared/elm/code regex \b(Array|Bool|Char|Float|Int|String)\b 0:t # http://elm-lang.org/docs/style-guide -def -hidden elm-filter-around-selections %{ +define-command -hidden elm-filter-around-selections %{ # remove trailing white spaces - try %{ exec -draft -itersel s \h+$ d } + try %{ execute-keys -draft -itersel s \h+$ d } } -def -hidden elm-indent-after " - exec -draft \\; k x ^\\h*(if)|(case\\h+[\\w']+\\h+of|let|in|\\{\\h+\\w+|\\w+\\h+->|[=(])$ j +define-command -hidden elm-indent-after " + execute-keys -draft \\; k x ^\\h*(if)|(case\\h+[\\w']+\\h+of|let|in|\\{\\h+\\w+|\\w+\\h+->|[=(])$ j " -def -hidden elm-indent-on-new-line %{ - eval -draft -itersel %{ +define-command -hidden elm-indent-on-new-line %{ + evaluate-commands -draft -itersel %{ # copy -- comments prefix and following white spaces - try %{ exec -draft k s ^\h*\K--\h* y gh j P } + try %{ execute-keys -draft k s ^\h*\K--\h* y gh j P } # preserve previous line indent - try %{ exec -draft \; K } + try %{ execute-keys -draft \; K } # align to first clause - try %{ exec -draft \; k x X s ^\h*(if|then|else)?\h*(([\w']+\h+)+=)?\h*(case\h+[\w']+\h+of|let)\h+\K.* s \A|.\z & } + try %{ execute-keys -draft \; k x X s ^\h*(if|then|else)?\h*(([\w']+\h+)+=)?\h*(case\h+[\w']+\h+of|let)\h+\K.* s \A|.\z & } # filter previous line - try %{ exec -draft k : elm-filter-around-selections } + try %{ execute-keys -draft k : elm-filter-around-selections } # indent after lines beginning with condition or ending with expression or =( try %{ elm-indent-after } } diff --git a/rc/extra/exherbo.kak b/rc/extra/exherbo.kak index 07bc05f7..d5bdd772 100644 --- a/rc/extra/exherbo.kak +++ b/rc/extra/exherbo.kak @@ -1,29 +1,29 @@ ## Repository metadata files -hook global BufCreate .*/metadata/mirrors\.conf %{ set buffer filetype paludis-mirrors-conf } -hook global BufCreate .*/metadata/licence_groups.conf %{ set buffer filetype exheres-0-licence-groups } -hook global BufCreate .*/metadata/options/descriptions/.*\.conf %{ set buffer filetype exheres-0-licence-groups } -hook global BufCreate .*/metadata/.*\.conf %{ set buffer filetype exheres-0-metadata } +hook global BufCreate .*/metadata/mirrors\.conf %{ set-option buffer filetype paludis-mirrors-conf } +hook global BufCreate .*/metadata/licence_groups.conf %{ set-option buffer filetype exheres-0-licence-groups } +hook global BufCreate .*/metadata/options/descriptions/.*\.conf %{ set-option buffer filetype exheres-0-licence-groups } +hook global BufCreate .*/metadata/.*\.conf %{ set-option buffer filetype exheres-0-metadata } ## News items -hook global BufCreate .*/metadata/news/.*/.*\.txt %{ set buffer filetype glep42 } +hook global BufCreate .*/metadata/news/.*/.*\.txt %{ set-option buffer filetype glep42 } ## exheres-0, exlib -hook global BufCreate .*\.(exheres-0|exlib) %{ set buffer filetype sh } +hook global BufCreate .*\.(exheres-0|exlib) %{ set-option buffer filetype sh } # Paludis configurations -hook global BufCreate .*/etc/paludis(-.*)?/bashrc %{ set buffer filetype sh } -hook global BufCreate .*/etc/paludis(-.*)?/general(\.conf.d/.*.conf|\.conf) %{ set buffer filetype paludis-key-value-conf } -hook global BufCreate .*/etc/paludis(-.*)?/licences(\.conf.d/.*.conf|\.conf) %{ set buffer filetype paludis-options-conf } -hook global BufCreate .*/etc/paludis(-.*)?/mirrors(\.conf.d/.*.conf|\.conf) %{ set buffer filetype paludis-mirrors-conf } -hook global BufCreate .*/etc/paludis(-.*)?/options(\.conf.d/.*.conf|\.conf) %{ set buffer filetype paludis-options-conf } -hook global BufCreate .*/etc/paludis(-.*)?/output(\.conf.d/.*.conf|\.conf) %{ set buffer filetype paludis-key-value-conf } -hook global BufCreate .*/etc/paludis(-.*)?/package_(unmask|mask)(\.conf.d/.*.conf|\.conf) %{ set buffer filetype paludis-specs-conf } -hook global BufCreate .*/etc/paludis(-.*)?/platforms(\.conf.d/.*.conf|\.conf) %{ set buffer filetype paludis-specs-conf } -hook global BufCreate .*/etc/paludis(-.*)?/repositories/.*\.conf %{ set buffer filetype paludis-key-value-conf } -hook global BufCreate .*/etc/paludis(-.*)?/repository\.template %{ set buffer filetype paludis-key-value-conf } -hook global BufCreate .*/etc/paludis(-.*)?/repository_defaults\.conf %{ set buffer filetype paludis-key-value-conf } -hook global BufCreate .*/etc/paludis(-.*)?/specpath\.conf %{ set buffer filetype paludis-key-value-conf } -hook global BufCreate .*/etc/paludis(-.*)?/suggestions(\.conf.d/.*.conf|\.conf) %{ set buffer filetype paludis-specs-conf } +hook global BufCreate .*/etc/paludis(-.*)?/bashrc %{ set-option buffer filetype sh } +hook global BufCreate .*/etc/paludis(-.*)?/general(\.conf.d/.*.conf|\.conf) %{ set-option buffer filetype paludis-key-value-conf } +hook global BufCreate .*/etc/paludis(-.*)?/licences(\.conf.d/.*.conf|\.conf) %{ set-option buffer filetype paludis-options-conf } +hook global BufCreate .*/etc/paludis(-.*)?/mirrors(\.conf.d/.*.conf|\.conf) %{ set-option buffer filetype paludis-mirrors-conf } +hook global BufCreate .*/etc/paludis(-.*)?/options(\.conf.d/.*.conf|\.conf) %{ set-option buffer filetype paludis-options-conf } +hook global BufCreate .*/etc/paludis(-.*)?/output(\.conf.d/.*.conf|\.conf) %{ set-option buffer filetype paludis-key-value-conf } +hook global BufCreate .*/etc/paludis(-.*)?/package_(unmask|mask)(\.conf.d/.*.conf|\.conf) %{ set-option buffer filetype paludis-specs-conf } +hook global BufCreate .*/etc/paludis(-.*)?/platforms(\.conf.d/.*.conf|\.conf) %{ set-option buffer filetype paludis-specs-conf } +hook global BufCreate .*/etc/paludis(-.*)?/repositories/.*\.conf %{ set-option buffer filetype paludis-key-value-conf } +hook global BufCreate .*/etc/paludis(-.*)?/repository\.template %{ set-option buffer filetype paludis-key-value-conf } +hook global BufCreate .*/etc/paludis(-.*)?/repository_defaults\.conf %{ set-option buffer filetype paludis-key-value-conf } +hook global BufCreate .*/etc/paludis(-.*)?/specpath\.conf %{ set-option buffer filetype paludis-key-value-conf } +hook global BufCreate .*/etc/paludis(-.*)?/suggestions(\.conf.d/.*.conf|\.conf) %{ set-option buffer filetype paludis-specs-conf } # Highlighters ## exheres-0 Repository metadata files diff --git a/rc/extra/git-tools.kak b/rc/extra/git-tools.kak index ad01b212..8f5d1c42 100644 --- a/rc/extra/git-tools.kak +++ b/rc/extra/git-tools.kak @@ -1,4 +1,4 @@ -decl -docstring "name of the client in which documentation is to be displayed" \ +declare-option -docstring "name of the client in which documentation is to be displayed" \ str docsclient hook -group git-log-highlight global WinSetOption filetype=git-log %{ @@ -17,13 +17,13 @@ hook -group git-status-highlight global WinSetOption filetype=git-status %{ hook -group git-status-highlight global WinSetOption filetype=(?!git-status).* %{ remove-highlighter window/git-status-highlight } -decl -hidden line-specs git_blame_flags -decl -hidden line-specs git_diff_flags +declare-option -hidden line-specs git_blame_flags +declare-option -hidden line-specs git_diff_flags -face GitBlame default,magenta -face GitDiffFlags default,black +set-face GitBlame default,magenta +set-face GitDiffFlags default,black -def -params 1.. \ +define-command -params 1.. \ -docstring %sh{printf '%%{git []: git wrapping helper All the optional arguments are forwarded to the git utility Available commands:\n-add\n-rm\n-blame\n-commit\n-checkout\n-diff\n-hide-blame\n-log\n-show\n-show-diff\n-status\n-update-diff}'} \ @@ -43,9 +43,9 @@ Available commands:\n-add\n-rm\n-blame\n-commit\n-checkout\n-diff\n-hide-blame\n mkfifo ${output} ( git "$@" > ${output} 2>&1 ) > /dev/null 2>&1 < /dev/null & - printf %s "eval -try-client '$kak_opt_docsclient' %{ + printf %s "evaluate-commands -try-client '$kak_opt_docsclient' %{ edit! -fifo ${output} *git* - set buffer filetype '${filetype}' + set-option buffer filetype '${filetype}' hook -group fifo buffer BufCloseFifo .* %{ nop %sh{ rm -r $(dirname ${output}) } remove-hooks buffer fifo @@ -55,9 +55,9 @@ Available commands:\n-add\n-rm\n-blame\n-commit\n-checkout\n-diff\n-hide-blame\n run_git_blame() { ( - printf %s "eval -client '$kak_client' %{ + printf %s "evaluate-commands -client '$kak_client' %{ try %{ add-highlighter window flag_lines GitBlame git_blame_flags } - set buffer=$kak_bufname git_blame_flags '$kak_timestamp' + set-option buffer=$kak_bufname git_blame_flags '$kak_timestamp' }" | kak -p ${kak_session} git blame "$@" --incremental ${kak_buffile} | awk ' function send_flags(text, flag, i) { @@ -70,7 +70,7 @@ Available commands:\n-add\n-rm\n-blame\n-commit\n-checkout\n-diff\n-hide-blame\n flag=flag ":" line+i "|" text } cmd = "kak -p " ENVIRON["kak_session"] - print "set -add buffer=" ENVIRON["kak_bufname"] " git_blame_flags %{" flag "}" | cmd + print "set-option -add buffer=" ENVIRON["kak_bufname"] " git_blame_flags %{" flag "}" | cmd close(cmd) } /^([0-9a-f]{40}) ([0-9]+) ([0-9]+) ([0-9]+)/ { @@ -107,7 +107,7 @@ Available commands:\n-add\n-rm\n-blame\n-commit\n-checkout\n-diff\n-hide-blame\n line++ } /^\-/ { flags=flags ":" line "|{red}-" } - END { print "set buffer git_diff_flags ", flags } + END { print "set-option buffer git_diff_flags ", flags } ' } @@ -130,9 +130,9 @@ Available commands:\n-add\n-rm\n-blame\n-commit\n-checkout\n-diff\n-hide-blame\n printf %s "edit '$msgfile' hook buffer BufWritePost '.*\Q$msgfile\E' %{ %sh{ if git commit -F '$msgfile' --cleanup=strip $@ > /dev/null; then - printf %s 'eval -client $kak_client echo -markup %{{Information}Commit succeeded}; delete-buffer' + printf %s 'evaluate-commands -client $kak_client echo -markup %{{Information}Commit succeeded}; delete-buffer' else - printf %s 'eval -client $kak_client echo -markup %{{Error}Commit failed}' + printf %s 'evaluate-commands -client $kak_client echo -markup %{{Error}Commit failed}' fi } }" } @@ -142,7 +142,7 @@ Available commands:\n-add\n-rm\n-blame\n-commit\n-checkout\n-diff\n-hide-blame\n blame) shift; run_git_blame "$@" ;; hide-blame) printf %s "try %{ - set buffer=$kak_bufname git_blame_flags '' + set-option buffer=$kak_bufname git_blame_flags '' remove-highlighter window/hlflags_git_blame_flags }" ;; diff --git a/rc/extra/go-tools.kak b/rc/extra/go-tools.kak index 70623fe3..439715ec 100644 --- a/rc/extra/go-tools.kak +++ b/rc/extra/go-tools.kak @@ -16,14 +16,14 @@ # Auto-completion # ‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾ -decl -hidden str go_complete_tmp_dir -decl -hidden completions gocode_completions +declare-option -hidden str go_complete_tmp_dir +declare-option -hidden completions gocode_completions -def go-complete -docstring "Complete the current selection with gocode" %{ +define-command go-complete -docstring "Complete the current selection with gocode" %{ %sh{ dir=$(mktemp -d "${TMPDIR:-/tmp}"/kak-go.XXXXXXXX) - printf %s\\n "set buffer go_complete_tmp_dir ${dir}" - printf %s\\n "eval -no-hooks write ${dir}/buf" + printf %s\\n "set-option buffer go_complete_tmp_dir ${dir}" + printf %s\\n "evaluate-commands -no-hooks write ${dir}/buf" } %sh{ dir=${kak_opt_go_complete_tmp_dir} @@ -34,24 +34,24 @@ def go-complete -docstring "Complete the current selection with gocode" %{ header="${kak_cursor_line}.$((${kak_cursor_column} - $column_offset))@${kak_timestamp}" compl=$(echo "${gocode_data}" | sed 1d | awk -F ",," '{print $2 "||" $1}' | paste -s -d: -) - printf %s\\n "eval -client '${kak_client}' %{ - set buffer=${kak_bufname} gocode_completions '${header}:${compl}' + printf %s\\n "evaluate-commands -client '${kak_client}' %{ + set-option buffer=${kak_bufname} gocode_completions '${header}:${compl}' }" | kak -p ${kak_session} ) > /dev/null 2>&1 < /dev/null & } } -def go-enable-autocomplete -docstring "Add gocode completion candidates to the completer" %{ - set window completers "option=gocode_completions:%opt{completers}" +define-command go-enable-autocomplete -docstring "Add gocode completion candidates to the completer" %{ + set-option window completers "option=gocode_completions:%opt{completers}" hook window -group go-autocomplete InsertIdle .* %{ try %{ - exec -draft [\w\.].\z + execute-keys -draft [\w\.].\z go-complete } } alias window complete go-complete } -def go-disable-autocomplete -docstring "Disable gocode completion" %{ - set window completers %sh{ printf %s\\n "'${kak_opt_completers}'" | sed 's/option=gocode_completions://g' } +define-command go-disable-autocomplete -docstring "Disable gocode completion" %{ + set-option window completers %sh{ printf %s\\n "'${kak_opt_completers}'" | sed 's/option=gocode_completions://g' } remove-hooks window go-autocomplete unalias window complete go-complete } @@ -59,14 +59,14 @@ def go-disable-autocomplete -docstring "Disable gocode completion" %{ # Auto-format # ‾‾‾‾‾‾‾‾‾‾‾ -decl -hidden str go_format_tmp_dir +declare-option -hidden str go_format_tmp_dir -def -params ..1 go-format \ +define-command -params ..1 go-format \ -docstring "go-format [-use-goimports]: custom formatter for go files" %{ %sh{ dir=$(mktemp -d "${TMPDIR:-/tmp}"/kak-go.XXXXXXXX) - printf %s\\n "set buffer go_format_tmp_dir ${dir}" - printf %s\\n "eval -no-hooks write ${dir}/buf" + printf %s\\n "set-option buffer go_format_tmp_dir ${dir}" + printf %s\\n "evaluate-commands -no-hooks write ${dir}/buf" } %sh{ dir=${kak_opt_go_format_tmp_dir} @@ -90,14 +90,14 @@ def -params ..1 go-format \ # Documentation # ‾‾‾‾‾‾‾‾‾‾‾‾‾ -decl -hidden str go_doc_tmp_dir +declare-option -hidden str go_doc_tmp_dir # FIXME text escaping -def -hidden -params 1..2 gogetdoc-cmd %{ +define-command -hidden -params 1..2 gogetdoc-cmd %{ %sh{ dir=$(mktemp -d "${TMPDIR:-/tmp}"/kak-go.XXXXXXXX) - printf %s\\n "set buffer go_doc_tmp_dir ${dir}" - printf %s\\n "eval -no-hooks write ${dir}/buf" + printf %s\\n "set-option buffer go_doc_tmp_dir ${dir}" + printf %s\\n "evaluate-commands -no-hooks write ${dir}/buf" } %sh{ dir=${kak_opt_go_doc_tmp_dir} @@ -119,12 +119,12 @@ def -hidden -params 1..2 gogetdoc-cmd %{ case "$1" in "info") if [ ${status} -eq 0 ]; then - printf %s\\n "eval -client '${kak_client}' %{ + printf %s\\n "evaluate-commands -client '${kak_client}' %{ info -anchor ${kak_cursor_line}.${kak_cursor_column} %@${output}@ }" | kak -p ${kak_session} else msg=$(printf %s "${output}" | cut -d' ' -f2-) - printf %s\\n "eval -client '${kak_client}' %{ + printf %s\\n "evaluate-commands -client '${kak_client}' %{ echo '${msg}' }" | kak -p ${kak_session} fi @@ -132,7 +132,7 @@ def -hidden -params 1..2 gogetdoc-cmd %{ "echo") if [ ${status} -eq 0 ]; then signature=$(printf %s "${output}" | sed -n 3p) - printf %s\\n "eval -client '${kak_client}' %{ + printf %s\\n "evaluate-commands -client '${kak_client}' %{ echo '${signature}' }" | kak -p ${kak_session} fi @@ -143,14 +143,14 @@ def -hidden -params 1..2 gogetdoc-cmd %{ file=$(printf %s "${pos}" | cut -d: -f1) line=$(printf %s "${pos}" | cut -d: -f2) col=$(printf %s "${pos}" | cut -d: -f3) - printf %s\\n "eval -client '${kak_client}' %{ - eval -try-client '${kak_opt_jumpclient}' edit -existing ${file} ${line} ${col} + printf %s\\n "evaluate-commands -client '${kak_client}' %{ + evaluate-commands -try-client '${kak_opt_jumpclient}' edit -existing ${file} ${line} ${col} try %{ focus '${kak_opt_jumpclient}' } }" | kak -p ${kak_session} fi ;; *) - printf %s\\n "eval -client '${kak_client}' %{ + printf %s\\n "evaluate-commands -client '${kak_client}' %{ echo -error %{unkown command '$1'} }" | kak -p ${kak_session} ;; @@ -160,19 +160,19 @@ def -hidden -params 1..2 gogetdoc-cmd %{ } } -def go-doc-info -docstring "Show the documention of the symbol under the cursor" %{ +define-command go-doc-info -docstring "Show the documention of the symbol under the cursor" %{ gogetdoc-cmd "info" } -def go-print-signature -docstring "Print the signature of the symbol under the cursor" %{ +define-command go-print-signature -docstring "Print the signature of the symbol under the cursor" %{ gogetdoc-cmd "echo" } -def go-jump -docstring "Jump to the symbol definition" %{ +define-command go-jump -docstring "Jump to the symbol definition" %{ gogetdoc-cmd "jump" 1 } -def go-share-selection -docstring "Share the selection using the Go Playground" %{ %sh{ +define-command go-share-selection -docstring "Share the selection using the Go Playground" %{ %sh{ snippet_id=$(printf %s\\n "${kak_selection}" | curl -s https://play.golang.org/share --data-binary @-) printf "echo https://play.golang.org/p/%s" ${snippet_id} } } diff --git a/rc/extra/haml.kak b/rc/extra/haml.kak index d9806112..846a4f72 100644 --- a/rc/extra/haml.kak +++ b/rc/extra/haml.kak @@ -5,7 +5,7 @@ # ‾‾‾‾‾‾‾‾‾ hook global BufCreate .*[.](haml) %{ - set buffer filetype haml + set-option buffer filetype haml } # Highlighters @@ -33,21 +33,21 @@ add-highlighter shared/haml/code regex ^\h*%([A-Za-z][A-Za-z0-9_-]*)([#.][A-Za-z # Commands # ‾‾‾‾‾‾‾‾ -def -hidden haml-filter-around-selections %{ +define-command -hidden haml-filter-around-selections %{ # remove trailing white spaces - try %{ exec -draft -itersel s \h+$ d } + try %{ execute-keys -draft -itersel s \h+$ d } } -def -hidden haml-indent-on-new-line %{ - eval -draft -itersel %{ +define-command -hidden haml-indent-on-new-line %{ + evaluate-commands -draft -itersel %{ # copy '/' comment prefix and following white spaces - try %{ exec -draft k s ^\h*\K/\h* y gh j P } + try %{ execute-keys -draft k s ^\h*\K/\h* y gh j P } # preserve previous line indent - try %{ exec -draft \; K } + try %{ execute-keys -draft \; K } # filter previous line - try %{ exec -draft k : haml-filter-around-selections } + try %{ execute-keys -draft k : haml-filter-around-selections } # indent after lines beginning with : or - - try %{ exec -draft k ^\h*[:-] j } + try %{ execute-keys -draft k ^\h*[:-] j } } } diff --git a/rc/extra/hbs.kak b/rc/extra/hbs.kak index f80dcad1..3c817e75 100644 --- a/rc/extra/hbs.kak +++ b/rc/extra/hbs.kak @@ -5,7 +5,7 @@ # ‾‾‾‾‾‾‾‾‾ hook global BufCreate .*[.](hbs) %{ - set buffer filetype hbs + set-option buffer filetype hbs } # Highlighters @@ -34,21 +34,21 @@ add-highlighter shared/hbs/block-expression regex ((\w|-)+)=(('|").*?('|")) 1:at # Commands # ‾‾‾‾‾‾‾‾ -def -hidden hbs-filter-around-selections %{ +define-command -hidden hbs-filter-around-selections %{ # remove trailing white spaces - try %{ exec -draft -itersel s \h+$ d } + try %{ execute-keys -draft -itersel s \h+$ d } } -def -hidden hbs-indent-on-new-line %{ - eval -draft -itersel %{ +define-command -hidden hbs-indent-on-new-line %{ + evaluate-commands -draft -itersel %{ # copy '/' comment prefix and following white spaces - try %{ exec -draft k s ^\h*\K/\h* y j p } + try %{ execute-keys -draft k s ^\h*\K/\h* y j p } # preserve previous line indent - try %{ exec -draft \; K } + try %{ execute-keys -draft \; K } # filter previous line - try %{ exec -draft k : hbs-filter-around-selections } + try %{ execute-keys -draft k : hbs-filter-around-selections } # indent after lines beginning with : or - - try %{ exec -draft k ^\h*[:-] j } + try %{ execute-keys -draft k ^\h*[:-] j } } } diff --git a/rc/extra/iterm.kak b/rc/extra/iterm.kak index 9a35000d..3e4ca05e 100644 --- a/rc/extra/iterm.kak +++ b/rc/extra/iterm.kak @@ -14,7 +14,7 @@ hook global KakBegin .* %{ } } -def -hidden -params 1.. iterm-new-split-impl %{ +define-command -hidden -params 1.. iterm-new-split-impl %{ %sh{ direction="$1" shift @@ -33,15 +33,15 @@ def -hidden -params 1.. iterm-new-split-impl %{ } } -def iterm-new-vertical -params .. -command-completion -docstring "Create a new vertical pane" %{ +define-command iterm-new-vertical -params .. -command-completion -docstring "Create a new vertical pane" %{ iterm-new-split-impl 'vertically' %arg{@} } -def iterm-new-horizontal -params .. -command-completion -docstring "Create a new horizontal pane" %{ +define-command iterm-new-horizontal -params .. -command-completion -docstring "Create a new horizontal pane" %{ iterm-new-split-impl 'horizontally' %arg{@} } -def -params .. -command-completion \ +define-command -params .. -command-completion \ -docstring %{iterm-new-tab []: create a new tab All optional arguments are forwarded to the new kak client} \ iterm-new-tab %{ @@ -60,7 +60,7 @@ All optional arguments are forwarded to the new kak client} \ } } -def -params .. -command-completion \ +define-command -params .. -command-completion \ -docstring %{iterm-new-window []: create a new window All optional arguments are forwarded to the new kak client} \ iterm-new-window %{ @@ -69,7 +69,7 @@ All optional arguments are forwarded to the new kak client} \ sh_cmd="kak -c ${kak_session} ${kakoune_params}" osascript \ -e "tell application \"iTerm\"" \ - -e " set w to (create window with default profile)" \ + -e " set-option w to (create window with default profile)" \ -e " tell current session of w" \ -e " write text \"export TMPDIR='${TMPDIR}'\"" \ -e " write text \"exec ${sh_cmd}\"" \ @@ -78,7 +78,7 @@ All optional arguments are forwarded to the new kak client} \ } } -def -params ..1 -client-completion \ +define-command -params ..1 -client-completion \ -docstring %{iterm-focus []: focus the given client If no client is passed then the current one is used} \ iterm-focus %{ diff --git a/rc/extra/jedi.kak b/rc/extra/jedi.kak index cf3c35f5..95eaa912 100644 --- a/rc/extra/jedi.kak +++ b/rc/extra/jedi.kak @@ -1,18 +1,18 @@ -decl -hidden str jedi_tmp_dir -decl -hidden completions jedi_completions -decl -docstring "colon separated list of path added to `python`'s $PYTHONPATH environment variable" \ +declare-option -hidden str jedi_tmp_dir +declare-option -hidden completions jedi_completions +declare-option -docstring "colon separated list of path added to `python`'s $PYTHONPATH environment variable" \ str-list jedi_python_path -def jedi-complete -docstring "Complete the current selection" %{ +define-command jedi-complete -docstring "Complete the current selection" %{ %sh{ dir=$(mktemp -d "${TMPDIR:-/tmp}"/kak-jedi.XXXXXXXX) mkfifo ${dir}/fifo - printf %s\\n "set buffer jedi_tmp_dir ${dir}" - printf %s\\n "eval -no-hooks write ${dir}/buf" + printf %s\\n "set-option buffer jedi_tmp_dir ${dir}" + printf %s\\n "evaluate-commands -no-hooks write ${dir}/buf" } %sh{ dir=${kak_opt_jedi_tmp_dir} - printf %s\\n "eval -draft %{ edit! -fifo ${dir}/fifo *jedi-output* }" + printf %s\\n "evaluate-commands -draft %{ edit! -fifo ${dir}/fifo *jedi-output* }" ( cd $(dirname ${kak_buffile}) header="${kak_cursor_line}.${kak_cursor_column}@${kak_timestamp}" @@ -24,24 +24,24 @@ def jedi-complete -docstring "Complete the current selection" %{ print(':'.join([(str(c.name).replace("|", "\\|") + "|" + str(c.docstring()).replace("|", "\\|")).replace(":", "\\:") + "|" + str(c.name).replace("|", "\\|") for c in script.completions()]).replace("'", r"\\\\'")) END ) - printf %s\\n "eval -client ${kak_client} 'echo completed; set %{buffer=${kak_buffile}} jedi_completions \'${header}:${compl}\''" | kak -p ${kak_session} + printf %s\\n "evaluate-commands -client ${kak_client} 'echo completed; set-option %{buffer=${kak_buffile}} jedi_completions \'${header}:${compl}\''" | kak -p ${kak_session} rm -r ${dir} ) > /dev/null 2>&1 < /dev/null & } } -def jedi-enable-autocomplete -docstring "Add jedi completion candidates to the completer" %{ - set window completers "option=jedi_completions:%opt{completers}" +define-command jedi-enable-autocomplete -docstring "Add jedi completion candidates to the completer" %{ + set-option window completers "option=jedi_completions:%opt{completers}" hook window -group jedi-autocomplete InsertIdle .* %{ try %{ - exec -draft \..\z + execute-keys -draft \..\z echo 'completing...' jedi-complete } } alias window complete jedi-complete } -def jedi-disable-autocomplete -docstring "Disable jedi completion" %{ - set window completers %sh{ printf %s\\n "'${kak_opt_completers}'" | sed -e 's/option=jedi_completions://g' } +define-command jedi-disable-autocomplete -docstring "Disable jedi completion" %{ + set-option window completers %sh{ printf %s\\n "'${kak_opt_completers}'" | sed -e 's/option=jedi_completions://g' } remove-hooks window jedi-autocomplete unalias window complete jedi-complete } diff --git a/rc/extra/kickstart.kak b/rc/extra/kickstart.kak index ec33ec58..807d92b1 100644 --- a/rc/extra/kickstart.kak +++ b/rc/extra/kickstart.kak @@ -1,5 +1,5 @@ hook global BufCreate .*\.ks %{ - set buffer filetype kickstart + set-option buffer filetype kickstart } add-highlighter shared/ regions -default code kickstart \ diff --git a/rc/extra/latex.kak b/rc/extra/latex.kak index 49a017ec..0b2ef860 100644 --- a/rc/extra/latex.kak +++ b/rc/extra/latex.kak @@ -5,7 +5,7 @@ # ‾‾‾‾‾‾‾‾‾ hook global BufCreate .*\.tex %{ - set buffer filetype latex + set-option buffer filetype latex } # Highlighters diff --git a/rc/extra/modeline.kak b/rc/extra/modeline.kak index dc14779a..17fcd30d 100644 --- a/rc/extra/modeline.kak +++ b/rc/extra/modeline.kak @@ -7,10 +7,10 @@ ## Only a few options are supported, in order to prevent the ## buffers from poking around the configuration too much -decl -docstring "amount of lines that will be checked at the beginning and the end of the buffer" \ +declare-option -docstring "amount of lines that will be checked at the beginning and the end of the buffer" \ int modelines 5 -def -hidden modeline-parse-impl %{ +define-command -hidden modeline-parse-impl %{ %sh{ # Translate a vim option into the corresponding kakoune one translate_opt_vim() { @@ -37,7 +37,7 @@ def -hidden modeline-parse-impl %{ *) printf %s\\n "echo -debug 'Unsupported vim variable: ${key}'";; esac - [ -n "${tr}" ] && printf %s\\n "set buffer ${tr}" + [ -n "${tr}" ] && printf %s\\n "set-option buffer ${tr}" } # Pass a few whitelisted options to kakoune directly @@ -51,7 +51,7 @@ def -hidden modeline-parse-impl %{ return;; esac - printf %s\\n "set buffer ${key} ${value}" + printf %s\\n "set-option buffer ${key} ${value}" } case "${kak_selection}" in @@ -93,10 +93,10 @@ def -hidden modeline-parse-impl %{ # ref. options.txt (in vim `:help options`) : 2 forms of modelines: # [text]{white}{vi:|vim:|ex:}[white]{options} # [text]{white}{vi:|vim:|Vim:|ex:}[white]se[t] {options}:[text] -def modeline-parse -docstring "Read and interpret vi-format modelines at the beginning/end of the buffer" %{ - try %{ eval -draft %{ - exec \%s\A|.\z %opt{modelines}k %opt{modelines}X \ +define-command modeline-parse -docstring "Read and interpret vi-format modelines at the beginning/end of the buffer" %{ + try %{ evaluate-commands -draft %{ + execute-keys \%s\A|.\z %opt{modelines}k %opt{modelines}X \ s^\S*?\s+?(vim?|kak(oune)?):\s?[^\n]+ - eval -draft -itersel modeline-parse-impl + evaluate-commands -draft -itersel modeline-parse-impl } } } diff --git a/rc/extra/moon.kak b/rc/extra/moon.kak index e8ff52ad..2aa3188d 100644 --- a/rc/extra/moon.kak +++ b/rc/extra/moon.kak @@ -5,7 +5,7 @@ # ‾‾‾‾‾‾‾‾‾ hook global BufCreate .*[.](moon) %{ - set buffer filetype moon + set-option buffer filetype moon } # Highlighters @@ -30,7 +30,7 @@ add-highlighter shared/moon/code regex \b(and|break|catch|class|continue|do|else # Commands # ‾‾‾‾‾‾‾‾ -def moon-alternative-file -docstring 'Jump to the alternate file (implementation ↔ test)' %{ %sh{ +define-command moon-alternative-file -docstring 'Jump to the alternate file (implementation ↔ test)' %{ %sh{ case $kak_buffile in *spec/*_spec.moon) altfile=$(eval printf %s\\n $(printf %s\\n $kak_buffile | sed s+spec/+'*'/+';'s/_spec//)) @@ -55,37 +55,37 @@ def moon-alternative-file -docstring 'Jump to the alternate file (implementation printf %s\\n "edit $altfile" }} -def -hidden moon-filter-around-selections %{ - eval -draft -itersel %{ - exec +define-command -hidden moon-filter-around-selections %{ + evaluate-commands -draft -itersel %{ + execute-keys # remove trailing white spaces - try %{ exec -draft s \h + $ d } + try %{ execute-keys -draft s \h + $ d } } } -def -hidden moon-indent-on-char %{ - eval -draft -itersel %{ +define-command -hidden moon-indent-on-char %{ + evaluate-commands -draft -itersel %{ # align _else_ statements to start - try %{ exec -draft ^ \h * (else(if)?) $ ^ \h * (if|unless|when) s \A | \z \' } + try %{ execute-keys -draft ^ \h * (else(if)?) $ ^ \h * (if|unless|when) s \A | \z \' } # align _when_ to _switch_ then indent - try %{ exec -draft ^ \h * (when) $ ^ \h * (switch) s \A | \z \' \' } + try %{ execute-keys -draft ^ \h * (when) $ ^ \h * (switch) s \A | \z \' \' } # align _catch_ and _finally_ to _try_ - try %{ exec -draft ^ \h * (catch|finally) $ ^ \h * (try) s \A | \z \' } + try %{ execute-keys -draft ^ \h * (catch|finally) $ ^ \h * (try) s \A | \z \' } } } -def -hidden moon-indent-on-new-line %{ - eval -draft -itersel %{ +define-command -hidden moon-indent-on-new-line %{ + evaluate-commands -draft -itersel %{ # copy -- comment prefix and following white spaces - try %{ exec -draft k s ^ \h * \K -- \h * y gh j P } + try %{ execute-keys -draft k s ^ \h * \K -- \h * y gh j P } # preserve previous line indent - try %{ exec -draft \; K } + try %{ execute-keys -draft \; K } # filter previous line - try %{ exec -draft k : moon-filter-around-selections } + try %{ execute-keys -draft k : moon-filter-around-selections } # indent after start structure - try %{ exec -draft k ^ \h * (class|else(if)?|for|if|switch|unless|when|while|with) \b | ([:=]|[-=]>) $ j } + try %{ execute-keys -draft k ^ \h * (class|else(if)?|for|if|switch|unless|when|while|with) \b | ([:=]|[-=]>) $ j } # deindent after return statements - try %{ exec -draft k ^ \h * (break|return) \b j } + try %{ execute-keys -draft k ^ \h * (break|return) \b j } } } diff --git a/rc/extra/php.kak b/rc/extra/php.kak index 3939ca1a..13213d97 100644 --- a/rc/extra/php.kak +++ b/rc/extra/php.kak @@ -2,7 +2,7 @@ # ‾‾‾‾‾‾‾‾‾ hook global BufCreate .*[.](php) %{ - set buffer filetype php + set-option buffer filetype php } # Highlighters @@ -32,28 +32,28 @@ add-highlighter shared/php/code regex \b(__halt_compiler|abstract|and|array|as|b # Commands # ‾‾‾‾‾‾‾‾ -def -hidden php-filter-around-selections %{ +define-command -hidden php-filter-around-selections %{ # remove trailing white spaces - try %{ exec -draft -itersel s \h+$ d } + try %{ execute-keys -draft -itersel s \h+$ d } } -def -hidden php-indent-on-char %< - eval -draft -itersel %< +define-command -hidden php-indent-on-char %< + evaluate-commands -draft -itersel %< # align closer token to its opener when alone on a line - try %/ exec -draft ^\h+[]}]$ m s \A|.\z 1 / + try %/ execute-keys -draft ^\h+[]}]$ m s \A|.\z 1 / > > -def -hidden php-indent-on-new-line %< - eval -draft -itersel %< +define-command -hidden php-indent-on-new-line %< + evaluate-commands -draft -itersel %< # copy // comments prefix and following white spaces - try %{ exec -draft k s ^\h*\K#\h* y gh j P } + try %{ execute-keys -draft k s ^\h*\K#\h* y gh j P } # preserve previous line indent - try %{ exec -draft \; K } + try %{ execute-keys -draft \; K } # filter previous line - try %{ exec -draft k : php-filter-around-selections } + try %{ execute-keys -draft k : php-filter-around-selections } # indent after lines beginning / ending with opener token - try %_ exec -draft k ^\h*[[{]|[[{]$ j _ + try %_ execute-keys -draft k ^\h*[[{]|[[{]$ j _ > > diff --git a/rc/extra/pony.kak b/rc/extra/pony.kak index 44dd290e..ce96fd48 100644 --- a/rc/extra/pony.kak +++ b/rc/extra/pony.kak @@ -5,21 +5,21 @@ # ‾‾‾‾‾‾‾‾‾ hook global BufCreate .*[.](pony) %{ - set buffer filetype pony + set-option buffer filetype pony } # Highlighters & Completion # ‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾ -addhl shared/ regions -default code pony \ +add-highlighter shared/ regions -default code pony \ double_string '"""' '"""' '' \ double_string '"' (?' 0:type - addhl shared/pony/code regex '\b(${keywords})\b' 0:keyword - addhl shared/pony/code regex ';' 0:keyword - addhl shared/pony/code regex '^\s*|' 0:keyword - addhl shared/pony/code regex '\b(${struct})\b' 0:variable - addhl shared/pony/code regex '\b(${capabilities})\b(!|^)?' 1:builtin 2:builtin + 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(${func_decl})(\s+(${capabilities}))?(\s+\w+)\(' 1:type 3:builtin 4:builtin + add-highlighter shared/pony/code regex '\b(${func_decl})\b' 0:type + add-highlighter shared/pony/code regex '=>' 0:type + 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 '^\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 printf %s " - addhl shared/pony/code regex '@[\w_]+\b' 0:attribute + add-highlighter shared/pony/code regex '@[\w_]+\b' 0:attribute " } # Commands # ‾‾‾‾‾‾‾‾ -def -hidden pony-indent-on-new-line %{ - eval -draft -itersel %{ +define-command -hidden pony-indent-on-new-line %{ + evaluate-commands -draft -itersel %{ # preserve previous line indent - try %{ exec -draft K } + try %{ execute-keys -draft K } # cleanup trailing whitespaces from previous line - try %{ exec -draft k s \h+$ d } + try %{ execute-keys -draft k s \h+$ d } # copy '//' comment prefix and following white spaces - # try %{ exec -draft k x s ^\h*//\h* y jgh P } + # try %{ execute-keys -draft k x s ^\h*//\h* y jgh P } # indent after line ending with : - try %{ exec -draft k x (do|try|then|else|:|=>)$ j } + try %{ execute-keys -draft k x (do|try|then|else|:|=>)$ j } # else, end are always de-indented - try %{ exec -draft k x (else|end):$ k x s ^\h* y j x ^" J } + try %{ execute-keys -draft k x (else|end):$ k x s ^\h* y j x ^" J } } } # Initialization # ‾‾‾‾‾‾‾‾‾‾‾‾‾‾ -hook -group pony-highlight global WinSetOption filetype=pony %{ addhl window ref pony } +hook -group pony-highlight global WinSetOption filetype=pony %{ add-highlighter window ref pony } hook global WinSetOption filetype=pony %{ hook window InsertChar \n -group pony-indent pony-indent-on-new-line # cleanup trailing whitespaces on current line insert end - hook window InsertEnd .* -group pony-indent %{ try %{ exec -draft \; s ^\h+$ d } } + hook window InsertEnd .* -group pony-indent %{ try %{ execute-keys -draft \; s ^\h+$ d } } } hook global WinSetOption filetype=pony %{ - set buffer tabstop 2 - set buffer indentwidth 2 + set-option buffer tabstop 2 + set-option buffer indentwidth 2 } -hook -group pony-highlight global WinSetOption filetype=(?!pony).* %{ rmhl pony } +hook -group pony-highlight global WinSetOption filetype=(?!pony).* %{ remove-highlighter pony } hook global WinSetOption filetype=(?!pony).* %{ - rmhooks window pony-indent + remove-hooks window pony-indent } diff --git a/rc/extra/pug.kak b/rc/extra/pug.kak index fd2778a8..927de876 100644 --- a/rc/extra/pug.kak +++ b/rc/extra/pug.kak @@ -9,7 +9,7 @@ # ‾‾‾‾‾‾‾‾‾ hook global BufCreate .*[.](pug|jade) %{ - set buffer filetype pug + set-option buffer filetype pug } # Highlighters @@ -44,21 +44,21 @@ add-highlighter shared/pug/code regex ((?:\.[A-Za-z][A-Za-z0-9_-]* # Commands # ‾‾‾‾‾‾‾‾ -def -hidden pug-filter-around-selections %{ +define-command -hidden pug-filter-around-selections %{ # remove trailing white spaces - try %{ exec -draft -itersel s \h+$ d } + try %{ execute-keys -draft -itersel s \h+$ d } } -def -hidden pug-indent-on-new-line %{ - eval -draft -itersel %{ +define-command -hidden pug-indent-on-new-line %{ + evaluate-commands -draft -itersel %{ # preserve previous line indent - try %{ exec -draft \; K } + try %{ execute-keys -draft \; K } # filter previous line - try %{ exec -draft k : pug-filter-around-selections } + try %{ execute-keys -draft k : pug-filter-around-selections } # copy '//', '|', '-' or '(!)=' prefix and following whitespace - try %{ exec -draft k s ^\h*\K[/|!=-]{1,2}\h* y gh j P } + try %{ execute-keys -draft k s ^\h*\K[/|!=-]{1,2}\h* y gh j P } # indent unless we copied something above - try %{ exec -draft b s \S g l } + try %{ execute-keys -draft b s \S g l } } } diff --git a/rc/extra/racer.kak b/rc/extra/racer.kak index ce8b5190..a1bb4866 100644 --- a/rc/extra/racer.kak +++ b/rc/extra/racer.kak @@ -1,11 +1,11 @@ -decl -hidden str racer_tmp_dir -decl -hidden completions racer_completions +declare-option -hidden str racer_tmp_dir +declare-option -hidden completions racer_completions -def racer-complete -docstring "Complete the current selection with racer" %{ +define-command racer-complete -docstring "Complete the current selection with racer" %{ %sh{ dir=$(mktemp -d "${TMPDIR:-/tmp}"/kak-racer.XXXXXXXX) - printf %s\\n "set buffer racer_tmp_dir ${dir}" - printf %s\\n "eval -no-hooks %{ write ${dir}/buf }" + printf %s\\n "set-option buffer racer_tmp_dir ${dir}" + printf %s\\n "evaluate-commands -no-hooks %{ write ${dir}/buf }" } %sh{ dir=${kak_opt_racer_tmp_dir} @@ -44,25 +44,25 @@ def racer-complete -docstring "Complete the current selection with racer" %{ print candidate }' ) - printf %s\\n "eval -client '${kak_client}' %{ - set buffer=${kak_bufname} racer_completions %@${compl}@ + printf %s\\n "evaluate-commands -client '${kak_client}' %{ + set-option buffer=${kak_bufname} racer_completions %@${compl}@ }" | kak -p ${kak_session} rm -r ${dir} ) > /dev/null 2>&1 < /dev/null & } } -def racer-enable-autocomplete -docstring "Add racer completion candidates to the completer" %{ - set window completers "option=racer_completions:%opt{completers}" +define-command racer-enable-autocomplete -docstring "Add racer completion candidates to the completer" %{ + set-option window completers "option=racer_completions:%opt{completers}" hook window -group racer-autocomplete InsertIdle .* %{ try %{ - exec -draft ([\w\.]|::).\z + execute-keys -draft ([\w\.]|::).\z racer-complete } } alias window complete racer-complete } -def racer-disable-autocomplete -docstring "Disable racer completion" %{ - set window completers %sh{ printf %s\\n "'${kak_opt_completers}'" | sed 's/option=racer_completions://g' } - rmhooks window racer-autocomplete +define-command racer-disable-autocomplete -docstring "Disable racer completion" %{ + set-option window completers %sh{ printf %s\\n "'${kak_opt_completers}'" | sed 's/option=racer_completions://g' } + remove-hooks window racer-autocomplete unalias window complete racer-complete } diff --git a/rc/extra/ragel.kak b/rc/extra/ragel.kak index 4f228962..39b072e0 100644 --- a/rc/extra/ragel.kak +++ b/rc/extra/ragel.kak @@ -7,7 +7,7 @@ # ‾‾‾‾‾‾‾‾‾ hook global BufCreate .*[.](ragel|rl) %{ - set buffer filetype ragel + set-option buffer filetype ragel } # Highlighters @@ -29,29 +29,29 @@ add-highlighter shared/ragel/code regex \b(action|alnum|alpha|any|ascii|case|cnt # Commands # ‾‾‾‾‾‾‾‾ -def -hidden ragel-filter-around-selections %{ +define-command -hidden ragel-filter-around-selections %{ # remove trailing white spaces - try %{ exec -draft -itersel s \h+$ d } + try %{ execute-keys -draft -itersel s \h+$ d } } -def -hidden ragel-indent-on-char %< - eval -draft -itersel %< +define-command -hidden ragel-indent-on-char %< + evaluate-commands -draft -itersel %< # align closer token to its opener when alone on a line - try %< exec -draft ^\h+[]})]$ m s \A|.\z 1 > - try %< exec -draft ^\h+ [*]$ [*]$ s \A|.\z 1 > + try %< execute-keys -draft ^\h+[]})]$ m s \A|.\z 1 > + try %< execute-keys -draft ^\h+ [*]$ [*]$ s \A|.\z 1 > > > -def -hidden ragel-indent-on-new-line %< - eval -draft -itersel %< +define-command -hidden ragel-indent-on-new-line %< + evaluate-commands -draft -itersel %< # copy _#_ comment prefix and following white spaces - try %{ exec -draft k s ^\h*\K#\h* y gh j P } + try %{ execute-keys -draft k s ^\h*\K#\h* y gh j P } # preserve previous line indent - try %{ exec -draft \; K } + try %{ execute-keys -draft \; K } # filter previous line - try %{ exec -draft k : ragel-filter-around-selections } + try %{ execute-keys -draft k : ragel-filter-around-selections } # indent after lines ending with opener token - try %< exec -draft k [[{(*]$ j > + try %< execute-keys -draft k [[{(*]$ j > > > diff --git a/rc/extra/ranger.kak b/rc/extra/ranger.kak index e27980a6..4ba2a64f 100644 --- a/rc/extra/ranger.kak +++ b/rc/extra/ranger.kak @@ -1,7 +1,7 @@ # http://ranger.nongnu.org # ‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾ -def ranger-open-on-edit-directory \ +define-command ranger-open-on-edit-directory \ -docstring 'Start the ranger file system explorer when trying to edit a directory' %{ hook global RuntimeError "\d+:\d+: '\w+' (.*): is a directory" %{ %sh{ directory=$kak_hook_param_capture_1 @@ -9,7 +9,7 @@ def ranger-open-on-edit-directory \ }} } -def \ +define-command \ -params .. -file-completion \ -docstring %{ranger []: open the file system explorer to select buffers to open All the optional arguments are forwarded to the ranger utility} \ @@ -19,7 +19,7 @@ All the optional arguments are forwarded to the ranger utility} \ ranger $@ --cmd " \ map eval \ fm.execute_console('shell \ - echo eval -client $kak_client edit {file} | \ + echo evaluate-commands -client $kak_client edit {file} | \ kak -p $kak_session; \ tmux select-pane -t $kak_client_env_TMUX_PANE'.format(file=fm.thisfile.path)) \ if fm.thisfile.is_file else fm.execute_console('move right=1')" @@ -28,7 +28,7 @@ All the optional arguments are forwarded to the ranger utility} \ ranger $@ --cmd "'"'" \ map eval \ fm.execute_console('shell \ - echo eval -client $kak_client edit {file} | \ + echo evaluate-commands -client $kak_client edit {file} | \ kak -p $kak_session; \ xdotool windowactivate $kak_client_env_WINDOWID'.format(file=fm.thisfile.path)) \ if fm.thisfile.is_file else fm.execute_console('move right=1')"'"' < /dev/null > /dev/null 2>&1 & diff --git a/rc/extra/sass.kak b/rc/extra/sass.kak index 7c901797..f3ba8f3f 100644 --- a/rc/extra/sass.kak +++ b/rc/extra/sass.kak @@ -5,7 +5,7 @@ # ‾‾‾‾‾‾‾‾‾ hook global BufCreate .*[.](sass) %{ - set buffer filetype sass + set-option buffer filetype sass } # Highlighters @@ -29,21 +29,21 @@ add-highlighter shared/sass/code regex !important 0:keyword # Commands # ‾‾‾‾‾‾‾‾ -def -hidden sass-filter-around-selections %{ +define-command -hidden sass-filter-around-selections %{ # remove trailing white spaces - try %{ exec -draft -itersel s \h+$ d } + try %{ execute-keys -draft -itersel s \h+$ d } } -def -hidden sass-indent-on-new-line %{ - eval -draft -itersel %{ +define-command -hidden sass-indent-on-new-line %{ + evaluate-commands -draft -itersel %{ # copy '/' comment prefix and following white spaces - try %{ exec -draft k s ^\h*\K/\h* y gh j P } + try %{ execute-keys -draft k s ^\h*\K/\h* y gh j P } # preserve previous line indent - try %{ exec -draft \; K } + try %{ execute-keys -draft \; K } # filter previous line - try %{ exec -draft k : sass-filter-around-selections } + try %{ execute-keys -draft k : sass-filter-around-selections } # avoid indent after properties and comments - try %{ exec -draft k [:/] j } + try %{ execute-keys -draft k [:/] j } } } diff --git a/rc/extra/scss.kak b/rc/extra/scss.kak index 791a1afa..4fd1ebcb 100644 --- a/rc/extra/scss.kak +++ b/rc/extra/scss.kak @@ -7,7 +7,7 @@ # ‾‾‾‾‾‾‾‾‾ hook global BufCreate .*[.](scss) %{ - set buffer filetype scss + set-option buffer filetype scss } # Highlighters @@ -25,9 +25,9 @@ add-highlighter shared/scss/core regex @[A-Za-z][A-Za-z0-9_-]* 0:meta # Commands # ‾‾‾‾‾‾‾‾ -def -hidden scss-filter-around-selections css-filter-around-selections -def -hidden scss-indent-on-new-line css-indent-on-new-line -def -hidden scss-indent-on-closing-curly-brace css-indent-on-closing-curly-brace +define-command -hidden scss-filter-around-selections css-filter-around-selections +define-command -hidden scss-indent-on-new-line css-indent-on-new-line +define-command -hidden scss-indent-on-closing-curly-brace css-indent-on-closing-curly-brace # Initialization # ‾‾‾‾‾‾‾‾‾‾‾‾‾‾ diff --git a/rc/extra/taskpaper.kak b/rc/extra/taskpaper.kak index 89b1aab4..1a832ad1 100644 --- a/rc/extra/taskpaper.kak +++ b/rc/extra/taskpaper.kak @@ -5,7 +5,7 @@ # ‾‾‾‾‾‾‾‾‾ hook global BufCreate .*\.taskpaper %{ - set buffer filetype taskpaper + set-option buffer filetype taskpaper } # Highlighters @@ -22,14 +22,14 @@ add-highlighter shared/taskpaper regex (([a-z]+://\S+)|((mailto:)[\w+-]+@\S+)) 0 # Commands # ‾‾‾‾‾‾‾‾ -def -hidden taskpaper-indent-on-new-line %{ - eval -draft -itersel %{ +define-command -hidden taskpaper-indent-on-new-line %{ + evaluate-commands -draft -itersel %{ # preserve previous line indent - try %{ exec -draft \;K } + try %{ execute-keys -draft \;K } ## If the line above is a project indent with a tab - try %{ exec -draft Z k ^\h*([^:\n]+): z i } + try %{ execute-keys -draft Z k ^\h*([^:\n]+): z i } # cleanup trailing white spaces on previous line - try %{ exec -draft k s \h+$ d } + try %{ execute-keys -draft k s \h+$ d } } } diff --git a/rc/extra/tmux-repl.kak b/rc/extra/tmux-repl.kak index f86b84da..1dfd7ab4 100644 --- a/rc/extra/tmux-repl.kak +++ b/rc/extra/tmux-repl.kak @@ -22,7 +22,7 @@ hook global KakBegin .* %{ } } -def -hidden -params 1..2 tmux-repl-impl %{ +define-command -hidden -params 1..2 tmux-repl-impl %{ %sh{ if [ -z "$TMUX" ]; then echo "echo -markup '{Error}This command is only available in a tmux session'" @@ -37,19 +37,19 @@ def -hidden -params 1..2 tmux-repl-impl %{ } } -def tmux-repl-vertical -params 0..1 -command-completion -docstring "Create a new vertical pane for repl interaction" %{ +define-command tmux-repl-vertical -params 0..1 -command-completion -docstring "Create a new vertical pane for repl interaction" %{ tmux-repl-impl 'split-window -v' %arg{@} } -def tmux-repl-horizontal -params 0..1 -command-completion -docstring "Create a new horizontal pane for repl interaction" %{ +define-command tmux-repl-horizontal -params 0..1 -command-completion -docstring "Create a new horizontal pane for repl interaction" %{ tmux-repl-impl 'split-window -h' %arg{@} } -def tmux-repl-window -params 0..1 -command-completion -docstring "Create a new window for repl interaction" %{ +define-command tmux-repl-window -params 0..1 -command-completion -docstring "Create a new window for repl interaction" %{ tmux-repl-impl 'new-window' %arg{@} } -def -hidden tmux-send-text -docstring "Send the selected text to the repl pane" %{ +define-command -hidden tmux-send-text -docstring "Send the selected text to the repl pane" %{ nop %sh{ tmux set-buffer -b kak_selection "${kak_selection}" kak_orig_window=$(tmux display-message -p '#I') @@ -62,7 +62,7 @@ def -hidden tmux-send-text -docstring "Send the selected text to the repl pane" } } -def -hidden tmux-repl-disabled %{ %sh{ +define-command -hidden tmux-repl-disabled %{ %sh{ VERSION_TMUX=$(tmux -V) printf %s "echo -markup %{{Error}The version of tmux is too old: got ${VERSION_TMUX}, expected >= 2.x}" } } diff --git a/rc/extra/tupfile.kak b/rc/extra/tupfile.kak index 74a5f350..77630c2e 100644 --- a/rc/extra/tupfile.kak +++ b/rc/extra/tupfile.kak @@ -5,7 +5,7 @@ # ‾‾‾‾‾‾‾‾‾ hook global BufCreate (.+/)?[Tt]upfile %{ - set buffer filetype tupfile + set-option buffer filetype tupfile } # Highlighters diff --git a/rc/extra/typescript.kak b/rc/extra/typescript.kak index 6212871d..81ab5d6d 100644 --- a/rc/extra/typescript.kak +++ b/rc/extra/typescript.kak @@ -5,7 +5,7 @@ # ‾‾‾‾‾‾‾‾‾ hook global BufCreate .*[.](ts)x? %{ - set buffer filetype typescript + set-option buffer filetype typescript } # Highlighters diff --git a/rc/extra/x11-repl.kak b/rc/extra/x11-repl.kak index 13bcd88b..41fdcb8f 100644 --- a/rc/extra/x11-repl.kak +++ b/rc/extra/x11-repl.kak @@ -1,18 +1,18 @@ -# termcmd should already be set in x11.kak -def -docstring %{x11-repl []: create a new window for repl interaction +# termcmd should already be set-option in x11.kak +define-command -docstring %{x11-repl []: create a new window for repl interaction All optional parameters are forwarded to the new window} \ -params .. \ -command-completion \ x11-repl %{ %sh{ if [ -z "${kak_opt_termcmd}" ]; then - echo "echo -markup '{Error}termcmd option is not set'" + echo "echo -markup '{Error}termcmd option is not set-option'" exit fi if [ $# -eq 0 ]; then cmd="${SHELL:-sh}"; else cmd="$@"; fi setsid ${kak_opt_termcmd} ${cmd} -t kak_repl_window < /dev/null > /dev/null 2>&1 & }} -def x11-send-text -docstring "send the selected text to the repl window" %{ +define-command x11-send-text -docstring "send the selected text to the repl window" %{ nop %sh{ printf %s\\n "${kak_selection}" | xsel -i wid=$(xdotool getactivewindow) diff --git a/src/commands.cc b/src/commands.cc index e0da8d58..761fc665 100644 --- a/src/commands.cc +++ b/src/commands.cc @@ -1669,9 +1669,9 @@ void context_wrap(const ParametersParser& parser, Context& context, Func func) } const CommandDesc exec_string_cmd = { + "execute-keys", "exec", - nullptr, - "exec : execute given keys as if entered by user", + "execute-keys : execute given keys as if entered by user", context_wrap_params, CommandFlags::None, CommandHelper{}, @@ -1694,9 +1694,9 @@ const CommandDesc exec_string_cmd = { }; const CommandDesc eval_string_cmd = { + "evaluate-commands", "eval", - nullptr, - "eval ...: execute commands as if entered by user", + "evaluate-commands ...: execute commands as if entered by user", context_wrap_params, CommandFlags::None, CommandHelper{},