diff --git a/IPython/html/static/base/js/utils.js b/IPython/html/static/base/js/utils.js
index ea9b842..2e6fcde 100644
--- a/IPython/html/static/base/js/utils.js
+++ b/IPython/html/static/base/js/utils.js
@@ -605,17 +605,6 @@ define([
msg += ajax_error_msg(jqXHR);
console.log(msg);
};
-
- // monkeypatch from CM4.7+... will be available soon, along with aliases!
- CodeMirror.findModeByName = CodeMirror.findModeByName || function(name) {
- name = name.toLowerCase();
- for (var i = 0; i < CodeMirror.modeInfo.length; i++) {
- var info = CodeMirror.modeInfo[i];
- if (info.name.toLowerCase() == name) return info;
- if (info.alias) for (var j = 0; j < info.alias.length; j++)
- if (info.alias[j].toLowerCase() == name) return info;
- }
- };
var requireCodeMirrorMode = function (mode, callback, errback) {
/**
diff --git a/IPython/html/static/notebook/less/highlight-refs.less b/IPython/html/static/notebook/less/highlight-refs.less
new file mode 100644
index 0000000..a2c0ab6
--- /dev/null
+++ b/IPython/html/static/notebook/less/highlight-refs.less
@@ -0,0 +1,5 @@
+/* load the codemirror defaults as LESS so that highlight.less
+ can load default theme declarations by reference without pulling in the
+ nasty positioning
+*/
+@import (less) "../../components/codemirror/lib/codemirror.css";
diff --git a/IPython/html/static/notebook/less/highlight.less b/IPython/html/static/notebook/less/highlight.less
index 15a878c..d0b2bf2 100644
--- a/IPython/html/static/notebook/less/highlight.less
+++ b/IPython/html/static/notebook/less/highlight.less
@@ -5,160 +5,108 @@ Adapted from GitHub theme
*/
-pre code {
- display: block;
- padding: 0.5em;
+@import (reference) "highlight-refs.less";
+
+@highlight-base: #000;
+
+.highlight-base{
+ color: @highlight-base;
+}
+
+.highlight-variable{
+ .highlight-base();
+}
+
+.highlight-variable-2{
+ color: lighten(@highlight-base, 10%);
}
-.highlight-base,
-pre code,
-pre .subst,
-pre .tag .title,
-pre .lisp .title,
-pre .clojure .built_in,
-pre .nginx .title {
- color: black;
+.highlight-variable-3{
+ color: lighten(@highlight-base, 20%);
}
-.highlight-string,
-pre .string,
-pre .constant,
-pre .parent,
-pre .tag .value,
-pre .rules .value,
-pre .rules .value .number,
-pre .preprocessor,
-pre .ruby .symbol,
-pre .ruby .symbol .string,
-pre .aggregate,
-pre .template_tag,
-pre .django .variable,
-pre .smalltalk .class,
-pre .addition,
-pre .flow,
-pre .stream,
-pre .bash .variable,
-pre .apache .tag,
-pre .apache .cbracket,
-pre .tex .command,
-pre .tex .special,
-pre .erlang_repl .function_or_atom,
-pre .markdown .header {
+.highlight-string{
color: #BA2121;
}
-.highlight-comment,
-pre .comment,
-pre .annotation,
-pre .template_comment,
-pre .diff .header,
-pre .chunk,
-pre .markdown .blockquote {
+.highlight-comment{
color: #408080;
font-style: italic;
}
-.highlight-number,
-pre .number,
-pre .date,
-pre .regexp,
-pre .literal,
-pre .smalltalk .symbol,
-pre .smalltalk .char,
-pre .go .constant,
-pre .change,
-pre .markdown .bullet,
-pre .markdown .link_url {
+.highlight-number{
color: #080;
}
-pre .label,
-pre .javadoc,
-pre .ruby .string,
-pre .decorator,
-pre .filter .argument,
-pre .localvars,
-pre .array,
-pre .attr_selector,
-pre .important,
-pre .pseudo,
-pre .pi,
-pre .doctype,
-pre .deletion,
-pre .envvar,
-pre .shebang,
-pre .apache .sqbracket,
-pre .nginx .built_in,
-pre .tex .formula,
-pre .erlang_repl .reserved,
-pre .prompt,
-pre .markdown .link_label,
-pre .vhdl .attribute,
-pre .clojure .attribute,
-pre .coffeescript .property {
- color: #88F
+.highlight-atom{
+ color: #88F;
}
-.highlight-keyword,
-pre .keyword,
-pre .id,
-pre .phpdoc,
-pre .aggregate,
-pre .css .tag,
-pre .javadoctag,
-pre .phpdoc,
-pre .yardoctag,
-pre .smalltalk .class,
-pre .winutils,
-pre .bash .variable,
-pre .apache .tag,
-pre .go .typename,
-pre .tex .command,
-pre .markdown .strong,
-pre .request,
-pre .status {
+.highlight-keyword{
color: #008000;
font-weight: bold;
}
-.highlight-builtin,
-pre .built_in {
+.highlight-builtin{
color: #008000;
}
-pre .markdown .emphasis {
- font-style: italic;
+.highlight-error{
+ color: #f00;
}
-pre .nginx .built_in {
- font-weight: normal;
+.highlight-operator{
+ color: #AA22FF;
+ font-weight: bold;
}
-pre .coffeescript .javascript,
-pre .javascript .xml,
-pre .tex .formula,
-pre .xml .javascript,
-pre .xml .vbscript,
-pre .xml .css,
-pre .xml .cdata {
- opacity: 0.5;
+.highlight-meta{
+ color: #AA22FF;
}
+/* previously not defined, copying from default codemirror */
+.highlight-def{ .cm-s-default.cm-def() }
+.highlight-punctuation{ .cm-s-default.cm-punctuation() }
+.highlight-property{ .cm-s-default.cm-property() }
+.highlight-string-2{ .cm-s-default.cm-string-2() }
+.highlight-qualifier{ .cm-s-default.cm-qualifier() }
+.highlight-bracket{ .cm-s-default.cm-bracket() }
+.highlight-tag{ .cm-s-default.cm-tag() }
+.highlight-attribute{ .cm-s-default.cm-attribute() }
+.highlight-header{ .cm-s-default.cm-header() }
+.highlight-quote{ .cm-s-default.cm-quote() }
+.highlight-link{ .cm-s-default.cm-link() }
+
+
/* apply the same style to codemirror */
-.cm-s-ipython {
- span.cm-variable { .highlight-base()}
- span.cm-keyword { .highlight-keyword() }
- span.cm-number { .highlight-number() }
- span.cm-comment { .highlight-comment() }
- span.cm-string { .highlight-string()}
- span.cm-builtin { .highlight-builtin() }
- span.cm-error { color: #f00; }
- span.cm-operator {color: #AA22FF; font-weight: bold;}
- span.cm-meta {color: #AA22FF;}
-
- span.cm-tab {
- background: url();
- background-position: right;
- background-repeat: no-repeat;
- }
+.cm-s-ipython span {
+ &.cm-keyword { .highlight-keyword() }
+ &.cm-atom { .highlight-atom() }
+ &.cm-number { .highlight-number() }
+ &.cm-def { .highlight-def() }
+ &.cm-variable { .highlight-variable() }
+ &.cm-punctuation { .highlight-punctuation() }
+ &.cm-property { .highlight-property() }
+ &.cm-operator { .highlight-operator() }
+ &.cm-variable-2 { .highlight-variable-2() }
+ &.cm-variable-3 { .highlight-variable-3() }
+ &.cm-comment { .highlight-comment() }
+ &.cm-string { .highlight-string() }
+ &.cm-string-2 { .highlight-string-2() }
+ &.cm-meta { .highlight-meta() }
+ &.cm-qualifier { .highlight-qualifier() }
+ &.cm-builtin { .highlight-builtin() }
+ &.cm-bracket { .highlight-bracket() }
+ &.cm-tag { .highlight-tag() }
+ &.cm-attribute { .highlight-attribute() }
+ &.cm-header { .highlight-header() }
+ &.cm-quote { .highlight-quote() }
+ &.cm-link { .highlight-link() }
+ &.cm-error { .highlight-error() }
+
+ &.cm-tab {
+ background: url();
+ background-position: right;
+ background-repeat: no-repeat;
+ }
}
diff --git a/IPython/html/tests/base/highlight.js b/IPython/html/tests/base/highlight.js
index d48cb43..3270598 100644
--- a/IPython/html/tests/base/highlight.js
+++ b/IPython/html/tests/base/highlight.js
@@ -31,7 +31,7 @@ casper.notebook_test(function () {
{from: ["../"], error: true},
{from: ["//"], error: true},
].map(function (mode) {
- [mode.to].concat(mode.from || []).map(function(from){
+ mode.from.concat(mode.to || []).map(function(from){
casper.evaluate(function(from, expected, error_expected){
IPython.utils.requireCodeMirrorMode(from, function(observed){
window.callPhantom({