mirror of
https://github.com/microsoft/monaco-editor.git
synced 2025-12-22 22:02:55 +01:00
Merge pull request #46 from spahnke/regex-flags
Improve tokenization of regular expressions
This commit is contained in:
commit
66b5497f3c
3 changed files with 69 additions and 3 deletions
|
|
@ -446,6 +446,39 @@ testTokenization('javascript', [
|
|||
]
|
||||
}],
|
||||
|
||||
[{
|
||||
line: '/foo/',
|
||||
tokens: [
|
||||
{ startIndex: 0, type: 'regexp.js' }
|
||||
]
|
||||
}],
|
||||
|
||||
[{
|
||||
line: '/foo/g',
|
||||
tokens: [
|
||||
{ startIndex: 0, type: 'regexp.js' },
|
||||
{ startIndex: 5, type: 'keyword.other.js' }
|
||||
]
|
||||
}],
|
||||
|
||||
[{
|
||||
line: '/foo/gimsuy',
|
||||
tokens: [
|
||||
{ startIndex: 0, type: 'regexp.js' },
|
||||
{ startIndex: 5, type: 'keyword.other.js' }
|
||||
]
|
||||
}],
|
||||
|
||||
[{
|
||||
line: '/foo/q', // invalid flag
|
||||
tokens: [
|
||||
{ startIndex: 0, type: 'delimiter.js' },
|
||||
{ startIndex: 1, type: 'identifier.js' },
|
||||
{ startIndex: 4, type: 'delimiter.js' },
|
||||
{ startIndex: 5, type: 'identifier.js' }
|
||||
]
|
||||
}],
|
||||
|
||||
[{
|
||||
line: 'x = 1 + f(2 / 3, /foo/)',
|
||||
tokens: [
|
||||
|
|
|
|||
|
|
@ -446,6 +446,39 @@ testTokenization('typescript', [
|
|||
]
|
||||
}],
|
||||
|
||||
[{
|
||||
line: '/foo/',
|
||||
tokens: [
|
||||
{ startIndex: 0, type: 'regexp.ts' }
|
||||
]
|
||||
}],
|
||||
|
||||
[{
|
||||
line: '/foo/g',
|
||||
tokens: [
|
||||
{ startIndex: 0, type: 'regexp.ts' },
|
||||
{ startIndex: 5, type: 'keyword.other.ts' }
|
||||
]
|
||||
}],
|
||||
|
||||
[{
|
||||
line: '/foo/gimsuy',
|
||||
tokens: [
|
||||
{ startIndex: 0, type: 'regexp.ts' },
|
||||
{ startIndex: 5, type: 'keyword.other.ts' }
|
||||
]
|
||||
}],
|
||||
|
||||
[{
|
||||
line: '/foo/q', // invalid flag
|
||||
tokens: [
|
||||
{ startIndex: 0, type: 'delimiter.ts' },
|
||||
{ startIndex: 1, type: 'identifier.ts' },
|
||||
{ startIndex: 4, type: 'delimiter.ts' },
|
||||
{ startIndex: 5, type: 'identifier.ts' }
|
||||
]
|
||||
}],
|
||||
|
||||
[{
|
||||
line: 'x = 1 + f(2 / 3, /foo/)',
|
||||
tokens: [
|
||||
|
|
|
|||
|
|
@ -130,7 +130,7 @@ export const language = {
|
|||
{ include: '@whitespace' },
|
||||
|
||||
// regular expression: ensure it is terminated before beginning (otherwise it is an opeator)
|
||||
[/\/(?=([^\\\/]|\\.)+\/([gimuy]*)(\s*)(\.|;|\/|,|\)|\]|\}|$))/, { token: 'regexp', bracket: '@open', next: '@regexp' }],
|
||||
[/\/(?=([^\\\/]|\\.)+\/([gimsuy]*)(\s*)(\.|;|\/|,|\)|\]|\}|$))/, { token: 'regexp', bracket: '@open', next: '@regexp' }],
|
||||
|
||||
// delimiters and operators
|
||||
[/[()\[\]]/, '@brackets'],
|
||||
|
|
@ -190,7 +190,7 @@ export const language = {
|
|||
[/[^\\\/]/, 'regexp'],
|
||||
[/@regexpesc/, 'regexp.escape'],
|
||||
[/\\\./, 'regexp.invalid'],
|
||||
['/', { token: 'regexp', bracket: '@close' }, '@pop'],
|
||||
[/(\/)([gimsuy]*)/, [{ token: 'regexp', bracket: '@close', next: '@pop' }, 'keyword.other']],
|
||||
],
|
||||
|
||||
regexrange: [
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue