mirror of
https://github.com/mawww/kakoune.git
synced 2024-12-25 12:36:11 +03:00
f6a2925950
Level out the builtin commands loaded at startup in terms of format and expressiveness. The following convention was followed: * commands that take more than one argument have to be described along with their parameters prior to the actual documentation, otherwise the docstring consists in a capitalized sentence e.g. `command <arg1>: do something` * optional arguments are enclosed in square brackets, to comply with the format used for hardcoded commands e.g. `cd [<directory>]` * describe the effects of the command in the documentation string and omit implementation details unless they are relevant. Usually command names include the name of the tool they use, so they don't need to be redundantly mentioned e.g. `tmux-new-pane <arguments>: open a new pane` * document the format the parameters to the commands, or list them if they are to be chosen among a list of static values (c.f. `spell.kak`)
110 lines
4.1 KiB
Plaintext
110 lines
4.1 KiB
Plaintext
##
|
|
## modeline.kak by lenormf
|
|
##
|
|
|
|
## Currently supported modeline format: vim
|
|
## Also supports kakoune options with a 'kak' or 'kakoune' prefix
|
|
## Only a few options are supported, in order to prevent the
|
|
## buffers from poking around the configuration too much
|
|
|
|
# Amount of additional lines that will be checked at the beginning
|
|
# and the end of the buffer
|
|
decl int modelines 5
|
|
|
|
def -hidden _modeline-parse %{
|
|
%sh{
|
|
# Translate a vim option into the corresponding kakoune one
|
|
function translate_opt_vim {
|
|
readonly key="$1"
|
|
readonly value="$2"
|
|
local tr=""
|
|
|
|
case "${key}" in
|
|
so|scrolloff) tr="scrolloff ${value},${kak_opt_scrolloff##*,}";;
|
|
siso|sidescrolloff) tr="scrolloff ${kak_opt_scrolloff%%,*},${value}";;
|
|
ts|tabstop) tr="tabstop ${value}";;
|
|
sw|shiftwidth) tr="indentwidth ${value}";;
|
|
tw|textwidth) tr="autowrap_column ${value}";;
|
|
ff|fileformat)
|
|
case "${value}" in
|
|
unix) tr="eolformat lf";;
|
|
dos) tr="eolformat crlf";;
|
|
*) printf %s\\n "echo -debug 'Unsupported file format: ${value}'";;
|
|
esac
|
|
;;
|
|
ft|filetype) tr="filetype ${value}";;
|
|
bomb) tr="BOM utf8";;
|
|
nobomb) tr="BOM none";;
|
|
*) printf %s\\n "echo -debug 'Unsupported vim variable: ${key}'";;
|
|
esac
|
|
|
|
[ -n "${tr}" ] && printf %s\\n "set buffer ${tr}"
|
|
}
|
|
|
|
# Pass a few whitelisted options to kakoune directly
|
|
function translate_opt_kakoune {
|
|
readonly key="$1"
|
|
readonly value="$2"
|
|
readonly OPTS_ALLOWED=(
|
|
scrolloff
|
|
tabstop
|
|
indentwidth
|
|
autowrap_column
|
|
eolformat
|
|
filetype
|
|
mimetype
|
|
BOM
|
|
)
|
|
|
|
printf %s\\n "${OPTS_ALLOWED[@]}" | grep -qw "${key}" || {
|
|
printf %s\\n "echo -debug 'Unsupported kakoune variable: ${key}'";
|
|
return;
|
|
}
|
|
|
|
printf %s\\n "set buffer ${key} ${value}"
|
|
}
|
|
|
|
# The following subshell will keep the actual options of the modeline, and strip:
|
|
# - the text that leads the first option, according to the official vim modeline format
|
|
# - the trailing text after the last option, and an optional ':' sign before it
|
|
# It will also convert the ':' seperators beween the option=value pairs
|
|
# More info: http://vimdoc.sourceforge.net/htmldoc/options.html#modeline
|
|
options=(
|
|
$(printf %s\\n "${kak_selection}" | sed \
|
|
-e 's/^[^:]\{1,\}://' \
|
|
-e 's/[ \t]*set\{0,1\}[ \t]//' \
|
|
-e 's/:[^a-zA-Z0-9_=-]*$//' \
|
|
-e 's/:/ /g')
|
|
)
|
|
|
|
case "${kak_selection}" in
|
|
*vi:*|*vim:*) type_selection="vim";;
|
|
*kak:*|*kakoune:*) type_selection="kakoune";;
|
|
*) echo "echo -debug Unsupported modeline format";;
|
|
esac
|
|
[ -n "${type_selection}" ] || exit 1
|
|
|
|
for option in "${options[@]}"; do
|
|
name_option="${option%%=*}"
|
|
value_option="${option#*=}"
|
|
|
|
case "${type_selection}" in
|
|
vim) tr=$(translate_opt_vim "${name_option}" "${value_option}");;
|
|
kakoune) tr=$(translate_opt_kakoune "${name_option}" "${value_option}");;
|
|
esac
|
|
|
|
[ -n "${tr}" ] && printf %s\\n "${tr}"
|
|
done
|
|
}
|
|
}
|
|
|
|
# Add the following function to a hook on BufOpen to automatically parse modelines
|
|
# Select the first and last `modelines` lines in the buffer, only keep modelines
|
|
def modeline-parse -docstring "Read and interpret vi-format modelines at the beginning/end of the buffer" %{
|
|
try %{ eval -draft %{
|
|
exec \%s\`|.\'<ret> %opt{modelines}k <a-x> %opt{modelines}X \
|
|
s^[^\s]+?\s(vim?|kak(oune)?):\s?[^\n]+<ret>
|
|
eval -draft -itersel _modeline-parse
|
|
} }
|
|
}
|