2021-04-06 22:50:52 +02:00
%YAML 1.2
---
# See http://www.sublimetext.com/docs/3/syntax.html
file_extensions:
- log
scope: text.log
variables:
ipv4_part: (?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)
2022-03-21 19:00:58 +01:00
hours_minutes_seconds: (?:[01]\d|2[0-3]):(?:[0-5]\d):(?:[0-5]\d)
2021-04-06 22:50:52 +02:00
contexts:
main:
- match: (\w+)(=)
captures:
1: variable.parameter.log
2: keyword.operator.assignment.log
- match: (')([^']*)(')
scope: string.quoted.single.log
captures:
1: punctuation.definition.string.begin.log
3: punctuation.definition.string.end.log
2022-03-21 19:00:58 +01:00
- match: \"
2021-04-06 22:50:52 +02:00
captures:
1: punctuation.definition.string.begin.log
2022-03-21 19:00:58 +01:00
push: double_quoted_string
2021-04-06 22:50:52 +02:00
- include: dates
- include: ip_addresses
- include: numbers
2021-04-07 21:01:10 +02:00
- match: \b(?i:fail(?:ure|ed)?|error|exception)\b
2021-04-09 21:09:01 +02:00
scope: markup.error.log
- match: \b(?i:warn(?:ing)?)\b
scope: markup.warning.log
2022-03-21 19:00:58 +01:00
- match: \b(?i:debug)\b
scope: markup.info.log
2021-04-06 22:50:52 +02:00
#- include: scope:text.html.markdown#autolink-inet
- match: \b\w+:/{2,3}
scope: markup.underline.link.scheme.log
push: url-host
dates:
2022-03-21 19:00:58 +01:00
- match: \b\d{4}-\d{2}-\d{2}(?=\b|T)
2021-04-06 22:50:52 +02:00
scope: meta.date.log meta.number.integer.decimal.log constant.numeric.value.log
2022-03-21 19:00:58 +01:00
push: maybe_date_time_separator
- match: \b\d{4}/\d{2}/\d{2}(?=\b|T)
2021-04-06 22:50:52 +02:00
scope: meta.date.log meta.number.integer.decimal.log constant.numeric.value.log
2022-03-21 19:00:58 +01:00
push: maybe_date_time_separator
- match: \b(?={{hours_minutes_seconds}})
push: time
time:
- match: (?:{{hours_minutes_seconds}})(?:(\.)\d{3})?\b
2021-04-06 22:50:52 +02:00
scope: meta.time.log meta.number.integer.decimal.log constant.numeric.value.log
captures:
1: punctuation.separator.decimal.log
2022-03-21 19:00:58 +01:00
- match: ''
pop: true
maybe_date_time_separator:
- match: T(?={{hours_minutes_seconds}})
scope: meta.date.log meta.time.log keyword.other.log
set: time
- match: ''
pop: true
2021-04-06 22:50:52 +02:00
ip_addresses:
2021-04-07 21:01:10 +02:00
- match: \b(?=(?:{{ipv4_part}}\.){3}{{ipv4_part}}\b)
2021-04-06 22:50:52 +02:00
push:
- meta_scope: meta.ipaddress.v4.log meta.number.integer.decimal.log
- match: \d+
scope: constant.numeric.value.log
- match: \.
scope: punctuation.separator.sequence.log
- match: ''
pop: true
2021-04-07 21:01:10 +02:00
- match: (?=(?:\h{0,4}:){2,6}\h{1,4}\b)
2021-04-06 22:50:52 +02:00
push:
- meta_scope: meta.ipaddress.v6.log meta.number.integer.hexadecimal.log
- match: \h{1,4}
scope: constant.numeric.value.log
- match: ':'
scope: punctuation.separator.sequence.log
- match: ''
pop: true
numbers:
2021-04-07 21:01:10 +02:00
- match: \b(0x)(\h+)(?:(\.)(\h+))?\b
2021-04-06 22:50:52 +02:00
scope: meta.number.float.hexadecimal.log
captures:
1: constant.numeric.base.log
2: constant.numeric.value.log
3: constant.numeric.value.log punctuation.separator.decimal.log
4: constant.numeric.value.log
- match: \b\d+(\.)\d+\b
scope: meta.number.float.log constant.numeric.value.log
captures:
1: punctuation.separator.decimal.log
- match: \b\d+\b
scope: meta.number.integer.log constant.numeric.value.log
url-host:
- meta_content_scope: markup.underline.link.host.log
- match: \[
scope: punctuation.section.brackets.begin.log
push:
- match: \]
scope: punctuation.section.brackets.end.log
pop: true
- include: ip_addresses
- match: '[^:/\s]+'
- match: ''
set: url-after-host
url-after-host:
- match: (:)(\d+)
scope: markup.underline.link.port.log
captures:
1: punctuation.separator.mapping.port.log
2: constant.numeric.value.log
#- include: scope:text.html.markdown#url-escaped-chars
- match: (%)\h{2}
scope: markup.underline.link.path.log constant.character.escape.url.log
captures:
1: punctuation.definition.escape.log
# After a valid domain, zero or more non-space non-< characters may follow
- match: (?=[?!.,:*_~]*[\s<]) # Trailing punctuation (specifically, ?, !, ., ,, :, *, _, and ~) will not be considered part of the autolink, though they may be included in the interior of the link
pop: true
- match: \( # When an autolink ends in ), we scan the entire autolink for the total number of parentheses. If there is a greater number of closing parentheses than opening ones, we don’ t consider the last character part of the autolink, in order to facilitate including an autolink inside a parenthesis
push:
- meta_scope: markup.underline.link.path.log
- match: (?=[?!.,:*_~]*[\s<])
pop: true
- match: \)
pop: true
- match: (?=\)[?!.,:*_~]*[\s<])
pop: true
- match: '[^?!.,:*_~\s<&()%]+|\S'
scope: markup.underline.link.path.log
- match: ''
pop: true
2022-03-21 19:00:58 +01:00
double_quoted_string:
- meta_scope: string.quoted.double.log
- match: \\"
scope: constant.character.escape.log
- match: \\n
scope: constant.character.escape.log
- match: \"
scope: punctuation.definition.string.end.log
pop: true