mirror of
https://github.com/jupyter/notebook.git
synced 2025-01-06 11:35:24 +08:00
Merge pull request #1674 from mdboom/notebook-carriage-return
HTML Notebook handles carriage-return special character
This commit is contained in:
commit
ebd26651ab
@ -61,11 +61,11 @@ var IPython = (function (IPython) {
|
|||||||
// handlers and is used to provide custom key handling. Its return
|
// handlers and is used to provide custom key handling. Its return
|
||||||
// value is used to determine if CodeMirror should ignore the event:
|
// value is used to determine if CodeMirror should ignore the event:
|
||||||
// true = ignore, false = don't ignore.
|
// true = ignore, false = don't ignore.
|
||||||
|
|
||||||
if (this.read_only){
|
if (this.read_only){
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
var that = this;
|
var that = this;
|
||||||
// whatever key is pressed, first, cancel the tooltip request before
|
// whatever key is pressed, first, cancel the tooltip request before
|
||||||
// they are sent, and remove tooltip if any, except for tab again
|
// they are sent, and remove tooltip if any, except for tab again
|
||||||
@ -90,7 +90,7 @@ var IPython = (function (IPython) {
|
|||||||
event.stop();
|
event.stop();
|
||||||
return false;
|
return false;
|
||||||
} else {
|
} else {
|
||||||
return true;
|
return true;
|
||||||
};
|
};
|
||||||
} else if (event.which === key.ESC) {
|
} else if (event.which === key.ESC) {
|
||||||
IPython.tooltip.remove_and_cancel_tooltip(true);
|
IPython.tooltip.remove_and_cancel_tooltip(true);
|
||||||
@ -102,7 +102,7 @@ var IPython = (function (IPython) {
|
|||||||
event.stop();
|
event.stop();
|
||||||
return false;
|
return false;
|
||||||
} else {
|
} else {
|
||||||
return true;
|
return true;
|
||||||
};
|
};
|
||||||
} else if (event.keyCode === key.TAB && event.type == 'keydown') {
|
} else if (event.keyCode === key.TAB && event.type == 'keydown') {
|
||||||
// Tab completion.
|
// Tab completion.
|
||||||
|
@ -181,11 +181,7 @@ var IPython = (function (IPython) {
|
|||||||
if (json.stream == undefined){
|
if (json.stream == undefined){
|
||||||
json.stream = 'stdout';
|
json.stream = 'stdout';
|
||||||
}
|
}
|
||||||
if (!utils.fixConsole(json.text)){
|
var text = json.text;
|
||||||
// fixConsole gives nothing (empty string, \r, etc.)
|
|
||||||
// so don't append any elements, which might add undesirable space
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
var subclass = "output_"+json.stream;
|
var subclass = "output_"+json.stream;
|
||||||
if (this.outputs.length > 0){
|
if (this.outputs.length > 0){
|
||||||
// have at least one output to consider
|
// have at least one output to consider
|
||||||
@ -194,15 +190,23 @@ var IPython = (function (IPython) {
|
|||||||
// latest output was in the same stream,
|
// latest output was in the same stream,
|
||||||
// so append directly into its pre tag
|
// so append directly into its pre tag
|
||||||
// escape ANSI & HTML specials:
|
// escape ANSI & HTML specials:
|
||||||
var text = utils.fixConsole(json.text);
|
var pre = this.element.find('div.'+subclass).last().find('pre');
|
||||||
this.element.find('div.'+subclass).last().find('pre').append(text);
|
var html = utils.fixCarriageReturn(
|
||||||
|
pre.html() + utils.fixConsole(text));
|
||||||
|
pre.html(html);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (!text.replace("\r", "")) {
|
||||||
|
// text is nothing (empty string, \r, etc.)
|
||||||
|
// so don't append any elements, which might add undesirable space
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
// If we got here, attach a new div
|
// If we got here, attach a new div
|
||||||
var toinsert = this.create_output_area();
|
var toinsert = this.create_output_area();
|
||||||
this.append_text(json.text, toinsert, "output_stream "+subclass);
|
this.append_text(text, toinsert, "output_stream "+subclass);
|
||||||
this.element.append(toinsert);
|
this.element.append(toinsert);
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -260,6 +264,7 @@ var IPython = (function (IPython) {
|
|||||||
var toinsert = $("<div/>").addClass("box-flex1 output_subarea output_text");
|
var toinsert = $("<div/>").addClass("box-flex1 output_subarea output_text");
|
||||||
// escape ANSI & HTML specials in plaintext:
|
// escape ANSI & HTML specials in plaintext:
|
||||||
data = utils.fixConsole(data);
|
data = utils.fixConsole(data);
|
||||||
|
data = utils.fixCarriageReturn(data);
|
||||||
if (extra_class){
|
if (extra_class){
|
||||||
toinsert.addClass(extra_class);
|
toinsert.addClass(extra_class);
|
||||||
}
|
}
|
||||||
@ -328,7 +333,7 @@ var IPython = (function (IPython) {
|
|||||||
|
|
||||||
OutputArea.prototype.clear_output_callback = function (stdout, stderr, other) {
|
OutputArea.prototype.clear_output_callback = function (stdout, stderr, other) {
|
||||||
var output_div = this.element;
|
var output_div = this.element;
|
||||||
|
|
||||||
if (stdout && stderr && other){
|
if (stdout && stderr && other){
|
||||||
// clear all, no need for logic
|
// clear all, no need for logic
|
||||||
output_div.html("");
|
output_div.html("");
|
||||||
@ -347,7 +352,7 @@ var IPython = (function (IPython) {
|
|||||||
if (other) {
|
if (other) {
|
||||||
output_div.find("div.output_subarea").not("div.output_stderr").not("div.output_stdout").parent().remove();
|
output_div.find("div.output_subarea").not("div.output_stderr").not("div.output_stdout").parent().remove();
|
||||||
}
|
}
|
||||||
|
|
||||||
// remove cleared outputs from JSON list:
|
// remove cleared outputs from JSON list:
|
||||||
for (var i = this.outputs.length - 1; i >= 0; i--) {
|
for (var i = this.outputs.length - 1; i >= 0; i--) {
|
||||||
var out = this.outputs[i];
|
var out = this.outputs[i];
|
||||||
|
@ -117,7 +117,7 @@ var IPython = (function (IPython) {
|
|||||||
|
|
||||||
Pager.prototype.append_text = function (text) {
|
Pager.prototype.append_text = function (text) {
|
||||||
var toinsert = $("<div/>").addClass("output_area output_stream");
|
var toinsert = $("<div/>").addClass("output_area output_stream");
|
||||||
toinsert.append($('<pre/>').html(utils.fixConsole(text)));
|
toinsert.append($('<pre/>').html(utils.fixCarriageReturn(utils.fixConsole(text))));
|
||||||
this.pager_element.append(toinsert);
|
this.pager_element.append(toinsert);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -43,11 +43,11 @@ IPython.utils = (function (IPython) {
|
|||||||
ansi_colormap = {
|
ansi_colormap = {
|
||||||
"30":"ansiblack", "31":"ansired",
|
"30":"ansiblack", "31":"ansired",
|
||||||
"32":"ansigreen", "33":"ansiyellow",
|
"32":"ansigreen", "33":"ansiyellow",
|
||||||
"34":"ansiblue", "35":"ansipurple","36":"ansicyan",
|
"34":"ansiblue", "35":"ansipurple","36":"ansicyan",
|
||||||
"37":"ansigrey", "01":"ansibold"
|
"37":"ansigrey", "01":"ansibold"
|
||||||
};
|
};
|
||||||
|
|
||||||
// Transform ANI color escape codes into HTML <span> tags with css
|
// Transform ANSI color escape codes into HTML <span> tags with css
|
||||||
// classes listed in the above ansi_colormap object. The actual color used
|
// classes listed in the above ansi_colormap object. The actual color used
|
||||||
// are set in the css file.
|
// are set in the css file.
|
||||||
function fixConsole(txt) {
|
function fixConsole(txt) {
|
||||||
@ -57,8 +57,6 @@ IPython.utils = (function (IPython) {
|
|||||||
var cmds = [];
|
var cmds = [];
|
||||||
var opener = "";
|
var opener = "";
|
||||||
var closer = "";
|
var closer = "";
|
||||||
// \r does nothing, so shouldn't be included
|
|
||||||
txt = txt.replace('\r', '');
|
|
||||||
while (re.test(txt)) {
|
while (re.test(txt)) {
|
||||||
var cmds = txt.match(re)[1].split(";");
|
var cmds = txt.match(re)[1].split(";");
|
||||||
closer = opened?"</span>":"";
|
closer = opened?"</span>":"";
|
||||||
@ -74,6 +72,16 @@ IPython.utils = (function (IPython) {
|
|||||||
return txt;
|
return txt;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Remove chunks that should be overridden by the effect of
|
||||||
|
// carriage return characters
|
||||||
|
function fixCarriageReturn(txt) {
|
||||||
|
tmp = txt;
|
||||||
|
do {
|
||||||
|
txt = tmp;
|
||||||
|
tmp = txt.replace(/^.*\r(?!\n)/gm, '');
|
||||||
|
} while (tmp.length < txt.length);
|
||||||
|
return txt;
|
||||||
|
}
|
||||||
|
|
||||||
grow = function(element) {
|
grow = function(element) {
|
||||||
// Grow the cell by hand. This is used upon reloading from JSON, when the
|
// Grow the cell by hand. This is used upon reloading from JSON, when the
|
||||||
@ -123,7 +131,7 @@ IPython.utils = (function (IPython) {
|
|||||||
fixConsole : fixConsole,
|
fixConsole : fixConsole,
|
||||||
keycodes : keycodes,
|
keycodes : keycodes,
|
||||||
grow : grow,
|
grow : grow,
|
||||||
|
fixCarriageReturn : fixCarriageReturn
|
||||||
};
|
};
|
||||||
|
|
||||||
}(IPython));
|
}(IPython));
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user