|
105 | 105 | "name": "support.other.meta-name.strings.yara",
|
106 | 106 | "match": "\\b([A-Z_a-z][0-9A-Z_a-z]{0,127})\\s*(=)\\s*(true|false)",
|
107 | 107 | "captures": {
|
108 |
| - "1": {"name": "keyword.other.identifier.yara"}, |
| 108 | + "1": {"name": "entity.other.meta.identifier.yara"}, |
109 | 109 | "2": {"name": "keyword.operator.assignment.yara"},
|
110 | 110 | "3": {"name": "constant.language.yara"}
|
111 | 111 | }
|
|
114 | 114 | "name": "support.other.meta-name.strings.yara",
|
115 | 115 | "match": "\\b([A-Z_a-z][0-9A-Z_a-z]{0,127})\\s*(=)\\s*([0-9]+)(KB|MB)?",
|
116 | 116 | "captures": {
|
117 |
| - "1": {"name": "keyword.other.identifier.yara"}, |
| 117 | + "1": {"name": "entity.other.meta.identifier.yara"}, |
118 | 118 | "2": {"name": "keyword.operator.assignment.yara"},
|
119 | 119 | "3": {"name": "constant.numeric.yara"},
|
120 | 120 | "4": {"name": "storage.type.number.postfix.yara"}
|
|
125 | 125 | "begin": "\\b([A-Z_a-z][0-9A-Z_a-z]{0,127})\\s*(=)\\s*(?=\")",
|
126 | 126 | "end": "(?<=\")",
|
127 | 127 | "beginCaptures": {
|
128 |
| - "1": {"name": "keyword.other.identifier.yara"}, |
| 128 | + "1": {"name": "entity.other.meta.identifier.yara"}, |
129 | 129 | "2": {"name": "keyword.operator.assignment.yara"}
|
130 | 130 | },
|
131 | 131 | "patterns": [
|
|
144 | 144 | {"include": "#comments"},
|
145 | 145 | {"include": "#string-assignment-text"},
|
146 | 146 | {"include": "#string-assignment-regex"},
|
147 |
| - {"include": "#string-assignment-hex"} |
| 147 | + {"include": "#string-assignment-hex"}, |
| 148 | + {"include": "#unmatched-characters"} |
148 | 149 | ]
|
149 | 150 | },
|
150 | 151 | "string-assignment-text": {
|
151 | 152 | "name": "support.other.attribute-name.strings.yara",
|
152 |
| - "begin": "(\\$([0-9A-Z_a-z]+\\b)?)\\s*(=)(?=\\s*\")", |
| 153 | + "begin": "(\\$)([0-9A-Z_a-z]+\\b)?+\\s*+([^\\n\\s=][^=]*)?(=)(?=\\s*\")", |
153 | 154 | "end": "(?=\\b(condition)\\b|\\$)",
|
154 | 155 | "beginCaptures": {
|
155 |
| - "1": {"name": "keyword.other.string.identifier.name.yara"}, |
156 |
| - "2": {"name": "keyword.other.string.identifier.yara"}, |
157 |
| - "3": {"name": "keyword.operator.assignment.yara"} |
| 156 | + "1": {"name": "variable.language.string.identifier.yara"}, |
| 157 | + "2": {"name": "variable.other.string.identifier.yara"}, |
| 158 | + "3": {"name": "invalid.illegal.string.identifier.yara"}, |
| 159 | + "4": {"name": "keyword.operator.assignment.yara"} |
158 | 160 | },
|
159 | 161 | "patterns": [
|
160 | 162 | {"include": "#comments"},
|
|
165 | 167 | },
|
166 | 168 | "string-assignment-regex": {
|
167 | 169 | "name": "support.other.attribute-name.strings.yara",
|
168 |
| - "begin": "(\\$([0-9A-Z_a-z]+)?)\\s*(=)(?=\\s*/)", |
| 170 | + "begin": "(\\$)([0-9A-Z_a-z]+\\b)?+\\s*+([^\\n\\s=][^=]*)?(=)(?=\\s*/)", |
169 | 171 | "end": "(?=\\b(condition)\\b|\\$)",
|
170 | 172 | "beginCaptures": {
|
171 |
| - "1": {"name": "keyword.other.string.identifier.yara"}, |
172 |
| - "2": {"name": "keyword.other.string.identifier.name.yara"}, |
173 |
| - "3": {"name": "keyword.operator.assignment.yara"} |
| 173 | + "1": {"name": "variable.language.string.identifier.yara"}, |
| 174 | + "2": {"name": "variable.other.string.identifier.yara"}, |
| 175 | + "3": {"name": "invalid.illegal.string.identifier.yara"}, |
| 176 | + "4": {"name": "keyword.operator.assignment.yara"} |
174 | 177 | },
|
175 | 178 | "patterns": [
|
176 | 179 | {"include": "#comments"},
|
|
185 | 188 | },
|
186 | 189 | "string-assignment-hex": {
|
187 | 190 | "name": "support.other.attribute-name.strings.yara",
|
188 |
| - "begin": "(\\$([0-9A-Z_a-z]+\\b)?)\\s*(=)", |
| 191 | + "begin": "(\\$)([0-9A-Z_a-z]+\\b)?+\\s*+([^\\n\\s=][^=]*)?(=)", |
189 | 192 | "end": "(?=\\b(condition)\\b|\\$)",
|
190 | 193 | "beginCaptures": {
|
191 |
| - "1": {"name": "keyword.other.string.identifier.name.yara"}, |
192 |
| - "2": {"name": "keyword.other.string.identifier.yara"}, |
193 |
| - "3": {"name": "keyword.operator.assignment.yara"} |
| 194 | + "1": {"name": "variable.language.string.identifier.yara"}, |
| 195 | + "2": {"name": "variable.other.string.identifier.yara"}, |
| 196 | + "3": {"name": "invalid.illegal.string.identifier.yara"}, |
| 197 | + "4": {"name": "keyword.operator.assignment.yara"} |
194 | 198 | },
|
195 | 199 | "patterns": [
|
196 | 200 | {"include": "#comments"},
|
|
253 | 257 | },
|
254 | 258 | "hex-jump": {
|
255 | 259 | "name": "entity.name.jump.hex.yara",
|
256 |
| - "begin": "\\[", |
| 260 | + "begin": "\\[\\s*(?=([1-9][0-9]*|[0-9]*\\s*-|[0-9]+\\s*-\\s*[0-9]*)\\s*\\])", |
257 | 261 | "end": "\\]",
|
258 | 262 | "patterns": [
|
259 | 263 | {
|
|
279 | 283 | }
|
280 | 284 | },
|
281 | 285 | "base64-modifier": {
|
282 |
| - "begin": "\\b(base64)\\s*(\\()", |
| 286 | + "begin": "\\b(base64)\\s*(\\()(?=\\s*\")", |
283 | 287 | "end": "(\\))",
|
284 | 288 | "beginCaptures": {
|
285 | 289 | "1": {"name": "keyword.other.modifier.yara"},
|
|
300 | 304 | {"include": "#base64-modifier"},
|
301 | 305 | {
|
302 | 306 | "name": "keyword.other.modifier.yara",
|
303 |
| - "match": "\\b(nocase|wide|ascii|xor|base64|base64wide|fullword|private)\\b" |
| 307 | + "match": "\\b(nocase|wide|ascii|xor|base64|base64wide|fullword|private)\\b(?!\\()" |
304 | 308 | },
|
305 | 309 | {"include": "#comments"},
|
306 | 310 | {"include": "#unmatched-characters"}
|
|
341 | 345 | {"include": "#string-identifiers"},
|
342 | 346 | {"include": "#booleans"},
|
343 | 347 | {
|
344 |
| - "name": "storage.type.keyword.yara", |
345 |
| - "match": "\\b(all|and|any|at|contains|endswith|entrypoint|filesize|for|icontains|iendswith|iequals|in|int16|int16be|int32|int32be|int8|int8be|istartswith|matches|none|not|of|or|startswith|them|uint16|uint16be|uint32|uint32be|uint8|uint8be|defined)\\b" |
| 348 | + "name": "constant.numeric.keyword.yara", |
| 349 | + "match": "\\b(all|any|none|filesize)\\b" |
| 350 | + }, |
| 351 | + { |
| 352 | + "name": "constant.numeric.keyword.yara invalid.deprecated.keyword.yara", |
| 353 | + "match": "\\b(entrypoint)\\b" |
| 354 | + }, |
| 355 | + { |
| 356 | + "name": "variable.language.string.identifier.wildcard.yara", |
| 357 | + "match": "\\b(them)\\b" |
| 358 | + }, |
| 359 | + { |
| 360 | + "name": "keyword.other.yara", |
| 361 | + "match": "\\b(at|for|in|of)\\b" |
| 362 | + }, |
| 363 | + { |
| 364 | + "name": "support.function.other.yara", |
| 365 | + "match": "\\b((?:u?int)(?:8|16|32)(?:be)?)(?=\\s*(\\(|\n))" |
| 366 | + }, |
| 367 | + { |
| 368 | + "name": "variable.language.loop.variable.yara", |
| 369 | + "match": "([!@#$])(?![0-9A-Z_a-z])" |
346 | 370 | },
|
347 | 371 | {"include": "#identifiers"},
|
348 | 372 | {"include": "#unmatched-characters"}
|
|
393 | 417 | },
|
394 | 418 | "relational-operators-text": {
|
395 | 419 | "name": "keyword.operator.comparison.yara",
|
396 |
| - "match": "\\b(contains|icontains|startswith|istartswith|endswith|iendswith|iequals)\\b" |
| 420 | + "match": "\\b(contains|icontains|startswith|istartswith|endswith|iendswith|iequals)(?=\\s*\")" |
397 | 421 | },
|
398 | 422 | "relational-operators-regexp": {
|
399 | 423 | "name": "keyword.operator.comparison.yara",
|
400 |
| - "match": "\\b(matches)\\b" |
| 424 | + "match": "\\b(matches)(?=\\s*/)" |
401 | 425 | },
|
402 | 426 | "rule-end": {
|
403 | 427 | "name": "punctuation.definition.rule.end.yara",
|
|
418 | 442 | },
|
419 | 443 | "string-identifiers": {
|
420 | 444 | "name": "variable.other.string_identifier.yara",
|
421 |
| - "match": "[!@#$][0-9A-Z_a-z]*" |
| 445 | + "match": "([!@#$])([0-9A-Z_a-z]+|(?=[*]))([*]?)", |
| 446 | + "captures": { |
| 447 | + "1": {"name": "variable.language.string.identifier.yara"}, |
| 448 | + "2": {"name": "variable.other.string.identifier.yara"}, |
| 449 | + "3": {"name": "string.interpolated.string.identifier.yara"} |
| 450 | + } |
422 | 451 | },
|
423 | 452 | "regexp-strings": {
|
424 | 453 | "name": "string.regexp.yara",
|
|
565 | 594 | ]
|
566 | 595 | },
|
567 | 596 | "regexp-parentheses": {
|
568 |
| - "begin": "\\(", |
569 |
| - "end": "(\\)|(?=\"))|((?=(?<!\\\\)\\n))", |
| 597 | + "begin": "(\\()([+*?])?", |
| 598 | + "end": "(\\)|(?=/))|((?=(?<!\\\\)\\n))", |
570 | 599 | "beginCaptures": {
|
571 |
| - "0": {"name": "punctuation.parenthesis.begin.regexp support.other.parenthesis.regexp"} |
| 600 | + "1": {"name": "punctuation.parenthesis.begin.regexp support.other.parenthesis.regexp"}, |
| 601 | + "2": {"name": "invalid.illegal.group.construct.regexp"} |
572 | 602 | },
|
573 | 603 | "endCaptures": {
|
574 | 604 | "1": {"name": "punctuation.parenthesis.end.regexp support.other.parenthesis.regexp"},
|
|
644 | 674 | "name":"constant.numeric.hex.yara",
|
645 | 675 | "match": "\\b(0x)[0-9A-Fa-f]+\\b",
|
646 | 676 | "captures": {
|
647 |
| - "1": {"name": "storage.type.number.yara"} |
| 677 | + "1": {"name": "storage.modifier.number.yara"} |
648 | 678 | }
|
649 | 679 | },
|
650 | 680 | {
|
|
708 | 738 | [ "/", "/" ],
|
709 | 739 | [ "(", ")" ],
|
710 | 740 | [ "{", "}" ],
|
711 |
| - [ "[", "]" ], |
712 |
| - [ "/*", "*/" ] |
| 741 | + [ "[", "]" ] |
713 | 742 | ]
|
714 | 743 | }
|
0 commit comments