Merge pull request #1674 from mdboom/notebook-carriage-return

HTML Notebook handles carriage-return special character
This commit is contained in:
Min RK 2012-06-08 10:57:06 -07:00
commit ebd26651ab
4 changed files with 34 additions and 21 deletions

View File

@ -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.

View File

@ -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];

View File

@ -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);
}; };

View File

@ -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));