aboutsummaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
authorMarak <[email protected]>2021-03-19 22:22:51 -0400
committerGitHub <[email protected]>2021-03-19 22:22:51 -0400
commitb943a25ac61174a99dcd3a10110ceb2846fb167e (patch)
tree60ad08e34465ce0e90e1b6415140f8f42a820289 /lib
parent81f27065297c3e29eb552911b9a5dc8755600efb (diff)
parent6d2902caf2df81fb14836b2cb4e1dbcdb72557ba (diff)
downloadfaker-b943a25ac61174a99dcd3a10110ceb2846fb167e.tar.xz
faker-b943a25ac61174a99dcd3a10110ceb2846fb167e.zip
Merge pull request #1143 from OleksandrYehorov/master
Improve faker.random.arrayElements performance
Diffstat (limited to 'lib')
-rw-r--r--lib/random.js18
1 files changed, 12 insertions, 6 deletions
diff --git a/lib/random.js b/lib/random.js
index 6b532f25..adc9537b 100644
--- a/lib/random.js
+++ b/lib/random.js
@@ -82,14 +82,20 @@ function Random (faker, seed) {
count = 0;
}
- var arrayCopy = array.slice();
- var countToRemove = arrayCopy.length - count;
- for (var i = 0; i < countToRemove; i++) {
- var indexToRemove = faker.datatype.number({ max: arrayCopy.length - 1 });
- arrayCopy.splice(indexToRemove, 1);
+ var arrayCopy = array.slice(0);
+ var i = array.length;
+ var min = i - count;
+ var temp;
+ var index;
+
+ while (i-- > min) {
+ index = Math.floor((i + 1) * faker.datatype.float({ min: 0, max: 0.99 }));
+ temp = arrayCopy[index];
+ arrayCopy[index] = arrayCopy[i];
+ arrayCopy[i] = temp;
}
- return arrayCopy;
+ return arrayCopy.slice(min);
};
/**