Merge pull request #873 from Tyriar/860_resize_exception

Fix exception when resizing both dimensions
This commit is contained in:
Daniel Imms 2017-08-08 18:03:02 -07:00 committed by GitHub
commit 0b1711fb79
5 changed files with 22 additions and 7 deletions

View File

@ -143,5 +143,16 @@ describe('Buffer', () => {
}); });
}); });
}); });
describe('row and column increased', () => {
it('should resize properly', () => {
buffer.fillViewportRows();
buffer.resize(INIT_COLS + 5, INIT_ROWS + 5);
assert.equal(buffer.lines.length, INIT_ROWS + 5);
for (let i = 0; i < INIT_ROWS + 5; i++) {
assert.equal(buffer.lines.get(i).length, INIT_COLS + 5);
}
});
});
}); });
}); });

View File

@ -85,8 +85,10 @@ export class Buffer implements IBuffer {
if (this._terminal.cols < newCols) { if (this._terminal.cols < newCols) {
const ch: [number, string, number] = [this._terminal.defAttr, ' ', 1]; // does xterm use the default attr? const ch: [number, string, number] = [this._terminal.defAttr, ' ', 1]; // does xterm use the default attr?
for (let i = 0; i < this._lines.length; i++) { for (let i = 0; i < this._lines.length; i++) {
// TODO: This should be removed, with tests setup for the case that was
// causing the underlying bug, see https://github.com/sourcelair/xterm.js/issues/824
if (this._lines.get(i) === undefined) { if (this._lines.get(i) === undefined) {
this._lines.set(i, this._terminal.blankLine()); this._lines.set(i, this._terminal.blankLine(undefined, undefined, newCols));
} }
while (this._lines.get(i).length < newCols) { while (this._lines.get(i).length < newCols) {
this._lines.get(i).push(ch); this._lines.get(i).push(ch);
@ -111,7 +113,7 @@ export class Buffer implements IBuffer {
} else { } else {
// Add a blank line if there is no buffer left at the top to scroll to, or if there // Add a blank line if there is no buffer left at the top to scroll to, or if there
// are blank lines after the cursor // are blank lines after the cursor
this._lines.push(this._terminal.blankLine()); this._lines.push(this._terminal.blankLine(undefined, undefined, newCols));
} }
} }
} }

View File

@ -48,7 +48,7 @@ export interface ITerminal {
emit(event: string, data: any); emit(event: string, data: any);
reset(): void; reset(): void;
showCursor(): void; showCursor(): void;
blankLine(cur?: boolean, isWrapped?: boolean); blankLine(cur?: boolean, isWrapped?: boolean, cols?: number);
} }
export interface IBuffer { export interface IBuffer {

View File

@ -43,9 +43,10 @@ export class MockTerminal implements ITerminal {
showCursor(): void { showCursor(): void {
throw new Error('Method not implemented.'); throw new Error('Method not implemented.');
} }
blankLine(cur?: boolean, isWrapped?: boolean) { blankLine(cur?: boolean, isWrapped?: boolean, cols?: number) {
const line = []; const line = [];
for (let i = 0; i < this.cols; i++) { cols = cols || this.cols;
for (let i = 0; i < cols; i++) {
line.push([0, ' ', 1]); line.push([0, ' ', 1]);
} }
return line; return line;

View File

@ -2091,7 +2091,7 @@ Terminal.prototype.eraseLine = function(y) {
* @param {number} cur First bunch of data for each "blank" character. * @param {number} cur First bunch of data for each "blank" character.
* @param {boolean} isWrapped Whether the new line is wrapped from the previous line. * @param {boolean} isWrapped Whether the new line is wrapped from the previous line.
*/ */
Terminal.prototype.blankLine = function(cur, isWrapped) { Terminal.prototype.blankLine = function(cur, isWrapped, cols) {
var attr = cur var attr = cur
? this.eraseAttr() ? this.eraseAttr()
: this.defAttr; : this.defAttr;
@ -2106,7 +2106,8 @@ Terminal.prototype.blankLine = function(cur, isWrapped) {
line.isWrapped = isWrapped; line.isWrapped = isWrapped;
} }
for (; i < this.cols; i++) { cols = cols || this.cols;
for (; i < cols; i++) {
line[i] = ch; line[i] = ch;
} }