# -*- coding: utf-8 -*- """ pygments.lexers.gdscript ~~~~~~~~~~~~~~~~~~~~~~ Lexer for GDScript. :copyright: Copyright 2xxx by The Godot Engine Community :license: MIT. modified by Daniel J. Ramirez based on the original python.py pygment """ import re from pygments.lexer import ( RegexLexer, include, bygroups, default, words, combined, ) from pygments.token import ( Text, Comment, Operator, Keyword, Name, String, Number, Punctuation, ) __all__ = ["GDScriptLexer"] line_re = re.compile(".*?\n") class GDScriptLexer(RegexLexer): """ For `GDScript source code `_. """ name = "GDScript" aliases = ["gdscript", "gd"] filenames = ["*.gd"] mimetypes = ["text/x-gdscript", "application/x-gdscript"] def innerstring_rules(ttype): return [ # the old style '%s' % (...) string formatting ( r"%(\(\w+\))?[-#0 +]*([0-9]+|[*])?(\.([0-9]+|[*]))?" "[hlL]?[E-GXc-giorsux%]", String.Interpol, ), # backslashes, quotes and formatting signs must be parsed one at a time (r'[^\\\'"%\n]+', ttype), (r'[\'"\\]', ttype), # unhandled string formatting sign (r"%", ttype), # newlines are an error (use "nl" state) ] tokens = { "root": [ (r"\n", Text), ( r'^(\s*)([rRuUbB]{,2})("""(?:.|\n)*?""")', bygroups(Text, String.Affix, String.Doc), ), ( r"^(\s*)([rRuUbB]{,2})('''(?:.|\n)*?''')", bygroups(Text, String.Affix, String.Doc), ), (r"[^\S\n]+", Text), (r"#.*$", Comment.Single), (r"[]{}:(),;[]", Punctuation), (r"\\\n", Text), (r"\\", Text), (r"(in|and|or|not)\b", Operator.Word), ( r"!=|==|<<|>>|&&|\+=|-=|\*=|/=|%=|&=|\|=|\|\||[-~+/*%=<>&^.!|$]", Operator, ), include("keywords"), (r"(func)((?:\s|\\\s)+)", bygroups(Keyword, Text), "funcname"), (r"(class)((?:\s|\\\s)+)", bygroups(Keyword, Text), "classname"), include("builtins"), ( '([rR]|[uUbB][rR]|[rR][uUbB])(""")', bygroups(String.Affix, String.Double), "tdqs", ), ( "([rR]|[uUbB][rR]|[rR][uUbB])(''')", bygroups(String.Affix, String.Single), "tsqs", ), ( '([rR]|[uUbB][rR]|[rR][uUbB])(")', bygroups(String.Affix, String.Double), "dqs", ), ( "([rR]|[uUbB][rR]|[rR][uUbB])(')", bygroups(String.Affix, String.Single), "sqs", ), ( '([uUbB]?)(""")', bygroups(String.Affix, String.Double), combined("stringescape", "tdqs"), ), ( "([uUbB]?)(''')", bygroups(String.Affix, String.Single), combined("stringescape", "tsqs"), ), ( '([uUbB]?)(")', bygroups(String.Affix, String.Double), combined("stringescape", "dqs"), ), ( "([uUbB]?)(')", bygroups(String.Affix, String.Single), combined("stringescape", "sqs"), ), include("name"), include("numbers"), ], "keywords": [ ( words( ( "and", "in", "not", "or", "as", "breakpoint", "class", "class_name", "extends", "is", "func", "setget", "signal", "tool", "const", "enum", "export", "onready", "static", "var", "break", "continue", "if", "elif", "else", "for", "pass", "return", "match", "while", "remote", "master", "puppet", "remotesync", "mastersync", "puppetsync", ), suffix=r"\b", ), Keyword, ), ], "builtins": [ ( words( ( "Color8", "ColorN", "abs", "acos", "asin", "assert", "atan", "atan2", "bytes2var", "cartesian2polar", "ceil", "char", "clamp", "convert", "cos", "cosh", "db2linear", "decimals", "dectime", "deep_equal", "deg2rad", "dict2inst", "ease", "exp", "floor", "fmod", "fposmod", "funcref", "get_stack", "hash", "inst2dict", "instance_from_id", "inverse_lerp", "is_equal_approx", "is_inf", "is_instance_valid", "is_nan", "is_zero_approx", "len", "lerp", "lerp_angle", "linear2db", "load", "log", "max", "min", "move_toward", "nearest_po2", "ord", "parse_json", "polar2cartesian", "posmod", "pow", "preload", "print", "print_debug", "print_stack", "printerr", "printraw", "prints", "printt", "push_error", "push_warning", "rad2deg", "rand_range", "rand_seed", "randf", "randi", "randomize", "range", "range_lerp", "round", "seed", "sign", "sin", "sinh", "smoothstep", "sqrt", "step_decimals", "stepify", "str", "str2var", "tan", "tanh", "to_json", "type_exists", "typeof", "validate_json", "var2bytes", "var2str", "weakref", "wrapf", "wrapi", "yield", ), prefix=r"(?