mirror of
https://github.com/whoisclebs/lodash.git
synced 2026-02-09 10:27:49 +00:00
Add _.fill.
This commit is contained in:
@@ -2027,6 +2027,36 @@
|
|||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The base implementation of `_.fill` without an iteratee call guard.
|
||||||
|
*
|
||||||
|
* @private
|
||||||
|
* @param {Array} array The array to fill.
|
||||||
|
* @param {*} value The value to fill `array` with.
|
||||||
|
* @param {number} [start=0] The start position.
|
||||||
|
* @param {number} [end=array.length] The end position.
|
||||||
|
* @returns {Array} Returns `array`.
|
||||||
|
*/
|
||||||
|
function baseFill(array, value, start, end) {
|
||||||
|
var length = array.length;
|
||||||
|
|
||||||
|
start = start == null ? 0 : (+start || 0);
|
||||||
|
if (start < 0) {
|
||||||
|
start = -start > length ? 0 : (length + start);
|
||||||
|
}
|
||||||
|
end = (typeof end == 'undefined' || end > length) ? length : (+end || 0);
|
||||||
|
if (end < 0) {
|
||||||
|
end += length;
|
||||||
|
}
|
||||||
|
length = start > end ? 0 : end >>> 0;
|
||||||
|
start >>>= 0;
|
||||||
|
|
||||||
|
while (start < length) {
|
||||||
|
array[start++] = value;
|
||||||
|
}
|
||||||
|
return array;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The base implementation of `_.filter` without support for callback
|
* The base implementation of `_.filter` without support for callback
|
||||||
* shorthands or `this` binding.
|
* shorthands or `this` binding.
|
||||||
@@ -4365,6 +4395,29 @@
|
|||||||
return baseSlice(array, index);
|
return baseSlice(array, index);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Fills elements of `array` with `value` from `start` up to, but not
|
||||||
|
* including, `end`.
|
||||||
|
*
|
||||||
|
* @private
|
||||||
|
* @param {Array} array The array to fill.
|
||||||
|
* @param {*} value The value to fill `array` with.
|
||||||
|
* @param {number} [start=0] The start position.
|
||||||
|
* @param {number} [end=array.length] The end position.
|
||||||
|
* @returns {Array} Returns `array`.
|
||||||
|
*/
|
||||||
|
function fill(array, value, start, end) {
|
||||||
|
var length = array ? array.length : 0;
|
||||||
|
if (!length) {
|
||||||
|
return [];
|
||||||
|
}
|
||||||
|
if (start && typeof start != 'number' && isIterateeCall(array, value, start)) {
|
||||||
|
start = 0;
|
||||||
|
end = length;
|
||||||
|
}
|
||||||
|
return baseFill(array, value, start, end);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* This method is like `_.find` except that it returns the index of the first
|
* This method is like `_.find` except that it returns the index of the first
|
||||||
* element `predicate` returns truthy for, instead of the element itself.
|
* element `predicate` returns truthy for, instead of the element itself.
|
||||||
@@ -10747,6 +10800,7 @@
|
|||||||
lodash.dropRight = dropRight;
|
lodash.dropRight = dropRight;
|
||||||
lodash.dropRightWhile = dropRightWhile;
|
lodash.dropRightWhile = dropRightWhile;
|
||||||
lodash.dropWhile = dropWhile;
|
lodash.dropWhile = dropWhile;
|
||||||
|
lodash.fill = fill;
|
||||||
lodash.filter = filter;
|
lodash.filter = filter;
|
||||||
lodash.flatten = flatten;
|
lodash.flatten = flatten;
|
||||||
lodash.flattenDeep = flattenDeep;
|
lodash.flattenDeep = flattenDeep;
|
||||||
|
|||||||
127
test/test.js
127
test/test.js
@@ -4056,6 +4056,124 @@
|
|||||||
|
|
||||||
/*--------------------------------------------------------------------------*/
|
/*--------------------------------------------------------------------------*/
|
||||||
|
|
||||||
|
QUnit.module('lodash.fill');
|
||||||
|
|
||||||
|
(function() {
|
||||||
|
test('should work with a positive `start`', 1, function() {
|
||||||
|
var array = [1, 2, 3];
|
||||||
|
deepEqual(_.fill(array, 'a', 1), [1, 'a', 'a']);
|
||||||
|
});
|
||||||
|
|
||||||
|
test('should work with a `start` >= `array.length`', 4, function() {
|
||||||
|
_.each([3, 4, Math.pow(2, 32), Infinity], function(start) {
|
||||||
|
var array = [1, 2, 3];
|
||||||
|
deepEqual(_.fill(array, 'a', start), [1, 2, 3]);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
test('should treat falsey `start` values as `0`', 1, function() {
|
||||||
|
var expected = _.map(falsey, _.constant(['a', 'a', 'a']));
|
||||||
|
|
||||||
|
var actual = _.map(falsey, function(start) {
|
||||||
|
var array = [1, 2, 3];
|
||||||
|
return _.fill(array, 'a', start);
|
||||||
|
});
|
||||||
|
|
||||||
|
deepEqual(actual, expected);
|
||||||
|
});
|
||||||
|
|
||||||
|
test('should work with a negative `start`', 1, function() {
|
||||||
|
var array = [1, 2, 3];
|
||||||
|
deepEqual(_.fill(array, 'a', -1), [1, 2, 'a']);
|
||||||
|
});
|
||||||
|
|
||||||
|
test('should work with a negative `start` <= negative `array.length`', 3, function() {
|
||||||
|
_.each([-3, -4, -Infinity], function(start) {
|
||||||
|
var array = [1, 2, 3];
|
||||||
|
deepEqual(_.fill(array, 'a', start), ['a', 'a', 'a']);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
test('should work with `start` >= `end`', 2, function() {
|
||||||
|
_.each([2, 3], function(start) {
|
||||||
|
var array = [1, 2, 3];
|
||||||
|
deepEqual(_.fill(array, 'a', start, 2), [1, 2, 3]);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
test('should work with a positive `end`', 1, function() {
|
||||||
|
var array = [1, 2, 3];
|
||||||
|
deepEqual(_.fill(array, 'a', 0, 1), ['a', 2, 3]);
|
||||||
|
});
|
||||||
|
|
||||||
|
test('should work with a `end` >= `array.length`', 4, function() {
|
||||||
|
_.each([3, 4, Math.pow(2, 32), Infinity], function(end) {
|
||||||
|
var array = [1, 2, 3];
|
||||||
|
deepEqual(_.fill(array, 'a', 0, end), ['a', 'a', 'a']);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
test('should treat falsey `end` values, except `undefined`, as `0`', 1, function() {
|
||||||
|
var expected = _.map(falsey, function(value) {
|
||||||
|
return value === undefined ? ['a', 'a', 'a'] : [1, 2, 3];
|
||||||
|
});
|
||||||
|
|
||||||
|
var actual = _.map(falsey, function(end) {
|
||||||
|
var array = [1, 2, 3];
|
||||||
|
return _.fill(array, 'a', 0, end);
|
||||||
|
});
|
||||||
|
|
||||||
|
deepEqual(actual, expected);
|
||||||
|
});
|
||||||
|
|
||||||
|
test('should work with a negative `end`', 1, function() {
|
||||||
|
var array = [1, 2, 3];
|
||||||
|
deepEqual(_.fill(array, 'a', 0, -1), ['a', 'a', 3]);
|
||||||
|
});
|
||||||
|
|
||||||
|
test('should work with a negative `end` <= negative `array.length`', 3, function() {
|
||||||
|
_.each([-3, -4, -Infinity], function(end) {
|
||||||
|
var array = [1, 2, 3];
|
||||||
|
deepEqual(_.fill(array, 'a', 0, end), [1, 2, 3]);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
test('should coerce `start` and `end` to integers', 1, function() {
|
||||||
|
var positions = [[0.1, 1.1], ['0', 1], [0, '1'], ['1'], [NaN, 1], [1, NaN]];
|
||||||
|
|
||||||
|
var actual = _.map(positions, function(pos) {
|
||||||
|
var array = [1, 2, 3];
|
||||||
|
return _.fill.apply(_, [array, 'a'].concat(pos));
|
||||||
|
});
|
||||||
|
|
||||||
|
deepEqual(actual, [['a', 2, 3], ['a', 2, 3], ['a', 2, 3], [1, 'a', 'a'], ['a', 2, 3], [1, 2, 3]]);
|
||||||
|
});
|
||||||
|
|
||||||
|
test('should work as an iteratee for `_.map`', 1, function() {
|
||||||
|
var array = [[1, 2], [3, 4]],
|
||||||
|
actual = _.map(array, _.fill);
|
||||||
|
|
||||||
|
deepEqual(actual, [[0, 0], [1, 1]]);
|
||||||
|
});
|
||||||
|
|
||||||
|
test('should return a wrapped value when chaining', 3, function() {
|
||||||
|
if (!isNpm) {
|
||||||
|
var array = [1, 2, 3],
|
||||||
|
wrapped = _(array).fill('a'),
|
||||||
|
actual = wrapped.value();
|
||||||
|
|
||||||
|
ok(wrapped instanceof _);
|
||||||
|
deepEqual(actual, ['a', 'a', 'a']);
|
||||||
|
strictEqual(actual, array);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
skipTest(3);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}());
|
||||||
|
|
||||||
|
/*--------------------------------------------------------------------------*/
|
||||||
|
|
||||||
QUnit.module('lodash.filter');
|
QUnit.module('lodash.filter');
|
||||||
|
|
||||||
(function() {
|
(function() {
|
||||||
@@ -11881,7 +11999,12 @@
|
|||||||
});
|
});
|
||||||
|
|
||||||
test('should coerce `start` and `end` to integers', 1, function() {
|
test('should coerce `start` and `end` to integers', 1, function() {
|
||||||
var actual = [_.slice(array, 0.1, 1.1), _.slice(array, '0', 1), _.slice(array, 0, '1'), _.slice(array, '1'), _.slice(array, NaN, 1), _.slice(array, 1, NaN)];
|
var positions = [[0.1, 1.1], ['0', 1], [0, '1'], ['1'], [NaN, 1], [1, NaN]];
|
||||||
|
|
||||||
|
var actual = _.map(positions, function(pos) {
|
||||||
|
return _.slice.apply(_, [array].concat(pos));
|
||||||
|
});
|
||||||
|
|
||||||
deepEqual(actual, [[1], [1], [1], [2, 3], [1], []]);
|
deepEqual(actual, [[1], [1], [1], [2, 3], [1], []]);
|
||||||
});
|
});
|
||||||
|
|
||||||
@@ -15092,7 +15215,7 @@
|
|||||||
|
|
||||||
var acceptFalsey = _.difference(allMethods, rejectFalsey);
|
var acceptFalsey = _.difference(allMethods, rejectFalsey);
|
||||||
|
|
||||||
test('should accept falsey arguments', 206, function() {
|
test('should accept falsey arguments', 207, function() {
|
||||||
var emptyArrays = _.map(falsey, _.constant([])),
|
var emptyArrays = _.map(falsey, _.constant([])),
|
||||||
isExposed = '_' in root,
|
isExposed = '_' in root,
|
||||||
oldDash = root._;
|
oldDash = root._;
|
||||||
|
|||||||
Reference in New Issue
Block a user