Browse Source

http: remove reference to onParserExecute

Parsers hold a reference to the socket associated with the request
through onParserExecute. This must be removed when the parser is
freed so that the socket can be garbage collected when destroyed.

Regression introduced in commit 59b91f1 ("http_parser: consume
StreamBase instance").

PR-URL: https://github.com/nodejs/node/pull/4773
Reviewed-By: Ben Noordhuis <info@bnoordhuis.nl>
Reviewed-By: Brian White <mscdex@mscdex.net>
Reviewed-By: Fedor Indutny <fedor.indutny@gmail.com>
v4.x
Tom Atkinson 9 years ago
committed by Myles Borins
parent
commit
bee86bbb12
  1. 3
      lib/_http_common.js

3
lib/_http_common.js

@ -20,6 +20,7 @@ const kOnHeaders = HTTPParser.kOnHeaders | 0;
const kOnHeadersComplete = HTTPParser.kOnHeadersComplete | 0; const kOnHeadersComplete = HTTPParser.kOnHeadersComplete | 0;
const kOnBody = HTTPParser.kOnBody | 0; const kOnBody = HTTPParser.kOnBody | 0;
const kOnMessageComplete = HTTPParser.kOnMessageComplete | 0; const kOnMessageComplete = HTTPParser.kOnMessageComplete | 0;
const kOnExecute = HTTPParser.kOnExecute | 0;
// Only called in the slow case where slow means // Only called in the slow case where slow means
// that the request headers were either fragmented // that the request headers were either fragmented
@ -169,6 +170,7 @@ var parsers = new FreeList('parsers', 1000, function() {
parser[kOnHeadersComplete] = parserOnHeadersComplete; parser[kOnHeadersComplete] = parserOnHeadersComplete;
parser[kOnBody] = parserOnBody; parser[kOnBody] = parserOnBody;
parser[kOnMessageComplete] = parserOnMessageComplete; parser[kOnMessageComplete] = parserOnMessageComplete;
parser[kOnExecute] = null;
return parser; return parser;
}); });
@ -194,6 +196,7 @@ function freeParser(parser, req, socket) {
parser.socket = null; parser.socket = null;
parser.incoming = null; parser.incoming = null;
parser.outgoing = null; parser.outgoing = null;
parser[kOnExecute] = null;
if (parsers.free(parser) === false) if (parsers.free(parser) === false)
parser.close(); parser.close();
parser = null; parser = null;

Loading…
Cancel
Save