blob: 391bae36b21bde9ba5ac0652ad7294367f04ffe4 (
plain)
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
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
|
<lexer>
<config>
<name>Prolog</name>
<alias>prolog</alias>
<filename>*.ecl</filename>
<filename>*.prolog</filename>
<filename>*.pro</filename>
<filename>*.pl</filename>
<mime_type>text/x-prolog</mime_type>
</config>
<rules>
<state name="root">
<rule pattern="/\*">
<token type="CommentMultiline"/>
<push state="nested-comment"/>
</rule>
<rule pattern="%.*">
<token type="CommentSingle"/>
</rule>
<rule pattern="0\'.">
<token type="LiteralStringChar"/>
</rule>
<rule pattern="0b[01]+">
<token type="LiteralNumberBin"/>
</rule>
<rule pattern="0o[0-7]+">
<token type="LiteralNumberOct"/>
</rule>
<rule pattern="0x[0-9a-fA-F]+">
<token type="LiteralNumberHex"/>
</rule>
<rule pattern="\d\d?\'[a-zA-Z0-9]+">
<token type="LiteralNumberInteger"/>
</rule>
<rule pattern="(\d+\.\d*|\d*\.\d+)([eE][+-]?[0-9]+)?">
<token type="LiteralNumberFloat"/>
</rule>
<rule pattern="\d+">
<token type="LiteralNumberInteger"/>
</rule>
<rule pattern="[\[\](){}|.,;!]">
<token type="Punctuation"/>
</rule>
<rule pattern=":-|-->">
<token type="Punctuation"/>
</rule>
<rule pattern=""(?:\\x[0-9a-fA-F]+\\|\\u[0-9a-fA-F]{4}|\\U[0-9a-fA-F]{8}|\\[0-7]+\\|\\["\nabcefnrstv]|[^\\"])*"">
<token type="LiteralStringDouble"/>
</rule>
<rule pattern="'(?:''|[^'])*'">
<token type="LiteralStringAtom"/>
</rule>
<rule pattern="is\b">
<token type="Operator"/>
</rule>
<rule pattern="(<|>|=<|>=|==|=:=|=|/|//|\*|\+|-)(?=\s|[a-zA-Z0-9\[])">
<token type="Operator"/>
</rule>
<rule pattern="(mod|div|not)\b">
<token type="Operator"/>
</rule>
<rule pattern="_">
<token type="Keyword"/>
</rule>
<rule pattern="([a-z]+)(:)">
<bygroups>
<token type="NameNamespace"/>
<token type="Punctuation"/>
</bygroups>
</rule>
<rule pattern="([a-zÀ---][\w$À---]*)(\s*)(:-|-->)">
<bygroups>
<token type="NameFunction"/>
<token type="Text"/>
<token type="Operator"/>
</bygroups>
</rule>
<rule pattern="([a-zÀ---][\w$À---]*)(\s*)(\()">
<bygroups>
<token type="NameFunction"/>
<token type="Text"/>
<token type="Punctuation"/>
</bygroups>
</rule>
<rule pattern="[a-zÀ---][\w$À---]*">
<token type="LiteralStringAtom"/>
</rule>
<rule pattern="[#&*+\-./:<=>?@\\^~¡-¿‐-〿]+">
<token type="LiteralStringAtom"/>
</rule>
<rule pattern="[A-Z_]\w*">
<token type="NameVariable"/>
</rule>
<rule pattern="\s+|[ --�]">
<token type="Text"/>
</rule>
</state>
<state name="nested-comment">
<rule pattern="\*/">
<token type="CommentMultiline"/>
<pop depth="1"/>
</rule>
<rule pattern="/\*">
<token type="CommentMultiline"/>
<push/>
</rule>
<rule pattern="[^*/]+">
<token type="CommentMultiline"/>
</rule>
<rule pattern="[*/]">
<token type="CommentMultiline"/>
</rule>
</state>
</rules>
</lexer>
|