123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557 |
- /*---------------------------------------------------------------------------------------------
- * Copyright (c) Microsoft Corporation. All rights reserved.
- * Licensed under the MIT License. See License.txt in the project root for license information.
- *--------------------------------------------------------------------------------------------*/
- 'use strict';
- import { testTokenization } from './testRunner';
- testTokenization('mysql', [
- // Comments
- [{
- line: '-- a comment',
- tokens: [
- { startIndex: 0, type: 'comment.sql' }
- ]
- }],
- [{
- line: '---sticky -- comment',
- tokens: [
- { startIndex: 0, type: 'comment.sql' }
- ]
- }],
- // [{
- // line: '-almost a comment',
- // tokens: [
- // { startIndex: 0, type: 'operator.sql' },
- // { startIndex: 1, type: 'identifier.sql' },
- // { startIndex: 7, type: 'white.sql' },
- // { startIndex: 8, type: 'identifier.sql' },
- // { startIndex: 9, type: 'white.sql' },
- // { startIndex: 10, type: 'identifier.sql' }
- // ]
- // }],
- [{
- line: '/* a full line comment */',
- tokens: [
- { startIndex: 0, type: 'comment.quote.sql' },
- { startIndex: 2, type: 'comment.sql' },
- { startIndex: 23, type: 'comment.quote.sql' }
- ]
- }],
- [{
- line: '/* /// *** /// */',
- tokens: [
- { startIndex: 0, type: 'comment.quote.sql' },
- { startIndex: 2, type: 'comment.sql' },
- { startIndex: 15, type: 'comment.quote.sql' }
- ]
- }],
- [{
- line: '# comment',
- tokens: [
- { startIndex: 0, type: 'comment.sql' }
- ]
- }],
- [{
- line: 'declare @x int = /* a simple comment */ 1;',
- tokens: [
- { startIndex: 0, type: 'keyword.sql' },
- { startIndex: 7, type: 'white.sql' },
- { startIndex: 8, type: 'identifier.sql' },
- { startIndex: 10, type: 'white.sql' },
- { startIndex: 11, type: 'keyword.sql' },
- { startIndex: 14, type: 'white.sql' },
- { startIndex: 15, type: 'operator.sql' },
- { startIndex: 16, type: 'white.sql' },
- { startIndex: 17, type: 'comment.quote.sql' },
- { startIndex: 19, type: 'comment.sql' },
- { startIndex: 37, type: 'comment.quote.sql' },
- { startIndex: 39, type: 'white.sql' },
- { startIndex: 40, type: 'number.sql' },
- { startIndex: 41, type: 'delimiter.sql' }
- ]
- }],
- // Not supporting nested comments, as nested comments seem to not be standard?
- // i.e. http://stackoverflow.com/questions/728172/are-there-multiline-comment-delimiters-in-sql-that-are-vendor-agnostic
- [{
- line: '@x=/* a /* nested comment 1*/;',
- tokens: [
- { startIndex: 0, type: 'identifier.sql' },
- { startIndex: 2, type: 'operator.sql' },
- { startIndex: 3, type: 'comment.quote.sql' },
- { startIndex: 5, type: 'comment.sql' },
- { startIndex: 28, type: 'comment.quote.sql' },
- { startIndex: 30, type: 'delimiter.sql' }
- ]
- }],
- [{
- line: '@x=/* another comment */ 1*/;',
- tokens: [
- { startIndex: 0, type: 'identifier.sql' },
- { startIndex: 2, type: 'operator.sql' },
- { startIndex: 3, type: 'comment.quote.sql' },
- { startIndex: 5, type: 'comment.sql' },
- { startIndex: 22, type: 'comment.quote.sql' },
- { startIndex: 24, type: 'white.sql' },
- { startIndex: 25, type: 'number.sql' },
- { startIndex: 26, type: 'operator.sql' },
- { startIndex: 28, type: 'delimiter.sql' }
- ]
- }],
- [{
- line: '@x=/*/;',
- tokens: [
- { startIndex: 0, type: 'identifier.sql' },
- { startIndex: 2, type: 'operator.sql' },
- { startIndex: 3, type: 'comment.quote.sql' },
- { startIndex: 5, type: 'comment.sql' }
- ]
- }],
- // Numbers
- [{
- line: '123',
- tokens: [
- { startIndex: 0, type: 'number.sql' }
- ]
- }],
- [{
- line: '-123',
- tokens: [
- { startIndex: 0, type: 'operator.sql' },
- { startIndex: 1, type: 'number.sql' }
- ]
- }],
- [{
- line: '0xaBc123',
- tokens: [
- { startIndex: 0, type: 'number.sql' }
- ]
- }],
- [{
- line: '0XaBc123',
- tokens: [
- { startIndex: 0, type: 'number.sql' }
- ]
- }],
- [{
- line: '0x',
- tokens: [
- { startIndex: 0, type: 'number.sql' }
- ]
- }],
- [{
- line: '0x0',
- tokens: [
- { startIndex: 0, type: 'number.sql' }
- ]
- }],
- [{
- line: '0xAB_CD',
- tokens: [
- { startIndex: 0, type: 'number.sql' },
- { startIndex: 4, type: 'identifier.sql' }
- ]
- }],
- [{
- line: '$',
- tokens: [
- { startIndex: 0, type: 'number.sql' }
- ]
- }],
- [{
- line: '$-123',
- tokens: [
- { startIndex: 0, type: 'number.sql' }
- ]
- }],
- [{
- line: '$-+-123',
- tokens: [
- { startIndex: 0, type: 'number.sql' }
- ]
- }],
- [{
- line: '$123.5678',
- tokens: [
- { startIndex: 0, type: 'number.sql' }
- ]
- }],
- [{
- line: '$0.99',
- tokens: [
- { startIndex: 0, type: 'number.sql' }
- ]
- }],
- [{
- line: '$.99',
- tokens: [
- { startIndex: 0, type: 'number.sql' }
- ]
- }],
- [{
- line: '$99.',
- tokens: [
- { startIndex: 0, type: 'number.sql' }
- ]
- }],
- [{
- line: '$0.',
- tokens: [
- { startIndex: 0, type: 'number.sql' }
- ]
- }],
- [{
- line: '$.0',
- tokens: [
- { startIndex: 0, type: 'number.sql' }
- ]
- }],
- [{
- line: '.',
- tokens: [
- { startIndex: 0, type: 'delimiter.sql' }
- ]
- }],
- [{
- line: '123',
- tokens: [
- { startIndex: 0, type: 'number.sql' }
- ]
- }],
- [{
- line: '123.5678',
- tokens: [
- { startIndex: 0, type: 'number.sql' }
- ]
- }],
- [{
- line: '0.99',
- tokens: [
- { startIndex: 0, type: 'number.sql' }
- ]
- }],
- [{
- line: '.99',
- tokens: [
- { startIndex: 0, type: 'number.sql' }
- ]
- }],
- [{
- line: '99.',
- tokens: [
- { startIndex: 0, type: 'number.sql' }
- ]
- }],
- [{
- line: '0.',
- tokens: [
- { startIndex: 0, type: 'number.sql' }
- ]
- }],
- [{
- line: '.0',
- tokens: [
- { startIndex: 0, type: 'number.sql' }
- ]
- }],
- [{
- line: '1E-2',
- tokens: [
- { startIndex: 0, type: 'number.sql' }
- ]
- }],
- [{
- line: '1E+2',
- tokens: [
- { startIndex: 0, type: 'number.sql' }
- ]
- }],
- [{
- line: '1E2',
- tokens: [
- { startIndex: 0, type: 'number.sql' }
- ]
- }],
- [{
- line: '0.1E2',
- tokens: [
- { startIndex: 0, type: 'number.sql' }
- ]
- }],
- [{
- line: '1.E2',
- tokens: [
- { startIndex: 0, type: 'number.sql' }
- ]
- }],
- [{
- line: '.1E2',
- tokens: [
- { startIndex: 0, type: 'number.sql' }
- ]
- }],
- // Identifiers
- [{
- line: 'declare `abc 321`;',
- tokens: [
- { startIndex: 0, type: 'keyword.sql' },
- { startIndex: 7, type: 'white.sql' },
- { startIndex: 8, type: 'identifier.quote.sql' },
- { startIndex: 9, type: 'identifier.sql' },
- { startIndex: 16, type: 'identifier.quote.sql' },
- { startIndex: 17, type: 'delimiter.sql' }
- ]
- }],
- [{
- line: '`abc`` 321 `` xyz`',
- tokens: [
- { startIndex: 0, type: 'identifier.quote.sql' },
- { startIndex: 1, type: 'identifier.sql' },
- { startIndex: 17, type: 'identifier.quote.sql' }
- ]
- }],
- [{
- line: '`abc',
- tokens: [
- { startIndex: 0, type: 'identifier.quote.sql' },
- { startIndex: 1, type: 'identifier.sql' }
- ]
- }],
- [{
- line: 'declare `abc 321`;',
- tokens: [
- { startIndex: 0, type: 'keyword.sql' },
- { startIndex: 7, type: 'white.sql' },
- { startIndex: 8, type: 'identifier.quote.sql' },
- { startIndex: 9, type: 'identifier.sql' },
- { startIndex: 16, type: 'identifier.quote.sql' },
- { startIndex: 17, type: 'delimiter.sql' }
- ]
- }],
- [{
- line: '`abc`` 321 `` xyz`',
- tokens: [
- { startIndex: 0, type: 'identifier.quote.sql' },
- { startIndex: 1, type: 'identifier.sql' },
- { startIndex: 17, type: 'identifier.quote.sql' }
- ]
- }],
- [{
- line: '`abc',
- tokens: [
- { startIndex: 0, type: 'identifier.quote.sql' },
- { startIndex: 1, type: 'identifier.sql' }
- ]
- }],
- [{
- line: 'int',
- tokens: [
- { startIndex: 0, type: 'keyword.sql' }
- ]
- }],
- [{
- line: '`int`',
- tokens: [
- { startIndex: 0, type: 'identifier.quote.sql' },
- { startIndex: 1, type: 'identifier.sql' },
- { startIndex: 4, type: 'identifier.quote.sql' }
- ]
- }],
- // Strings
- [{
- line: 'declare @x=\'a string\';',
- tokens: [
- { startIndex: 0, type: 'keyword.sql' },
- { startIndex: 7, type: 'white.sql' },
- { startIndex: 8, type: 'identifier.sql' },
- { startIndex: 10, type: 'operator.sql' },
- { startIndex: 11, type: 'string.sql' },
- { startIndex: 21, type: 'delimiter.sql' }
- ]
- }],
- [{
- line: 'declare @x="a string";',
- tokens: [
- { startIndex: 0, type: 'keyword.sql' },
- { startIndex: 7, type: 'white.sql' },
- { startIndex: 8, type: 'identifier.sql' },
- { startIndex: 10, type: 'operator.sql' },
- { startIndex: 11, type: 'string.double.sql' },
- { startIndex: 21, type: 'delimiter.sql' }
- ]
- }],
- [{
- line: '\'a \'\' string with quotes\'',
- tokens: [
- { startIndex: 0, type: 'string.sql' },
- ]
- }],
- [{
- line: '"a "" string with quotes"',
- tokens: [
- { startIndex: 0, type: 'string.double.sql' },
- ]
- }],
- [{
- line: '\'a " string with quotes\'',
- tokens: [
- { startIndex: 0, type: 'string.sql' },
- ]
- }],
- [{
- line: '"a ` string with quotes"',
- tokens: [
- { startIndex: 0, type: 'string.double.sql' },
- ]
- }],
- [{
- line: '\'a -- string with comment\'',
- tokens: [
- { startIndex: 0, type: 'string.sql' },
- ]
- }],
- [{
- line: '"a -- string with comment"',
- tokens: [
- { startIndex: 0, type: 'string.double.sql' },
- ]
- }],
- [{
- line: '\'a endless string',
- tokens: [
- { startIndex: 0, type: 'string.sql' },
- ]
- }],
- [{
- line: '"a endless string',
- tokens: [
- { startIndex: 0, type: 'string.double.sql' },
- ]
- }],
- // Operators
- [{
- line: 'SET @x=@x+1',
- tokens: [
- { startIndex: 0, type: 'keyword.sql' },
- { startIndex: 3, type: 'white.sql' },
- { startIndex: 4, type: 'identifier.sql' },
- { startIndex: 6, type: 'operator.sql' },
- { startIndex: 7, type: 'identifier.sql' },
- { startIndex: 9, type: 'operator.sql' },
- { startIndex: 10, type: 'number.sql' }
- ]
- }],
- [{
- line: '@x^=@x',
- tokens: [
- { startIndex: 0, type: 'identifier.sql' },
- { startIndex: 2, type: 'operator.sql' },
- { startIndex: 4, type: 'identifier.sql' }
- ]
- }],
- [{
- line: 'WHERE x IS NOT NULL',
- tokens: [
- { startIndex: 0, type: 'keyword.sql' },
- { startIndex: 5, type: 'white.sql' },
- { startIndex: 6, type: 'identifier.sql' },
- { startIndex: 7, type: 'white.sql' },
- { startIndex: 8, type: 'operator.sql' },
- { startIndex: 10, type: 'white.sql' },
- { startIndex: 11, type: 'operator.sql' },
- { startIndex: 14, type: 'white.sql' },
- { startIndex: 15, type: 'operator.sql' }
- ]
- }],
- [{
- line: 'SELECT * FROM MyTable WHERE MyColumn IN (1,2)',
- tokens: [
- { startIndex: 0, type: 'keyword.sql' },
- { startIndex: 6, type: 'white.sql' },
- { startIndex: 7, type: 'operator.sql' },
- { startIndex: 8, type: 'white.sql' },
- { startIndex: 9, type: 'keyword.sql' },
- { startIndex: 13, type: 'white.sql' },
- { startIndex: 14, type: 'identifier.sql' },
- { startIndex: 17, type: 'delimiter.sql' },
- { startIndex: 18, type: 'identifier.sql' },
- { startIndex: 25, type: 'white.sql' },
- { startIndex: 26, type: 'keyword.sql' },
- { startIndex: 31, type: 'white.sql' },
- { startIndex: 32, type: 'identifier.sql' },
- { startIndex: 40, type: 'white.sql' },
- { startIndex: 41, type: 'operator.sql' },
- { startIndex: 43, type: 'white.sql' },
- { startIndex: 44, type: 'delimiter.parenthesis.sql' },
- { startIndex: 45, type: 'number.sql' },
- { startIndex: 46, type: 'delimiter.sql' },
- { startIndex: 47, type: 'number.sql' },
- { startIndex: 48, type: 'delimiter.parenthesis.sql' }
- ]
- }]
- ]);
|