Browse Source

readline: don't cache the "keypress" listeners

it's not safe to since `removeAllListeners()` will detach the returned
Array from the stream instance if that's ever called by the user.
v0.9.1-release
Nathan Rajlich 13 years ago
committed by isaacs
parent
commit
032fc42e64
  1. 6
      lib/readline.js

6
lib/readline.js

@ -786,10 +786,8 @@ function emitKeypressEvents(stream) {
if (stream._emitKeypress) return; if (stream._emitKeypress) return;
stream._emitKeypress = true; stream._emitKeypress = true;
var keypressListeners = stream.listeners('keypress');
function onData(b) { function onData(b) {
if (keypressListeners.length) { if (stream.listeners('keypress').length > 0) {
emitKey(stream, b); emitKey(stream, b);
} else { } else {
// Nobody's watching anyway // Nobody's watching anyway
@ -805,7 +803,7 @@ function emitKeypressEvents(stream) {
} }
} }
if (keypressListeners.length) { if (stream.listeners('keypress').length > 0) {
stream.on('data', onData); stream.on('data', onData);
} else { } else {
stream.on('newListener', onNewListener); stream.on('newListener', onNewListener);

Loading…
Cancel
Save