codemirror-rails 2.3 → 2.21

Sign up to get free protection for your applications and to get access to all the features.
Files changed (71) hide show
  1. data/README.md +0 -16
  2. data/codemirror-rails.gemspec +1 -1
  3. data/lib/codemirror/rails/version.rb +2 -2
  4. data/vendor/assets/javascripts/codemirror.js +323 -687
  5. data/vendor/assets/javascripts/codemirror/modes/clike.js +3 -40
  6. data/vendor/assets/javascripts/codemirror/modes/clojure.js +14 -14
  7. data/vendor/assets/javascripts/codemirror/modes/coffeescript.js +0 -6
  8. data/vendor/assets/javascripts/codemirror/modes/css.js +1 -1
  9. data/vendor/assets/javascripts/codemirror/modes/diff.js +5 -24
  10. data/vendor/assets/javascripts/codemirror/modes/gfm.js +4 -40
  11. data/vendor/assets/javascripts/codemirror/modes/go.js +22 -20
  12. data/vendor/assets/javascripts/codemirror/modes/htmlembedded.js +1 -1
  13. data/vendor/assets/javascripts/codemirror/modes/htmlmixed.js +2 -4
  14. data/vendor/assets/javascripts/codemirror/modes/javascript.js +7 -8
  15. data/vendor/assets/javascripts/codemirror/modes/less.js +54 -100
  16. data/vendor/assets/javascripts/codemirror/modes/markdown.js +49 -52
  17. data/vendor/assets/javascripts/codemirror/modes/pascal.js +46 -2
  18. data/vendor/assets/javascripts/codemirror/modes/perl.js +1 -1
  19. data/vendor/assets/javascripts/codemirror/modes/php.js +25 -54
  20. data/vendor/assets/javascripts/codemirror/modes/python.js +16 -14
  21. data/vendor/assets/javascripts/codemirror/modes/rpm-spec.js +1 -1
  22. data/vendor/assets/javascripts/codemirror/modes/rst.js +1 -1
  23. data/vendor/assets/javascripts/codemirror/modes/ruby.js +9 -4
  24. data/vendor/assets/javascripts/codemirror/modes/scheme.js +46 -74
  25. data/vendor/assets/javascripts/codemirror/modes/smalltalk.js +16 -16
  26. data/vendor/assets/javascripts/codemirror/modes/stex.js +6 -21
  27. data/vendor/assets/javascripts/codemirror/modes/tiddlywiki.js +45 -55
  28. data/vendor/assets/javascripts/codemirror/modes/xml.js +14 -79
  29. data/vendor/assets/javascripts/codemirror/{utils/overlay.js → overlay.js} +2 -3
  30. data/vendor/assets/javascripts/codemirror/runmode.js +27 -0
  31. data/vendor/assets/stylesheets/codemirror.css +2 -63
  32. data/vendor/assets/stylesheets/codemirror/modes/tiddlywiki.css +21 -14
  33. data/vendor/assets/stylesheets/codemirror/themes/eclipse.css +1 -1
  34. data/vendor/assets/stylesheets/codemirror/themes/elegant.css +2 -2
  35. data/vendor/assets/stylesheets/codemirror/themes/neat.css +3 -3
  36. data/vendor/assets/stylesheets/codemirror/themes/night.css +1 -1
  37. data/vendor/assets/stylesheets/codemirror/themes/rubyblue.css +2 -2
  38. metadata +6 -39
  39. data/vendor/assets/javascripts/codemirror/keymaps/emacs.js +0 -29
  40. data/vendor/assets/javascripts/codemirror/keymaps/vim.js +0 -766
  41. data/vendor/assets/javascripts/codemirror/modes/ecl.js +0 -203
  42. data/vendor/assets/javascripts/codemirror/modes/erlang.js +0 -251
  43. data/vendor/assets/javascripts/codemirror/modes/pig.js +0 -172
  44. data/vendor/assets/javascripts/codemirror/modes/properties.js +0 -63
  45. data/vendor/assets/javascripts/codemirror/modes/shell.js +0 -103
  46. data/vendor/assets/javascripts/codemirror/modes/smarty.js +0 -148
  47. data/vendor/assets/javascripts/codemirror/modes/tiki.js +0 -316
  48. data/vendor/assets/javascripts/codemirror/modes/vbscript.js +0 -26
  49. data/vendor/assets/javascripts/codemirror/modes/xquery.js +0 -448
  50. data/vendor/assets/javascripts/codemirror/utils/closetag.js +0 -146
  51. data/vendor/assets/javascripts/codemirror/utils/dialog.js +0 -63
  52. data/vendor/assets/javascripts/codemirror/utils/foldcode.js +0 -196
  53. data/vendor/assets/javascripts/codemirror/utils/formatting.js +0 -297
  54. data/vendor/assets/javascripts/codemirror/utils/javascript-hint.js +0 -134
  55. data/vendor/assets/javascripts/codemirror/utils/loadmode.js +0 -51
  56. data/vendor/assets/javascripts/codemirror/utils/match-highlighter.js +0 -44
  57. data/vendor/assets/javascripts/codemirror/utils/multiplex.js +0 -72
  58. data/vendor/assets/javascripts/codemirror/utils/pig-hint.js +0 -123
  59. data/vendor/assets/javascripts/codemirror/utils/runmode.js +0 -49
  60. data/vendor/assets/javascripts/codemirror/utils/search.js +0 -118
  61. data/vendor/assets/javascripts/codemirror/utils/searchcursor.js +0 -117
  62. data/vendor/assets/javascripts/codemirror/utils/simple-hint.js +0 -72
  63. data/vendor/assets/stylesheets/codemirror/modes/tiki.css +0 -26
  64. data/vendor/assets/stylesheets/codemirror/themes/ambiance.css +0 -81
  65. data/vendor/assets/stylesheets/codemirror/themes/blackboard.css +0 -25
  66. data/vendor/assets/stylesheets/codemirror/themes/erlang-dark.css +0 -21
  67. data/vendor/assets/stylesheets/codemirror/themes/lesser-dark.css +0 -44
  68. data/vendor/assets/stylesheets/codemirror/themes/vibrant-ink.css +0 -27
  69. data/vendor/assets/stylesheets/codemirror/themes/xq-dark.css +0 -46
  70. data/vendor/assets/stylesheets/codemirror/utils/dialog.css +0 -23
  71. data/vendor/assets/stylesheets/codemirror/utils/simple-hint.css +0 -16
