2018-04-10 03:00:39 +00:00
|
|
|
/**
|
|
|
|
* @author Richard Davey <rich@photonstorm.com>
|
2019-01-15 16:20:22 +00:00
|
|
|
* @copyright 2019 Photon Storm Ltd.
|
2018-04-10 03:00:39 +00:00
|
|
|
* @license {@link https://github.com/photonstorm/phaser/blob/master/license.txt|MIT License}
|
|
|
|
*/
|
|
|
|
|
2018-04-10 14:21:30 +00:00
|
|
|
var SafeRange = require('./SafeRange');
|
|
|
|
|
2018-04-10 03:00:39 +00:00
|
|
|
/**
|
|
|
|
* Removes the item within the given range in the array.
|
|
|
|
*
|
|
|
|
* The array is modified in-place.
|
|
|
|
*
|
|
|
|
* You can optionally specify a callback to be invoked for the item/s successfully removed from the array.
|
|
|
|
*
|
|
|
|
* @function Phaser.Utils.Array.RemoveBetween
|
|
|
|
* @since 3.4.0
|
|
|
|
*
|
|
|
|
* @param {array} array - The array to be modified.
|
|
|
|
* @param {integer} startIndex - The start index to remove from.
|
|
|
|
* @param {integer} endIndex - The end index to remove to.
|
|
|
|
* @param {function} [callback] - A callback to be invoked for the item removed from the array.
|
|
|
|
* @param {object} [context] - The context in which the callback is invoked.
|
|
|
|
*
|
|
|
|
* @return {Array.<*>} An array of items that were removed.
|
|
|
|
*/
|
|
|
|
var RemoveBetween = function (array, startIndex, endIndex, callback, context)
|
|
|
|
{
|
|
|
|
if (startIndex === undefined) { startIndex = 0; }
|
2018-04-10 14:21:30 +00:00
|
|
|
if (endIndex === undefined) { endIndex = array.length; }
|
|
|
|
if (context === undefined) { context = array; }
|
2018-04-10 03:00:39 +00:00
|
|
|
|
2018-04-10 14:21:30 +00:00
|
|
|
if (SafeRange(array, startIndex, endIndex))
|
2018-04-10 03:00:39 +00:00
|
|
|
{
|
2018-04-10 14:21:30 +00:00
|
|
|
var size = endIndex - startIndex;
|
2018-04-10 03:00:39 +00:00
|
|
|
|
2018-04-10 14:21:30 +00:00
|
|
|
var removed = array.splice(startIndex, size);
|
2018-04-10 03:00:39 +00:00
|
|
|
|
2018-04-10 14:21:30 +00:00
|
|
|
if (callback)
|
2018-04-10 03:00:39 +00:00
|
|
|
{
|
2018-04-10 14:21:30 +00:00
|
|
|
for (var i = 0; i < removed.length; i++)
|
|
|
|
{
|
|
|
|
var entry = removed[i];
|
2018-04-10 03:00:39 +00:00
|
|
|
|
2018-04-10 14:21:30 +00:00
|
|
|
callback.call(context, entry);
|
|
|
|
}
|
2018-04-10 03:00:39 +00:00
|
|
|
}
|
|
|
|
|
2018-04-10 14:21:30 +00:00
|
|
|
return removed;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
return [];
|
|
|
|
}
|
2018-04-10 03:00:39 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
module.exports = RemoveBetween;
|