1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
|
"""
pygments.lexers.tlb
~~~~~~~~~~~~~~~~~~~
Lexers for TL-b.
:copyright: Copyright 2006-2024 by the Pygments team, see AUTHORS.
:license: BSD, see LICENSE for details.
"""
from pygments.lexer import RegexLexer, include, words
from pygments.token import Operator, Name, \
Number, Whitespace, Punctuation, Comment
__all__ = ['TlbLexer']
class TlbLexer(RegexLexer):
"""
For TL-b source code.
"""
name = 'Tl-b'
aliases = ['tlb']
filenames = ['*.tlb']
url = 'https://docs.ton.org/#/overviews/TL-B'
version_added = ''
tokens = {
'root': [
(r'\s+', Whitespace),
include('comments'),
(r'[0-9]+', Number),
(words((
'+', '-', '*', '=', '?', '~', '.',
'^', '==', '<', '>', '<=', '>=', '!='
)), Operator),
(words(('##', '#<', '#<=')), Name.Tag),
(r'#[0-9a-f]*_?', Name.Tag),
(r'\$[01]*_?', Name.Tag),
(r'[a-zA-Z_][0-9a-zA-Z_]*', Name),
(r'[;():\[\]{}]', Punctuation)
],
'comments': [
(r'//.*', Comment.Singleline),
(r'/\*', Comment.Multiline, 'comment'),
],
'comment': [
(r'[^/*]+', Comment.Multiline),
(r'/\*', Comment.Multiline, '#push'),
(r'\*/', Comment.Multiline, '#pop'),
(r'[*/]', Comment.Multiline),
],
}
|