Skip to content

Commit

Permalink
readline: properly handle 0-width characters
Browse files Browse the repository at this point in the history
PR-URL: #13918
Reviewed-By: James M Snell <[email protected]>
  • Loading branch information
TimothyGu authored and addaleax committed Jul 11, 2017
1 parent c6602f1 commit c461079
Show file tree
Hide file tree
Showing 2 changed files with 35 additions and 3 deletions.
7 changes: 4 additions & 3 deletions lib/readline.js
Original file line number Diff line number Diff line change
Expand Up @@ -670,13 +670,14 @@ Interface.prototype._getDisplayPos = function(str) {
row += 1;
continue;
}
if (isFullWidthCodePoint(code)) {
const width = getStringWidth(code);
if (width === 0 || width === 1) {
offset += width;
} else { // width === 2
if ((offset + 1) % col === 0) {
offset++;
}
offset += 2;
} else {
offset++;
}
}
var cols = offset % col;
Expand Down
31 changes: 31 additions & 0 deletions test/parallel/test-readline-position.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,31 @@
'use strict';
require('../common');
const { PassThrough } = require('stream');
const readline = require('readline');
const assert = require('assert');

const ctrlU = { ctrl: true, name: 'u' };

{
const input = new PassThrough();
const rl = readline.createInterface({
terminal: true,
input: input,
prompt: ''
});

for (const [cursor, string] of [
[1, 'a'],
[2, 'ab'],
[2, '丁'],
[0, '\u0301'], // COMBINING ACUTE ACCENT
[1, 'a\u0301'], // á
[0, '\u20DD'], // COMBINING ENCLOSING CIRCLE
[2, 'a\u20DDb'], // a⃝b
[0, '\u200E'] // LEFT-TO-RIGHT MARK
]) {
rl.write(string);
assert.strictEqual(rl._getCursorPos().cols, cursor);
rl.write(null, ctrlU);
}
}

0 comments on commit c461079

Please sign in to comment.