-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathgoblin.sublime-syntax
59 lines (52 loc) · 1.7 KB
/
goblin.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
57
58
59
%YAML 1.2
---
# See http://www.sublimetext.com/docs/3/syntax.html
name: Goblin
file_extensions:
- gb
scope: source.goblin
contexts:
# The prototype context is prepended to all contexts but those setting
# meta_include_prototype: false.
prototype:
- include: comments
main:
# The main context is the initial starting point of our syntax.
# Include other contexts from here (or specify them directly).
- include: keywords
- include: numbers
- include: strings
keywords:
# Keywords are if, else for and while.
# Note that blackslashes don't need to be escaped within single quoted
# strings in YAML. When using single quoted strings, only single quotes
# need to be escaped: this is done by using two single quotes next to each
# other.
- match: '\b(if|else|for|while|vars|subprograms|process)\b'
scope: support.constant.goblin
numbers:
- match: '\b(-)?[0-9.]+\b'
scope: constant.numeric.goblin
strings:
# Strings begin and end with quotes, and use backslashes as an escape
# character.
- match: '"'
scope: punctuation.definition.string.begin.goblin
push: inside_string
inside_string:
- meta_include_prototype: false
- meta_scope: string.quoted.double.goblin
- match: '\.'
scope: constant.character.escape.goblin
- match: '"'
scope: punctuation.definition.string.end.goblin
pop: true
comments:
# Comments begin with a '//' and finish at the end of the line.
- match: '//'
scope: punctuation.definition.comment.goblin
push:
# This is an anonymous context push for brevity.
- meta_scope: comment.line.double-slash.goblin
- match: $\n?
pop: true