fix chrome69 (dungeon master edition)
This commit is contained in:
parent
5d49edc823
commit
afa76b65b7
1 changed files with 7 additions and 3 deletions
|
@ -128,14 +128,18 @@ export const topoSort = (
|
||||||
while (unprocessed.length > 0) {
|
while (unprocessed.length > 0) {
|
||||||
step(unprocessed.pop())
|
step(unprocessed.pop())
|
||||||
}
|
}
|
||||||
return output.sort((a, b) => {
|
|
||||||
|
// The index thing is to make sorting stable on browsers
|
||||||
|
// where Array.sort() isn't stable
|
||||||
|
return output.map((data, index) => ({ data, index })).sort(({ data: a, index: ai }, { data: b, index: bi }) => {
|
||||||
|
console.log(a, b, ai, bi)
|
||||||
const depsA = getDeps(a, inheritance).length
|
const depsA = getDeps(a, inheritance).length
|
||||||
const depsB = getDeps(b, inheritance).length
|
const depsB = getDeps(b, inheritance).length
|
||||||
|
|
||||||
if (depsA === depsB || (depsB !== 0 && depsA !== 0)) return 0
|
if (depsA === depsB || (depsB !== 0 && depsA !== 0)) return ai - bi
|
||||||
if (depsA === 0 && depsB !== 0) return -1
|
if (depsA === 0 && depsB !== 0) return -1
|
||||||
if (depsB === 0 && depsA !== 0) return 1
|
if (depsB === 0 && depsA !== 0) return 1
|
||||||
})
|
}).map(({ data }) => data)
|
||||||
}
|
}
|
||||||
|
|
||||||
const expandSlotValue = (value) => {
|
const expandSlotValue = (value) => {
|
||||||
|
|
Loading…
Reference in a new issue