readline: properly handle 0-width characters
PR-URL: https://github.com/nodejs/node/pull/13918 Reviewed-By: James M Snell <jasnell@gmail.com>
This commit is contained in:
parent
a71d20518a
commit
01aeb38800
@ -682,13 +682,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;
|
||||
|
31
test/parallel/test-readline-position.js
Normal file
31
test/parallel/test-readline-position.js
Normal file
@ -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);
|
||||
}
|
||||
}
|
Loading…
x
Reference in New Issue
Block a user