133 lines
5.6 KiB
Plaintext
133 lines
5.6 KiB
Plaintext
# http://www.scheme-reports.org
|
|
# ‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾
|
|
|
|
# require lisp.kak
|
|
|
|
# Detection
|
|
# ‾‾‾‾‾‾‾‾‾
|
|
|
|
hook global BufCreate (.*/)?(.*\.(scm|ss|sld)) %{
|
|
set-option buffer filetype scheme
|
|
}
|
|
|
|
# Highlighters
|
|
# ‾‾‾‾‾‾‾‾‾‾‾‾
|
|
|
|
add-highlighter shared/scheme regions
|
|
add-highlighter shared/scheme/code default-region group
|
|
|
|
add-highlighter shared/scheme/string region '"' (?<!\\)(\\\\)*" fill string
|
|
add-highlighter shared/scheme/comment region ';' '$' fill comment
|
|
add-highlighter shared/scheme/comment-form region -recurse "\(" "#;\(" "\)" fill comment
|
|
add-highlighter shared/scheme/comment-block region "#\|" "\|#" fill comment
|
|
add-highlighter shared/scheme/quoted-form region -recurse "\(" "'\(" "\)" fill variable
|
|
|
|
add-highlighter shared/scheme/code/ regex (#t|#f) 0:value
|
|
add-highlighter shared/scheme/code/ regex \b[0-9]+\.[0-9]*\b 0:value
|
|
|
|
evaluate-commands %sh{
|
|
|
|
# Primitive expressions that cannot be derived.
|
|
keywords='define do let let* letrec if cond case and or begin lambda delay delay-force set!'
|
|
|
|
# Macro expressions.
|
|
meta="define-syntax let-syntax letrec-syntax syntax-rules syntax-case"
|
|
|
|
# Basic operators.
|
|
operators='* + - ... / < <= = => > >='
|
|
|
|
# Procedures that create a base type and their predicates (for easier type checking)
|
|
types="list vector bytevector cons string boolean? list? pair?
|
|
vector? bytevector? string? char? complex? eof-object? input-port?
|
|
null? number? output-port? procedure? symbol?"
|
|
|
|
# R5RS available procedures
|
|
builtins="abs acos angle append apply asin assoc assq assv atan
|
|
caaaar caaadr caaar caadar caaddr caadr
|
|
caar cadaar cadadr cadar caddar cadddr caddr cadr
|
|
call-with-current-continuation call-with-input-file
|
|
call-with-output-file call-with-values car cdaaar cdaadr cdaar
|
|
cdadar cdaddr cdadr cdar cddaar cddadr cddar cdddar cddddr cdddr
|
|
cddr cdr ceiling char->integer char-alphabetic? char-ci<=?
|
|
char-ci<? char-ci=? char-ci>=? char-ci>? char-downcase
|
|
char-lower-case? char-numeric? char-ready? char-upcase
|
|
char-upper-case? char-whitespace? char<=? char<? char=?
|
|
char>=? char>? close-input-port close-output-port cons cos
|
|
current-input-port current-output-port denominator display
|
|
dynamic-wind else eq? equal? eqv? eval even? exact->inexact
|
|
exact? exp expt floor for-each force gcd imag-part inexact->exact
|
|
inexact? integer->char integer? interaction-environment lcm
|
|
length list list->string list->vector list-ref list-tail load log
|
|
magnitude make-polar make-rectangular make-string make-vector
|
|
map max member memq memv min modulo negative? newline not
|
|
null-environment number->string numerator odd? open-input-file
|
|
open-output-file or peek-char positive? quasiquote quote quotient
|
|
rational? rationalize read read-char real-part real? remainder
|
|
reverse round scheme-report-environment set-car! set-cdr! sin
|
|
sqrt string->list string->number string->symbol string-append
|
|
string-ci<=? string-ci<? string-ci=? string-ci>=?
|
|
string-ci>? string-copy string-fill! string-length string-ref
|
|
string-set! string<=? string<? string=? string>=? string>?
|
|
substring symbol->string tan truncate values vector
|
|
vector->list vector-fill! vector-length vector-ref vector-set!
|
|
with-input-from-file with-output-to-file write write-char zero?"
|
|
|
|
join () { printf "%s" "$1" | tr -s ' \n\t' "$2"; }
|
|
|
|
printf '%s\n' "hook global WinSetOption filetype=scheme %{
|
|
set-option window static_words '$(join "$keywords:$meta:$operators:$builtins" ':' )'
|
|
}"
|
|
|
|
exact_quote () {
|
|
for symbol in "$@"
|
|
do
|
|
printf '\\Q%s\\E ' "$symbol"
|
|
done
|
|
}
|
|
|
|
qkeys=$(join "$(exact_quote $keywords)" '|')
|
|
qmeta=$(join "$(exact_quote $meta)" '|')
|
|
qops=$(join "$(exact_quote "$operators")" '|')
|
|
qbuiltins=$(join "$(exact_quote $builtins)" '|')
|
|
qtypes=$(join "$(exact_quote $types)" '|')
|
|
|
|
non_word_chars='[\s\(\)\[\]\{\};\|]'
|
|
normal_identifiers='-!$%&\*\+\./:<=>\?\^_~a-zA-Z0-9'
|
|
identifier_chars="[${normal_identifiers}][${normal_identifiers},#]*"
|
|
|
|
add_highlighter () {
|
|
printf '%s\n' "add-highlighter shared/scheme/code/ regex \"$1\" $2"
|
|
}
|
|
|
|
add_highlighter "${non_word_chars}+(${qkeys})${non_word_chars}" "1:keyword"
|
|
add_highlighter "${non_word_chars}+(${qmeta})${non_word_chars}" "1:meta"
|
|
add_highlighter "${non_word_chars}+(${qops})${non_word_chars}" "1:operator"
|
|
add_highlighter "${non_word_chars}+(${qbuiltins})${non_word_chars}" "1:builtin"
|
|
add_highlighter "${non_word_chars}+('${identifier_chars})" "1:attribute"
|
|
add_highlighter "${non_word_chars}+(${qtypes})${non_word_chars}" "1:type"
|
|
add_highlighter "\(define\W+\(($identifier_chars)" "1:function"
|
|
add_highlighter "\(define\W+($identifier_chars)\W+\(lambda" "1:function"
|
|
}
|
|
|
|
# Initialization
|
|
# ‾‾‾‾‾‾‾‾‾‾‾‾‾‾
|
|
|
|
hook -group scheme-highlight global WinSetOption filetype=scheme %{
|
|
add-highlighter window/scheme ref scheme
|
|
}
|
|
|
|
hook -group scheme-highlight global WinSetOption filetype=(?!scheme).* %{
|
|
remove-highlighter window/scheme
|
|
}
|
|
|
|
hook global WinSetOption filetype=scheme %{
|
|
set-option -add buffer extra_word_chars %{-:!:%:?:<:>:=}
|
|
hook window InsertEnd .* -group scheme-hooks lisp-filter-around-selections
|
|
hook window InsertChar \n -group scheme-indent lisp-indent-on-new-line
|
|
}
|
|
|
|
hook global WinSetOption filetype=(?!scheme).* %{
|
|
remove-hooks window scheme-indent
|
|
remove-hooks window scheme-hooks
|
|
}
|