aboutsummaryrefslogtreecommitdiffstats
path: root/contrib/python/Pygments/py3/pygments/lexers/roboconf.py
blob: bbffc1c84eb42768352ee4fd0f3926a5930c6b30 (plain) (blame)
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
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
""" 
    pygments.lexers.roboconf 
    ~~~~~~~~~~~~~~~~~~~~~~~~ 
 
    Lexers for Roboconf DSL. 
 
    :copyright: Copyright 2006-2021 by the Pygments team, see AUTHORS.
    :license: BSD, see LICENSE for details. 
""" 
 
from pygments.lexer import RegexLexer, words, re 
from pygments.token import Text, Operator, Keyword, Name, Comment 
 
__all__ = ['RoboconfGraphLexer', 'RoboconfInstancesLexer'] 
 
 
class RoboconfGraphLexer(RegexLexer): 
    """ 
    Lexer for `Roboconf <http://roboconf.net/en/roboconf.html>`_ graph files. 
 
    .. versionadded:: 2.1 
    """ 
    name = 'Roboconf Graph' 
    aliases = ['roboconf-graph'] 
    filenames = ['*.graph'] 
 
    flags = re.IGNORECASE | re.MULTILINE 
    tokens = { 
        'root': [ 
            # Skip white spaces 
            (r'\s+', Text), 
 
            # There is one operator 
            (r'=', Operator), 
 
            # Keywords 
            (words(('facet', 'import'), suffix=r'\s*\b', prefix=r'\b'), Keyword), 
            (words(( 
                'installer', 'extends', 'exports', 'imports', 'facets', 
                'children'), suffix=r'\s*:?', prefix=r'\b'), Name), 
 
            # Comments 
            (r'#.*\n', Comment), 
 
            # Default 
            (r'[^#]', Text), 
            (r'.*\n', Text) 
        ] 
    } 
 
 
class RoboconfInstancesLexer(RegexLexer): 
    """ 
    Lexer for `Roboconf <http://roboconf.net/en/roboconf.html>`_ instances files. 
 
    .. versionadded:: 2.1 
    """ 
    name = 'Roboconf Instances' 
    aliases = ['roboconf-instances'] 
    filenames = ['*.instances'] 
 
    flags = re.IGNORECASE | re.MULTILINE 
    tokens = { 
        'root': [ 
 
            # Skip white spaces 
            (r'\s+', Text), 
 
            # Keywords 
            (words(('instance of', 'import'), suffix=r'\s*\b', prefix=r'\b'), Keyword), 
            (words(('name', 'count'), suffix=r's*:?', prefix=r'\b'), Name), 
            (r'\s*[\w.-]+\s*:', Name), 
 
            # Comments 
            (r'#.*\n', Comment), 
 
            # Default 
            (r'[^#]', Text), 
            (r'.*\n', Text) 
        ] 
    }