oberon07.js 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338
  1. CodeMirror.defineMode("oberon07", function () {
  2. var CSS_KEYWORD = 'keyword', CSS_ATOM = 'atom',
  3. CSS_NUMBER = 'number', CSS_DEF = 'def',
  4. CSS_VARIABLE = 'variable', CSS_VARIABLE_2 = 'variable-2',
  5. CSS_VARIABLE_3 = 'variable-3', CSS_PROPERTY = 'property',
  6. CSS_OPERATOR = 'operator', CSS_COMMENT = 'comment',
  7. CSS_STRING = 'string', CSS_STRING_2 = 'string-2',
  8. CSS_META = 'meta', CSS_ERROR = 'error',
  9. CSS_QUALIFIER = 'qualifier', CSS_BUILTIN = 'builtin',
  10. CSS_BRACKET = 'bracket', CSS_TAG = 'tag',
  11. CSS_ATTRIBUTE = 'attribute', CSS_HEADER = 'header',
  12. CSS_QUOTE = 'quote', CSS_HR = 'hr',
  13. CSS_LINK = 'link',
  14. ED_DEF = CSS_DEF, ED_TYPE = CSS_ATOM,
  15. ED_CHAR = CSS_STRING_2, ED_SYSTEM = CSS_META,
  16. ED_IDENT = CSS_VARIABLE, ED_ERROR = CSS_ERROR,
  17. ED_STRING = CSS_STRING, ED_COMMENT = CSS_COMMENT,
  18. ED_BRACKET = CSS_BRACKET, ED_KEYWORD = CSS_KEYWORD,
  19. ED_OPERATOR = CSS_OPERATOR, ED_QUALIFIER = CSS_QUALIFIER,
  20. OBJ_KEYWORD = 'keyword',
  21. OBJ_PREDEFINED = 'predefined',
  22. OBJ_SYSTEM = 'system',
  23. OBERON = (function () {
  24. var _symbols = {
  25. NULL: 0, TIMES: 1, SLASH: 2, DIV: 3, MOD: 4,
  26. AND: 5, PLUS: 6, MINUS: 7, OR: 8, EQL: 9,
  27. NEQ: 10, LSS: 11, LEQ: 12, GTR: 13, GEQ: 14,
  28. IN: 15, IS: 16, ARROW: 17, PERIOD: 18, COMMA: 19,
  29. COLON: 20, UPTO: 21, RPAREN: 22, RBRAK: 23, RBRACE: 24,
  30. OF: 25, THEN: 26, DO: 27, TO: 28, BY: 29,
  31. LPAREN: 30, LBRAK: 31, LBRACE: 32, NOT: 33, BECOMES: 34,
  32. NUMBER: 35, NIL: 36, TRUE: 37, FALSE: 38, STRING: 39,
  33. IDENT: 40, SEMICOLON: 41, BAR: 42, END: 43, ELSE: 44,
  34. ELSIF: 45, UNTIL: 46, IF: 47, CASE: 48, WHILE: 49,
  35. REPEAT: 50, FOR: 51, LOOP: 52, WITH: 53, EXIT: 54,
  36. RETURN: 55, ARRAY: 56, OBJECT: 57, RECORD: 58, POINTER: 59,
  37. BEGIN: 60, CODE: 61, CONST: 62, TYPE: 63, VAR: 64,
  38. PROCEDURE: 65, IMPORT: 66, MODULE: 67, EOF: 68, ERROR: 69
  39. },
  40. _words = {
  41. 'ABS' : { sym: _symbols.IDENT, type: OBJ_PREDEFINED, name: 'ABS', css: ED_DEF },
  42. 'ASR' : { sym: _symbols.IDENT, type: OBJ_PREDEFINED, name: 'ASR', css: ED_DEF },
  43. 'ASSERT': { sym: _symbols.IDENT, type: OBJ_PREDEFINED, name: 'ASSERT', css: ED_DEF },
  44. 'CHR' : { sym: _symbols.IDENT, type: OBJ_PREDEFINED, name: 'CHR', css: ED_DEF },
  45. 'COPY' : { sym: _symbols.IDENT, type: OBJ_PREDEFINED, name: 'COPY', css: ED_DEF },
  46. 'DEC' : { sym: _symbols.IDENT, type: OBJ_PREDEFINED, name: 'DEC', css: ED_DEF },
  47. 'EXCL' : { sym: _symbols.IDENT, type: OBJ_PREDEFINED, name: 'EXCL', css: ED_DEF },
  48. 'FLOOR' : { sym: _symbols.IDENT, type: OBJ_PREDEFINED, name: 'FLOOR', css: ED_DEF },
  49. 'FLT' : { sym: _symbols.IDENT, type: OBJ_PREDEFINED, name: 'FLT', css: ED_DEF },
  50. 'INC' : { sym: _symbols.IDENT, type: OBJ_PREDEFINED, name: 'INC', css: ED_DEF },
  51. 'INCL' : { sym: _symbols.IDENT, type: OBJ_PREDEFINED, name: 'INCL', css: ED_DEF },
  52. 'LEN' : { sym: _symbols.IDENT, type: OBJ_PREDEFINED, name: 'LEN', css: ED_DEF },
  53. 'LSL' : { sym: _symbols.IDENT, type: OBJ_PREDEFINED, name: 'LSL', css: ED_DEF },
  54. 'LONG' : { sym: _symbols.IDENT, type: OBJ_PREDEFINED, name: 'LONG', css: ED_DEF },
  55. 'NEW' : { sym: _symbols.IDENT, type: OBJ_PREDEFINED, name: 'NEW', css: ED_DEF },
  56. 'ODD' : { sym: _symbols.IDENT, type: OBJ_PREDEFINED, name: 'ODD', css: ED_DEF },
  57. 'ORD' : { sym: _symbols.IDENT, type: OBJ_PREDEFINED, name: 'ORD', css: ED_DEF },
  58. 'PACK' : { sym: _symbols.IDENT, type: OBJ_PREDEFINED, name: 'PACK', css: ED_DEF },
  59. 'ROR' : { sym: _symbols.IDENT, type: OBJ_PREDEFINED, name: 'ROR', css: ED_DEF },
  60. 'SHORT' : { sym: _symbols.IDENT, type: OBJ_PREDEFINED, name: 'SHORT', css: ED_DEF },
  61. 'UNPK' : { sym: _symbols.IDENT, type: OBJ_PREDEFINED, name: 'UNPK', css: ED_DEF },
  62. 'BOOLEAN' : { sym: _symbols.IDENT, type: OBJ_PREDEFINED, name: 'BOOLEAN', css: ED_TYPE },
  63. 'CHAR' : { sym: _symbols.IDENT, type: OBJ_PREDEFINED, name: 'CHAR', css: ED_TYPE },
  64. 'INTEGER' : { sym: _symbols.IDENT, type: OBJ_PREDEFINED, name: 'INTEGER', css: ED_TYPE },
  65. 'LONGREAL': { sym: _symbols.IDENT, type: OBJ_PREDEFINED, name: 'LONGREAL', css: ED_TYPE },
  66. 'REAL' : { sym: _symbols.IDENT, type: OBJ_PREDEFINED, name: 'REAL', css: ED_TYPE },
  67. 'SET' : { sym: _symbols.IDENT, type: OBJ_PREDEFINED, name: 'SET', css: ED_TYPE },
  68. 'ADR' : { sym: _symbols.IDENT, type: OBJ_SYSTEM, name: 'ADR', css: ED_SYSTEM },
  69. 'SIZE': { sym: _symbols.IDENT, type: OBJ_SYSTEM, name: 'SIZE', css: ED_SYSTEM },
  70. 'BIT' : { sym: _symbols.IDENT, type: OBJ_SYSTEM, name: 'BIT', css: ED_SYSTEM },
  71. 'GET' : { sym: _symbols.IDENT, type: OBJ_SYSTEM, name: 'GET', css: ED_SYSTEM },
  72. 'PUT' : { sym: _symbols.IDENT, type: OBJ_SYSTEM, name: 'PUT', css: ED_SYSTEM },
  73. 'ARRAY' : { sym: _symbols.ARRAY, type: OBJ_KEYWORD, name: 'ARRAY', css: ED_KEYWORD },
  74. 'BEGIN' : { sym: _symbols.BEGIN, type: OBJ_KEYWORD, name: 'BEGIN', css: ED_KEYWORD },
  75. 'BY' : { sym: _symbols.BY, type: OBJ_KEYWORD, name: 'BY', css: ED_KEYWORD },
  76. 'CASE' : { sym: _symbols.CASE, type: OBJ_KEYWORD, name: 'CASE', css: ED_KEYWORD },
  77. 'CONST' : { sym: _symbols.CONST, type: OBJ_KEYWORD, name: 'CONST', css: ED_KEYWORD },
  78. 'DIV' : { sym: _symbols.DIV, type: OBJ_KEYWORD, name: 'DIV', css: ED_KEYWORD },
  79. 'DO' : { sym: _symbols.DO, type: OBJ_KEYWORD, name: 'DO', css: ED_KEYWORD },
  80. 'ELSE' : { sym: _symbols.ELSE, type: OBJ_KEYWORD, name: 'ELSE', css: ED_KEYWORD },
  81. 'ELSIF' : { sym: _symbols.ELSIF, type: OBJ_KEYWORD, name: 'ELSIF', css: ED_KEYWORD },
  82. 'END' : { sym: _symbols.END, type: OBJ_KEYWORD, name: 'END', css: ED_KEYWORD },
  83. 'FALSE' : { sym: _symbols.FALSE, type: OBJ_KEYWORD, name: 'FALSE', css: ED_KEYWORD },
  84. 'FOR' : { sym: _symbols.FOR, type: OBJ_KEYWORD, name: 'FOR', css: ED_KEYWORD },
  85. 'IF' : { sym: _symbols.IF, type: OBJ_KEYWORD, name: 'IF', css: ED_KEYWORD },
  86. 'IMPORT' : { sym: _symbols.IMPORT, type: OBJ_KEYWORD, name: 'IMPORT', css: ED_KEYWORD },
  87. 'IN' : { sym: _symbols.IN, type: OBJ_KEYWORD, name: 'IN', css: ED_KEYWORD },
  88. 'IS' : { sym: _symbols.IS, type: OBJ_KEYWORD, name: 'IS', css: ED_KEYWORD },
  89. 'MOD' : { sym: _symbols.MOD, type: OBJ_KEYWORD, name: 'MOD', css: ED_KEYWORD },
  90. 'MODULE' : { sym: _symbols.MODULE, type: OBJ_KEYWORD, name: 'MODULE', css: ED_KEYWORD },
  91. 'NIL' : { sym: _symbols.NIL, type: OBJ_KEYWORD, name: 'NIL', css: ED_KEYWORD },
  92. 'OF' : { sym: _symbols.OF, type: OBJ_KEYWORD, name: 'OF', css: ED_KEYWORD },
  93. 'OR' : { sym: _symbols.OR, type: OBJ_KEYWORD, name: 'OR', css: ED_KEYWORD },
  94. 'POINTER' : { sym: _symbols.POINTER, type: OBJ_KEYWORD, name: 'POINTER', css: ED_KEYWORD },
  95. 'PROCEDURE': { sym: _symbols.PROCEDURE, type: OBJ_KEYWORD, name: 'PROCEDURE', css: ED_KEYWORD },
  96. 'RECORD' : { sym: _symbols.RECORD, type: OBJ_KEYWORD, name: 'RECORD', css: ED_KEYWORD },
  97. 'REPEAT' : { sym: _symbols.REPEAT, type: OBJ_KEYWORD, name: 'REPEAT', css: ED_KEYWORD },
  98. 'RETURN' : { sym: _symbols.RETURN, type: OBJ_KEYWORD, name: 'RETURN', css: ED_KEYWORD },
  99. 'THEN' : { sym: _symbols.THEN, type: OBJ_KEYWORD, name: 'THEN', css: ED_KEYWORD },
  100. 'TO' : { sym: _symbols.TO, type: OBJ_KEYWORD, name: 'TO', css: ED_KEYWORD },
  101. 'TRUE' : { sym: _symbols.TRUE, type: OBJ_KEYWORD, name: 'TRUE', css: ED_KEYWORD },
  102. 'TYPE' : { sym: _symbols.TYPE, type: OBJ_KEYWORD, name: 'TYPE', css: ED_KEYWORD },
  103. 'UNTIL' : { sym: _symbols.UNTIL, type: OBJ_KEYWORD, name: 'UNIL', css: ED_KEYWORD },
  104. 'VAR' : { sym: _symbols.VAR, type: OBJ_KEYWORD, name: 'VAR', css: ED_KEYWORD },
  105. 'WHILE' : { sym: _symbols.WHILE, type: OBJ_KEYWORD, name: 'WHILE', css: ED_KEYWORD }
  106. };
  107. return {
  108. Symbol: _symbols,
  109. Words: _words,
  110. };
  111. })(),
  112. _words = OBERON.Words,
  113. _alphaREX = /[a-zA-Z_]/,
  114. _alphaDigitREX = /[0-9a-zA-Z_]/,
  115. _cyrREX = /[а-яА-Я]/
  116. _isAlpha = function (ch) {
  117. return _alphaREX.test(ch);
  118. },
  119. _isAlphaOrDigit = function (ch) {
  120. return _alphaDigitREX.test(ch);
  121. },
  122. _isCyr = function (ch) {
  123. return _cyrREX.test(ch);
  124. },
  125. _startState = function () {
  126. return {
  127. stack: [],
  128. state: null,
  129. ch: null,
  130. scope: 0,
  131. level: 0,
  132. error: null,
  133. name: null,
  134. };
  135. },
  136. _token = function (stream, state) {
  137. var _state = state.state;
  138. _ident = function (sym) {
  139. var _word,
  140. _token = ED_IDENT,
  141. _str = sym,
  142. _ch = stream.next();
  143. while (_ch && _isAlphaOrDigit(_ch) && !stream.eol()) {
  144. _str += _ch;
  145. _ch = stream.next();
  146. }
  147. if (_isAlphaOrDigit(_ch)) {
  148. _str += _ch;
  149. }
  150. state.name = _str;
  151. if (_ch === '.' || _ch === '[') {
  152. _token = ED_QUALIFIER;
  153. }
  154. _word = OBERON.Words[_str];
  155. if (_word) {
  156. switch (_word.name) {
  157. case 'BEGIN':
  158. case 'IF':
  159. case 'FOR':
  160. case 'WHILE':
  161. state.scope += 1;
  162. break;
  163. case 'END':
  164. state.scope -= state.scope > 0 ? 1 : 0;
  165. default:
  166. }
  167. _token = _word.css;
  168. }
  169. if (!stream.eol() || _ch === ")") {
  170. stream.backUp(1);
  171. }
  172. if (_ch === "'" || _isCyr(_ch)) {
  173. state.error = 'string.not.close';
  174. return ED_ERROR;
  175. }
  176. return _token;
  177. },
  178. _number = function () {},
  179. _string = function (sym) {
  180. var _str,
  181. _ch = stream.next();
  182. while (_ch && _ch != sym && !stream.eol()) {
  183. _str += _ch;
  184. _ch = stream.next();
  185. }
  186. if (stream.eol() && _ch != sym) {
  187. state.error = 'string.not.close';
  188. return ED_ERROR;
  189. }
  190. state.name = _str;
  191. return ED_STRING;
  192. },
  193. _comment = function () {
  194. var mode = '?',
  195. _ch;
  196. while (state.level > 0 && !stream.eol()) {
  197. _ch = stream.next();
  198. switch (_ch) {
  199. case '(':
  200. mode = '(';
  201. break;
  202. case '*':
  203. if (mode === '(') {
  204. state.level += 1;
  205. }
  206. mode = '*';
  207. break;
  208. case ')':
  209. if (mode === '*') {
  210. state.level -= 1;
  211. }
  212. mode = ')';
  213. break;
  214. default:
  215. mode = '?';
  216. }
  217. }
  218. return ED_COMMENT;
  219. },
  220. _ch = stream.next();
  221. if (state.level > 0) {
  222. return _comment();
  223. }
  224. if (_isAlpha(_ch)) {
  225. return _ident(_ch);
  226. }
  227. if (_isCyr(_ch)) {
  228. state.error = 'string.not.close';
  229. return ED_ERROR;
  230. }
  231. switch (_ch) {
  232. case '"':
  233. //case "'": for Oberon-07 not allowed
  234. return _string(_ch);
  235. case '[':
  236. case ']':
  237. case '{':
  238. case '}':
  239. case ')':
  240. return ED_BRACKET;
  241. case '(':
  242. if (stream.peek() === '*') {
  243. state.level += 1;
  244. return _comment();
  245. }
  246. return ED_BRACKET;
  247. case ':':
  248. if (stream.peek() === '=') {
  249. _ch = stream.next();
  250. return ED_KEYWORD;
  251. }
  252. return ED_OPERATOR;
  253. case '<':
  254. case '>':
  255. case '#':
  256. case '&':
  257. case '+':
  258. case '-':
  259. case '*':
  260. case '/':
  261. case '~':
  262. case '|':
  263. case '^':
  264. case ',':
  265. case ';':
  266. return ED_OPERATOR;
  267. }
  268. return null;
  269. },
  270. _indent = function (state, textAfter) {
  271. var word;
  272. if (textAfter) {
  273. word = textAfter.split(' ');
  274. if (word[0] === 'END') {
  275. state.scope -= state.scope > 0 ? 1 : 0;
  276. }
  277. }
  278. return state.scope;
  279. };
  280. // Interface
  281. return {
  282. startState: _startState,
  283. token: _token,
  284. indent: _indent,
  285. electricChars: null
  286. };
  287. });
  288. CodeMirror.defineMIME("text/x-oberon07", "oberon07");