123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287 |
- /*---------------------------------------------------------------------------------------------
- * Copyright (c) Microsoft Corporation. All rights reserved.
- * Licensed under the MIT License. See License.txt in the project root for license information.
- *--------------------------------------------------------------------------------------------*/
- define(["require", "exports"], function (require, exports) {
- 'use strict';
- Object.defineProperty(exports, "__esModule", { value: true });
- exports.conf = {
- // the default separators except `@$`
- wordPattern: /(-?\d*\.\d\w*)|([^\`\~\!\#\%\^\&\*\(\)\-\=\+\[\{\]\}\\\|\;\:\'\"\,\.\<\>\/\?\s]+)/g,
- comments: {
- lineComment: '//',
- blockComment: ['/*', '*/'],
- },
- brackets: [
- ['{', '}'],
- ['[', ']'],
- ['(', ')'],
- ],
- autoClosingPairs: [
- { open: '{', close: '}' },
- { open: '[', close: ']' },
- { open: '(', close: ')' },
- { open: '"', close: '"' },
- { open: '\'', close: '\'' },
- ],
- surroundingPairs: [
- { open: '{', close: '}' },
- { open: '[', close: ']' },
- { open: '(', close: ')' },
- { open: '"', close: '"' },
- { open: '\'', close: '\'' },
- { open: '<', close: '>' },
- ],
- folding: {
- markers: {
- start: new RegExp("^\\s*//\\s*(?:(?:#?region\\b)|(?:<editor-fold\\b))"),
- end: new RegExp("^\\s*//\\s*(?:(?:#?endregion\\b)|(?:</editor-fold>))")
- }
- }
- };
- var keywords = [
- 'abstract',
- 'activate',
- 'and',
- 'any',
- 'array',
- 'as',
- 'asc',
- 'assert',
- 'autonomous',
- 'begin',
- 'bigdecimal',
- 'blob',
- 'boolean',
- 'break',
- 'bulk',
- 'by',
- 'case',
- 'cast',
- 'catch',
- 'char',
- 'class',
- 'collect',
- 'commit',
- 'const',
- 'continue',
- 'convertcurrency',
- 'decimal',
- 'default',
- 'delete',
- 'desc',
- 'do',
- 'double',
- 'else',
- 'end',
- 'enum',
- 'exception',
- 'exit',
- 'export',
- 'extends',
- 'false',
- 'final',
- 'finally',
- 'float',
- 'for',
- 'from',
- 'future',
- 'get',
- 'global',
- 'goto',
- 'group',
- 'having',
- 'hint',
- 'if',
- 'implements',
- 'import',
- 'in',
- 'inner',
- 'insert',
- 'instanceof',
- 'int',
- 'interface',
- 'into',
- 'join',
- 'last_90_days',
- 'last_month',
- 'last_n_days',
- 'last_week',
- 'like',
- 'limit',
- 'list',
- 'long',
- 'loop',
- 'map',
- 'merge',
- 'native',
- 'new',
- 'next_90_days',
- 'next_month',
- 'next_n_days',
- 'next_week',
- 'not',
- 'null',
- 'nulls',
- 'number',
- 'object',
- 'of',
- 'on',
- 'or',
- 'outer',
- 'override',
- 'package',
- 'parallel',
- 'pragma',
- 'private',
- 'protected',
- 'public',
- 'retrieve',
- 'return',
- 'returning',
- 'rollback',
- 'savepoint',
- 'search',
- 'select',
- 'set',
- 'short',
- 'sort',
- 'stat',
- 'static',
- 'strictfp',
- 'super',
- 'switch',
- 'synchronized',
- 'system',
- 'testmethod',
- 'then',
- 'this',
- 'this_month',
- 'this_week',
- 'throw',
- 'throws',
- 'today',
- 'tolabel',
- 'tomorrow',
- 'transaction',
- 'transient',
- 'trigger',
- 'true',
- 'try',
- 'type',
- 'undelete',
- 'update',
- 'upsert',
- 'using',
- 'virtual',
- 'void',
- 'volatile',
- 'webservice',
- 'when',
- 'where',
- 'while',
- 'yesterday'
- ];
- // create case variations of the keywords - apex is case insensitive, but we can't make the highlighter case insensitive
- // because we use a heuristic to assume that identifiers starting with an upper case letter are types.
- var uppercaseFirstLetter = function (lowercase) { return lowercase.charAt(0).toUpperCase() + lowercase.substr(1); };
- var keywordsWithCaseVariations = [];
- keywords.forEach(function (lowercase) {
- keywordsWithCaseVariations.push(lowercase);
- keywordsWithCaseVariations.push(lowercase.toUpperCase());
- keywordsWithCaseVariations.push(uppercaseFirstLetter(lowercase));
- });
- exports.language = {
- defaultToken: '',
- tokenPostfix: '.apex',
- keywords: keywordsWithCaseVariations,
- operators: [
- '=', '>', '<', '!', '~', '?', ':',
- '==', '<=', '>=', '!=', '&&', '||', '++', '--',
- '+', '-', '*', '/', '&', '|', '^', '%', '<<',
- '>>', '>>>', '+=', '-=', '*=', '/=', '&=', '|=',
- '^=', '%=', '<<=', '>>=', '>>>='
- ],
- // we include these common regular expressions
- symbols: /[=><!~?:&|+\-*\/\^%]+/,
- escapes: /\\(?:[abfnrtv\\"']|x[0-9A-Fa-f]{1,4}|u[0-9A-Fa-f]{4}|U[0-9A-Fa-f]{8})/,
- digits: /\d+(_+\d+)*/,
- octaldigits: /[0-7]+(_+[0-7]+)*/,
- binarydigits: /[0-1]+(_+[0-1]+)*/,
- hexdigits: /[[0-9a-fA-F]+(_+[0-9a-fA-F]+)*/,
- // The main tokenizer for our languages
- tokenizer: {
- root: [
- // identifiers and keywords
- [/[a-z_$][\w$]*/, {
- cases: {
- '@keywords': { token: 'keyword.$0' },
- '@default': 'identifier'
- }
- }],
- // assume that identifiers starting with an uppercase letter are types
- [/[A-Z][\w\$]*/, {
- cases: {
- '@keywords': { token: 'keyword.$0' },
- '@default': 'type.identifier'
- }
- }],
- // whitespace
- { include: '@whitespace' },
- // delimiters and operators
- [/[{}()\[\]]/, '@brackets'],
- [/[<>](?!@symbols)/, '@brackets'],
- [/@symbols/, {
- cases: {
- '@operators': 'delimiter',
- '@default': ''
- }
- }],
- // @ annotations.
- [/@\s*[a-zA-Z_\$][\w\$]*/, 'annotation'],
- // numbers
- [/(@digits)[eE]([\-+]?(@digits))?[fFdD]?/, 'number.float'],
- [/(@digits)\.(@digits)([eE][\-+]?(@digits))?[fFdD]?/, 'number.float'],
- [/(@digits)[fFdD]/, 'number.float'],
- [/(@digits)[lL]?/, 'number'],
- // delimiter: after number because of .\d floats
- [/[;,.]/, 'delimiter'],
- // strings
- [/"([^"\\]|\\.)*$/, 'string.invalid'],
- [/'([^'\\]|\\.)*$/, 'string.invalid'],
- [/"/, 'string', '@string."'],
- [/'/, 'string', '@string.\''],
- // characters
- [/'[^\\']'/, 'string'],
- [/(')(@escapes)(')/, ['string', 'string.escape', 'string']],
- [/'/, 'string.invalid']
- ],
- whitespace: [
- [/[ \t\r\n]+/, ''],
- [/\/\*\*(?!\/)/, 'comment.doc', '@apexdoc'],
- [/\/\*/, 'comment', '@comment'],
- [/\/\/.*$/, 'comment'],
- ],
- comment: [
- [/[^\/*]+/, 'comment'],
- // [/\/\*/, 'comment', '@push' ], // nested comment not allowed :-(
- // [/\/\*/, 'comment.invalid' ], // this breaks block comments in the shape of /* //*/
- [/\*\//, 'comment', '@pop'],
- [/[\/*]/, 'comment']
- ],
- //Identical copy of comment above, except for the addition of .doc
- apexdoc: [
- [/[^\/*]+/, 'comment.doc'],
- [/\*\//, 'comment.doc', '@pop'],
- [/[\/*]/, 'comment.doc']
- ],
- string: [
- [/[^\\"']+/, 'string'],
- [/@escapes/, 'string.escape'],
- [/\\./, 'string.escape.invalid'],
- [/["']/, { cases: { '$#==$S2': { token: 'string', next: '@pop' },
- '@default': 'string' } }]
- ],
- },
- };
- });
|