|
|
|
@ -66522,6 +66522,8 @@ const Range = __nccwpck_require__(9828)
|
|
|
|
|
/***/ 9828:
|
|
|
|
|
/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
|
|
|
|
|
|
|
|
|
|
const SPACE_CHARACTERS = /\s+/g
|
|
|
|
|
|
|
|
|
|
// hoisted class for cyclic dependency
|
|
|
|
|
class Range {
|
|
|
|
|
constructor (range, options) {
|
|
|
|
@ -66542,7 +66544,7 @@ class Range {
|
|
|
|
|
// just put it in the set and return
|
|
|
|
|
this.raw = range.value
|
|
|
|
|
this.set = [[range]]
|
|
|
|
|
this.format()
|
|
|
|
|
this.formatted = undefined
|
|
|
|
|
return this
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
@ -66553,10 +66555,7 @@ class Range {
|
|
|
|
|
// First reduce all whitespace as much as possible so we do not have to rely
|
|
|
|
|
// on potentially slow regexes like \s*. This is then stored and used for
|
|
|
|
|
// future error messages as well.
|
|
|
|
|
this.raw = range
|
|
|
|
|
.trim()
|
|
|
|
|
.split(/\s+/)
|
|
|
|
|
.join(' ')
|
|
|
|
|
this.raw = range.trim().replace(SPACE_CHARACTERS, ' ')
|
|
|
|
|
|
|
|
|
|
// First, split on ||
|
|
|
|
|
this.set = this.raw
|
|
|
|
@ -66590,14 +66589,29 @@ class Range {
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
this.format()
|
|
|
|
|
this.formatted = undefined
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
get range () {
|
|
|
|
|
if (this.formatted === undefined) {
|
|
|
|
|
this.formatted = ''
|
|
|
|
|
for (let i = 0; i < this.set.length; i++) {
|
|
|
|
|
if (i > 0) {
|
|
|
|
|
this.formatted += '||'
|
|
|
|
|
}
|
|
|
|
|
const comps = this.set[i]
|
|
|
|
|
for (let k = 0; k < comps.length; k++) {
|
|
|
|
|
if (k > 0) {
|
|
|
|
|
this.formatted += ' '
|
|
|
|
|
}
|
|
|
|
|
this.formatted += comps[k].toString().trim()
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
return this.formatted
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
format () {
|
|
|
|
|
this.range = this.set
|
|
|
|
|
.map((comps) => comps.join(' ').trim())
|
|
|
|
|
.join('||')
|
|
|
|
|
.trim()
|
|
|
|
|
return this.range
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
@ -66722,8 +66736,8 @@ class Range {
|
|
|
|
|
|
|
|
|
|
module.exports = Range
|
|
|
|
|
|
|
|
|
|
const LRU = __nccwpck_require__(1196)
|
|
|
|
|
const cache = new LRU({ max: 1000 })
|
|
|
|
|
const LRU = __nccwpck_require__(5339)
|
|
|
|
|
const cache = new LRU()
|
|
|
|
|
|
|
|
|
|
const parseOptions = __nccwpck_require__(785)
|
|
|
|
|
const Comparator = __nccwpck_require__(1532)
|
|
|
|
@ -66994,9 +67008,10 @@ const replaceGTE0 = (comp, options) => {
|
|
|
|
|
// 1.2 - 3.4.5 => >=1.2.0 <=3.4.5
|
|
|
|
|
// 1.2.3 - 3.4 => >=1.2.0 <3.5.0-0 Any 3.4.x will do
|
|
|
|
|
// 1.2 - 3.4 => >=1.2.0 <3.5.0-0
|
|
|
|
|
// TODO build?
|
|
|
|
|
const hyphenReplace = incPr => ($0,
|
|
|
|
|
from, fM, fm, fp, fpr, fb,
|
|
|
|
|
to, tM, tm, tp, tpr, tb) => {
|
|
|
|
|
to, tM, tm, tp, tpr) => {
|
|
|
|
|
if (isX(fM)) {
|
|
|
|
|
from = ''
|
|
|
|
|
} else if (isX(fm)) {
|
|
|
|
@ -67228,7 +67243,7 @@ class SemVer {
|
|
|
|
|
do {
|
|
|
|
|
const a = this.build[i]
|
|
|
|
|
const b = other.build[i]
|
|
|
|
|
debug('prerelease compare', i, a, b)
|
|
|
|
|
debug('build compare', i, a, b)
|
|
|
|
|
if (a === undefined && b === undefined) {
|
|
|
|
|
return 0
|
|
|
|
|
} else if (b === undefined) {
|
|
|
|
@ -68015,6 +68030,53 @@ module.exports = {
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/***/ }),
|
|
|
|
|
|
|
|
|
|
/***/ 5339:
|
|
|
|
|
/***/ ((module) => {
|
|
|
|
|
|
|
|
|
|
class LRUCache {
|
|
|
|
|
constructor () {
|
|
|
|
|
this.max = 1000
|
|
|
|
|
this.map = new Map()
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
get (key) {
|
|
|
|
|
const value = this.map.get(key)
|
|
|
|
|
if (value === undefined) {
|
|
|
|
|
return undefined
|
|
|
|
|
} else {
|
|
|
|
|
// Remove the key from the map and add it to the end
|
|
|
|
|
this.map.delete(key)
|
|
|
|
|
this.map.set(key, value)
|
|
|
|
|
return value
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
delete (key) {
|
|
|
|
|
return this.map.delete(key)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
set (key, value) {
|
|
|
|
|
const deleted = this.delete(key)
|
|
|
|
|
|
|
|
|
|
if (!deleted && value !== undefined) {
|
|
|
|
|
// If cache is full, delete the least recently used item
|
|
|
|
|
if (this.map.size >= this.max) {
|
|
|
|
|
const firstKey = this.map.keys().next().value
|
|
|
|
|
this.delete(firstKey)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
this.map.set(key, value)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return this
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
module.exports = LRUCache
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/***/ }),
|
|
|
|
|
|
|
|
|
|
/***/ 785:
|
|
|
|
@ -68261,798 +68323,6 @@ createToken('GTE0', '^\\s*>=\\s*0\\.0\\.0\\s*$')
|
|
|
|
|
createToken('GTE0PRE', '^\\s*>=\\s*0\\.0\\.0-0\\s*$')
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/***/ }),
|
|
|
|
|
|
|
|
|
|
/***/ 1196:
|
|
|
|
|
/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
|
|
|
|
|
|
|
|
|
|
"use strict";
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// A linked list to keep track of recently-used-ness
|
|
|
|
|
const Yallist = __nccwpck_require__(220)
|
|
|
|
|
|
|
|
|
|
const MAX = Symbol('max')
|
|
|
|
|
const LENGTH = Symbol('length')
|
|
|
|
|
const LENGTH_CALCULATOR = Symbol('lengthCalculator')
|
|
|
|
|
const ALLOW_STALE = Symbol('allowStale')
|
|
|
|
|
const MAX_AGE = Symbol('maxAge')
|
|
|
|
|
const DISPOSE = Symbol('dispose')
|
|
|
|
|
const NO_DISPOSE_ON_SET = Symbol('noDisposeOnSet')
|
|
|
|
|
const LRU_LIST = Symbol('lruList')
|
|
|
|
|
const CACHE = Symbol('cache')
|
|
|
|
|
const UPDATE_AGE_ON_GET = Symbol('updateAgeOnGet')
|
|
|
|
|
|
|
|
|
|
const naiveLength = () => 1
|
|
|
|
|
|
|
|
|
|
// lruList is a yallist where the head is the youngest
|
|
|
|
|
// item, and the tail is the oldest. the list contains the Hit
|
|
|
|
|
// objects as the entries.
|
|
|
|
|
// Each Hit object has a reference to its Yallist.Node. This
|
|
|
|
|
// never changes.
|
|
|
|
|
//
|
|
|
|
|
// cache is a Map (or PseudoMap) that matches the keys to
|
|
|
|
|
// the Yallist.Node object.
|
|
|
|
|
class LRUCache {
|
|
|
|
|
constructor (options) {
|
|
|
|
|
if (typeof options === 'number')
|
|
|
|
|
options = { max: options }
|
|
|
|
|
|
|
|
|
|
if (!options)
|
|
|
|
|
options = {}
|
|
|
|
|
|
|
|
|
|
if (options.max && (typeof options.max !== 'number' || options.max < 0))
|
|
|
|
|
throw new TypeError('max must be a non-negative number')
|
|
|
|
|
// Kind of weird to have a default max of Infinity, but oh well.
|
|
|
|
|
const max = this[MAX] = options.max || Infinity
|
|
|
|
|
|
|
|
|
|
const lc = options.length || naiveLength
|
|
|
|
|
this[LENGTH_CALCULATOR] = (typeof lc !== 'function') ? naiveLength : lc
|
|
|
|
|
this[ALLOW_STALE] = options.stale || false
|
|
|
|
|
if (options.maxAge && typeof options.maxAge !== 'number')
|
|
|
|
|
throw new TypeError('maxAge must be a number')
|
|
|
|
|
this[MAX_AGE] = options.maxAge || 0
|
|
|
|
|
this[DISPOSE] = options.dispose
|
|
|
|
|
this[NO_DISPOSE_ON_SET] = options.noDisposeOnSet || false
|
|
|
|
|
this[UPDATE_AGE_ON_GET] = options.updateAgeOnGet || false
|
|
|
|
|
this.reset()
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// resize the cache when the max changes.
|
|
|
|
|
set max (mL) {
|
|
|
|
|
if (typeof mL !== 'number' || mL < 0)
|
|
|
|
|
throw new TypeError('max must be a non-negative number')
|
|
|
|
|
|
|
|
|
|
this[MAX] = mL || Infinity
|
|
|
|
|
trim(this)
|
|
|
|
|
}
|
|
|
|
|
get max () {
|
|
|
|
|
return this[MAX]
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
set allowStale (allowStale) {
|
|
|
|
|
this[ALLOW_STALE] = !!allowStale
|
|
|
|
|
}
|
|
|
|
|
get allowStale () {
|
|
|
|
|
return this[ALLOW_STALE]
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
set maxAge (mA) {
|
|
|
|
|
if (typeof mA !== 'number')
|
|
|
|
|
throw new TypeError('maxAge must be a non-negative number')
|
|
|
|
|
|
|
|
|
|
this[MAX_AGE] = mA
|
|
|
|
|
trim(this)
|
|
|
|
|
}
|
|
|
|
|
get maxAge () {
|
|
|
|
|
return this[MAX_AGE]
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// resize the cache when the lengthCalculator changes.
|
|
|
|
|
set lengthCalculator (lC) {
|
|
|
|
|
if (typeof lC !== 'function')
|
|
|
|
|
lC = naiveLength
|
|
|
|
|
|
|
|
|
|
if (lC !== this[LENGTH_CALCULATOR]) {
|
|
|
|
|
this[LENGTH_CALCULATOR] = lC
|
|
|
|
|
this[LENGTH] = 0
|
|
|
|
|
this[LRU_LIST].forEach(hit => {
|
|
|
|
|
hit.length = this[LENGTH_CALCULATOR](hit.value, hit.key)
|
|
|
|
|
this[LENGTH] += hit.length
|
|
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
trim(this)
|
|
|
|
|
}
|
|
|
|
|
get lengthCalculator () { return this[LENGTH_CALCULATOR] }
|
|
|
|
|
|
|
|
|
|
get length () { return this[LENGTH] }
|
|
|
|
|
get itemCount () { return this[LRU_LIST].length }
|
|
|
|
|
|
|
|
|
|
rforEach (fn, thisp) {
|
|
|
|
|
thisp = thisp || this
|
|
|
|
|
for (let walker = this[LRU_LIST].tail; walker !== null;) {
|
|
|
|
|
const prev = walker.prev
|
|
|
|
|
forEachStep(this, fn, walker, thisp)
|
|
|
|
|
walker = prev
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
forEach (fn, thisp) {
|
|
|
|
|
thisp = thisp || this
|
|
|
|
|
for (let walker = this[LRU_LIST].head; walker !== null;) {
|
|
|
|
|
const next = walker.next
|
|
|
|
|
forEachStep(this, fn, walker, thisp)
|
|
|
|
|
walker = next
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
keys () {
|
|
|
|
|
return this[LRU_LIST].toArray().map(k => k.key)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
values () {
|
|
|
|
|
return this[LRU_LIST].toArray().map(k => k.value)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
reset () {
|
|
|
|
|
if (this[DISPOSE] &&
|
|
|
|
|
this[LRU_LIST] &&
|
|
|
|
|
this[LRU_LIST].length) {
|
|
|
|
|
this[LRU_LIST].forEach(hit => this[DISPOSE](hit.key, hit.value))
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
this[CACHE] = new Map() // hash of items by key
|
|
|
|
|
this[LRU_LIST] = new Yallist() // list of items in order of use recency
|
|
|
|
|
this[LENGTH] = 0 // length of items in the list
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
dump () {
|
|
|
|
|
return this[LRU_LIST].map(hit =>
|
|
|
|
|
isStale(this, hit) ? false : {
|
|
|
|
|
k: hit.key,
|
|
|
|
|
v: hit.value,
|
|
|
|
|
e: hit.now + (hit.maxAge || 0)
|
|
|
|
|
}).toArray().filter(h => h)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
dumpLru () {
|
|
|
|
|
return this[LRU_LIST]
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
set (key, value, maxAge) {
|
|
|
|
|
maxAge = maxAge || this[MAX_AGE]
|
|
|
|
|
|
|
|
|
|
if (maxAge && typeof maxAge !== 'number')
|
|
|
|
|
throw new TypeError('maxAge must be a number')
|
|
|
|
|
|
|
|
|
|
const now = maxAge ? Date.now() : 0
|
|
|
|
|
const len = this[LENGTH_CALCULATOR](value, key)
|
|
|
|
|
|
|
|
|
|
if (this[CACHE].has(key)) {
|
|
|
|
|
if (len > this[MAX]) {
|
|
|
|
|
del(this, this[CACHE].get(key))
|
|
|
|
|
return false
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
const node = this[CACHE].get(key)
|
|
|
|
|
const item = node.value
|
|
|
|
|
|
|
|
|
|
// dispose of the old one before overwriting
|
|
|
|
|
// split out into 2 ifs for better coverage tracking
|
|
|
|
|
if (this[DISPOSE]) {
|
|
|
|
|
if (!this[NO_DISPOSE_ON_SET])
|
|
|
|
|
this[DISPOSE](key, item.value)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
item.now = now
|
|
|
|
|
item.maxAge = maxAge
|
|
|
|
|
item.value = value
|
|
|
|
|
this[LENGTH] += len - item.length
|
|
|
|
|
item.length = len
|
|
|
|
|
this.get(key)
|
|
|
|
|
trim(this)
|
|
|
|
|
return true
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
const hit = new Entry(key, value, len, now, maxAge)
|
|
|
|
|
|
|
|
|
|
// oversized objects fall out of cache automatically.
|
|
|
|
|
if (hit.length > this[MAX]) {
|
|
|
|
|
if (this[DISPOSE])
|
|
|
|
|
this[DISPOSE](key, value)
|
|
|
|
|
|
|
|
|
|
return false
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
this[LENGTH] += hit.length
|
|
|
|
|
this[LRU_LIST].unshift(hit)
|
|
|
|
|
this[CACHE].set(key, this[LRU_LIST].head)
|
|
|
|
|
trim(this)
|
|
|
|
|
return true
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
has (key) {
|
|
|
|
|
if (!this[CACHE].has(key)) return false
|
|
|
|
|
const hit = this[CACHE].get(key).value
|
|
|
|
|
return !isStale(this, hit)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
get (key) {
|
|
|
|
|
return get(this, key, true)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
peek (key) {
|
|
|
|
|
return get(this, key, false)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
pop () {
|
|
|
|
|
const node = this[LRU_LIST].tail
|
|
|
|
|
if (!node)
|
|
|
|
|
return null
|
|
|
|
|
|
|
|
|
|
del(this, node)
|
|
|
|
|
return node.value
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
del (key) {
|
|
|
|
|
del(this, this[CACHE].get(key))
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
load (arr) {
|
|
|
|
|
// reset the cache
|
|
|
|
|
this.reset()
|
|
|
|
|
|
|
|
|
|
const now = Date.now()
|
|
|
|
|
// A previous serialized cache has the most recent items first
|
|
|
|
|
for (let l = arr.length - 1; l >= 0; l--) {
|
|
|
|
|
const hit = arr[l]
|
|
|
|
|
const expiresAt = hit.e || 0
|
|
|
|
|
if (expiresAt === 0)
|
|
|
|
|
// the item was created without expiration in a non aged cache
|
|
|
|
|
this.set(hit.k, hit.v)
|
|
|
|
|
else {
|
|
|
|
|
const maxAge = expiresAt - now
|
|
|
|
|
// dont add already expired items
|
|
|
|
|
if (maxAge > 0) {
|
|
|
|
|
this.set(hit.k, hit.v, maxAge)
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
prune () {
|
|
|
|
|
this[CACHE].forEach((value, key) => get(this, key, false))
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
const get = (self, key, doUse) => {
|
|
|
|
|
const node = self[CACHE].get(key)
|
|
|
|
|
if (node) {
|
|
|
|
|
const hit = node.value
|
|
|
|
|
if (isStale(self, hit)) {
|
|
|
|
|
del(self, node)
|
|
|
|
|
if (!self[ALLOW_STALE])
|
|
|
|
|
return undefined
|
|
|
|
|
} else {
|
|
|
|
|
if (doUse) {
|
|
|
|
|
if (self[UPDATE_AGE_ON_GET])
|
|
|
|
|
node.value.now = Date.now()
|
|
|
|
|
self[LRU_LIST].unshiftNode(node)
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
return hit.value
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
const isStale = (self, hit) => {
|
|
|
|
|
if (!hit || (!hit.maxAge && !self[MAX_AGE]))
|
|
|
|
|
return false
|
|
|
|
|
|
|
|
|
|
const diff = Date.now() - hit.now
|
|
|
|
|
return hit.maxAge ? diff > hit.maxAge
|
|
|
|
|
: self[MAX_AGE] && (diff > self[MAX_AGE])
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
const trim = self => {
|
|
|
|
|
if (self[LENGTH] > self[MAX]) {
|
|
|
|
|
for (let walker = self[LRU_LIST].tail;
|
|
|
|
|
self[LENGTH] > self[MAX] && walker !== null;) {
|
|
|
|
|
// We know that we're about to delete this one, and also
|
|
|
|
|
// what the next least recently used key will be, so just
|
|
|
|
|
// go ahead and set it now.
|
|
|
|
|
const prev = walker.prev
|
|
|
|
|
del(self, walker)
|
|
|
|
|
walker = prev
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
const del = (self, node) => {
|
|
|
|
|
if (node) {
|
|
|
|
|
const hit = node.value
|
|
|
|
|
if (self[DISPOSE])
|
|
|
|
|
self[DISPOSE](hit.key, hit.value)
|
|
|
|
|
|
|
|
|
|
self[LENGTH] -= hit.length
|
|
|
|
|
self[CACHE].delete(hit.key)
|
|
|
|
|
self[LRU_LIST].removeNode(node)
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
class Entry {
|
|
|
|
|
constructor (key, value, length, now, maxAge) {
|
|
|
|
|
this.key = key
|
|
|
|
|
this.value = value
|
|
|
|
|
this.length = length
|
|
|
|
|
this.now = now
|
|
|
|
|
this.maxAge = maxAge || 0
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
const forEachStep = (self, fn, node, thisp) => {
|
|
|
|
|
let hit = node.value
|
|
|
|
|
if (isStale(self, hit)) {
|
|
|
|
|
del(self, node)
|
|
|
|
|
if (!self[ALLOW_STALE])
|
|
|
|
|
hit = undefined
|
|
|
|
|
}
|
|
|
|
|
if (hit)
|
|
|
|
|
fn.call(thisp, hit.value, hit.key, self)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
module.exports = LRUCache
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/***/ }),
|
|
|
|
|
|
|
|
|
|
/***/ 5327:
|
|
|
|
|
/***/ ((module) => {
|
|
|
|
|
|
|
|
|
|
"use strict";
|
|
|
|
|
|
|
|
|
|
module.exports = function (Yallist) {
|
|
|
|
|
Yallist.prototype[Symbol.iterator] = function* () {
|
|
|
|
|
for (let walker = this.head; walker; walker = walker.next) {
|
|
|
|
|
yield walker.value
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/***/ }),
|
|
|
|
|
|
|
|
|
|
/***/ 220:
|
|
|
|
|
/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
|
|
|
|
|
|
|
|
|
|
"use strict";
|
|
|
|
|
|
|
|
|
|
module.exports = Yallist
|
|
|
|
|
|
|
|
|
|
Yallist.Node = Node
|
|
|
|
|
Yallist.create = Yallist
|
|
|
|
|
|
|
|
|
|
function Yallist (list) {
|
|
|
|
|
var self = this
|
|
|
|
|
if (!(self instanceof Yallist)) {
|
|
|
|
|
self = new Yallist()
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
self.tail = null
|
|
|
|
|
self.head = null
|
|
|
|
|
self.length = 0
|
|
|
|
|
|
|
|
|
|
if (list && typeof list.forEach === 'function') {
|
|
|
|
|
list.forEach(function (item) {
|
|
|
|
|
self.push(item)
|
|
|
|
|
})
|
|
|
|
|
} else if (arguments.length > 0) {
|
|
|
|
|
for (var i = 0, l = arguments.length; i < l; i++) {
|
|
|
|
|
self.push(arguments[i])
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return self
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Yallist.prototype.removeNode = function (node) {
|
|
|
|
|
if (node.list !== this) {
|
|
|
|
|
throw new Error('removing node which does not belong to this list')
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
var next = node.next
|
|
|
|
|
var prev = node.prev
|
|
|
|
|
|
|
|
|
|
if (next) {
|
|
|
|
|
next.prev = prev
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (prev) {
|
|
|
|
|
prev.next = next
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (node === this.head) {
|
|
|
|
|
this.head = next
|
|
|
|
|
}
|
|
|
|
|
if (node === this.tail) {
|
|
|
|
|
this.tail = prev
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
node.list.length--
|
|
|
|
|
node.next = null
|
|
|
|
|
node.prev = null
|
|
|
|
|
node.list = null
|
|
|
|
|
|
|
|
|
|
return next
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Yallist.prototype.unshiftNode = function (node) {
|
|
|
|
|
if (node === this.head) {
|
|
|
|
|
return
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (node.list) {
|
|
|
|
|
node.list.removeNode(node)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
var head = this.head
|
|
|
|
|
node.list = this
|
|
|
|
|
node.next = head
|
|
|
|
|
if (head) {
|
|
|
|
|
head.prev = node
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
this.head = node
|
|
|
|
|
if (!this.tail) {
|
|
|
|
|
this.tail = node
|
|
|
|
|
}
|
|
|
|
|
this.length++
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Yallist.prototype.pushNode = function (node) {
|
|
|
|
|
if (node === this.tail) {
|
|
|
|
|
return
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (node.list) {
|
|
|
|
|
node.list.removeNode(node)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
var tail = this.tail
|
|
|
|
|
node.list = this
|
|
|
|
|
node.prev = tail
|
|
|
|
|
if (tail) {
|
|
|
|
|
tail.next = node
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
this.tail = node
|
|
|
|
|
if (!this.head) {
|
|
|
|
|
this.head = node
|
|
|
|
|
}
|
|
|
|
|
this.length++
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Yallist.prototype.push = function () {
|
|
|
|
|
for (var i = 0, l = arguments.length; i < l; i++) {
|
|
|
|
|
push(this, arguments[i])
|
|
|
|
|
}
|
|
|
|
|
return this.length
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Yallist.prototype.unshift = function () {
|
|
|
|
|
for (var i = 0, l = arguments.length; i < l; i++) {
|
|
|
|
|
unshift(this, arguments[i])
|
|
|
|
|
}
|
|
|
|
|
return this.length
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Yallist.prototype.pop = function () {
|
|
|
|
|
if (!this.tail) {
|
|
|
|
|
return undefined
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
var res = this.tail.value
|
|
|
|
|
this.tail = this.tail.prev
|
|
|
|
|
if (this.tail) {
|
|
|
|
|
this.tail.next = null
|
|
|
|
|
} else {
|
|
|
|
|
this.head = null
|
|
|
|
|
}
|
|
|
|
|
this.length--
|
|
|
|
|
return res
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Yallist.prototype.shift = function () {
|
|
|
|
|
if (!this.head) {
|
|
|
|
|
return undefined
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
var res = this.head.value
|
|
|
|
|
this.head = this.head.next
|
|
|
|
|
if (this.head) {
|
|
|
|
|
this.head.prev = null
|
|
|
|
|
} else {
|
|
|
|
|
this.tail = null
|
|
|
|
|
}
|
|
|
|
|
this.length--
|
|
|
|
|
return res
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Yallist.prototype.forEach = function (fn, thisp) {
|
|
|
|
|
thisp = thisp || this
|
|
|
|
|
for (var walker = this.head, i = 0; walker !== null; i++) {
|
|
|
|
|
fn.call(thisp, walker.value, i, this)
|
|
|
|
|
walker = walker.next
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Yallist.prototype.forEachReverse = function (fn, thisp) {
|
|
|
|
|
thisp = thisp || this
|
|
|
|
|
for (var walker = this.tail, i = this.length - 1; walker !== null; i--) {
|
|
|
|
|
fn.call(thisp, walker.value, i, this)
|
|
|
|
|
walker = walker.prev
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Yallist.prototype.get = function (n) {
|
|
|
|
|
for (var i = 0, walker = this.head; walker !== null && i < n; i++) {
|
|
|
|
|
// abort out of the list early if we hit a cycle
|
|
|
|
|
walker = walker.next
|
|
|
|
|
}
|
|
|
|
|
if (i === n && walker !== null) {
|
|
|
|
|
return walker.value
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Yallist.prototype.getReverse = function (n) {
|
|
|
|
|
for (var i = 0, walker = this.tail; walker !== null && i < n; i++) {
|
|
|
|
|
// abort out of the list early if we hit a cycle
|
|
|
|
|
walker = walker.prev
|
|
|
|
|
}
|
|
|
|
|
if (i === n && walker !== null) {
|
|
|
|
|
return walker.value
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Yallist.prototype.map = function (fn, thisp) {
|
|
|
|
|
thisp = thisp || this
|
|
|
|
|
var res = new Yallist()
|
|
|
|
|
for (var walker = this.head; walker !== null;) {
|
|
|
|
|
res.push(fn.call(thisp, walker.value, this))
|
|
|
|
|
walker = walker.next
|
|
|
|
|
}
|
|
|
|
|
return res
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Yallist.prototype.mapReverse = function (fn, thisp) {
|
|
|
|
|
thisp = thisp || this
|
|
|
|
|
var res = new Yallist()
|
|
|
|
|
for (var walker = this.tail; walker !== null;) {
|
|
|
|
|
res.push(fn.call(thisp, walker.value, this))
|
|
|
|
|
walker = walker.prev
|
|
|
|
|
}
|
|
|
|
|
return res
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Yallist.prototype.reduce = function (fn, initial) {
|
|
|
|
|
var acc
|
|
|
|
|
var walker = this.head
|
|
|
|
|
if (arguments.length > 1) {
|
|
|
|
|
acc = initial
|
|
|
|
|
} else if (this.head) {
|
|
|
|
|
walker = this.head.next
|
|
|
|
|
acc = this.head.value
|
|
|
|
|
} else {
|
|
|
|
|
throw new TypeError('Reduce of empty list with no initial value')
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
for (var i = 0; walker !== null; i++) {
|
|
|
|
|
acc = fn(acc, walker.value, i)
|
|
|
|
|
walker = walker.next
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return acc
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Yallist.prototype.reduceReverse = function (fn, initial) {
|
|
|
|
|
var acc
|
|
|
|
|
var walker = this.tail
|
|
|
|
|
if (arguments.length > 1) {
|
|
|
|
|
acc = initial
|
|
|
|
|
} else if (this.tail) {
|
|
|
|
|
walker = this.tail.prev
|
|
|
|
|
acc = this.tail.value
|
|
|
|
|
} else {
|
|
|
|
|
throw new TypeError('Reduce of empty list with no initial value')
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
for (var i = this.length - 1; walker !== null; i--) {
|
|
|
|
|
acc = fn(acc, walker.value, i)
|
|
|
|
|
walker = walker.prev
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return acc
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Yallist.prototype.toArray = function () {
|
|
|
|
|
var arr = new Array(this.length)
|
|
|
|
|
for (var i = 0, walker = this.head; walker !== null; i++) {
|
|
|
|
|
arr[i] = walker.value
|
|
|
|
|
walker = walker.next
|
|
|
|
|
}
|
|
|
|
|
return arr
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Yallist.prototype.toArrayReverse = function () {
|
|
|
|
|
var arr = new Array(this.length)
|
|
|
|
|
for (var i = 0, walker = this.tail; walker !== null; i++) {
|
|
|
|
|
arr[i] = walker.value
|
|
|
|
|
walker = walker.prev
|
|
|
|
|
}
|
|
|
|
|
return arr
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Yallist.prototype.slice = function (from, to) {
|
|
|
|
|
to = to || this.length
|
|
|
|
|
if (to < 0) {
|
|
|
|
|
to += this.length
|
|
|
|
|
}
|
|
|
|
|
from = from || 0
|
|
|
|
|
if (from < 0) {
|
|
|
|
|
from += this.length
|
|
|
|
|
}
|
|
|
|
|
var ret = new Yallist()
|
|
|
|
|
if (to < from || to < 0) {
|
|
|
|
|
return ret
|
|
|
|
|
}
|
|
|
|
|
if (from < 0) {
|
|
|
|
|
from = 0
|
|
|
|
|
}
|
|
|
|
|
if (to > this.length) {
|
|
|
|
|
to = this.length
|
|
|
|
|
}
|
|
|
|
|
for (var i = 0, walker = this.head; walker !== null && i < from; i++) {
|
|
|
|
|
walker = walker.next
|
|
|
|
|
}
|
|
|
|
|
for (; walker !== null && i < to; i++, walker = walker.next) {
|
|
|
|
|
ret.push(walker.value)
|
|
|
|
|
}
|
|
|
|
|
return ret
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Yallist.prototype.sliceReverse = function (from, to) {
|
|
|
|
|
to = to || this.length
|
|
|
|
|
if (to < 0) {
|
|
|
|
|
to += this.length
|
|
|
|
|
}
|
|
|
|
|
from = from || 0
|
|
|
|
|
if (from < 0) {
|
|
|
|
|
from += this.length
|
|
|
|
|
}
|
|
|
|
|
var ret = new Yallist()
|
|
|
|
|
if (to < from || to < 0) {
|
|
|
|
|
return ret
|
|
|
|
|
}
|
|
|
|
|
if (from < 0) {
|
|
|
|
|
from = 0
|
|
|
|
|
}
|
|
|
|
|
if (to > this.length) {
|
|
|
|
|
to = this.length
|
|
|
|
|
}
|
|
|
|
|
for (var i = this.length, walker = this.tail; walker !== null && i > to; i--) {
|
|
|
|
|
walker = walker.prev
|
|
|
|
|
}
|
|
|
|
|
for (; walker !== null && i > from; i--, walker = walker.prev) {
|
|
|
|
|
ret.push(walker.value)
|
|
|
|
|
}
|
|
|
|
|
return ret
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Yallist.prototype.splice = function (start, deleteCount, ...nodes) {
|
|
|
|
|
if (start > this.length) {
|
|
|
|
|
start = this.length - 1
|
|
|
|
|
}
|
|
|
|
|
if (start < 0) {
|
|
|
|
|
start = this.length + start;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
for (var i = 0, walker = this.head; walker !== null && i < start; i++) {
|
|
|
|
|
walker = walker.next
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
var ret = []
|
|
|
|
|
for (var i = 0; walker && i < deleteCount; i++) {
|
|
|
|
|
ret.push(walker.value)
|
|
|
|
|
walker = this.removeNode(walker)
|
|
|
|
|
}
|
|
|
|
|
if (walker === null) {
|
|
|
|
|
walker = this.tail
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (walker !== this.head && walker !== this.tail) {
|
|
|
|
|
walker = walker.prev
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
for (var i = 0; i < nodes.length; i++) {
|
|
|
|
|
walker = insert(this, walker, nodes[i])
|
|
|
|
|
}
|
|
|
|
|
return ret;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Yallist.prototype.reverse = function () {
|
|
|
|
|
var head = this.head
|
|
|
|
|
var tail = this.tail
|
|
|
|
|
for (var walker = head; walker !== null; walker = walker.prev) {
|
|
|
|
|
var p = walker.prev
|
|
|
|
|
walker.prev = walker.next
|
|
|
|
|
walker.next = p
|
|
|
|
|
}
|
|
|
|
|
this.head = tail
|
|
|
|
|
this.tail = head
|
|
|
|
|
return this
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
function insert (self, node, value) {
|
|
|
|
|
var inserted = node === self.head ?
|
|
|
|
|
new Node(value, null, node, self) :
|
|
|
|
|
new Node(value, node, node.next, self)
|
|
|
|
|
|
|
|
|
|
if (inserted.next === null) {
|
|
|
|
|
self.tail = inserted
|
|
|
|
|
}
|
|
|
|
|
if (inserted.prev === null) {
|
|
|
|
|
self.head = inserted
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
self.length++
|
|
|
|
|
|
|
|
|
|
return inserted
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
function push (self, item) {
|
|
|
|
|
self.tail = new Node(item, self.tail, null, self)
|
|
|
|
|
if (!self.head) {
|
|
|
|
|
self.head = self.tail
|
|
|
|
|
}
|
|
|
|
|
self.length++
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
function unshift (self, item) {
|
|
|
|
|
self.head = new Node(item, null, self.head, self)
|
|
|
|
|
if (!self.tail) {
|
|
|
|
|
self.tail = self.head
|
|
|
|
|
}
|
|
|
|
|
self.length++
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
function Node (value, prev, next, list) {
|
|
|
|
|
if (!(this instanceof Node)) {
|
|
|
|
|
return new Node(value, prev, next, list)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
this.list = list
|
|
|
|
|
this.value = value
|
|
|
|
|
|
|
|
|
|
if (prev) {
|
|
|
|
|
prev.next = this
|
|
|
|
|
this.prev = prev
|
|
|
|
|
} else {
|
|
|
|
|
this.prev = null
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (next) {
|
|
|
|
|
next.prev = this
|
|
|
|
|
this.next = next
|
|
|
|
|
} else {
|
|
|
|
|
this.next = null
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
try {
|
|
|
|
|
// add if support for Symbol.iterator is present
|
|
|
|
|
__nccwpck_require__(5327)(Yallist)
|
|
|
|
|
} catch (er) {}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/***/ }),
|
|
|
|
|
|
|
|
|
|
/***/ 9380:
|
|
|
|
|