Skip to content
Closed
Changes from 1 commit
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Next Next commit
timers: refactor to use rest parameter
  • Loading branch information
aduh95 committed Dec 28, 2020
commit fadc581d55bc3c686ee3d0243b48918ce9d26aea
31 changes: 10 additions & 21 deletions lib/timers.js
Original file line number Diff line number Diff line change
Expand Up @@ -22,6 +22,7 @@
'use strict';

const {
ArrayPrototypeSlice,
MathTrunc,
ObjectCreate,
ObjectDefineProperty,
Expand Down Expand Up @@ -131,10 +132,10 @@ function enroll(item, msecs) {
* DOM-style timers
*/

function setTimeout(callback, after, arg1, arg2, arg3) {
function setTimeout(callback, after, arg1, arg2, ...arg3) {
validateCallback(callback);

let i, args;
let args;
switch (arguments.length) {
// fast cases
case 1:
Expand All @@ -147,11 +148,7 @@ function setTimeout(callback, after, arg1, arg2, arg3) {
args = [arg1, arg2];
break;
default:
args = [arg1, arg2, arg3];
for (i = 5; i < arguments.length; i++) {
// Extend array dynamically, makes .apply run much faster in v6.0.0
args[i - 2] = arguments[i];
}
args = [arg1, arg2, ...new SafeArrayIterator(arg3)];
break;
}

Expand Down Expand Up @@ -185,10 +182,10 @@ function clearTimeout(timer) {
}
}

function setInterval(callback, repeat, arg1, arg2, arg3) {
function setInterval(callback, repeat, arg1, arg2, ...arg3) {
validateCallback(callback);

let i, args;
let args;
switch (arguments.length) {
// fast cases
case 1:
Expand All @@ -201,11 +198,7 @@ function setInterval(callback, repeat, arg1, arg2, arg3) {
args = [arg1, arg2];
break;
default:
args = [arg1, arg2, arg3];
for (i = 5; i < arguments.length; i++) {
// Extend array dynamically, makes .apply run much faster in v6.0.0
args[i - 2] = arguments[i];
}
args = [arg1, arg2, ...new SafeArrayIterator(arg3)];
break;
}

Expand Down Expand Up @@ -236,10 +229,10 @@ Timeout.prototype[SymbolToPrimitive] = function() {
return id;
};

function setImmediate(callback, arg1, arg2, arg3) {
function setImmediate(callback, arg1, arg2) {
validateCallback(callback);

let i, args;
let args;
switch (arguments.length) {
// fast cases
case 1:
Expand All @@ -251,11 +244,7 @@ function setImmediate(callback, arg1, arg2, arg3) {
args = [arg1, arg2];
break;
default:
args = [arg1, arg2, arg3];
for (i = 4; i < arguments.length; i++) {
// Extend array dynamically, makes .apply run much faster in v6.0.0
args[i - 1] = arguments[i];
}
args = ArrayPrototypeSlice(arguments, 1);
break;
}

Expand Down