From e3413f08fdcd0476cd9e0c2f934a6f7c6816c322 Mon Sep 17 00:00:00 2001 From: Ryan Dahl Date: Tue, 23 Aug 2011 02:31:20 -0700 Subject: [PATCH] net_uv: throw when people construct net.Socket(fd) Easier to catch compatibility errors. --- lib/net_uv.js | 15 +++++++++++++-- 1 file changed, 13 insertions(+), 2 deletions(-) diff --git a/lib/net_uv.js b/lib/net_uv.js index d6f6d231f37..532a231327c 100644 --- a/lib/net_uv.js +++ b/lib/net_uv.js @@ -84,6 +84,17 @@ function Socket(options) { stream.Stream.call(this); + if (typeof options == 'number') { + // Legacy interface. Uncomment the following lines after + // libuv backend is stable and API compatibile with legaacy. + // console.error('Deprecated interface net.Socket(fd).'); + // console.trace(); + // Must support legacy interface. NPM depends on it. + // https://github.com/isaacs/npm/blob/c7824f412f0cb59d6f55cf0bc220253c39e6029f/lib/utils/output.js#L110 + // TODO Before we can do this we need a way to open a uv_stream_t by fd. + throw new Error("Not yet implemented") + } + // private this._handle = options && options.handle; initSocketHandle(this); @@ -245,7 +256,7 @@ Socket.prototype.destroy = function(exception) { self._connectQueueCleanUp(); - debug('destroy ' + this.fd); + debug('destroy'); this.readable = this.writable = false; @@ -256,7 +267,7 @@ Socket.prototype.destroy = function(exception) { this.server._emitCloseIfDrained(); } - debug('close ' + this.fd); + debug('close'); if (this._handle) { this._handle.close(); this._handle = null;