| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290 |
- /*
- Language: Python
- Description: Python is an interpreted, object-oriented, high-level programming language with dynamic semantics.
- Website: https://www.python.org
- Category: common
- */
- function python(hljs) {
- const RESERVED_WORDS = [
- 'and',
- 'as',
- 'assert',
- 'async',
- 'await',
- 'break',
- 'class',
- 'continue',
- 'def',
- 'del',
- 'elif',
- 'else',
- 'except',
- 'finally',
- 'for',
- '',
- 'from',
- 'global',
- 'if',
- 'import',
- 'in',
- 'is',
- 'lambda',
- 'nonlocal|10',
- 'not',
- 'or',
- 'pass',
- 'raise',
- 'return',
- 'try',
- 'while',
- 'with',
- 'yield',
- ];
- const BUILT_INS = [
- '__import__',
- 'abs',
- 'all',
- 'any',
- 'ascii',
- 'bin',
- 'bool',
- 'breakpoint',
- 'bytearray',
- 'bytes',
- 'callable',
- 'chr',
- 'classmethod',
- 'compile',
- 'complex',
- 'delattr',
- 'dict',
- 'dir',
- 'divmod',
- 'enumerate',
- 'eval',
- 'exec',
- 'filter',
- 'float',
- 'format',
- 'frozenset',
- 'getattr',
- 'globals',
- 'hasattr',
- 'hash',
- 'help',
- 'hex',
- 'id',
- 'input',
- 'int',
- 'isinstance',
- 'issubclass',
- 'iter',
- 'len',
- 'list',
- 'locals',
- 'map',
- 'max',
- 'memoryview',
- 'min',
- 'next',
- 'object',
- 'oct',
- 'open',
- 'ord',
- 'pow',
- 'print',
- 'property',
- 'range',
- 'repr',
- 'reversed',
- 'round',
- 'set',
- 'setattr',
- 'slice',
- 'sorted',
- 'staticmethod',
- 'str',
- 'sum',
- 'super',
- 'tuple',
- 'type',
- 'vars',
- 'zip',
- ];
- const LITERALS = [
- '__debug__',
- 'Ellipsis',
- 'False',
- 'None',
- 'NotImplemented',
- 'True',
- ];
- const KEYWORDS = {
- keyword: RESERVED_WORDS.join(' '),
- built_in: BUILT_INS.join(' '),
- literal: LITERALS.join(' ')
- };
- const PROMPT = {
- className: 'meta', begin: /^(>>>|\.\.\.) /
- };
- const SUBST = {
- className: 'subst',
- begin: /\{/, end: /\}/,
- keywords: KEYWORDS,
- illegal: /#/
- };
- const LITERAL_BRACKET = {
- begin: /\{\{/,
- relevance: 0
- };
- const STRING = {
- className: 'string',
- contains: [hljs.BACKSLASH_ESCAPE],
- variants: [
- {
- begin: /([uU]|[bB]|[rR]|[bB][rR]|[rR][bB])?'''/, end: /'''/,
- contains: [hljs.BACKSLASH_ESCAPE, PROMPT],
- relevance: 10
- },
- {
- begin: /([uU]|[bB]|[rR]|[bB][rR]|[rR][bB])?"""/, end: /"""/,
- contains: [hljs.BACKSLASH_ESCAPE, PROMPT],
- relevance: 10
- },
- {
- begin: /([fF][rR]|[rR][fF]|[fF])'''/, end: /'''/,
- contains: [hljs.BACKSLASH_ESCAPE, PROMPT, LITERAL_BRACKET, SUBST]
- },
- {
- begin: /([fF][rR]|[rR][fF]|[fF])"""/, end: /"""/,
- contains: [hljs.BACKSLASH_ESCAPE, PROMPT, LITERAL_BRACKET, SUBST]
- },
- {
- begin: /([uU]|[rR])'/, end: /'/,
- relevance: 10
- },
- {
- begin: /([uU]|[rR])"/, end: /"/,
- relevance: 10
- },
- {
- begin: /([bB]|[bB][rR]|[rR][bB])'/, end: /'/
- },
- {
- begin: /([bB]|[bB][rR]|[rR][bB])"/, end: /"/
- },
- {
- begin: /([fF][rR]|[rR][fF]|[fF])'/, end: /'/,
- contains: [hljs.BACKSLASH_ESCAPE, LITERAL_BRACKET, SUBST]
- },
- {
- begin: /([fF][rR]|[rR][fF]|[fF])"/, end: /"/,
- contains: [hljs.BACKSLASH_ESCAPE, LITERAL_BRACKET, SUBST]
- },
- hljs.APOS_STRING_MODE,
- hljs.QUOTE_STRING_MODE
- ]
- };
- // https://docs.python.org/3.9/reference/lexical_analysis.html#numeric-literals
- const digitpart = '[0-9](_?[0-9])*';
- const pointfloat = `(\\b(${digitpart}))?\\.(${digitpart})|\\b(${digitpart})\\.`;
- const NUMBER = {
- className: 'number', relevance: 0,
- variants: [
- // exponentfloat, pointfloat
- // https://docs.python.org/3.9/reference/lexical_analysis.html#floating-point-literals
- // optionally imaginary
- // https://docs.python.org/3.9/reference/lexical_analysis.html#imaginary-literals
- // Note: no leading \b because floats can start with a decimal point
- // and we don't want to mishandle e.g. `fn(.5)`,
- // no trailing \b for pointfloat because it can end with a decimal point
- // and we don't want to mishandle e.g. `0..hex()`; this should be safe
- // because both MUST contain a decimal point and so cannot be confused with
- // the interior part of an identifier
- { begin: `(\\b(${digitpart})|(${pointfloat}))[eE][+-]?(${digitpart})[jJ]?\\b` },
- { begin: `(${pointfloat})[jJ]?` },
- // decinteger, bininteger, octinteger, hexinteger
- // https://docs.python.org/3.9/reference/lexical_analysis.html#integer-literals
- // optionally "long" in Python 2
- // https://docs.python.org/2.7/reference/lexical_analysis.html#integer-and-long-integer-literals
- // decinteger is optionally imaginary
- // https://docs.python.org/3.9/reference/lexical_analysis.html#imaginary-literals
- { begin: '\\b([1-9](_?[0-9])*|0+(_?0)*)[lLjJ]?\\b' },
- { begin: '\\b0[bB](_?[01])+[lL]?\\b' },
- { begin: '\\b0[oO](_?[0-7])+[lL]?\\b' },
- { begin: '\\b0[xX](_?[0-9a-fA-F])+[lL]?\\b' },
- // imagnumber (digitpart-based)
- // https://docs.python.org/3.9/reference/lexical_analysis.html#imaginary-literals
- { begin: `\\b(${digitpart})[jJ]\\b` },
- ]
- };
- const PARAMS = {
- className: 'params',
- variants: [
- // Exclude params at functions without params
- {begin: /\(\s*\)/, skip: true, className: null },
- {
- begin: /\(/, end: /\)/, excludeBegin: true, excludeEnd: true,
- keywords: KEYWORDS,
- contains: ['self', PROMPT, NUMBER, STRING, hljs.HASH_COMMENT_MODE],
- },
- ],
- };
- SUBST.contains = [STRING, NUMBER, PROMPT];
- return {
- name: 'Python',
- aliases: ['py', 'gyp', 'ipython'],
- keywords: KEYWORDS,
- illegal: /(<\/|->|\?)|=>/,
- contains: [
- PROMPT,
- NUMBER,
- // eat "if" prior to string so that it won't accidentally be
- // labeled as an f-string as in:
- { begin: /\bself\b/, }, // very common convention
- { beginKeywords: "if", relevance: 0 },
- STRING,
- hljs.HASH_COMMENT_MODE,
- {
- variants: [
- {className: 'function', beginKeywords: 'def'},
- {className: 'class', beginKeywords: 'class'}
- ],
- end: /:/,
- illegal: /[${=;\n,]/,
- contains: [
- hljs.UNDERSCORE_TITLE_MODE,
- PARAMS,
- {
- begin: /->/, endsWithParent: true,
- keywords: 'None'
- }
- ]
- },
- {
- className: 'meta',
- begin: /^[\t ]*@/, end: /(?=#)|$/,
- contains: [NUMBER, PARAMS, STRING]
- },
- {
- begin: /\b(print|exec)\(/ // don’t highlight keywords-turned-functions in Python 3
- }
- ]
- };
- }
- module.exports = python;
|