Command Parsing
Kakoune commands, either loaded from a script or written in the command prompt, are parsed according to the following rules:
1. Basic parsing
-
Commands are terminated by a
;
or an end of line. -
Words (command names and parameters) are delimited by whitespaces.
2. Quoted Strings
If a word starts with '
, "
, or %X
with X
a non-nestable punctuation
character (see Balanced Strings below for
nestable characters), it is parsed as a quoted string whose delimiter is,
respectively, '
, "
, or X
.
A quoted string contains every character (including whitespaces). Doubling a closing delimiter escapes it. Thus, for example, entering two closing delimiters at the end of a quoted string will render one of the characters literally; that is, it will be considered as part of the quoted string’s content.
Inside double quotes, %
-strings are processed unless the %
is escaped by
doubling it. Double quotes inside these nested strings must also be escaped.
No other escaping takes place in quoted strings.
2.1. Quoted Strings Examples
-
'foo'
contains foo. -
foo’bar'
is read verbatim, so it contains foo’bar'. -
foo%|bar|
is read verbatim, so it contains foo%|bar|. -
'foo''bar'
is a single word whose content is foo’bar. -
"baz"""
is a single word whose content is baz". -
%|foo||bar|
is a single word whose content is foo|bar. -
"foo %|""bar| %%,baz,"
is a single word whose content is foo "bar %,baz,.
3. Balanced Strings
If a word starts with %X
with X
a nestable punctuation character (one
of (
, [
, {
and <
), it is parsed as a balanced string whose closing
delimiter matches that of its opening delimiter (respectively, )
, ]
,
}
, and >
).
There is no way to escape the opening and closing characters, even if they are nested inside some other kind of string.
3.1. Balanced Strings Examples
-
%{foo}
contains foo. -
%{foo{bar}}
contains foo{bar}. -
foo%{bar}
contains foo%{bar}. -
"foo %{bar}"
is a single word whose content is foo bar. -
%{foo\{}
is a parse error, since the{}
delimiters are not balanced. -
%[foo\{]
contains foo\{, since it uses different delimiters.
4. Non-Quoted words
Other words are non-quoted. Non-quoted words are terminated by either a
whitespace or a ;
.
If they start with a \
followed by a %
, '
, or "
, then that leading
\
escapes those characters and is discarded.
If a whitespace or ;
is preceded by a \
, then the \
is discarded, and
the whitespace or ;
becomes part of the word. Any other \
is treated
as a literal \
.
5. Typed Expansions
Quoted and Balanced strings starting with %
might have an optional
alphabetic expansion type between the %
and their delimiter (which is
always a punctuation character). This expansion type defines how the
string’s content is going to be expanded. Rules for expanding and escaping
expansion types are the same as for %
-strings.
-
If the expansion type is empty, the string content is used verbatim.
-
If the expansion type is one of
sh
,reg
,opt
,val
orarg
, the string is expanded as described in:doc expansions
. -
For any other expansion type, a parsing error is raised.