mirror of
https://github.com/jupyter/notebook.git
synced 2025-01-24 12:05:22 +08:00
Merge pull request #893 from minrk/clearoutput
Adding clear_output to kernel and HTML notebook. This enables the clearing of output during the execution of a cell. It can be used for simple forms of animation in the notebook.
This commit is contained in:
commit
986f2e7223
@ -364,9 +364,41 @@ var IPython = (function (IPython) {
|
||||
}
|
||||
|
||||
|
||||
CodeCell.prototype.clear_output = function () {
|
||||
this.element.find("div.output").html("");
|
||||
this.outputs = [];
|
||||
CodeCell.prototype.clear_output = function (stdout, stderr, other) {
|
||||
var output_div = this.element.find("div.output");
|
||||
if (stdout && stderr && other){
|
||||
// clear all, no need for logic
|
||||
output_div.html("");
|
||||
this.outputs = [];
|
||||
return;
|
||||
}
|
||||
// remove html output
|
||||
// each output_subarea that has an identifying class is in an output_area
|
||||
// which is the element to be removed.
|
||||
if (stdout){
|
||||
output_div.find("div.output_stdout").parent().remove();
|
||||
}
|
||||
if (stderr){
|
||||
output_div.find("div.output_stderr").parent().remove();
|
||||
}
|
||||
if (other){
|
||||
output_div.find("div.output_subarea").not("div.output_stderr").not("div.output_stdout").parent().remove();
|
||||
}
|
||||
|
||||
// remove cleared outputs from JSON list:
|
||||
for (var i = this.outputs.length - 1; i >= 0; i--){
|
||||
var out = this.outputs[i];
|
||||
var output_type = out.output_type;
|
||||
if (output_type == "display_data" && other){
|
||||
this.outputs.splice(i,1);
|
||||
}else if (output_type == "stream"){
|
||||
if (stdout && out.stream == "stdout"){
|
||||
this.outputs.splice(i,1);
|
||||
}else if (stderr && out.stream == "stderr"){
|
||||
this.outputs.splice(i,1);
|
||||
}
|
||||
}
|
||||
}
|
||||
};
|
||||
|
||||
|
||||
|
@ -627,7 +627,7 @@ var IPython = (function (IPython) {
|
||||
var cells = this.cells();
|
||||
for (var i=0; i<ncells; i++) {
|
||||
if (cells[i] instanceof IPython.CodeCell) {
|
||||
cells[i].clear_output();
|
||||
cells[i].clear_output(true,true,true);
|
||||
}
|
||||
};
|
||||
this.dirty = true;
|
||||
@ -733,7 +733,9 @@ var IPython = (function (IPython) {
|
||||
} else if (content.execution_state === 'dead') {
|
||||
this.handle_status_dead();
|
||||
};
|
||||
}
|
||||
} else if (msg_type === 'clear_output') {
|
||||
cell.clear_output(content.stdout, content.stderr, content.other);
|
||||
};
|
||||
};
|
||||
|
||||
|
||||
@ -823,7 +825,7 @@ var IPython = (function (IPython) {
|
||||
var cell = that.selected_cell();
|
||||
var cell_index = that.find_cell_index(cell);
|
||||
if (cell instanceof IPython.CodeCell) {
|
||||
cell.clear_output();
|
||||
cell.clear_output(true, true, true);
|
||||
var code = cell.get_code();
|
||||
var msg_id = that.kernel.execute(cell.get_code());
|
||||
that.msg_cell_map[msg_id] = cell.cell_id;
|
||||
|
Loading…
Reference in New Issue
Block a user