shiki
Version:
1,739 lines (1,738 loc) • 118 kB
JSON
{
"information_for_contributors": [
"This file has been converted from https://github.com/MagicStack/MagicPython/blob/master/grammars/MagicPython.tmLanguage",
"If you want to provide a fix or improvement, please create a pull request against the original repository.",
"Once accepted there, we are happy to receive an update request."
],
"version": "https://github.com/MagicStack/MagicPython/commit/7d0f2b22a5ad8fccbd7341bc7b7a715169283044",
"name": "python",
"scopeName": "source.python",
"patterns": [
{
"include": "#statement"
},
{
"include": "#expression"
}
],
"repository": {
"impossible": {
"comment": "This is a special rule that should be used where no match is desired. It is not a good idea to match something like '1{0}' because in some cases that can result in infinite loops in token generation. So the rule instead matches and impossible expression to allow a match to fail and move to the next token.",
"match": "$.^"
},
"statement": {
"patterns": [
{
"include": "#import"
},
{
"include": "#class-declaration"
},
{
"include": "#function-declaration"
},
{
"include": "#generator"
},
{
"include": "#statement-keyword"
},
{
"include": "#assignment-operator"
},
{
"include": "#decorator"
},
{
"include": "#docstring-statement"
},
{
"include": "#semicolon"
}
]
},
"semicolon": {
"patterns": [
{
"name": "invalid.deprecated.semicolon.python",
"match": "\\;$"
}
]
},
"comments": {
"patterns": [
{
"name": "comment.line.number-sign.python",
"contentName": "meta.typehint.comment.python",
"begin": "(?x)\n (?:\n \\# \\s* (type:)\n \\s*+ (?# we want `\\s*+` which is possessive quantifier since\n we do not actually want to backtrack when matching\n whitespace here)\n (?! $ | \\#)\n )\n",
"end": "(?:$|(?=\\#))",
"beginCaptures": {
"0": {
"name": "meta.typehint.comment.python"
},
"1": {
"name": "comment.typehint.directive.notation.python"
}
},
"patterns": [
{
"name": "comment.typehint.ignore.notation.python",
"match": "(?x)\n \\G ignore\n (?= \\s* (?: $ | \\#))\n"
},
{
"name": "comment.typehint.type.notation.python",
"match": "(?x)\n (?<!\\.)\\b(\n bool | bytes | float | int | object | str\n | List | Dict | Iterable | Sequence | Set\n | FrozenSet | Callable | Union | Tuple\n | Any | None\n )\\b\n"
},
{
"name": "comment.typehint.punctuation.notation.python",
"match": "([\\[\\]\\(\\),\\.\\=\\*]|(->))"
},
{
"name": "comment.typehint.variable.notation.python",
"match": "([[:alpha:]_]\\w*)"
}
]
},
{
"include": "#comments-base"
}
]
},
"docstring-statement": {
"begin": "^(?=\\s*[rR]?(\\'\\'\\'|\\\"\\\"\\\"|\\'|\\\"))",
"comment": "the string either terminates correctly or by the beginning of a new line (this is for single line docstrings that aren't terminated) AND it's not followed by another docstring",
"end": "((?<=\\1)|^)(?!\\s*[rR]?(\\'\\'\\'|\\\"\\\"\\\"|\\'|\\\"))",
"patterns": [
{
"include": "#docstring"
}
]
},
"docstring": {
"patterns": [
{
"name": "string.quoted.docstring.multi.python",
"begin": "(\\'\\'\\'|\\\"\\\"\\\")",
"end": "(\\1)",
"beginCaptures": {
"1": {
"name": "punctuation.definition.string.begin.python"
}
},
"endCaptures": {
"1": {
"name": "punctuation.definition.string.end.python"
}
},
"patterns": [
{
"include": "#docstring-prompt"
},
{
"include": "#codetags"
},
{
"include": "#docstring-guts-unicode"
}
]
},
{
"name": "string.quoted.docstring.raw.multi.python",
"begin": "([rR])(\\'\\'\\'|\\\"\\\"\\\")",
"end": "(\\2)",
"beginCaptures": {
"1": {
"name": "storage.type.string.python"
},
"2": {
"name": "punctuation.definition.string.begin.python"
}
},
"endCaptures": {
"1": {
"name": "punctuation.definition.string.end.python"
}
},
"patterns": [
{
"include": "#string-consume-escape"
},
{
"include": "#docstring-prompt"
},
{
"include": "#codetags"
}
]
},
{
"name": "string.quoted.docstring.single.python",
"begin": "(\\'|\\\")",
"end": "(\\1)|(\\n)",
"beginCaptures": {
"1": {
"name": "punctuation.definition.string.begin.python"
}
},
"endCaptures": {
"1": {
"name": "punctuation.definition.string.end.python"
},
"2": {
"name": "invalid.illegal.newline.python"
}
},
"patterns": [
{
"include": "#codetags"
},
{
"include": "#docstring-guts-unicode"
}
]
},
{
"name": "string.quoted.docstring.raw.single.python",
"begin": "([rR])(\\'|\\\")",
"end": "(\\2)|(\\n)",
"beginCaptures": {
"1": {
"name": "storage.type.string.python"
},
"2": {
"name": "punctuation.definition.string.begin.python"
}
},
"endCaptures": {
"1": {
"name": "punctuation.definition.string.end.python"
},
"2": {
"name": "invalid.illegal.newline.python"
}
},
"patterns": [
{
"include": "#string-consume-escape"
},
{
"include": "#codetags"
}
]
}
]
},
"docstring-guts-unicode": {
"patterns": [
{
"include": "#escape-sequence-unicode"
},
{
"include": "#escape-sequence"
},
{
"include": "#string-line-continuation"
}
]
},
"docstring-prompt": {
"match": "(?x)\n (?:\n (?:^|\\G) \\s* (?# '\\G' is necessary for ST)\n ((?:>>>|\\.\\.\\.) \\s) (?=\\s*\\S)\n )\n",
"captures": {
"1": {
"name": "keyword.control.flow.python"
}
}
},
"statement-keyword": {
"patterns": [
{
"name": "storage.type.function.python",
"match": "\\b((async\\s+)?\\s*def)\\b"
},
{
"name": "keyword.control.flow.python",
"comment": "if `as` is eventually followed by `:` or line continuation\nit's probably control flow like:\n with foo as bar, \\\n Foo as Bar:\n try:\n do_stuff()\n except Exception as e:\n pass\n",
"match": "\\b(?<!\\.)as\\b(?=.*[:\\\\])"
},
{
"name": "keyword.control.import.python",
"comment": "other legal use of `as` is in an import",
"match": "\\b(?<!\\.)as\\b"
},
{
"name": "keyword.control.flow.python",
"match": "(?x)\n \\b(?<!\\.)(\n async | continue | del | assert | break | finally | for\n | from | elif | else | if | except | pass | raise\n | return | try | while | with\n )\\b\n"
},
{
"name": "storage.modifier.declaration.python",
"match": "(?x)\n \\b(?<!\\.)(\n global | nonlocal\n )\\b\n"
},
{
"name": "storage.type.class.python",
"match": "\\b(?<!\\.)(class)\\b"
},
{
"match": "(?x)\n ^\\s*(\n case | match\n )(?=\\s*([-+\\w\\d(\\[{'\":#]|$))\\b\n",
"captures": {
"1": {
"name": "keyword.control.flow.python"
}
}
}
]
},
"expression-bare": {
"comment": "valid Python expressions w/o comments and line continuation",
"patterns": [
{
"include": "#backticks"
},
{
"include": "#illegal-anno"
},
{
"include": "#literal"
},
{
"include": "#regexp"
},
{
"include": "#string"
},
{
"include": "#lambda"
},
{
"include": "#generator"
},
{
"include": "#illegal-operator"
},
{
"include": "#operator"
},
{
"include": "#curly-braces"
},
{
"include": "#item-access"
},
{
"include": "#list"
},
{
"include": "#odd-function-call"
},
{
"include": "#round-braces"
},
{
"include": "#function-call"
},
{
"include": "#builtin-functions"
},
{
"include": "#builtin-types"
},
{
"include": "#builtin-exceptions"
},
{
"include": "#magic-names"
},
{
"include": "#special-names"
},
{
"include": "#illegal-names"
},
{
"include": "#special-variables"
},
{
"include": "#ellipsis"
},
{
"include": "#punctuation"
},
{
"include": "#line-continuation"
}
]
},
"expression-base": {
"comment": "valid Python expressions with comments and line continuation",
"patterns": [
{
"include": "#comments"
},
{
"include": "#expression-bare"
},
{
"include": "#line-continuation"
}
]
},
"expression": {
"comment": "All valid Python expressions",
"patterns": [
{
"include": "#expression-base"
},
{
"include": "#member-access"
},
{
"comment": "Tokenize identifiers to help linters",
"match": "(?x) \\b ([[:alpha:]_]\\w*) \\b"
}
]
},
"member-access": {
"name": "meta.member.access.python",
"begin": "(\\.)\\s*(?!\\.)",
"end": "(?x)\n # stop when you've just read non-whitespace followed by non-word\n # i.e. when finished reading an identifier or function call\n (?<=\\S)(?=\\W) |\n # stop when seeing the start of something that's not a word,\n # i.e. when seeing a non-identifier\n (^|(?<=\\s))(?=[^\\\\\\w\\s]) |\n $\n",
"beginCaptures": {
"1": {
"name": "punctuation.separator.period.python"
}
},
"patterns": [
{
"include": "#function-call"
},
{
"include": "#member-access-base"
},
{
"include": "#member-access-attribute"
}
]
},
"member-access-base": {
"patterns": [
{
"include": "#magic-names"
},
{
"include": "#illegal-names"
},
{
"include": "#illegal-object-name"
},
{
"include": "#special-names"
},
{
"include": "#line-continuation"
},
{
"include": "#item-access"
}
]
},
"member-access-attribute": {
"comment": "Highlight attribute access in otherwise non-specialized cases.",
"name": "meta.attribute.python",
"match": "(?x)\n \\b ([[:alpha:]_]\\w*) \\b\n"
},
"special-names": {
"name": "constant.other.caps.python",
"match": "(?x)\n \\b\n # we want to see \"enough\", meaning 2 or more upper-case\n # letters in the beginning of the constant\n #\n # for more details refer to:\n # https://github.com/MagicStack/MagicPython/issues/42\n (\n _* [[:upper:]] [_\\d]* [[:upper:]]\n )\n [[:upper:]\\d]* (_\\w*)?\n \\b\n"
},
"curly-braces": {
"begin": "\\{",
"end": "\\}",
"beginCaptures": {
"0": {
"name": "punctuation.definition.dict.begin.python"
}
},
"endCaptures": {
"0": {
"name": "punctuation.definition.dict.end.python"
}
},
"patterns": [
{
"name": "punctuation.separator.dict.python",
"match": ":"
},
{
"include": "#expression"
}
]
},
"list": {
"begin": "\\[",
"end": "\\]",
"beginCaptures": {
"0": {
"name": "punctuation.definition.list.begin.python"
}
},
"endCaptures": {
"0": {
"name": "punctuation.definition.list.end.python"
}
},
"patterns": [
{
"include": "#expression"
}
]
},
"odd-function-call": {
"comment": "A bit obscured function call where there may have been an\narbitrary number of other operations to get the function.\nE.g. \"arr[idx](args)\"\n",
"begin": "(?x)\n (?<= \\] | \\) ) \\s*\n (?=\\()\n",
"end": "(\\))",
"endCaptures": {
"1": {
"name": "punctuation.definition.arguments.end.python"
}
},
"patterns": [
{
"include": "#function-arguments"
}
]
},
"round-braces": {
"begin": "\\(",
"end": "\\)",
"beginCaptures": {
"0": {
"name": "punctuation.parenthesis.begin.python"
}
},
"endCaptures": {
"0": {
"name": "punctuation.parenthesis.end.python"
}
},
"patterns": [
{
"include": "#expression"
}
]
},
"line-continuation": {
"patterns": [
{
"match": "(\\\\)\\s*(\\S.*$\\n?)",
"captures": {
"1": {
"name": "punctuation.separator.continuation.line.python"
},
"2": {
"name": "invalid.illegal.line.continuation.python"
}
}
},
{
"begin": "(\\\\)\\s*$\\n?",
"end": "(?x)\n (?=^\\s*$)\n |\n (?! (\\s* [rR]? (\\'\\'\\'|\\\"\\\"\\\"|\\'|\\\"))\n |\n (\\G $) (?# '\\G' is necessary for ST)\n )\n",
"beginCaptures": {
"1": {
"name": "punctuation.separator.continuation.line.python"
}
},
"patterns": [
{
"include": "#regexp"
},
{
"include": "#string"
}
]
}
]
},
"assignment-operator": {
"name": "keyword.operator.assignment.python",
"match": "(?x)\n <<= | >>= | //= | \\*\\*=\n | \\+= | -= | /= | @=\n | \\*= | %= | ~= | \\^= | &= | \\|=\n | =(?!=)\n"
},
"operator": {
"match": "(?x)\n \\b(?<!\\.)\n (?:\n (and | or | not | in | is) (?# 1)\n |\n (for | if | else | await | (?:yield(?:\\s+from)?)) (?# 2)\n )\n (?!\\s*:)\\b\n\n | (<< | >> | & | \\| | \\^ | ~) (?# 3)\n\n | (\\*\\* | \\* | \\+ | - | % | // | / | @) (?# 4)\n\n | (!= | == | >= | <= | < | >) (?# 5)\n\n | (:=) (?# 6)\n",
"captures": {
"1": {
"name": "keyword.operator.logical.python"
},
"2": {
"name": "keyword.control.flow.python"
},
"3": {
"name": "keyword.operator.bitwise.python"
},
"4": {
"name": "keyword.operator.arithmetic.python"
},
"5": {
"name": "keyword.operator.comparison.python"
},
"6": {
"name": "keyword.operator.assignment.python"
}
}
},
"punctuation": {
"patterns": [
{
"name": "punctuation.separator.colon.python",
"match": ":"
},
{
"name": "punctuation.separator.element.python",
"match": ","
}
]
},
"literal": {
"patterns": [
{
"name": "constant.language.python",
"match": "\\b(True|False|None|NotImplemented|Ellipsis)\\b"
},
{
"include": "#number"
}
]
},
"number": {
"name": "constant.numeric.python",
"patterns": [
{
"include": "#number-float"
},
{
"include": "#number-dec"
},
{
"include": "#number-hex"
},
{
"include": "#number-oct"
},
{
"include": "#number-bin"
},
{
"include": "#number-long"
},
{
"name": "invalid.illegal.name.python",
"match": "\\b[0-9]+\\w+"
}
]
},
"number-float": {
"name": "constant.numeric.float.python",
"match": "(?x)\n (?<! \\w)(?:\n (?:\n \\.[0-9](?: _?[0-9] )*\n |\n [0-9](?: _?[0-9] )* \\. [0-9](?: _?[0-9] )*\n |\n [0-9](?: _?[0-9] )* \\.\n ) (?: [eE][+-]?[0-9](?: _?[0-9] )* )?\n |\n [0-9](?: _?[0-9] )* (?: [eE][+-]?[0-9](?: _?[0-9] )* )\n )([jJ])?\\b\n",
"captures": {
"1": {
"name": "storage.type.imaginary.number.python"
}
}
},
"number-dec": {
"name": "constant.numeric.dec.python",
"match": "(?x)\n (?<![\\w\\.])(?:\n [1-9](?: _?[0-9] )*\n |\n 0+\n |\n [0-9](?: _?[0-9] )* ([jJ])\n |\n 0 ([0-9]+)(?![eE\\.])\n )\\b\n",
"captures": {
"1": {
"name": "storage.type.imaginary.number.python"
},
"2": {
"name": "invalid.illegal.dec.python"
}
}
},
"number-hex": {
"name": "constant.numeric.hex.python",
"match": "(?x)\n (?<![\\w\\.])\n (0[xX]) (_?[0-9a-fA-F])+\n \\b\n",
"captures": {
"1": {
"name": "storage.type.number.python"
}
}
},
"number-oct": {
"name": "constant.numeric.oct.python",
"match": "(?x)\n (?<![\\w\\.])\n (0[oO]) (_?[0-7])+\n \\b\n",
"captures": {
"1": {
"name": "storage.type.number.python"
}
}
},
"number-bin": {
"name": "constant.numeric.bin.python",
"match": "(?x)\n (?<![\\w\\.])\n (0[bB]) (_?[01])+\n \\b\n",
"captures": {
"1": {
"name": "storage.type.number.python"
}
}
},
"number-long": {
"name": "constant.numeric.bin.python",
"comment": "this is to support python2 syntax for long ints",
"match": "(?x)\n (?<![\\w\\.])\n ([1-9][0-9]* | 0) ([lL])\n \\b\n",
"captures": {
"2": {
"name": "storage.type.number.python"
}
}
},
"regexp": {
"patterns": [
{
"include": "#regexp-single-three-line"
},
{
"include": "#regexp-double-three-line"
},
{
"include": "#regexp-single-one-line"
},
{
"include": "#regexp-double-one-line"
}
]
},
"string": {
"patterns": [
{
"include": "#string-quoted-multi-line"
},
{
"include": "#string-quoted-single-line"
},
{
"include": "#string-bin-quoted-multi-line"
},
{
"include": "#string-bin-quoted-single-line"
},
{
"include": "#string-raw-quoted-multi-line"
},
{
"include": "#string-raw-quoted-single-line"
},
{
"include": "#string-raw-bin-quoted-multi-line"
},
{
"include": "#string-raw-bin-quoted-single-line"
},
{
"include": "#fstring-fnorm-quoted-multi-line"
},
{
"include": "#fstring-fnorm-quoted-single-line"
},
{
"include": "#fstring-normf-quoted-multi-line"
},
{
"include": "#fstring-normf-quoted-single-line"
},
{
"include": "#fstring-raw-quoted-multi-line"
},
{
"include": "#fstring-raw-quoted-single-line"
}
]
},
"string-unicode-guts": {
"patterns": [
{
"include": "#escape-sequence-unicode"
},
{
"include": "#string-entity"
},
{
"include": "#string-brace-formatting"
}
]
},
"string-consume-escape": {
"match": "\\\\['\"\\n\\\\]"
},
"string-raw-guts": {
"patterns": [
{
"include": "#string-consume-escape"
},
{
"include": "#string-formatting"
},
{
"include": "#string-brace-formatting"
}
]
},
"string-raw-bin-guts": {
"patterns": [
{
"include": "#string-consume-escape"
},
{
"include": "#string-formatting"
}
]
},
"string-entity": {
"patterns": [
{
"include": "#escape-sequence"
},
{
"include": "#string-line-continuation"
},
{
"include": "#string-formatting"
}
]
},
"fstring-guts": {
"patterns": [
{
"include": "#escape-sequence-unicode"
},
{
"include": "#escape-sequence"
},
{
"include": "#string-line-continuation"
},
{
"include": "#fstring-formatting"
}
]
},
"fstring-raw-guts": {
"patterns": [
{
"include": "#string-consume-escape"
},
{
"include": "#fstring-formatting"
}
]
},
"fstring-illegal-single-brace": {
"comment": "it is illegal to have a multiline brace inside a single-line string",
"begin": "(\\{)(?=[^\\n}]*$\\n?)",
"end": "(\\})|(?=\\n)",
"beginCaptures": {
"1": {
"name": "constant.character.format.placeholder.other.python"
}
},
"endCaptures": {
"1": {
"name": "constant.character.format.placeholder.other.python"
}
},
"patterns": [
{
"include": "#fstring-terminator-single"
},
{
"include": "#f-expression"
}
]
},
"fstring-illegal-multi-brace": {
"patterns": [
{
"include": "#impossible"
}
]
},
"f-expression": {
"comment": "All valid Python expressions, except comments and line continuation",
"patterns": [
{
"include": "#expression-bare"
},
{
"include": "#member-access"
},
{
"comment": "Tokenize identifiers to help linters",
"match": "(?x) \\b ([[:alpha:]_]\\w*) \\b"
}
]
},
"escape-sequence-unicode": {
"patterns": [
{
"name": "constant.character.escape.python",
"match": "(?x)\n \\\\ (\n u[0-9A-Fa-f]{4}\n | U[0-9A-Fa-f]{8}\n | N\\{[\\w\\s]+?\\}\n )\n"
}
]
},
"escape-sequence": {
"name": "constant.character.escape.python",
"match": "(?x)\n \\\\ (\n x[0-9A-Fa-f]{2}\n | [0-7]{1,3}\n | [\\\\\"'abfnrtv]\n )\n"
},
"string-line-continuation": {
"name": "constant.language.python",
"match": "\\\\$"
},
"string-formatting": {
"name": "meta.format.percent.python",
"match": "(?x)\n (\n % (\\([\\w\\s]*\\))?\n [-+#0 ]*\n (\\d+|\\*)? (\\.(\\d+|\\*))?\n ([hlL])?\n [diouxXeEfFgGcrsab%]\n )\n",
"captures": {
"1": {
"name": "constant.character.format.placeholder.other.python"
}
}
},
"string-brace-formatting": {
"patterns": [
{
"name": "meta.format.brace.python",
"match": "(?x)\n (\n {{ | }}\n | (?:\n {\n \\w* (\\.[[:alpha:]_]\\w* | \\[[^\\]'\"]+\\])*\n (![rsa])?\n ( : \\w? [<>=^]? [-+ ]? \\#?\n \\d* ,? (\\.\\d+)? [bcdeEfFgGnosxX%]? )?\n })\n )\n",
"captures": {
"1": {
"name": "constant.character.format.placeholder.other.python"
},
"3": {
"name": "storage.type.format.python"
},
"4": {
"name": "storage.type.format.python"
}
}
},
{
"name": "meta.format.brace.python",
"match": "(?x)\n (\n {\n \\w* (\\.[[:alpha:]_]\\w* | \\[[^\\]'\"]+\\])*\n (![rsa])?\n (:)\n [^'\"{}\\n]* (?:\n \\{ [^'\"}\\n]*? \\} [^'\"{}\\n]*\n )*\n }\n )\n",
"captures": {
"1": {
"name": "constant.character.format.placeholder.other.python"
},
"3": {
"name": "storage.type.format.python"
},
"4": {
"name": "storage.type.format.python"
}
}
}
]
},
"fstring-formatting": {
"patterns": [
{
"include": "#fstring-formatting-braces"
},
{
"include": "#fstring-formatting-singe-brace"
}
]
},
"fstring-formatting-singe-brace": {
"name": "invalid.illegal.brace.python",
"match": "(}(?!}))"
},
"import": {
"comment": "Import statements used to correctly mark `from`, `import`, and `as`\n",
"patterns": [
{
"begin": "\\b(?<!\\.)(from)\\b(?=.+import)",
"end": "$|(?=import)",
"beginCaptures": {
"1": {
"name": "keyword.control.import.python"
}
},
"patterns": [
{
"name": "punctuation.separator.period.python",
"match": "\\.+"
},
{
"include": "#expression"
}
]
},
{
"begin": "\\b(?<!\\.)(import)\\b",
"end": "$",
"beginCaptures": {
"1": {
"name": "keyword.control.import.python"
}
},
"patterns": [
{
"name": "keyword.control.import.python",
"match": "\\b(?<!\\.)as\\b"
},
{
"include": "#expression"
}
]
}
]
},
"class-declaration": {
"patterns": [
{
"name": "meta.class.python",
"begin": "(?x)\n \\s*(class)\\s+\n (?=\n [[:alpha:]_]\\w* \\s* (:|\\()\n )\n",
"end": "(:)",
"beginCaptures": {
"1": {
"name": "storage.type.class.python"
}
},
"endCaptures": {
"1": {
"name": "punctuation.section.class.begin.python"
}
},
"patterns": [
{
"include": "#class-name"
},
{
"include": "#class-inheritance"
}
]
}
]
},
"class-name": {
"patterns": [
{
"include": "#illegal-object-name"
},
{
"include": "#builtin-possible-callables"
},
{
"name": "entity.name.type.class.python",
"match": "(?x)\n \\b ([[:alpha:]_]\\w*) \\b\n"
}
]
},
"class-inheritance": {
"name": "meta.class.inheritance.python",
"begin": "(\\()",
"end": "(\\))",
"beginCaptures": {
"1": {
"name": "punctuation.definition.inheritance.begin.python"
}
},
"endCaptures": {
"1": {
"name": "punctuation.definition.inheritance.end.python"
}
},
"patterns": [
{
"name": "keyword.operator.unpacking.arguments.python",
"match": "(\\*\\*|\\*)"
},
{
"name": "punctuation.separator.inheritance.python",
"match": ","
},
{
"name": "keyword.operator.assignment.python",
"match": "=(?!=)"
},
{
"name": "support.type.metaclass.python",
"match": "\\bmetaclass\\b"
},
{
"include": "#illegal-names"
},
{
"include": "#class-kwarg"
},
{
"include": "#call-wrapper-inheritance"
},
{
"include": "#expression-base"
},
{
"include": "#member-access-class"
},
{
"include": "#inheritance-identifier"
}
]
},
"class-kwarg": {
"match": "(?x)\n \\b ([[:alpha:]_]\\w*) \\s*(=)(?!=)\n",
"captures": {
"1": {
"name": "entity.other.inherited-class.python variable.parameter.class.python"
},
"2": {
"name": "keyword.operator.assignment.python"
}
}
},
"inheritance-identifier": {
"match": "(?x)\n \\b ([[:alpha:]_]\\w*) \\b\n",
"captures": {
"1": {
"name": "entity.other.inherited-class.python"
}
}
},
"member-access-class": {
"name": "meta.member.access.python",
"begin": "(\\.)\\s*(?!\\.)",
"end": "(?<=\\S)(?=\\W)|$",
"beginCaptures": {
"1": {
"name": "punctuation.separator.period.python"
}
},
"patterns": [
{
"include": "#call-wrapper-inheritance"
},
{
"include": "#member-access-base"
},
{
"include": "#inheritance-identifier"
}
]
},
"lambda": {
"patterns": [
{
"match": "((?<=\\.)lambda|lambda(?=\\s*[\\.=]))",
"captures": {
"1": {
"name": "keyword.control.flow.python"
}
}
},
{
"match": "\\b(lambda)\\s*?(?=[,\\n]|$)",
"captures": {
"1": {
"name": "storage.type.function.lambda.python"
}
}
},
{
"name": "meta.lambda-function.python",
"begin": "(?x)\n \\b (lambda) \\b\n",
"end": "(:)|(\\n)",
"beginCaptures": {
"1": {
"name": "storage.type.function.lambda.python"
}
},
"endCaptures": {
"1": {
"name": "punctuation.section.function.lambda.begin.python"
}
},
"contentName": "meta.function.lambda.parameters.python",
"patterns": [
{
"name": "keyword.operator.positional.parameter.python",
"match": "/"
},
{
"name": "keyword.operator.unpacking.parameter.python",
"match": "(\\*\\*|\\*)"
},
{
"include": "#lambda-nested-incomplete"
},
{
"include": "#illegal-names"
},
{
"match": "([[:alpha:]_]\\w*)\\s*(?:(,)|(?=:|$))",
"captures": {
"1": {
"name": "variable.parameter.function.language.python"
},
"2": {
"name": "punctuation.separator.parameters.python"
}
}
},
{
"include": "#comments"
},
{
"include": "#backticks"
},
{
"include": "#illegal-anno"
},
{
"include": "#lambda-parameter-with-default"
},
{
"include": "#line-continuation"
},
{
"include": "#illegal-operator"
}
]
}
]
},
"lambda-incomplete": {
"name": "storage.type.function.lambda.python",
"match": "\\blambda(?=\\s*[,)])"
},
"lambda-nested-incomplete": {
"name": "storage.type.function.lambda.python",
"match": "\\blambda(?=\\s*[:,)])"
},
"lambda-parameter-with-default": {
"begin": "(?x)\n \\b\n ([[:alpha:]_]\\w*) \\s* (=)\n",
"end": "(,)|(?=:|$)",
"beginCaptures": {
"1": {
"name": "variable.parameter.function.language.python"
},
"2": {
"name": "keyword.operator.python"
}
},
"endCaptures": {
"1": {
"name": "punctuation.separator.parameters.python"
}
},
"patterns": [
{
"include": "#expression"
}
]
},
"generator": {
"comment": "Match \"for ... in\" construct used in generators and for loops to\ncorrectly identify the \"in\" as a control flow keyword.\n",
"begin": "\\bfor\\b",
"beginCaptures": {
"0": {
"name": "keyword.control.flow.python"
}
},
"end": "\\bin\\b",
"endCaptures": {
"0": {
"name": "keyword.control.flow.python"
}
},
"patterns": [
{
"include": "#expression"
}
]
},
"function-declaration": {
"name": "meta.function.python",
"begin": "(?x)\n \\s*\n (?:\\b(async) \\s+)? \\b(def)\\s+\n (?=\n [[:alpha:]_][[:word:]]* \\s* \\(\n )\n",
"end": "(:|(?=[#'\"\\n]))",
"beginCaptures": {
"1": {
"name": "storage.type.function.async.python"
},
"2": {
"name": "storage.type.function.python"
}
},
"endCaptures": {
"1": {
"name": "punctuation.section.function.begin.python"
}
},
"patterns": [
{
"include": "#function-def-name"
},
{
"include": "#parameters"
},
{
"include": "#line-continuation"
},
{
"include": "#return-annotation"
}
]
},
"function-def-name": {
"patterns": [
{
"include": "#illegal-object-name"
},
{
"include": "#builtin-possible-callables"
},
{
"name": "entity.name.function.python",
"match": "(?x)\n \\b ([[:alpha:]_]\\w*) \\b\n"
}
]
},
"parameters": {
"name": "meta.function.parameters.python",
"begin": "(\\()",
"end": "(\\))",
"beginCaptures": {
"1": {
"name": "punctuation.definition.parameters.begin.python"
}
},
"endCaptures": {
"1": {
"name": "punctuation.definition.parameters.end.python"
}
},
"patterns": [
{
"name": "keyword.operator.positional.parameter.python",
"match": "/"
},
{
"name": "keyword.operator.unpacking.parameter.python",
"match": "(\\*\\*|\\*)"
},
{
"include": "#lambda-incomplete"
},
{
"include": "#illegal-names"
},
{
"include": "#illegal-object-name"
},
{
"include": "#parameter-special"
},
{
"match": "(?x)\n ([[:alpha:]_]\\w*)\n \\s* (?: (,) | (?=[)#\\n=]))\n",
"captures": {
"1": {
"name": "variable.parameter.function.language.python"
},
"2": {
"name": "punctuation.separator.parameters.python"
}
}
},
{
"include": "#comments"
},
{
"include": "#loose-default"
},
{
"include": "#annotated-parameter"
}
]
},
"parameter-special": {
"match": "(?x)\n \\b ((self)|(cls)) \\b \\s*(?:(,)|(?=\\)))\n",
"captures": {
"1": {
"name": "variable.parameter.function.language.python"
},
"2": {
"name": "variable.parameter.function.language.special.self.python"
},
"3": {
"name": "variable.parameter.function.language.special.cls.python"
},
"4": {
"name": "punctuation.separator.parameters.python"
}
}
},
"loose-default": {
"begin": "(=)",
"end": "(,)|(?=\\))",
"beginCaptures": {
"1": {
"name": "keyword.operator.python"
}
},
"endCaptures": {
"1": {
"name": "punctuation.separator.parameters.python"
}
},
"patterns": [
{
"include": "#expression"
}
]
},
"annotated-parameter": {
"begin": "(?x)\n \\b\n ([[:alpha:]_]\\w*) \\s* (:)\n",
"end": "(,)|(?=\\))",
"beginCaptures": {
"1": {
"name": "variable.parameter.function.language.python"
},
"2": {
"name": "punctuation.separator.annotation.python"
}
},
"endCaptures": {
"1": {
"name": "punctuation.separator.parameters.python"
}
},
"patterns": [
{
"include": "#expression"
},
{
"name": "keyword.operator.assignment.python",
"match": "=(?!=)"
}
]
},
"return-annotation": {
"begin": "(->)",
"end": "(?=:)",
"beginCaptures": {
"1": {
"name": "punctuation.separator.annotation.result.python"
}
},
"patterns": [
{
"include": "#expression"
}
]
},
"item-access": {
"patterns": [
{
"name": "meta.item-access.python",
"begin": "(?x)\n \\b(?=\n [[:alpha:]_]\\w* \\s* \\[\n )\n",
"end": "(\\])",
"endCaptures": {
"1": {
"name": "punctuation.definition.arguments.end.python"
}
},
"patterns": [
{
"include": "#item-name"
},
{
"include": "#item-index"
},
{
"include": "#expression"
}
]
}
]
},
"item-name": {
"patterns": [
{
"include": "#special-variables"
},
{
"include": "#builtin-functions"
},
{
"include": "#special-names"
},
{
"name": "meta.indexed-name.python",
"match": "(?x)\n \\b ([[:alpha:]_]\\w*) \\b\n"
}
]
},
"item-index": {
"begin": "(\\[)",
"end": "(?=\\])",
"beginCaptures": {
"1": {
"name": "punctuation.definition.arguments.begin.python"
}
},
"contentName": "meta.item-access.arguments.python",
"patterns": [
{
"name": "punctuation.separator.slice.python",
"match": ":"
},
{
"include": "#expression"
}
]
},
"decorator": {
"name": "meta.function.decorator.python",
"begin": "(?x)\n ^\\s*\n ((@)) \\s* (?=[[:alpha:]_]\\w*)\n",
"end": "(?x)\n ( \\) )\n # trailing whitespace and comments are legal\n (?: (.*?) (?=\\s*(?:\\#|$)) )\n | (?=\\n|\\#)\n",
"beginCaptures": {
"1": {
"name": "entity.name.function.decorator.python"
},
"2": {
"name": "punctuation.definition.decorator.python"
}
},
"endCaptures": {
"1": {
"name": "punctuation.definition.arguments.end.python"
},
"2": {
"name": "invalid.illegal.decorator.python"
}
},
"patterns": [
{
"include": "#decorator-name"
},
{
"include": "#function-arguments"
}
]
},
"decorator-name": {
"patterns": [
{
"include": "#builtin-callables"
},
{
"include": "#illegal-object-name"
},
{
"name": "entity.name.function.decorator.python",
"match": "(?x)\n ([[:alpha:]_]\\w*) | (\\.)\n",
"captures": {
"2": {
"name": "punctuation.separator.period.python"
}
}
},
{
"include": "#line-continuation"
},
{
"name": "invalid.illegal.decorator.python",
"match": "(?x)\n \\s* ([^([:alpha:]\\s_\\.#\\\\] .*?) (?=\\#|$)\n",
"captures": {
"1": {
"name": "invalid.illegal.decorator.python"
}
}
}
]
},
"call-wrapper-inheritance": {
"comment": "same as a function call, but in inheritance context",
"name": "meta.function-call.python",
"begin": "(?x)\n \\b(?=\n ([[:alpha:]_]\\w*) \\s* (\\()\n )\n",
"end": "(\\))",
"endCaptures": {
"1": {
"name": "punctuation.definition.arguments.end.python"
}
},
"patterns": [
{
"include": "#inheritance-name"
},
{
"include": "#function-arguments"
}
]
},
"inheritance-name": {
"patterns": [
{
"include": "#lambda-incomplete"
},
{
"include": "#builtin-possible-callables"
},
{
"include": "#inheritance-identifier"
}
]
},
"function-call": {
"name": "meta.function-call.python",
"comment": "Regular function call of the type \"name(args)\"",
"begin": "(?x)\n \\b(?=\n ([[:alpha:]_]\\w*) \\s* (\\()\n )\n",
"end": "(\\))",
"endCaptures": {
"1": {
"name": "punctuation.definition.arguments.end.python"
}
},
"patterns": [
{
"include": "#special-variables"
},
{
"include": "#function-name"
},
{
"include": "#function-arguments"
}
]
},
"function-name": {
"patterns": [
{
"include": "#builtin-possible-callables"
},
{
"comment": "Some color schemas support meta.function-call.generic scope",
"name": "meta.function-call.generic.python",
"match": "(?x)\n \\b ([[:alpha:]_]\\w*) \\b\n"
}
]
},
"function-arguments": {
"begin": "(\\()",
"end": "(?=\\))(?!\\)\\s*\\()",
"beginCaptures": {
"1": {
"name": "punctuation.definition.arguments.begin.python"
}
},
"contentName": "meta.function-call.arguments.python",
"patterns": [
{
"name": "punctuation.separator.arguments.python",
"match": "(,)"
},
{
"match": "(?x)\n (?:(?<=[,(])|^) \\s* (\\*{1,2})\n",
"captures": {
"1": {
"name": "keyword.operator.unpacking.arguments.python"
}
}
},
{
"include": "#lambda-incomplete"
},
{
"include": "#illegal-names"
},
{
"match": "\\b([[:alpha:]_]\\w*)\\s*(=)(?!=)",
"captures": {
"1": {
"name": "variable.parameter.function-call.python"
},
"2": {
"name": "keyword.operator.assignment.python"
}
}
},
{
"name": "keyword.operator.assignment.python",
"match": "=(?!=)"
},
{
"include": "#expression"
},
{
"match": "\\s*(\\))\\s*(\\()",
"captures": {
"1": {
"name": "punctuation.definition.arguments.end.python"
},
"2": {
"name": "punctuation.definition.arguments.begin.python"
}
}
}
]
},
"builtin-callables": {
"patterns": [
{
"include": "#illegal-names"
},
{
"include": "#illegal-object-name"
},
{
"include": "#builtin-exceptions"
},
{
"include": "#builtin-functions"
},
{
"include": "#builtin-types"
}
]
},
"builtin-possible-callables": {
"patterns": [
{
"include": "#builtin-callables"
},
{
"include": "#magic-names"
}
]
},
"builtin-exceptions": {
"name": "support.type.exception.python",
"match": "(?x) (?<!\\.) \\b(\n (\n Arithmetic | Assertion | Attribute | Buffer | BlockingIO\n | BrokenPipe | ChildProcess\n | (Connection (Aborted | Refused | Reset)?)\n | EOF | Environment | FileExists | FileNotFound\n | FloatingPoint | IO | Import | Indentation | Index | Interrupted\n | IsADirectory | NotADirectory | Permission | ProcessLookup\n | Timeout\n | Key | Lookup | Memory | Name | NotImplemented | OS | Overflow\n | Reference | Runtime | Recursion | Syntax | System\n | Tab | Type | UnboundLocal | Unicode(Encode|Decode|Translate)?\n | Value | Windows | ZeroDivision | ModuleNotFound\n ) Error\n|\n ((Pending)?Deprecation | Runtime | Syntax | User | Future | Import\n | Unicode | Bytes | Resource\n )? Warning\n|\n SystemExit | Stop(Async)?Iteration\n | KeyboardInterrupt\n | GeneratorExit | (Base)?Exception\n)\\b\n"
},
"builtin-functions": {
"patterns": [
{
"name": "support.function.builtin.python",
"match": "(?x)\n (?<!\\.) \\b(\n __import__ | abs | aiter | all | any | anext | ascii | bin\n | breakpoint | callable | chr | compile | copyright | credits\n | delattr | dir | divmod | enumerate | eval | exec | exit\n | filter | format | getattr | globals | hasattr | hash | help\n | hex | id | input | isinstance | issubclass | iter | len\n | license | locals | map | max | memoryview | min | next\n | oct | open | ord | pow | print | quit | range | reload | repr\n | reversed | round | setattr | sorted | sum | vars | zip\n )\\b\n"
},
{
"name": "variable.legacy.builtin.python",
"match": "(?x)\n (?<!\\.) \\b(\n file | reduce | intern | raw_input | unicode | cmp | basestring\n | execfile | long | xrange\n )\\b\n"
}
]
},
"builtin-types": {
"name": "support.type.python",
"match": "(?x)\n (?<!\\.) \\b(\n bool | bytearray | bytes | classmethod | complex | dict\n | float | frozenset | int | list | object | property\n | set | slice | staticmethod | str | tuple | type\n\n (?# Although 'super' is not a type, it's related to types,\n and is special enough to be highlighted differently from\n other built-ins)\n | super\n )\\b\n"
},
"magic-function-names": {
"comment": "these methods have magic interpretation by python and are generally called\nindirectly through syntactic constructs\n",
"match": "(?x)\n \\b(\n __(?:\n abs | add | aenter | aexit | aiter | and | anext\n | await | bool | call | ceil | class_getitem\n | cmp | coerce | complex | contains | copy\n | deepcopy | del | delattr | delete | delitem\n | delslice | dir | div | divmod | enter | eq\n | exit | float | floor | floordiv | format | ge\n | get | getattr | getattribute | getinitargs\n | getitem | getnewargs | getslice | getstate | gt\n | hash | hex | iadd | iand | idiv | ifloordiv |\n | ilshift | imod | imul | index | init\n | instancecheck | int | invert | ior | ipow\n | irshift | isub | iter | itruediv | ixor | le\n | len | long | lshift | lt | missing | mod | mul\n | ne | neg | new | next | nonzero | oct | or | pos\n | pow | radd | rand | rdiv | rdivmod | reduce\n | reduce_ex | repr | reversed | rfloordiv |\n | rlshift | rmod | rmul | ror | round | rpow\n | rrshift | rshift | rsub | rtruediv | rxor | set\n | setattr | setitem | set_name | setslice\n | setstate | sizeof | str | sub | subclasscheck\n | truediv | trunc | unicode | xor | matmul\n | rmatmul | imatmul | init_subclass | set_name\n | fspath | bytes | prepare | length_hint\n )__\n )\\b\n",
"captures": {
"1": {
"name": "support.function.magic.python"
}
}
},
"magic-variable-names": {
"comment": "magic variables which a class/module may have.",
"match": "(?x)\n \\b(\n __(?:\n all | annotations | bases | builtins | class\n | closure | code | debug | defaults | dict | doc | file | func\n | globals | kwdefaults | match_args | members | metaclass | methods\n | module | mro | mro_entries | name | qualname | post_init | self\n | signature | slots | subclasses | version | weakref | wrapped\n | classcell | spec | path | package | future | traceback\n )__\n )\\b\n",
"captures": {
"1": {
"name": "support.variable.magic.python"