@@ -1,118 +0,0 @@
1
- // Define search commands. Depends on dialog.js or another
2
- // implementation of the openDialog method.
3
-
4
- // Replace works a little oddly -- it will do the replace on the next
5
- // Ctrl-G (or whatever is bound to findNext) press. You prevent a
6
- // replace by making sure the match is no longer selected when hitting
7
- // Ctrl-G.
8
-
9
- (function() {
10
- function SearchState() {
11
- this.posFrom = this.posTo = this.query = null;
12
- this.marked = [];
13
- }
14
- function getSearchState(cm) {
15
- return cm._searchState || (cm._searchState = new SearchState());
16
- }
17
- function getSearchCursor(cm, query, pos) {
18
- // Heuristic: if the query string is all lowercase, do a case insensitive search.
19
- return cm.getSearchCursor(query, pos, typeof query == "string" && query == query.toLowerCase());
20
- }
21
- function dialog(cm, text, shortText, f) {
22
- if (cm.openDialog) cm.openDialog(text, f);
23
- else f(prompt(shortText, ""));
24
- }
25
- function confirmDialog(cm, text, shortText, fs) {
26
- if (cm.openConfirm) cm.openConfirm(text, fs);
27
- else if (confirm(shortText)) fs[0]();
28
- }
29
- function parseQuery(query) {
30
- var isRE = query.match(/^\/(.*)\/([a-z]*)$/);
31
- return isRE ? new RegExp(isRE[1], isRE[2].indexOf("i") == -1 ? "" : "i") : query;
32
- }
33
- var queryDialog =
34
- 'Search: <input type="text" style="width: 10em"/> <span style="color: #888">(Use /re/ syntax for regexp search)</span>';
35
- function doSearch(cm, rev) {
36
- var state = getSearchState(cm);
37
- if (state.query) return findNext(cm, rev);
38
- dialog(cm, queryDialog, "Search for:", function(query) {
39
- cm.operation(function() {
40
- if (!query || state.query) return;
41
- state.query = parseQuery(query);
42
- if (cm.lineCount() < 2000) { // This is too expensive on big documents.
43
- for (var cursor = getSearchCursor(cm, query); cursor.findNext();)
44
- state.marked.push(cm.markText(cursor.from(), cursor.to(), "CodeMirror-searching"));
45
- }
46
- state.posFrom = state.posTo = cm.getCursor();
47
- findNext(cm, rev);
48
- });
49
- });
50
- }
51
- function findNext(cm, rev) {cm.operation(function() {
52
- var state = getSearchState(cm);
53
- var cursor = getSearchCursor(cm, state.query, rev ? state.posFrom : state.posTo);
54
- if (!cursor.find(rev)) {
55
- cursor = getSearchCursor(cm, state.query, rev ? {line: cm.lineCount() - 1} : {line: 0, ch: 0});
56
- if (!cursor.find(rev)) return;
57
- }
58
- cm.setSelection(cursor.from(), cursor.to());
59
- state.posFrom = cursor.from(); state.posTo = cursor.to();
60
- })}
61
- function clearSearch(cm) {cm.operation(function() {
62
- var state = getSearchState(cm);
63
- if (!state.query) return;
64
- state.query = null;
65
- for (var i = 0; i < state.marked.length; ++i) state.marked[i].clear();
66
- state.marked.length = 0;
67
- })}
68
-
69
- var replaceQueryDialog =
70
- 'Replace: <input type="text" style="width: 10em"/> <span style="color: #888">(Use /re/ syntax for regexp search)</span>';
71
- var replacementQueryDialog = 'With: <input type="text" style="width: 10em"/>';
72
- var doReplaceConfirm = "Replace? <button>Yes</button> <button>No</button> <button>Stop</button>";
73
- function replace(cm, all) {
74
- dialog(cm, replaceQueryDialog, "Replace:", function(query) {
75
- if (!query) return;
76
- query = parseQuery(query);
77
- dialog(cm, replacementQueryDialog, "Replace with:", function(text) {
78
- if (all) {
79
- cm.compoundChange(function() { cm.operation(function() {
80
- for (var cursor = getSearchCursor(cm, query); cursor.findNext();) {
81
- if (typeof query != "string") {
82
- var match = cm.getRange(cursor.from(), cursor.to()).match(query);
83
- cursor.replace(text.replace(/\$(\d)/, function(w, i) {return match[i];}));
84
- } else cursor.replace(text);
85
- }
86
- })});
87
- } else {
88
- clearSearch(cm);
89
- var cursor = getSearchCursor(cm, query, cm.getCursor());
90
- function advance() {
91
- var start = cursor.from(), match;
92
- if (!(match = cursor.findNext())) {
93
- cursor = getSearchCursor(cm, query);
94
- if (!(match = cursor.findNext()) ||
95
- (start && cursor.from().line == start.line && cursor.from().ch == start.ch)) return;
96
- }
97
- cm.setSelection(cursor.from(), cursor.to());
98
- confirmDialog(cm, doReplaceConfirm, "Replace?",
99
- [function() {doReplace(match);}, advance]);
100
- }
101
- function doReplace(match) {
102
- cursor.replace(typeof query == "string" ? text :
103
- text.replace(/\$(\d)/, function(w, i) {return match[i];}));
104
- advance();
105
- }
106
- advance();
107
- }
108
- });
109
- });
110
- }
111
-
112
- CodeMirror.commands.find = function(cm) {clearSearch(cm); doSearch(cm);};
113
- CodeMirror.commands.findNext = doSearch;
114
- CodeMirror.commands.findPrev = function(cm) {doSearch(cm, true);};
115
- CodeMirror.commands.clearSearch = clearSearch;
116
- CodeMirror.commands.replace = replace;
117
- CodeMirror.commands.replaceAll = function(cm) {replace(cm, true);};
118
- })();
@@ -1,117 +0,0 @@
1
- (function(){
2
- function SearchCursor(cm, query, pos, caseFold) {
3
- this.atOccurrence = false; this.cm = cm;
4
- if (caseFold == null && typeof query == "string") caseFold = false;
5
-
6
- pos = pos ? cm.clipPos(pos) : {line: 0, ch: 0};
7
- this.pos = {from: pos, to: pos};
8
-
9
- // The matches method is filled in based on the type of query.
10
- // It takes a position and a direction, and returns an object
11
- // describing the next occurrence of the query, or null if no
12
- // more matches were found.
13
- if (typeof query != "string") // Regexp match
14
- this.matches = function(reverse, pos) {
15
- if (reverse) {
16
- var line = cm.getLine(pos.line).slice(0, pos.ch), match = line.match(query), start = 0;
17
- while (match) {
18
- var ind = line.indexOf(match[0]);
19
- start += ind;
20
- line = line.slice(ind + 1);
21
- var newmatch = line.match(query);
22
- if (newmatch) match = newmatch;
23
- else break;
24
- start++;
25
- }
26
- }
27
- else {
28
- var line = cm.getLine(pos.line).slice(pos.ch), match = line.match(query),
29
- start = match && pos.ch + line.indexOf(match[0]);
30
- }
31
- if (match)
32
- return {from: {line: pos.line, ch: start},
33
- to: {line: pos.line, ch: start + match[0].length},
34
- match: match};
35
- };
36
- else { // String query
37
- if (caseFold) query = query.toLowerCase();
38
- var fold = caseFold ? function(str){return str.toLowerCase();} : function(str){return str;};
39
- var target = query.split("\n");
40
- // Different methods for single-line and multi-line queries
41
- if (target.length == 1)
42
- this.matches = function(reverse, pos) {
43
- var line = fold(cm.getLine(pos.line)), len = query.length, match;
44
- if (reverse ? (pos.ch >= len && (match = line.lastIndexOf(query, pos.ch - len)) != -1)
45
- : (match = line.indexOf(query, pos.ch)) != -1)
46
- return {from: {line: pos.line, ch: match},
47
- to: {line: pos.line, ch: match + len}};
48
- };
49
- else
50
- this.matches = function(reverse, pos) {
51
- var ln = pos.line, idx = (reverse ? target.length - 1 : 0), match = target[idx], line = fold(cm.getLine(ln));
52
- var offsetA = (reverse ? line.indexOf(match) + match.length : line.lastIndexOf(match));
53
- if (reverse ? offsetA >= pos.ch || offsetA != match.length
54
- : offsetA <= pos.ch || offsetA != line.length - match.length)
55
- return;
56
- for (;;) {
57
- if (reverse ? !ln : ln == cm.lineCount() - 1) return;
58
- line = fold(cm.getLine(ln += reverse ? -1 : 1));
59
- match = target[reverse ? --idx : ++idx];
60
- if (idx > 0 && idx < target.length - 1) {
61
- if (line != match) return;
62
- else continue;
63
- }
64
- var offsetB = (reverse ? line.lastIndexOf(match) : line.indexOf(match) + match.length);
65
- if (reverse ? offsetB != line.length - match.length : offsetB != match.length)
66
- return;
67
- var start = {line: pos.line, ch: offsetA}, end = {line: ln, ch: offsetB};
68
- return {from: reverse ? end : start, to: reverse ? start : end};
69
- }
70
- };
71
- }
72
- }
73
-
74
- SearchCursor.prototype = {
75
- findNext: function() {return this.find(false);},
76
- findPrevious: function() {return this.find(true);},
77
-
78
- find: function(reverse) {
79
- var self = this, pos = this.cm.clipPos(reverse ? this.pos.from : this.pos.to);
80
- function savePosAndFail(line) {
81
- var pos = {line: line, ch: 0};
82
- self.pos = {from: pos, to: pos};
83
- self.atOccurrence = false;
84
- return false;
85
- }
86
-
87
- for (;;) {
88
- if (this.pos = this.matches(reverse, pos)) {
89
- this.atOccurrence = true;
90
- return this.pos.match || true;
91
- }
92
- if (reverse) {
93
- if (!pos.line) return savePosAndFail(0);
94
- pos = {line: pos.line-1, ch: this.cm.getLine(pos.line-1).length};
95
- }
96
- else {
97
- var maxLine = this.cm.lineCount();
98
- if (pos.line == maxLine - 1) return savePosAndFail(maxLine);
99
- pos = {line: pos.line+1, ch: 0};
100
- }
101
- }
102
- },
103
-
104
- from: function() {if (this.atOccurrence) return this.pos.from;},
105
- to: function() {if (this.atOccurrence) return this.pos.to;},
106
-
107
- replace: function(newText) {
108
- var self = this;
109
- if (this.atOccurrence)
110
- self.pos.to = this.cm.replaceRange(newText, self.pos.from, self.pos.to);
111
- }
112
- };
113
-
114
- CodeMirror.defineExtension("getSearchCursor", function(query, pos, caseFold) {
115
- return new SearchCursor(this, query, pos, caseFold);
116
- });
117
- })();
@@ -1,72 +0,0 @@
1
- (function() {
2
- CodeMirror.simpleHint = function(editor, getHints) {
3
- // We want a single cursor position.
4
- if (editor.somethingSelected()) return;
5
- var result = getHints(editor);
6
- if (!result || !result.list.length) return;
7
- var completions = result.list;
8
- function insert(str) {
9
- editor.replaceRange(str, result.from, result.to);
10
- }
11
- // When there is only one completion, use it directly.
12
- if (completions.length == 1) {insert(completions[0]); return true;}
13
-
14
- // Build the select widget
15
- var complete = document.createElement("div");
16
- complete.className = "CodeMirror-completions";
17
- var sel = complete.appendChild(document.createElement("select"));
18
- // Opera doesn't move the selection when pressing up/down in a
19
- // multi-select, but it does properly support the size property on
20
- // single-selects, so no multi-select is necessary.
21
- if (!window.opera) sel.multiple = true;
22
- for (var i = 0; i < completions.length; ++i) {
23
- var opt = sel.appendChild(document.createElement("option"));
24
- opt.appendChild(document.createTextNode(completions[i]));
25
- }
26
- sel.firstChild.selected = true;
27
- sel.size = Math.min(10, completions.length);
28
- var pos = editor.cursorCoords();
29
- complete.style.left = pos.x + "px";
30
- complete.style.top = pos.yBot + "px";
31
- document.body.appendChild(complete);
32
- // If we're at the edge of the screen, then we want the menu to appear on the left of the cursor.
33
- var winW = window.innerWidth || Math.max(document.body.offsetWidth, document.documentElement.offsetWidth);
34
- if(winW - pos.x < sel.clientWidth)
35
- complete.style.left = (pos.x - sel.clientWidth) + "px";
36
- // Hack to hide the scrollbar.
37
- if (completions.length <= 10)
38
- complete.style.width = (sel.clientWidth - 1) + "px";
39
-
40
- var done = false;
41
- function close() {
42
- if (done) return;
43
- done = true;
44
- complete.parentNode.removeChild(complete);
45
- }
46
- function pick() {
47
- insert(completions[sel.selectedIndex]);
48
- close();
49
- setTimeout(function(){editor.focus();}, 50);
50
- }
51
- CodeMirror.connect(sel, "blur", close);
52
- CodeMirror.connect(sel, "keydown", function(event) {
53
- var code = event.keyCode;
54
- // Enter
55
- if (code == 13) {CodeMirror.e_stop(event); pick();}
56
- // Escape
57
- else if (code == 27) {CodeMirror.e_stop(event); close(); editor.focus();}
58
- else if (code != 38 && code != 40) {
59
- close(); editor.focus();
60
- // Pass the event to the CodeMirror instance so that it can handle things like backspace properly.
61
- editor.triggerOnKeyDown(event);
62
- setTimeout(function(){CodeMirror.simpleHint(editor, getHints);}, 50);
63
- }
64
- });
65
- CodeMirror.connect(sel, "dblclick", pick);
66
-
67
- sel.focus();
68
- // Opera sometimes ignores focusing a freshly created node
69
- if (window.opera) setTimeout(function(){if (!done) sel.focus();}, 100);
70
- return true;
71
- };
72
- })();
@@ -1,26 +0,0 @@
1
- .cm-tw-syntaxerror {
2
- color: #FFFFFF;
3
- background-color: #990000;
4
- }
5
-
6
- .cm-tw-deleted {
7
- text-decoration: line-through;
8
- }
9
-
10
- .cm-tw-header5 {
11
- font-weight: bold;
12
- }
13
- .cm-tw-listitem:first-child { /*Added first child to fix duplicate padding when highlighting*/
14
- padding-left: 10px;
15
- }
16
-
17
- .cm-tw-box {
18
- border-top-width: 0px ! important;
19
- border-style: solid;
20
- border-width: 1px;
21
- border-color: inherit;
22
- }
23
-
24
- .cm-tw-underline {
25
- text-decoration: underline;
26
- }
@@ -1,81 +0,0 @@
1
- /* ambiance theme for code-mirror */
2
-
3
- /* Color scheme */
4
-
5
- .cm-s-ambiance .cm-keyword { color: #cda869; }
6
- .cm-s-ambiance .cm-atom { color: #CF7EA9; }
7
- .cm-s-ambiance .cm-number { color: #78CF8A; }
8
- .cm-s-ambiance .cm-def { color: #aac6e3; }
9
- .cm-s-ambiance .cm-variable { color: #ffb795; }
10
- .cm-s-ambiance .cm-variable-2 { color: #eed1b3; }
11
- .cm-s-ambiance .cm-variable-3 { color: #faded3; }
12
- .cm-s-ambiance .cm-property { color: #eed1b3; }
13
- .cm-s-ambiance .cm-operator {color: #fa8d6a;}
14
- .cm-s-ambiance .cm-comment { color: #555; font-style:italic; }
15
- .cm-s-ambiance .cm-string { color: #8f9d6a; }
16
- .cm-s-ambiance .cm-string-2 { color: #9d937c; }
17
- .cm-s-ambiance .cm-meta { color: #D2A8A1; }
18
- .cm-s-ambiance .cm-error { color: #AF2018; }
19
- .cm-s-ambiance .cm-qualifier { color: yellow; }
20
- .cm-s-ambiance .cm-builtin { color: #9999cc; }
21
- .cm-s-ambiance .cm-bracket { color: #24C2C7; }
22
- .cm-s-ambiance .cm-tag { color: #fee4ff }
23
- .cm-s-ambiance .cm-attribute { color: #9B859D; }
24
- .cm-s-ambiance .cm-header {color: blue;}
25
- .cm-s-ambiance .cm-quote { color: #24C2C7; }
26
- .cm-s-ambiance .cm-hr { color: pink; }
27
- .cm-s-ambiance .cm-link { color: #F4C20B; }
28
- .cm-s-ambiance .cm-special { color: #FF9D00; }
29
-
30
- .cm-s-ambiance .CodeMirror-matchingbracket { color: #0f0; }
31
- .cm-s-ambiance .CodeMirror-nonmatchingbracket { color: #f22; }
32
-
33
- .cm-s-ambiance .CodeMirror-selected {
34
- background: rgba(255, 255, 255, 0.15);
35
- }
36
- .CodeMirror-focused .cm-s-ambiance .CodeMirror-selected {
37
- background: rgba(255, 255, 255, 0.10);
38
- }
39
-
40
- /* Editor styling */
41
-
42
- .cm-s-ambiance {
43
- line-height: 1.40em;
44
- font-family: Monaco, Menlo,"Andale Mono","lucida console","Courier New",monospace !important;
45
- color: #E6E1DC;
46
- background-color: #202020;
47
- -webkit-box-shadow: inset 0 0 10px black;
48
- -moz-box-shadow: inset 0 0 10px black;
49
- -o-box-shadow: inset 0 0 10px black;
50
- box-shadow: inset 0 0 10px black;
51
- }
52
-
53
- .cm-s-ambiance .CodeMirror-gutter {
54
- background: #3D3D3D;
55
- padding: 0 5px;
56
- text-shadow: #333 1px 1px;
57
- border-right: 1px solid #4D4D4D;
58
- box-shadow: 0 10px 20px black;
59
- }
60
-
61
- .cm-s-ambiance .CodeMirror-gutter .CodeMirror-gutter-text {
62
- text-shadow: 0px 1px 1px #4d4d4d;
63
- color: #222;
64
- }
65
-
66
- .cm-s-ambiance .CodeMirror-lines {
67
-
68
- }
69
-
70
- .cm-s-ambiance .CodeMirror-lines .CodeMirror-cursor {
71
- border-left: 1px solid #7991E8;
72
- }
73
-
74
- .cm-s-ambiance .activeline {
75
- background: none repeat scroll 0% 0% rgba(255, 255, 255, 0.031);
76
- }
77
-
78
- .cm-s-ambiance,
79
- .cm-s-ambiance .CodeMirror-gutter {
80
- background-image: url("");
81
- }
@@ -1,25 +0,0 @@
1
- /* Port of TextMate's Blackboard theme */
2
-
3
- .cm-s-blackboard { background: #0C1021; color: #F8F8F8; }
4
- .cm-s-blackboard .CodeMirror-selected { background: #253B76 !important; }
5
- .cm-s-blackboard .CodeMirror-gutter { background: #0C1021; border-right: 0; }
6
- .cm-s-blackboard .CodeMirror-gutter-text { color: #888; }
7
- .cm-s-blackboard .CodeMirror-cursor { border-left: 1px solid #A7A7A7 !important; }
8
-
9
- .cm-s-blackboard .cm-keyword { color: #FBDE2D; }
10
- .cm-s-blackboard .cm-atom { color: #D8FA3C; }
11
- .cm-s-blackboard .cm-number { color: #D8FA3C; }
12
- .cm-s-blackboard .cm-def { color: #8DA6CE; }
13
- .cm-s-blackboard .cm-variable { color: #FF6400; }
14
- .cm-s-blackboard .cm-operator { color: #FBDE2D;}
15
- .cm-s-blackboard .cm-comment { color: #AEAEAE; }
16
- .cm-s-blackboard .cm-string { color: #61CE3C; }
17
- .cm-s-blackboard .cm-string-2 { color: #61CE3C; }
18
- .cm-s-blackboard .cm-meta { color: #D8FA3C; }
19
- .cm-s-blackboard .cm-error { background: #9D1E15; color: #F8F8F8; }
20
- .cm-s-blackboard .cm-builtin { color: #8DA6CE; }
21
- .cm-s-blackboard .cm-tag { color: #8DA6CE; }
22
- .cm-s-blackboard .cm-attribute { color: #8DA6CE; }
23
- .cm-s-blackboard .cm-header { color: #FF6400; }
24
- .cm-s-blackboard .cm-hr { color: #AEAEAE; }
25
- .cm-s-blackboard .cm-link { color: #8DA6CE; }
@@ -1,21 +0,0 @@
1
- .cm-s-erlang-dark { background: #002240; color: white; }
2
- .cm-s-erlang-dark div.CodeMirror-selected { background: #b36539 !important; }
3
- .cm-s-erlang-dark .CodeMirror-gutter { background: #002240; border-right: 1px solid #aaa; }
4
- .cm-s-erlang-dark .CodeMirror-gutter-text { color: #d0d0d0; }
5
- .cm-s-erlang-dark .CodeMirror-cursor { border-left: 1px solid white !important; }
6
-
7
- .cm-s-erlang-dark span.cm-atom { color: #845dc4; }
8
- .cm-s-erlang-dark span.cm-attribute { color: #ff80e1; }
9
- .cm-s-erlang-dark span.cm-bracket { color: #ff9d00; }
10
- .cm-s-erlang-dark span.cm-builtin { color: #eeaaaa; }
11
- .cm-s-erlang-dark span.cm-comment { color: #7777ff; }
12
- .cm-s-erlang-dark span.cm-def { color: #ee77aa; }
13
- .cm-s-erlang-dark span.cm-error { color: #9d1e15; }
14
- .cm-s-erlang-dark span.cm-keyword { color: #ffee80; }
15
- .cm-s-erlang-dark span.cm-meta { color: #50fefe; }
16
- .cm-s-erlang-dark span.cm-number { color: #ffd0d0; }
17
- .cm-s-erlang-dark span.cm-operator { color: #dd1111; }
18
- .cm-s-erlang-dark span.cm-string { color: #3ad900; }
19
- .cm-s-erlang-dark span.cm-tag { color: #9effff; }
20
- .cm-s-erlang-dark span.cm-variable { color: #50fe50; }
21
- .cm-s-erlang-dark span.cm-variable-2 { color: #ee00ee; }