From 632da2a393a633f8da432096b14bec5915480115 Mon Sep 17 00:00:00 2001 From: Ryan Dahl Date: Wed, 15 Dec 2010 15:57:13 -0800 Subject: [PATCH] Add callback paramenter to socket.connect() --- doc/api/net.markdown | 7 +++++-- lib/net.js | 5 +++++ test/simple/test-net-connect-buffer.js | 5 +---- 3 files changed, 11 insertions(+), 6 deletions(-) diff --git a/doc/api/net.markdown b/doc/api/net.markdown index 6146fd751d8..4e905686f66 100644 --- a/doc/api/net.markdown +++ b/doc/api/net.markdown @@ -153,8 +153,8 @@ and passed to the user through the `'connection'` event of a server. `net.Stream` instances are EventEmitters with the following events: -#### stream.connect(port, [host]) -#### stream.connect(path) +#### stream.connect(port, [host], [callback]) +#### stream.connect(path, [callback]) Opens the connection for a given stream. If `port` and `host` are given, then the stream will be opened as a TCP stream, if `host` is omitted, @@ -170,6 +170,9 @@ stream is established. If there is a problem connecting, the `'connect'` event will not be emitted, the `'error'` event will be emitted with the exception. +The `callback` paramenter will be added as an listener for the 'connect' +event. + #### stream.setEncoding(encoding=null) diff --git a/lib/net.js b/lib/net.js index db491be59bb..d29984668a3 100644 --- a/lib/net.js +++ b/lib/net.js @@ -638,6 +638,11 @@ Stream.prototype.connect = function() { self._connecting = true; // set false in doConnect self.writable = true; + var lastArg = arguments[arguments.length - 1]; + if (typeof lastArg == 'function') { + self.addListener('connect', lastArg); + } + var port = toPort(arguments[0]); if (port === false) { // UNIX diff --git a/test/simple/test-net-connect-buffer.js b/test/simple/test-net-connect-buffer.js index 6e6bc885280..4843f43d947 100644 --- a/test/simple/test-net-connect-buffer.js +++ b/test/simple/test-net-connect-buffer.js @@ -33,10 +33,7 @@ tcp.listen(common.PORT, function () { console.log('Connecting to socket'); - socket.connect(tcpPort); - - - socket.on('connect', function() { + socket.connect(tcpPort, function() { console.log('socket connected'); connectHappened = true; });