summaryrefslogtreecommitdiffstats
path: root/assets
diff options
context:
space:
mode:
authorKeith Hall <kingkeith+github@gmail.com>2021-04-05 22:17:47 +0300
committerKeith Hall <kingkeith+github@gmail.com>2021-04-05 22:24:04 +0300
commit782ede5db5ad601e44468c9ca32bd201e5c75aaa (patch)
tree1ea887d74d18957b1eb10371df6cd76630a7f93b /assets
parent1537733e6b0d764e092b701565de94c51ef3ecf1 (diff)
improve syslog syntax
Diffstat (limited to 'assets')
-rw-r--r--assets/syntaxes/02_Extra/syslog.sublime-syntax51
1 files changed, 46 insertions, 5 deletions
diff --git a/assets/syntaxes/02_Extra/syslog.sublime-syntax b/assets/syntaxes/02_Extra/syslog.sublime-syntax
index 6233da17..9b243c9c 100644
--- a/assets/syntaxes/02_Extra/syslog.sublime-syntax
+++ b/assets/syntaxes/02_Extra/syslog.sublime-syntax
@@ -5,10 +5,15 @@ name: syslog
file_extensions:
- syslog
scope: text.syslog
+variables:
+ ipv4_part: (?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)
contexts:
main:
- - match: '^\w+\s+\d+\s+\d{2}:\d{2}:\d{2}'
+ - match: ^(\w+\s+\d+)\s+(\d{2}:\d{2}:\d{2})
scope: meta.datetime.syslog constant.numeric.syslog
+ captures:
+ 1: meta.date.syslog
+ 2: meta.time.syslog
push: loghost
loghost:
- match: '[\w-]+'
@@ -20,7 +25,8 @@ contexts:
1: support.function.process.syslog
2: punctuation.separator.pid.begin.syslog
3: meta.pid.syslog meta.number.integer.syslog constant.numeric.value.syslog
- 4: punctuation.separator.mapping.syslog
+ 4: punctuation.separator.pid.end.syslog
+ 5: punctuation.separator.mapping.syslog
set: structured-data
structured-data:
- match: '\['
@@ -56,15 +62,50 @@ contexts:
captures:
1: punctuation.definition.string.begin.syslog
3: punctuation.definition.string.end.syslog
- - match: \d+
- scope: meta.number.integer.syslog constant.numeric.value.syslog
+ - include: numbers
- match: \b(CMD)\b\s+(\()
captures:
1: entity.name.label.syslog
2: punctuation.section.block.begin.syslog
embed: scope:source.shell.bash
- escape: \)
+ escape: \)$
escape_captures:
0: punctuation.section.block.end.syslog
+ - match: '<\w+>'
+ scope: constant.language.syslog
+ - match: (?i:fail(?:ure|ed)?|error)
+ scope: invalid.illegal.error.syslog
- match: $
pop: true
+ numbers:
+ - match: (?=(?:{{ipv4_part}}\.){3}{{ipv4_part}})
+ push:
+ - meta_scope: meta.ipaddress.v4.syslog meta.number.integer.decimal.syslog
+ - match: \d+
+ scope: constant.numeric.value.syslog
+ - match: \.
+ scope: punctuation.separator.sequence.syslog
+ - match: ''
+ pop: true
+ - match: (?=(?:\h{0,4}:){2,6}\h{1,4})
+ push:
+ - meta_scope: meta.ipaddress.v6.syslog meta.number.integer.hexadecimal.syslog
+ - match: \h{1,4}
+ scope: constant.numeric.value.syslog
+ - match: ':'
+ scope: punctuation.separator.sequence.syslog
+ - match: ''
+ pop: true
+ - match: (0x)(\h+)(?:(\.)(\h+))?
+ scope: meta.number.float.hexadecimal.syslog
+ captures:
+ 1: constant.numeric.base.syslog
+ 2: constant.numeric.value.syslog
+ 3: constant.numeric.value.syslog punctuation.separator.decimal.syslog
+ 4: constant.numeric.value.syslog
+ - match: \b\d+(\.)\d+\b
+ scope: meta.number.float.syslog constant.numeric.value.syslog
+ captures:
+ 1: punctuation.separator.decimal.syslog
+ - match: \b\d+\b
+ scope: meta.number.integer.syslog constant.numeric.value.syslog