syntax items
vim が理解する3つのタイプ
優先順位
- 複数の Match や Region が同じ場所で始まった場合,最後に設定された item が優先される.
- Keyword は Match や Region よりも優先される.
- より前の位置で始まる item が優先される
Case
:syntax case [match|ignore]
Case sensitive or not.
Spell
:syntax spell [toplevel|notoplevel|default]
Syntax item のなかに入ってないテキストに対してスペルチェックをするかどうか.
Keyword
:syntax keyword {group-name} [{options}] {keyword} .. [{options}]
キーワードを設定.
- group-name: keyword のグループ.(ex. Comment, Type)
- keyword: syntax となる keyword
- options: オプション.どこに来てもいい. 詳細は arguments を参照
Matches
:syntax match {group-name} [{options}] [excludenl] {pattern} [{options}]
- group-name: match のグループ.(ex. Comment)
- options: オプション.詳細は arguments を参照
- excludenl: 行末 "$" を含むパターンに対して,行末以降まで拡張しない.
- pattern: 正規表現のパターン
Regions
:syntax region {group-name} [{options}]
[matchgroup={group-name}]
[keepend]
[extend]
[excludenl]
start={start_pattern} ..
[skip={skip_pattern}]
end={end_pattern} ..
- group-name: region のグループ
- options: オプション.詳細は arguments を参照
- matchgroup={group-name}: region と,その開始,終了パターンで別のハイライトを用いる
- keepend: 内包された match が終了パターンを超えないようにする
- extend: この region を含む item の "keepend" を上書きする
- start={start_pattern}: region の開始のパターン
- skip={skip_pattern}: end_pattern を探さないパターン
- end={end_pattern}: region の終了のパターン
arguments
すべての command で使える
- conceal:concealable とする
- ccar:'conceal' とされている keyword のなかでも表示される文字
- contained:トップレベルでは認識されず,別の match の中で指定された時に認識される
- containedin:
- nextgroup:
- transparent:
- skipwhite:
- skipnl:
- skipempty
match と region で使える
- contains={group-name}:ここで指定されたグループは,そのアイテムのなかで始まることができる.
ms=
とme=
でオフセットを設定可能.
- fold:折りたたみレベルを1つ増加させる
- display:検出されたハイライトが表示されない時にはスキップされる.行末を超えて継続しない場合など.
- extend:
region で使える
- oneline:一行のみで完結
- concealends:
Group name
Comment
Constant
String
Character
Number
Boolean
Float
Identifier
Function
Statement
Conditional
Repeat
Label
Operator
Keyword
Exception
PreProc
Include
Define
Macro
PreCondit
Type
StorageClass
Structure
Typedef
Special
SpecialChar
Tag
Delimiter
SpecialComment
Debug
Underline
Ignore
Error
Todo