|
|
|
"""
|
|
|
|
pygments.lexers.maxima
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
Lexer for the computer algebra system Maxima.
|
|
|
|
|
|
|
|
Derived from pygments/lexers/algebra.py.
|
|
|
|
|
|
|
|
:copyright: Copyright 2006-2023 by the Pygments team, see AUTHORS.
|
|
|
|
:license: BSD, see LICENSE for details.
|
|
|
|
"""
|
|
|
|
|
|
|
|
import re
|
|
|
|
|
|
|
|
from pygments.lexer import RegexLexer, bygroups, words
|
|
|
|
from pygments.token import Text, Comment, Operator, Keyword, Name, String, \
|
|
|
|
Number, Punctuation
|
|
|
|
|
|
|
|
__all__ = ['MaximaLexer']
|
|
|
|
|
|
|
|
class MaximaLexer(RegexLexer):
|
|
|
|
"""
|
|
|
|
A Maxima lexer.
|
|
|
|
Derived from pygments.lexers.MuPADLexer.
|
|
|
|
|
|
|
|
.. versionadded:: 2.11
|
|
|
|
"""
|
|
|
|
name = 'Maxima'
|
|
|
|
url = 'http://maxima.sourceforge.net'
|
|
|
|
aliases = ['maxima', 'macsyma']
|
|
|
|
filenames = ['*.mac', '*.max']
|
|
|
|
|
|
|
|
keywords = ('if', 'then', 'else', 'elseif',
|
|
|
|
'do', 'while', 'repeat', 'until',
|
|
|
|
'for', 'from', 'to', 'downto', 'step', 'thru')
|
|
|
|
|
|
|
|
constants = ('%pi', '%e', '%phi', '%gamma', '%i',
|
|
|
|
'und', 'ind', 'infinity', 'inf', 'minf',
|
|
|
|
'true', 'false', 'unknown', 'done')
|
|
|
|
|
|
|
|
operators = (r'.', r':', r'=', r'#',
|
|
|
|
r'+', r'-', r'*', r'/', r'^',
|
|
|
|
r'@', r'>', r'<', r'|', r'!', r"'")
|
|
|
|
|
|
|
|
operator_words = ('and', 'or', 'not')
|
|
|
|
|
|
|
|
tokens = {
|
|
|
|
'root': [
|
|
|
|
(r'/\*', Comment.Multiline, 'comment'),
|
|
|
|
(r'"(?:[^"\\]|\\.)*"', String),
|
|
|
|
(r'\(|\)|\[|\]|\{|\}', Punctuation),
|
|
|
|
(r'[,;$]', Punctuation),
|
|
|
|
(words (constants), Name.Constant),
|
|
|
|
(words (keywords), Keyword),
|
|
|
|
(words (operators), Operator),
|
|
|
|
(words (operator_words), Operator.Word),
|
|
|
|
(r'''(?x)
|
|
|
|
((?:[a-zA-Z_#][\w#]*|`[^`]*`)
|
|
|
|
(?:::[a-zA-Z_#][\w#]*|`[^`]*`)*)(\s*)([(])''',
|
|
|
|
bygroups(Name.Function, Text.Whitespace, Punctuation)),
|
|
|
|
(r'''(?x)
|
|
|
|
(?:[a-zA-Z_#%][\w#%]*|`[^`]*`)
|
|
|
|
(?:::[a-zA-Z_#%][\w#%]*|`[^`]*`)*''', Name.Variable),
|
|
|
|
(r'[-+]?(\d*\.\d+([bdefls][-+]?\d+)?|\d+(\.\d*)?[bdefls][-+]?\d+)', Number.Float),
|
|
|
|
(r'[-+]?\d+', Number.Integer),
|
|
|
|
(r'\s+', Text.Whitespace),
|
|
|
|
(r'.', Text)
|
|
|
|
],
|
|
|
|
'comment': [
|
|
|
|
(r'[^*/]+', Comment.Multiline),
|
|
|
|
(r'/\*', Comment.Multiline, '#push'),
|
|
|
|
(r'\*/', Comment.Multiline, '#pop'),
|
|
|
|
(r'[*/]', Comment.Multiline)
|
|
|
|
]
|
|
|
|
}
|
|
|
|
|
|
|
|
def analyse_text (text):
|
|
|
|
strength = 0.0
|
|
|
|
# Input expression terminator.
|
|
|
|
if re.search (r'\$\s*$', text, re.MULTILINE):
|
|
|
|
strength += 0.05
|
|
|
|
# Function definition operator.
|
|
|
|
if ':=' in text:
|
|
|
|
strength += 0.02
|
|
|
|
return strength
|