mirror of
https://github.com/idanoo/GoScrobble.git
synced 2024-11-24 09:25:15 +00:00
35 lines
851 B
JavaScript
35 lines
851 B
JavaScript
|
import ListCache from './_ListCache.js';
|
||
|
import Map from './_Map.js';
|
||
|
import MapCache from './_MapCache.js';
|
||
|
|
||
|
/** Used as the size to enable large array optimizations. */
|
||
|
var LARGE_ARRAY_SIZE = 200;
|
||
|
|
||
|
/**
|
||
|
* Sets the stack `key` to `value`.
|
||
|
*
|
||
|
* @private
|
||
|
* @name set
|
||
|
* @memberOf Stack
|
||
|
* @param {string} key The key of the value to set.
|
||
|
* @param {*} value The value to set.
|
||
|
* @returns {Object} Returns the stack cache instance.
|
||
|
*/
|
||
|
function stackSet(key, value) {
|
||
|
var data = this.__data__;
|
||
|
if (data instanceof ListCache) {
|
||
|
var pairs = data.__data__;
|
||
|
if (!Map || (pairs.length < LARGE_ARRAY_SIZE - 1)) {
|
||
|
pairs.push([key, value]);
|
||
|
this.size = ++data.size;
|
||
|
return this;
|
||
|
}
|
||
|
data = this.__data__ = new MapCache(pairs);
|
||
|
}
|
||
|
data.set(key, value);
|
||
|
this.size = data.size;
|
||
|
return this;
|
||
|
}
|
||
|
|
||
|
export default stackSet;
|