Browse Source

dgram: fix possibly deoptimizing use of arguments

This commit adds a guard against an out of bounds access of
arguments, and replaces another use of arguments with a named
function parameter.

Refs: https://github.com/nodejs/node/issues/10323
PR-URL: https://github.com/nodejs/node/pull/11242
Reviewed-By: Colin Ihrig <cjihrig@gmail.com>
Reviewed-By: James M Snell <jasnell@gmail.com>
v6.x
Vse Mozhet Byt 8 years ago
committed by Myles Borins
parent
commit
e5d1e273d7
No known key found for this signature in database GPG Key ID: 933B01F40B5CA946
  1. 6
      lib/dgram.js

6
lib/dgram.js

@ -134,7 +134,7 @@ function replaceHandle(self, newHandle) {
self._handle = newHandle; self._handle = newHandle;
} }
Socket.prototype.bind = function(port_ /*, address, callback*/) { Socket.prototype.bind = function(port_, address_ /*, callback*/) {
let port = port_; let port = port_;
this._healthCheck(); this._healthCheck();
@ -144,7 +144,7 @@ Socket.prototype.bind = function(port_ /*, address, callback*/) {
this._bindState = BIND_STATE_BINDING; this._bindState = BIND_STATE_BINDING;
if (typeof arguments[arguments.length - 1] === 'function') if (arguments.length && typeof arguments[arguments.length - 1] === 'function')
this.once('listening', arguments[arguments.length - 1]); this.once('listening', arguments[arguments.length - 1]);
if (port instanceof UDP) { if (port instanceof UDP) {
@ -161,7 +161,7 @@ Socket.prototype.bind = function(port_ /*, address, callback*/) {
exclusive = !!port.exclusive; exclusive = !!port.exclusive;
port = port.port; port = port.port;
} else { } else {
address = typeof arguments[1] === 'function' ? '' : arguments[1]; address = typeof address_ === 'function' ? '' : address_;
exclusive = false; exclusive = false;
} }

Loading…
Cancel
Save