@nxtedition/lib 23.15.5 → 23.15.7

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@nxtedition/lib",
3
- "version": "23.15.5",
3
+ "version": "23.15.7",
4
4
  "license": "MIT",
5
5
  "author": "Robert Nagy <robert.nagy@boffins.se>",
6
6
  "type": "module",
@@ -631,14 +631,17 @@ export default function ({ ds, proxify, compiler, logger, platform }) {
631
631
  script = new Function(
632
632
  transform(`
633
633
  const _ = (value, ...fns) => {
634
- if (value != null) {
635
- for (const fn of fns) {
636
- value = fn(value)
637
- if (value == null) {
638
- return value
639
- }
634
+ if (value == null) {
635
+ return value
636
+ }
637
+
638
+ for (const fn of fns) {
639
+ value = fn(value)
640
+ if (value == null) {
641
+ return value
640
642
  }
641
643
  }
644
+
642
645
  return value
643
646
  };
644
647
  _.asset = (type, state, suspend) => (name) => nxt._asset(name, type, state, suspend);
package/yield.js CHANGED
@@ -1,29 +1,39 @@
1
1
  import { FixedQueue } from './fixed-queue.js'
2
2
 
3
- const yieldTimeout = 50
4
3
  const yieldQueue = new FixedQueue()
5
4
  const yieldSchedule = globalThis.setImmediate ?? ((fn) => setTimeout(fn, 0))
6
- let yieldScheduled = false
5
+
6
+ let yieldTimeout = 40
7
+ let yieldState = 0
7
8
  let yieldTime = performance.now()
8
- let yieldActive = false
9
9
 
10
- export function maybeYield(opts, callback) {
10
+ export function setYieldTimeout(timeout) {
11
+ if (typeof timeout !== 'number' || timeout < 0) {
12
+ throw new TypeError('timeout must be a positive number')
13
+ }
14
+ yieldTimeout = timeout
15
+ }
16
+
17
+ export function maybeYield(callback) {
11
18
  if (callback != null && typeof callback !== 'function') {
12
19
  throw new TypeError('callback must be a function')
13
20
  }
14
21
 
15
- return performance.now() - yieldTime < yieldTimeout ? null : doYield(opts, callback)
22
+ if (performance.now() - yieldTime < yieldTimeout) {
23
+ return null
24
+ }
25
+
26
+ return doYield(callback) ?? true
16
27
  }
17
28
 
18
- export function doYield(opts, callback) {
19
- if (!yieldScheduled) {
20
- yieldScheduled = true
29
+ export function doYield(callback) {
30
+ if (yieldState === 0) {
31
+ yieldState = 1
21
32
  yieldSchedule(dispatchYield)
22
33
  }
23
34
 
24
35
  if (callback) {
25
36
  yieldQueue.push(callback)
26
- return true
27
37
  } else {
28
38
  return new Promise((resolve) => {
29
39
  yieldQueue.push(resolve)
@@ -32,11 +42,11 @@ export function doYield(opts, callback) {
32
42
  }
33
43
 
34
44
  function dispatchYield() {
35
- if (yieldActive) {
45
+ if (yieldState === 2) {
36
46
  return
37
47
  }
38
48
 
39
- yieldActive = true
49
+ yieldState = 2
40
50
  yieldTime = performance.now()
41
51
 
42
52
  while (!yieldQueue.isEmpty()) {
@@ -45,15 +55,11 @@ function dispatchYield() {
45
55
  resolve(null)
46
56
 
47
57
  if (performance.now() - yieldTime > yieldTimeout) {
58
+ yieldState = 1
48
59
  yieldSchedule(dispatchYield)
49
60
  return
50
61
  }
51
62
  }
52
63
 
53
- yieldActive = false
54
- yieldScheduled = false
64
+ yieldState = 0
55
65
  }
56
-
57
- setInterval(() => {
58
- yieldTime = performance.now()
59
- }, 500).unref()