blob: 53e0734828029dd3b1e6b801fd485a155c8887d8 [file] [log] [blame]
Bram Moolenaar071d4272004-06-13 20:20:40 +00001" Vim syntax file
2" Language: Python
Bram Moolenaar541f92d2015-06-19 13:27:23 +02003" Maintainer: Zvezdan Petkovic <zpetkovic@acm.org>
Bram Moolenaar9faec4e2021-02-27 16:38:07 +01004" Last Change: 2021 Feb 15
Bram Moolenaar541f92d2015-06-19 13:27:23 +02005" Credits: Neil Schemenauer <nas@python.ca>
Bram Moolenaar5c736222010-01-06 20:54:52 +01006" Dmitry Vasiliev
Bram Moolenaar071d4272004-06-13 20:20:40 +00007"
Bram Moolenaar5c736222010-01-06 20:54:52 +01008" This version is a major rewrite by Zvezdan Petkovic.
Bram Moolenaar071d4272004-06-13 20:20:40 +00009"
Bram Moolenaar5c736222010-01-06 20:54:52 +010010" - introduced highlighting of doctests
11" - updated keywords, built-ins, and exceptions
12" - corrected regular expressions for
Bram Moolenaar071d4272004-06-13 20:20:40 +000013"
Bram Moolenaar5c736222010-01-06 20:54:52 +010014" * functions
15" * decorators
16" * strings
17" * escapes
18" * numbers
19" * space error
Bram Moolenaar071d4272004-06-13 20:20:40 +000020"
Bram Moolenaar5c736222010-01-06 20:54:52 +010021" - corrected synchronization
22" - more highlighting is ON by default, except
23" - space error highlighting is OFF by default
Bram Moolenaar071d4272004-06-13 20:20:40 +000024"
Bram Moolenaar5c736222010-01-06 20:54:52 +010025" Optional highlighting can be controlled using these variables.
Bram Moolenaar071d4272004-06-13 20:20:40 +000026"
Bram Moolenaar5c736222010-01-06 20:54:52 +010027" let python_no_builtin_highlight = 1
28" let python_no_doctest_code_highlight = 1
29" let python_no_doctest_highlight = 1
30" let python_no_exception_highlight = 1
31" let python_no_number_highlight = 1
32" let python_space_error_highlight = 1
Bram Moolenaar071d4272004-06-13 20:20:40 +000033"
Bram Moolenaar5c736222010-01-06 20:54:52 +010034" All the options above can be switched on together.
Bram Moolenaar071d4272004-06-13 20:20:40 +000035"
Bram Moolenaar5c736222010-01-06 20:54:52 +010036" let python_highlight_all = 1
Bram Moolenaar071d4272004-06-13 20:20:40 +000037"
38
Bram Moolenaar89bcfda2016-08-30 23:26:57 +020039" quit when a syntax file was already loaded.
40if exists("b:current_syntax")
Bram Moolenaar071d4272004-06-13 20:20:40 +000041 finish
42endif
43
Bram Moolenaar00659062010-09-21 22:34:02 +020044" We need nocompatible mode in order to continue lines with backslashes.
45" Original setting will be restored.
46let s:cpo_save = &cpo
47set cpo&vim
48
Bram Moolenaarb4ada792016-10-30 21:55:26 +010049if exists("python_no_doctest_highlight")
50 let python_no_doctest_code_highlight = 1
51endif
52
53if exists("python_highlight_all")
54 if exists("python_no_builtin_highlight")
55 unlet python_no_builtin_highlight
56 endif
57 if exists("python_no_doctest_code_highlight")
58 unlet python_no_doctest_code_highlight
59 endif
60 if exists("python_no_doctest_highlight")
61 unlet python_no_doctest_highlight
62 endif
63 if exists("python_no_exception_highlight")
64 unlet python_no_exception_highlight
65 endif
66 if exists("python_no_number_highlight")
67 unlet python_no_number_highlight
68 endif
69 let python_space_error_highlight = 1
70endif
71
Bram Moolenaar5c736222010-01-06 20:54:52 +010072" Keep Python keywords in alphabetical order inside groups for easy
73" comparison with the table in the 'Python Language Reference'
Bram Moolenaar9faec4e2021-02-27 16:38:07 +010074" https://docs.python.org/reference/lexical_analysis.html#keywords.
Bram Moolenaar5c736222010-01-06 20:54:52 +010075" Groups are in the order presented in NAMING CONVENTIONS in syntax.txt.
76" Exceptions come last at the end of each group (class and def below).
77"
Bram Moolenaar9faec4e2021-02-27 16:38:07 +010078" The list can be checked using:
Bram Moolenaar5c736222010-01-06 20:54:52 +010079"
Bram Moolenaar9faec4e2021-02-27 16:38:07 +010080" python3 -c 'import keyword, pprint; pprint.pprint(keyword.kwlist, compact=True)'
Bram Moolenaar5c736222010-01-06 20:54:52 +010081"
Bram Moolenaar6f1d9a02016-07-24 14:12:38 +020082syn keyword pythonStatement False None True
Bram Moolenaar9faec4e2021-02-27 16:38:07 +010083syn keyword pythonStatement as assert break continue del global
84syn keyword pythonStatement lambda nonlocal pass return with yield
Bram Moolenaar5c736222010-01-06 20:54:52 +010085syn keyword pythonStatement class def nextgroup=pythonFunction skipwhite
86syn keyword pythonConditional elif else if
Bram Moolenaar071d4272004-06-13 20:20:40 +000087syn keyword pythonRepeat for while
Bram Moolenaar071d4272004-06-13 20:20:40 +000088syn keyword pythonOperator and in is not or
Bram Moolenaar5c736222010-01-06 20:54:52 +010089syn keyword pythonException except finally raise try
90syn keyword pythonInclude from import
Bram Moolenaarca635012015-09-25 20:34:21 +020091syn keyword pythonAsync async await
Bram Moolenaar071d4272004-06-13 20:20:40 +000092
Bram Moolenaar9faec4e2021-02-27 16:38:07 +010093" Decorators
Bram Moolenaar5c736222010-01-06 20:54:52 +010094" A dot must be allowed because of @MyClass.myfunc decorators.
Bram Moolenaarb4ada792016-10-30 21:55:26 +010095syn match pythonDecorator "@" display contained
96syn match pythonDecoratorName "@\s*\h\%(\w\|\.\)*" display contains=pythonDecorator
Bram Moolenaare4a3bcf2016-08-26 19:52:37 +020097
Bram Moolenaarb4ada792016-10-30 21:55:26 +010098" Python 3.5 introduced the use of the same symbol for matrix multiplication:
99" https://www.python.org/dev/peps/pep-0465/. We now have to exclude the
100" symbol from highlighting when used in that context.
101" Single line multiplication.
102syn match pythonMatrixMultiply
103 \ "\%(\w\|[])]\)\s*@"
104 \ contains=ALLBUT,pythonDecoratorName,pythonDecorator,pythonFunction,pythonDoctestValue
105 \ transparent
106" Multiplication continued on the next line after backslash.
107syn match pythonMatrixMultiply
108 \ "[^\\]\\\s*\n\%(\s*\.\.\.\s\)\=\s\+@"
109 \ contains=ALLBUT,pythonDecoratorName,pythonDecorator,pythonFunction,pythonDoctestValue
110 \ transparent
111" Multiplication in a parenthesized expression over multiple lines with @ at
112" the start of each continued line; very similar to decorators and complex.
113syn match pythonMatrixMultiply
114 \ "^\s*\%(\%(>>>\|\.\.\.\)\s\+\)\=\zs\%(\h\|\%(\h\|[[(]\).\{-}\%(\w\|[])]\)\)\s*\n\%(\s*\.\.\.\s\)\=\s\+@\%(.\{-}\n\%(\s*\.\.\.\s\)\=\s\+@\)*"
115 \ contains=ALLBUT,pythonDecoratorName,pythonDecorator,pythonFunction,pythonDoctestValue
116 \ transparent
117
118syn match pythonFunction "\h\w*" display contained
Bram Moolenaar9c102382006-05-03 21:26:49 +0000119
Bram Moolenaar5c736222010-01-06 20:54:52 +0100120syn match pythonComment "#.*$" contains=pythonTodo,@Spell
121syn keyword pythonTodo FIXME NOTE NOTES TODO XXX contained
122
123" Triple-quoted strings can contain doctests.
Bram Moolenaar541f92d2015-06-19 13:27:23 +0200124syn region pythonString matchgroup=pythonQuotes
Bram Moolenaar5c736222010-01-06 20:54:52 +0100125 \ start=+[uU]\=\z(['"]\)+ end="\z1" skip="\\\\\|\\\z1"
126 \ contains=pythonEscape,@Spell
Bram Moolenaar541f92d2015-06-19 13:27:23 +0200127syn region pythonString matchgroup=pythonTripleQuotes
Bram Moolenaar5c736222010-01-06 20:54:52 +0100128 \ start=+[uU]\=\z('''\|"""\)+ end="\z1" keepend
129 \ contains=pythonEscape,pythonSpaceError,pythonDoctest,@Spell
Bram Moolenaar541f92d2015-06-19 13:27:23 +0200130syn region pythonRawString matchgroup=pythonQuotes
Bram Moolenaar5c736222010-01-06 20:54:52 +0100131 \ start=+[uU]\=[rR]\z(['"]\)+ end="\z1" skip="\\\\\|\\\z1"
132 \ contains=@Spell
Bram Moolenaar541f92d2015-06-19 13:27:23 +0200133syn region pythonRawString matchgroup=pythonTripleQuotes
Bram Moolenaar5c736222010-01-06 20:54:52 +0100134 \ start=+[uU]\=[rR]\z('''\|"""\)+ end="\z1" keepend
135 \ contains=pythonSpaceError,pythonDoctest,@Spell
136
137syn match pythonEscape +\\[abfnrtv'"\\]+ contained
138syn match pythonEscape "\\\o\{1,3}" contained
139syn match pythonEscape "\\x\x\{2}" contained
140syn match pythonEscape "\%(\\u\x\{4}\|\\U\x\{8}\)" contained
141" Python allows case-insensitive Unicode IDs: http://www.unicode.org/charts/
Bram Moolenaar541f92d2015-06-19 13:27:23 +0200142syn match pythonEscape "\\N{\a\+\%(\s\a\+\)*}" contained
Bram Moolenaar5c736222010-01-06 20:54:52 +0100143syn match pythonEscape "\\$"
Bram Moolenaar071d4272004-06-13 20:20:40 +0000144
Bram Moolenaar5c736222010-01-06 20:54:52 +0100145" It is very important to understand all details before changing the
146" regular expressions below or their order.
147" The word boundaries are *not* the floating-point number boundaries
148" because of a possible leading or trailing decimal point.
149" The expressions below ensure that all valid number literals are
150" highlighted, and invalid number literals are not. For example,
151"
152" - a decimal point in '4.' at the end of a line is highlighted,
153" - a second dot in 1.0.0 is not highlighted,
154" - 08 is not highlighted,
155" - 08e0 or 08j are highlighted,
156"
157" and so on, as specified in the 'Python Language Reference'.
Bram Moolenaar9faec4e2021-02-27 16:38:07 +0100158" https://docs.python.org/reference/lexical_analysis.html#numeric-literals
Bram Moolenaar5c736222010-01-06 20:54:52 +0100159if !exists("python_no_number_highlight")
Bram Moolenaar071d4272004-06-13 20:20:40 +0000160 " numbers (including longs and complex)
Bram Moolenaar5c736222010-01-06 20:54:52 +0100161 syn match pythonNumber "\<0[oO]\=\o\+[Ll]\=\>"
162 syn match pythonNumber "\<0[xX]\x\+[Ll]\=\>"
163 syn match pythonNumber "\<0[bB][01]\+[Ll]\=\>"
164 syn match pythonNumber "\<\%([1-9]\d*\|0\)[Ll]\=\>"
165 syn match pythonNumber "\<\d\+[jJ]\>"
166 syn match pythonNumber "\<\d\+[eE][+-]\=\d\+[jJ]\=\>"
167 syn match pythonNumber
168 \ "\<\d\+\.\%([eE][+-]\=\d\+\)\=[jJ]\=\%(\W\|$\)\@="
169 syn match pythonNumber
Bram Moolenaarf9132812015-07-21 19:19:13 +0200170 \ "\%(^\|\W\)\zs\d*\.\d\+\%([eE][+-]\=\d\+\)\=[jJ]\=\>"
Bram Moolenaar071d4272004-06-13 20:20:40 +0000171endif
172
Bram Moolenaar5c736222010-01-06 20:54:52 +0100173" Group the built-ins in the order in the 'Python Library Reference' for
174" easier comparison.
Bram Moolenaar9faec4e2021-02-27 16:38:07 +0100175" https://docs.python.org/library/constants.html
176" http://docs.python.org/library/functions.html
Bram Moolenaar5c736222010-01-06 20:54:52 +0100177" Python built-in functions are in alphabetical order.
Bram Moolenaar9faec4e2021-02-27 16:38:07 +0100178"
179" The list can be checked using:
180"
181" python3 -c 'import builtins, pprint; pprint.pprint(dir(builtins), compact=True)'
182"
183" The constants added by the `site` module are not listed below because they
184" should not be used in programs, only in interactive interpreter.
185" Similarly for some other attributes and functions `__`-enclosed from the
186" output of the above command.
187"
Bram Moolenaar5c736222010-01-06 20:54:52 +0100188if !exists("python_no_builtin_highlight")
189 " built-in constants
Bram Moolenaarf9132812015-07-21 19:19:13 +0200190 " 'False', 'True', and 'None' are also reserved words in Python 3
Bram Moolenaar5c736222010-01-06 20:54:52 +0100191 syn keyword pythonBuiltin False True None
192 syn keyword pythonBuiltin NotImplemented Ellipsis __debug__
Bram Moolenaar9faec4e2021-02-27 16:38:07 +0100193 " constants added by the `site` module
194 syn keyword pythonBuiltin quit exit copyright credits license
Bram Moolenaar5c736222010-01-06 20:54:52 +0100195 " built-in functions
Bram Moolenaar9faec4e2021-02-27 16:38:07 +0100196 syn keyword pythonBuiltin abs all any ascii bin bool breakpoint bytearray
197 syn keyword pythonBuiltin bytes callable chr classmethod compile complex
198 syn keyword pythonBuiltin delattr dict dir divmod enumerate eval exec
199 syn keyword pythonBuiltin filter float format frozenset getattr globals
200 syn keyword pythonBuiltin hasattr hash help hex id input int isinstance
Bram Moolenaar5c736222010-01-06 20:54:52 +0100201 syn keyword pythonBuiltin issubclass iter len list locals map max
Bram Moolenaarf9132812015-07-21 19:19:13 +0200202 syn keyword pythonBuiltin memoryview min next object oct open ord pow
203 syn keyword pythonBuiltin print property range repr reversed round set
Bram Moolenaar9faec4e2021-02-27 16:38:07 +0100204 syn keyword pythonBuiltin setattr slice sorted staticmethod str sum super
205 syn keyword pythonBuiltin tuple type vars zip __import__
Bram Moolenaar77cdfd12016-03-12 12:57:59 +0100206 " avoid highlighting attributes as builtins
Bram Moolenaarb4ada792016-10-30 21:55:26 +0100207 syn match pythonAttribute /\.\h\w*/hs=s+1
208 \ contains=ALLBUT,pythonBuiltin,pythonFunction,pythonAsync
209 \ transparent
Bram Moolenaar071d4272004-06-13 20:20:40 +0000210endif
211
Bram Moolenaar5c736222010-01-06 20:54:52 +0100212" From the 'Python Library Reference' class hierarchy at the bottom.
Bram Moolenaar9faec4e2021-02-27 16:38:07 +0100213" http://docs.python.org/library/exceptions.html
Bram Moolenaar5c736222010-01-06 20:54:52 +0100214if !exists("python_no_exception_highlight")
Bram Moolenaarf9132812015-07-21 19:19:13 +0200215 " builtin base exceptions (used mostly as base classes for other exceptions)
Bram Moolenaar5c736222010-01-06 20:54:52 +0100216 syn keyword pythonExceptions BaseException Exception
Bram Moolenaar9faec4e2021-02-27 16:38:07 +0100217 syn keyword pythonExceptions ArithmeticError BufferError LookupError
Bram Moolenaar5c736222010-01-06 20:54:52 +0100218 " builtin exceptions (actually raised)
Bram Moolenaar9faec4e2021-02-27 16:38:07 +0100219 syn keyword pythonExceptions AssertionError AttributeError EOFError
220 syn keyword pythonExceptions FloatingPointError GeneratorExit ImportError
221 syn keyword pythonExceptions IndentationError IndexError KeyError
222 syn keyword pythonExceptions KeyboardInterrupt MemoryError
223 syn keyword pythonExceptions ModuleNotFoundError NameError
224 syn keyword pythonExceptions NotImplementedError OSError OverflowError
225 syn keyword pythonExceptions RecursionError ReferenceError RuntimeError
226 syn keyword pythonExceptions StopAsyncIteration StopIteration SyntaxError
Bram Moolenaar5c736222010-01-06 20:54:52 +0100227 syn keyword pythonExceptions SystemError SystemExit TabError TypeError
Bram Moolenaar9faec4e2021-02-27 16:38:07 +0100228 syn keyword pythonExceptions UnboundLocalError UnicodeDecodeError
229 syn keyword pythonExceptions UnicodeEncodeError UnicodeError
Bram Moolenaarf9132812015-07-21 19:19:13 +0200230 syn keyword pythonExceptions UnicodeTranslateError ValueError
231 syn keyword pythonExceptions ZeroDivisionError
Bram Moolenaar9faec4e2021-02-27 16:38:07 +0100232 " builtin exception aliases for OSError
233 syn keyword pythonExceptions EnvironmentError IOError WindowsError
Bram Moolenaarf9132812015-07-21 19:19:13 +0200234 " builtin OS exceptions in Python 3
235 syn keyword pythonExceptions BlockingIOError BrokenPipeError
236 syn keyword pythonExceptions ChildProcessError ConnectionAbortedError
237 syn keyword pythonExceptions ConnectionError ConnectionRefusedError
238 syn keyword pythonExceptions ConnectionResetError FileExistsError
239 syn keyword pythonExceptions FileNotFoundError InterruptedError
240 syn keyword pythonExceptions IsADirectoryError NotADirectoryError
Bram Moolenaar9faec4e2021-02-27 16:38:07 +0100241 syn keyword pythonExceptions PermissionError ProcessLookupError TimeoutError
Bram Moolenaar5c736222010-01-06 20:54:52 +0100242 " builtin warnings
243 syn keyword pythonExceptions BytesWarning DeprecationWarning FutureWarning
244 syn keyword pythonExceptions ImportWarning PendingDeprecationWarning
Bram Moolenaar9faec4e2021-02-27 16:38:07 +0100245 syn keyword pythonExceptions ResourceWarning RuntimeWarning
246 syn keyword pythonExceptions SyntaxWarning UnicodeWarning
Bram Moolenaar5c736222010-01-06 20:54:52 +0100247 syn keyword pythonExceptions UserWarning Warning
Bram Moolenaar071d4272004-06-13 20:20:40 +0000248endif
249
Bram Moolenaar5c736222010-01-06 20:54:52 +0100250if exists("python_space_error_highlight")
Bram Moolenaar071d4272004-06-13 20:20:40 +0000251 " trailing whitespace
Bram Moolenaar5c736222010-01-06 20:54:52 +0100252 syn match pythonSpaceError display excludenl "\s\+$"
Bram Moolenaar071d4272004-06-13 20:20:40 +0000253 " mixed tabs and spaces
Bram Moolenaar5c736222010-01-06 20:54:52 +0100254 syn match pythonSpaceError display " \+\t"
255 syn match pythonSpaceError display "\t\+ "
Bram Moolenaar071d4272004-06-13 20:20:40 +0000256endif
257
Bram Moolenaar5c736222010-01-06 20:54:52 +0100258" Do not spell doctests inside strings.
259" Notice that the end of a string, either ''', or """, will end the contained
260" doctest too. Thus, we do *not* need to have it as an end pattern.
261if !exists("python_no_doctest_highlight")
Bram Moolenaar34700a62013-03-07 13:20:54 +0100262 if !exists("python_no_doctest_code_highlight")
Bram Moolenaar5c736222010-01-06 20:54:52 +0100263 syn region pythonDoctest
264 \ start="^\s*>>>\s" end="^\s*$"
Bram Moolenaarb4ada792016-10-30 21:55:26 +0100265 \ contained contains=ALLBUT,pythonDoctest,pythonFunction,@Spell
Bram Moolenaar5c736222010-01-06 20:54:52 +0100266 syn region pythonDoctestValue
267 \ start=+^\s*\%(>>>\s\|\.\.\.\s\|"""\|'''\)\@!\S\++ end="$"
268 \ contained
269 else
270 syn region pythonDoctest
271 \ start="^\s*>>>" end="^\s*$"
272 \ contained contains=@NoSpell
273 endif
274endif
275
276" Sync at the beginning of class, function, or method definition.
Bram Moolenaarb4ada792016-10-30 21:55:26 +0100277syn sync match pythonSync grouphere NONE "^\%(def\|class\)\s\+\h\w*\s*[(:]"
Bram Moolenaar071d4272004-06-13 20:20:40 +0000278
Bram Moolenaar89bcfda2016-08-30 23:26:57 +0200279" The default highlight links. Can be overridden later.
Bram Moolenaard0796902016-09-16 20:02:31 +0200280hi def link pythonStatement Statement
281hi def link pythonConditional Conditional
Bram Moolenaarf37506f2016-08-31 22:22:10 +0200282hi def link pythonRepeat Repeat
283hi def link pythonOperator Operator
Bram Moolenaard0796902016-09-16 20:02:31 +0200284hi def link pythonException Exception
Bram Moolenaarf37506f2016-08-31 22:22:10 +0200285hi def link pythonInclude Include
Bram Moolenaard0796902016-09-16 20:02:31 +0200286hi def link pythonAsync Statement
287hi def link pythonDecorator Define
288hi def link pythonDecoratorName Function
Bram Moolenaarf37506f2016-08-31 22:22:10 +0200289hi def link pythonFunction Function
290hi def link pythonComment Comment
Bram Moolenaard0796902016-09-16 20:02:31 +0200291hi def link pythonTodo Todo
Bram Moolenaarf37506f2016-08-31 22:22:10 +0200292hi def link pythonString String
Bram Moolenaard0796902016-09-16 20:02:31 +0200293hi def link pythonRawString String
Bram Moolenaarf37506f2016-08-31 22:22:10 +0200294hi def link pythonQuotes String
Bram Moolenaard0796902016-09-16 20:02:31 +0200295hi def link pythonTripleQuotes pythonQuotes
Bram Moolenaarf37506f2016-08-31 22:22:10 +0200296hi def link pythonEscape Special
Bram Moolenaar89bcfda2016-08-30 23:26:57 +0200297if !exists("python_no_number_highlight")
Bram Moolenaarf37506f2016-08-31 22:22:10 +0200298 hi def link pythonNumber Number
Bram Moolenaar071d4272004-06-13 20:20:40 +0000299endif
Bram Moolenaar89bcfda2016-08-30 23:26:57 +0200300if !exists("python_no_builtin_highlight")
Bram Moolenaard0796902016-09-16 20:02:31 +0200301 hi def link pythonBuiltin Function
Bram Moolenaar89bcfda2016-08-30 23:26:57 +0200302endif
303if !exists("python_no_exception_highlight")
Bram Moolenaard0796902016-09-16 20:02:31 +0200304 hi def link pythonExceptions Structure
Bram Moolenaar89bcfda2016-08-30 23:26:57 +0200305endif
306if exists("python_space_error_highlight")
Bram Moolenaard0796902016-09-16 20:02:31 +0200307 hi def link pythonSpaceError Error
Bram Moolenaar89bcfda2016-08-30 23:26:57 +0200308endif
309if !exists("python_no_doctest_highlight")
Bram Moolenaard0796902016-09-16 20:02:31 +0200310 hi def link pythonDoctest Special
Bram Moolenaarf37506f2016-08-31 22:22:10 +0200311 hi def link pythonDoctestValue Define
Bram Moolenaar89bcfda2016-08-30 23:26:57 +0200312endif
313
Bram Moolenaar071d4272004-06-13 20:20:40 +0000314let b:current_syntax = "python"
315
Bram Moolenaar00659062010-09-21 22:34:02 +0200316let &cpo = s:cpo_save
317unlet s:cpo_save
318
Bram Moolenaar5c736222010-01-06 20:54:52 +0100319" vim:set sw=2 sts=2 ts=8 noet: