-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathSimplate (Python).sublime-syntax
56 lines (46 loc) · 1.39 KB
/
Simplate (Python).sublime-syntax
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
%YAML 1.2
---
name: Simplate - Python
file_extensions: [spt]
scope: source.spt
contexts:
main:
- match: ""
push: initialization_logic
initialization_logic:
# If we encounter a specline without content at this point,
# the request_logic section is starting.
- match: ^\[-{3,}\]$
scope: punctuation.separator
push: request_logic
- match: ^\[-{3,}\](?<=[^$])
scope: punctuation.separator
push: specline_for_content
# This is the initialization logic section, it contains Python code.
- include: "Packages/Python/Python.sublime-syntax"
request_logic:
# Another specline without content. Assume the remaining content is HTML.
- match: ^\[-{3,}\]$
scope: punctuation.separator
push: html_content
- match: ^\[-{3,}\](?<=[^$])
scope: punctuation.separator
push: specline_for_content
# Request logic is Python code too, just like initialization logic.
- include: "Packages/Python/Python.sublime-syntax"
specline_for_content:
- match: "via"
scope: keyword
- match: (jinja2|text\html)$
scope: entity.name
push: html_content
- match: \w
scope: entity.name
# Add more content sections!
- match: $
pop: true
html_content:
- match: ^\[-{3,}\]
scope: punctuation.separator
pop: true
- include: "Packages/Simplates/Jinja2/HTML (Jinja2).tmLanguage"