coffee.js 8.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239
  1. /*---------------------------------------------------------------------------------------------
  2. * Copyright (c) Microsoft Corporation. All rights reserved.
  3. * Licensed under the MIT License. See License.txt in the project root for license information.
  4. *--------------------------------------------------------------------------------------------*/
  5. define('vs/basic-languages/coffee/coffee',["require", "exports"], function (require, exports) {
  6. "use strict";
  7. Object.defineProperty(exports, "__esModule", { value: true });
  8. exports.language = exports.conf = void 0;
  9. exports.conf = {
  10. wordPattern: /(-?\d*\.\d\w*)|([^\`\~\!\@\#%\^\&\*\(\)\=\$\-\+\[\{\]\}\\\|\;\:\'\"\,\.\<\>\/\?\s]+)/g,
  11. comments: {
  12. blockComment: ['###', '###'],
  13. lineComment: '#'
  14. },
  15. brackets: [
  16. ['{', '}'],
  17. ['[', ']'],
  18. ['(', ')']
  19. ],
  20. autoClosingPairs: [
  21. { open: '{', close: '}' },
  22. { open: '[', close: ']' },
  23. { open: '(', close: ')' },
  24. { open: '"', close: '"' },
  25. { open: "'", close: "'" }
  26. ],
  27. surroundingPairs: [
  28. { open: '{', close: '}' },
  29. { open: '[', close: ']' },
  30. { open: '(', close: ')' },
  31. { open: '"', close: '"' },
  32. { open: "'", close: "'" }
  33. ],
  34. folding: {
  35. markers: {
  36. start: new RegExp('^\\s*#region\\b'),
  37. end: new RegExp('^\\s*#endregion\\b')
  38. }
  39. }
  40. };
  41. exports.language = {
  42. defaultToken: '',
  43. ignoreCase: true,
  44. tokenPostfix: '.coffee',
  45. brackets: [
  46. { open: '{', close: '}', token: 'delimiter.curly' },
  47. { open: '[', close: ']', token: 'delimiter.square' },
  48. { open: '(', close: ')', token: 'delimiter.parenthesis' }
  49. ],
  50. regEx: /\/(?!\/\/)(?:[^\/\\]|\\.)*\/[igm]*/,
  51. keywords: [
  52. 'and',
  53. 'or',
  54. 'is',
  55. 'isnt',
  56. 'not',
  57. 'on',
  58. 'yes',
  59. '@',
  60. 'no',
  61. 'off',
  62. 'true',
  63. 'false',
  64. 'null',
  65. 'this',
  66. 'new',
  67. 'delete',
  68. 'typeof',
  69. 'in',
  70. 'instanceof',
  71. 'return',
  72. 'throw',
  73. 'break',
  74. 'continue',
  75. 'debugger',
  76. 'if',
  77. 'else',
  78. 'switch',
  79. 'for',
  80. 'while',
  81. 'do',
  82. 'try',
  83. 'catch',
  84. 'finally',
  85. 'class',
  86. 'extends',
  87. 'super',
  88. 'undefined',
  89. 'then',
  90. 'unless',
  91. 'until',
  92. 'loop',
  93. 'of',
  94. 'by',
  95. 'when'
  96. ],
  97. // we include these common regular expressions
  98. symbols: /[=><!~?&%|+\-*\/\^\.,\:]+/,
  99. escapes: /\\(?:[abfnrtv\\"'$]|x[0-9A-Fa-f]{1,4}|u[0-9A-Fa-f]{4}|U[0-9A-Fa-f]{8})/,
  100. // The main tokenizer for our languages
  101. tokenizer: {
  102. root: [
  103. // identifiers and keywords
  104. [/\@[a-zA-Z_]\w*/, 'variable.predefined'],
  105. [
  106. /[a-zA-Z_]\w*/,
  107. {
  108. cases: {
  109. this: 'variable.predefined',
  110. '@keywords': { token: 'keyword.$0' },
  111. '@default': ''
  112. }
  113. }
  114. ],
  115. // whitespace
  116. [/[ \t\r\n]+/, ''],
  117. // Comments
  118. [/###/, 'comment', '@comment'],
  119. [/#.*$/, 'comment'],
  120. // regular expressions
  121. ['///', { token: 'regexp', next: '@hereregexp' }],
  122. [/^(\s*)(@regEx)/, ['', 'regexp']],
  123. [/(\()(\s*)(@regEx)/, ['@brackets', '', 'regexp']],
  124. [/(\,)(\s*)(@regEx)/, ['delimiter', '', 'regexp']],
  125. [/(\=)(\s*)(@regEx)/, ['delimiter', '', 'regexp']],
  126. [/(\:)(\s*)(@regEx)/, ['delimiter', '', 'regexp']],
  127. [/(\[)(\s*)(@regEx)/, ['@brackets', '', 'regexp']],
  128. [/(\!)(\s*)(@regEx)/, ['delimiter', '', 'regexp']],
  129. [/(\&)(\s*)(@regEx)/, ['delimiter', '', 'regexp']],
  130. [/(\|)(\s*)(@regEx)/, ['delimiter', '', 'regexp']],
  131. [/(\?)(\s*)(@regEx)/, ['delimiter', '', 'regexp']],
  132. [/(\{)(\s*)(@regEx)/, ['@brackets', '', 'regexp']],
  133. [/(\;)(\s*)(@regEx)/, ['', '', 'regexp']],
  134. // delimiters
  135. [
  136. /}/,
  137. {
  138. cases: {
  139. '$S2==interpolatedstring': {
  140. token: 'string',
  141. next: '@pop'
  142. },
  143. '@default': '@brackets'
  144. }
  145. }
  146. ],
  147. [/[{}()\[\]]/, '@brackets'],
  148. [/@symbols/, 'delimiter'],
  149. // numbers
  150. [/\d+[eE]([\-+]?\d+)?/, 'number.float'],
  151. [/\d+\.\d+([eE][\-+]?\d+)?/, 'number.float'],
  152. [/0[xX][0-9a-fA-F]+/, 'number.hex'],
  153. [/0[0-7]+(?!\d)/, 'number.octal'],
  154. [/\d+/, 'number'],
  155. // delimiter: after number because of .\d floats
  156. [/[,.]/, 'delimiter'],
  157. // strings:
  158. [/"""/, 'string', '@herestring."""'],
  159. [/'''/, 'string', "@herestring.'''"],
  160. [
  161. /"/,
  162. {
  163. cases: {
  164. '@eos': 'string',
  165. '@default': { token: 'string', next: '@string."' }
  166. }
  167. }
  168. ],
  169. [
  170. /'/,
  171. {
  172. cases: {
  173. '@eos': 'string',
  174. '@default': { token: 'string', next: "@string.'" }
  175. }
  176. }
  177. ]
  178. ],
  179. string: [
  180. [/[^"'\#\\]+/, 'string'],
  181. [/@escapes/, 'string.escape'],
  182. [/\./, 'string.escape.invalid'],
  183. [/\./, 'string.escape.invalid'],
  184. [
  185. /#{/,
  186. {
  187. cases: {
  188. '$S2=="': {
  189. token: 'string',
  190. next: 'root.interpolatedstring'
  191. },
  192. '@default': 'string'
  193. }
  194. }
  195. ],
  196. [
  197. /["']/,
  198. {
  199. cases: {
  200. '$#==$S2': { token: 'string', next: '@pop' },
  201. '@default': 'string'
  202. }
  203. }
  204. ],
  205. [/#/, 'string']
  206. ],
  207. herestring: [
  208. [
  209. /("""|''')/,
  210. {
  211. cases: {
  212. '$1==$S2': { token: 'string', next: '@pop' },
  213. '@default': 'string'
  214. }
  215. }
  216. ],
  217. [/[^#\\'"]+/, 'string'],
  218. [/['"]+/, 'string'],
  219. [/@escapes/, 'string.escape'],
  220. [/\./, 'string.escape.invalid'],
  221. [/#{/, { token: 'string.quote', next: 'root.interpolatedstring' }],
  222. [/#/, 'string']
  223. ],
  224. comment: [
  225. [/[^#]+/, 'comment'],
  226. [/###/, 'comment', '@pop'],
  227. [/#/, 'comment']
  228. ],
  229. hereregexp: [
  230. [/[^\\\/#]+/, 'regexp'],
  231. [/\\./, 'regexp'],
  232. [/#.*$/, 'comment'],
  233. ['///[igm]*', { token: 'regexp', next: '@pop' }],
  234. [/\//, 'regexp']
  235. ]
  236. }
  237. };
  238. });