Source code for mau.lexers.text_lexer
import re
from mau.lexers.base_lexer import BaseLexer, TokenTypes
[docs]class TextLexer(BaseLexer):
def _process_whitespace(self):
regexp = re.compile(r"\ +")
match = regexp.match(self._tail)
if not match:
return None
return self._create_token_and_skip(TokenTypes.TEXT, " ")
def _process_literal(self):
if self._current_char not in '~^_*`{}()[]#\\"':
return None
return self._create_token_and_skip(TokenTypes.LITERAL, self._current_char)
def _process_text(self):
regexp = re.compile(r'[^~\^_*`{}()[\]#"\\ ]+')
match = regexp.match(self._tail)
if not match: # pragma: no cover
return None
return self._create_token_and_skip(TokenTypes.TEXT, match.group())
def _process_functions(self):
return [
self._process_eof,
self._process_eol,
self._process_whitespace,
self._process_literal,
self._process_text,
]