@webreflection/signals 0.1.8 → 0.1.9

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/README.md CHANGED
@@ -76,9 +76,9 @@ You know, nowadays it's hard to find libraries that are still 100% under control
76
76
  #### The Beauty
77
77
 
78
78
  * [signal](https://github.com/WebReflection/signals/blob/main/src/signal.js) is 26 LOC.
79
- * [computed](https://github.com/WebReflection/signals/blob/main/src/computed.js) is 33 LOC.
79
+ * [computed](https://github.com/WebReflection/signals/blob/main/src/computed.js) is 31 LOC.
80
80
  * the shared [stack](https://github.com/WebReflection/signals/blob/main/src/stack.js) is 18 LOC.
81
- * [effect](https://github.com/WebReflection/signals/blob/main/src/effect.js) is where business happens, 74 LOC.
81
+ * [effect](https://github.com/WebReflection/signals/blob/main/src/effect.js) is where business happens, 65 LOC.
82
82
  * [disposable](https://github.com/WebReflection/signals/blob/main/src/disposable.js) is 10 LOC, based on the core library mentioned in the previous points.
83
83
  * [branded](https://github.com/WebReflection/signals/blob/main/src/branded.js) is 25 LOC extra needed only for libraries building on top.
84
84
 
package/dist/branded.js CHANGED
@@ -1 +1 @@
1
- var c=!0,l=t=>{c=t},n,a=t=>{c&&n&&t.add(n)},i=(t,e)=>{let r=n;n=t;try{return e()}finally{n=r}};var u=new WeakSet,p=new WeakMap,f,W=t=>{let e=f;e||(f=[]);try{return t()}finally{if(!e){[e,f]=[f,e];for(let[r,o]of e)u.has(r)||o()}}},d=t=>{let e=p.get(t);if(e.length)for(let o of e.splice(0))b(o)},b=t=>{u.add(t),d(t),p.delete(t)},x=t=>{let e=()=>{o||u.has(e)||(o=!0,n||(f?f.push([e,r]):r()))},r=()=>{for(;o;)if(o=!1,d(e),s?.(),s=i(e,t),u.has(e))return},o=!0,s;return n&&p.get(n).push(e),p.set(e,[]),r(),()=>{p.has(e)&&(s?.(),b(e))}};var h=t=>{let e=new Set,r=!0,o,s=()=>{for(;r;)r=!1,o=i(k,t);return o},k=()=>{if(r)return;r=!0;let w=e;e=new Set;for(let y of w)y()};return{get value(){return a(e),s()},peek:s}};var g=t=>{let e=new Set;return{get value(){return a(e),t},set value(r){if(t=r,c){let o=e;e=new Set;for(let s of o)s()}},peek(){return t}}};var z=t=>{let e=c;l(!1);try{return t()}finally{l(e)}};var H=t=>function(...r){let o,s=x(()=>{o??=t.apply(this,r)??this});return o[Symbol.dispose]=s,o};var m=new WeakSet,N=t=>{let e=h(t);return m.add(e),e},O=t=>m.has(t),P=t=>{let e=g(t);return m.add(e),e};export{W as batch,N as computed,H as disposable,x as effect,O as isSignal,P as signal,z as untracked};
1
+ var f=!0,l=t=>{f=t},s,u=t=>{f&&s&&t.add(s)},a=(t,e)=>{let r=s;s=t;try{return e()}finally{s=r}};var i=new WeakMap,p,S=t=>{let e=p;e||(p=[]);try{return t()}finally{if(!e){[e,p]=[p,e];for(let[r,o]of e)i.has(r)&&o()}}},d=t=>{t.c?.(),t.s.length&&t.s.splice(0).forEach(x)},x=t=>{let e=i.get(t);e.d=!0,d(e),i.delete(t)},b=t=>{let e=()=>{o||c.d||(o=!0,s||(p?p.push([e,r]):r()))},r=()=>{for(;o;)if(o=!1,d(c),c.c=a(e,t),c.d)return},o=!0,n,c={s:[],d:!o,c:n};return s&&i.get(s).s.push(e),i.set(e,c),r(),()=>{c.d||x(e)}};var g=t=>{let e=new Set,r=!0,o,n=()=>{for(;r;)r=!1,o=a(c,t);return o},c=()=>{if(r)return;r=!0;let k=e;e=new Set;for(let w of k)w()};return{get value(){return u(e),n()},peek:n}};var h=t=>{let e=new Set;return{get value(){return u(e),t},set value(r){if(t=r,f){let o=e;e=new Set;for(let n of o)n()}},peek(){return t}}};var j=t=>{let e=f;l(!1);try{return t()}finally{l(e)}};var G=t=>function(...r){let o,n=b(()=>{o??=t.apply(this,r)??this});return o[Symbol.dispose]=n,o};var m=new WeakSet,L=t=>{let e=g(t);return m.add(e),e},N=t=>m.has(t),O=t=>{let e=h(t);return m.add(e),e};export{S as batch,L as computed,G as disposable,b as effect,N as isSignal,O as signal,j as untracked};
@@ -1 +1 @@
1
- var c=!0,a=t=>{c=t},n,i=t=>{c&&n&&t.add(n)},p=(t,e)=>{let r=n;n=t;try{return e()}finally{n=r}};var l=new WeakSet,u=new WeakMap,f,y=t=>{let e=f;e||(f=[]);try{return t()}finally{if(!e){[e,f]=[f,e];for(let[r,o]of e)l.has(r)||o()}}},b=t=>{let e=u.get(t);if(e.length)for(let o of e.splice(0))h(o)},h=t=>{l.add(t),b(t),u.delete(t)},m=t=>{let e=()=>{o||l.has(e)||(o=!0,n||(f?f.push([e,r]):r()))},r=()=>{for(;o;)if(o=!1,b(e),s?.(),s=p(e,t),l.has(e))return},o=!0,s;return n&&u.get(n).push(e),u.set(e,[]),r(),()=>{u.has(e)&&(s?.(),h(e))}};var T=t=>{let e=new Set,r=!0,o,s=()=>{for(;r;)r=!1,o=p(d,t);return o},d=()=>{if(r)return;r=!0;let x=e;e=new Set;for(let g of x)g()};return{get value(){return i(e),s()},peek:s}};var U=t=>{let e=new Set;return{get value(){return i(e),t},set value(r){if(t=r,c){let o=e;e=new Set;for(let s of o)s()}},peek(){return t}}};var z=t=>{let e=c;a(!1);try{return t()}finally{a(e)}};var H=t=>function(...r){let o,s=m(()=>{o??=t.apply(this,r)??this});return o[Symbol.dispose]=s,o};export{y as batch,T as computed,H as disposable,m as effect,U as signal,z as untracked};
1
+ var c=!0,a=t=>{c=t},s,p=t=>{c&&s&&t.add(s)},l=(t,e)=>{let r=s;s=t;try{return e()}finally{s=r}};var i=new WeakMap,u,y=t=>{let e=u;e||(u=[]);try{return t()}finally{if(!e){[e,u]=[u,e];for(let[r,o]of e)i.has(r)&&o()}}},b=t=>{t.c?.(),t.s.length&&t.s.splice(0).forEach(m)},m=t=>{let e=i.get(t);e.d=!0,b(e),i.delete(t)},d=t=>{let e=()=>{o||f.d||(o=!0,s||(u?u.push([e,r]):r()))},r=()=>{for(;o;)if(o=!1,b(f),f.c=l(e,t),f.d)return},o=!0,n,f={s:[],d:!o,c:n};return s&&i.get(s).s.push(e),i.set(e,f),r(),()=>{f.d||m(e)}};var S=t=>{let e=new Set,r=!0,o,n=()=>{for(;r;)r=!1,o=l(f,t);return o},f=()=>{if(r)return;r=!0;let x=e;e=new Set;for(let h of x)h()};return{get value(){return p(e),n()},peek:n}};var M=t=>{let e=new Set;return{get value(){return p(e),t},set value(r){if(t=r,c){let o=e;e=new Set;for(let n of o)n()}},peek(){return t}}};var j=t=>{let e=c;a(!1);try{return t()}finally{a(e)}};var G=t=>function(...r){let o,n=d(()=>{o??=t.apply(this,r)??this});return o[Symbol.dispose]=n,o};export{y as batch,S as computed,G as disposable,d as effect,M as signal,j as untracked};
package/dist/signals.js CHANGED
@@ -1 +1 @@
1
- var c=!0,p=t=>{c=t},s,a=t=>{c&&s&&t.add(s)},i=(t,e)=>{let r=s;s=t;try{return e()}finally{s=r}};var l=new WeakSet,u=new WeakMap,f,w=t=>{let e=f;e||(f=[]);try{return t()}finally{if(!e){[e,f]=[f,e];for(let[r,o]of e)l.has(r)||o()}}},b=t=>{let e=u.get(t);if(e.length)for(let o of e.splice(0))h(o)},h=t=>{l.add(t),b(t),u.delete(t)},v=t=>{let e=()=>{o||l.has(e)||(o=!0,s||(f?f.push([e,r]):r()))},r=()=>{for(;o;)if(o=!1,b(e),n?.(),n=i(e,t),l.has(e))return},o=!0,n;return s&&u.get(s).push(e),u.set(e,[]),r(),()=>{u.has(e)&&(n?.(),h(e))}};var T=t=>{let e=new Set,r=!0,o,n=()=>{for(;r;)r=!1,o=i(x,t);return o},x=()=>{if(r)return;r=!0;let d=e;e=new Set;for(let g of d)g()};return{get value(){return a(e),n()},peek:n}};var U=t=>{let e=new Set;return{get value(){return a(e),t},set value(r){if(t=r,c){let o=e;e=new Set;for(let n of o)n()}},peek(){return t}}};var z=t=>{let e=c;p(!1);try{return t()}finally{p(e)}};export{w as batch,T as computed,v as effect,U as signal,z as untracked};
1
+ var f=!0,a=t=>{f=t},s,l=t=>{f&&s&&t.add(s)},p=(t,e)=>{let r=s;s=t;try{return e()}finally{s=r}};var i=new WeakMap,u,k=t=>{let e=u;e||(u=[]);try{return t()}finally{if(!e){[e,u]=[u,e];for(let[r,o]of e)i.has(r)&&o()}}},b=t=>{t.c?.(),t.s.length&&t.s.splice(0).forEach(x)},x=t=>{let e=i.get(t);e.d=!0,b(e),i.delete(t)},w=t=>{let e=()=>{o||n.d||(o=!0,s||(u?u.push([e,r]):r()))},r=()=>{for(;o;)if(o=!1,b(n),n.c=p(e,t),n.d)return},o=!0,c,n={s:[],d:!o,c};return s&&i.get(s).s.push(e),i.set(e,n),r(),()=>{n.d||x(e)}};var S=t=>{let e=new Set,r=!0,o,c=()=>{for(;r;)r=!1,o=p(n,t);return o},n=()=>{if(r)return;r=!0;let d=e;e=new Set;for(let m of d)m()};return{get value(){return l(e),c()},peek:c}};var M=t=>{let e=new Set;return{get value(){return l(e),t},set value(r){if(t=r,f){let o=e;e=new Set;for(let c of o)c()}},peek(){return t}}};var j=t=>{let e=f;a(!1);try{return t()}finally{a(e)}};export{k as batch,S as computed,w as effect,M as signal,j as untracked};
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@webreflection/signals",
3
- "version": "0.1.8",
3
+ "version": "0.1.9",
4
4
  "description": "A minimalistic Preact-like signals implementation",
5
5
  "main": "src/index.js",
6
6
  "module": "src/index.js",
package/src/effect.js CHANGED
@@ -1,45 +1,40 @@
1
1
  import { run, stack } from './stack.js';
2
2
 
3
- const disposed = new WeakSet;
4
3
  const effects = new WeakMap;
5
4
 
6
5
  let batches;
7
6
 
8
7
  /** @type {<T>(fn: () => T) => T} */
9
8
  export const batch = fn => {
10
- let updates = batches;
11
- if (!updates) batches = [];
9
+ let before = batches;
10
+ if (!before) batches = [];
12
11
  try { return fn() }
13
12
  finally {
14
- if (!updates) {
15
- [updates, batches] = [batches, updates];
16
- for (const [subscriber, run] of updates) {
17
- if (!disposed.has(subscriber)) run();
13
+ if (!before) {
14
+ [before, batches] = [batches, before];
15
+ for (const [sub, loop] of before) {
16
+ if (effects.has(sub)) loop();
18
17
  }
19
18
  }
20
19
  }
21
20
  };
22
21
 
23
- const cleanUp = subscriber => {
24
- const subscribers = effects.get(subscriber);
25
- const length = subscribers.length;
26
- if (length) {
27
- for (const subscriber of subscribers.splice(0)) {
28
- drop(subscriber);
29
- }
30
- }
22
+ const cleanUp = state => {
23
+ state.c?.();
24
+ if (state.s.length) state.s.splice(0).forEach(dispose);
31
25
  };
32
26
 
33
- const drop = subscriber => {
34
- disposed.add(subscriber);
35
- cleanUp(subscriber);
27
+ const dispose = subscriber => {
28
+ const state = effects.get(subscriber);
29
+ state.d = true;
30
+ cleanUp(state);
36
31
  effects.delete(subscriber);
37
32
  };
38
33
 
39
34
  /** @type {(fn: (() => void | (() => void))) => (() => void)} */
40
35
  export const effect = fn => {
41
36
  const subscriber = () => {
42
- if (invalid || disposed.has(subscriber)) return;
37
+ if (invalid || state.d) return;
43
38
  invalid = true;
44
39
  if (!stack) {
45
40
  if (batches) batches.push([subscriber, loop]);
@@ -50,25 +45,21 @@ export const effect = fn => {
50
45
  const loop = () => {
51
46
  while (invalid) {
52
47
  invalid = false;
53
- cleanUp(subscriber);
54
- clean?.();
55
- clean = run(subscriber, fn);
56
- if (disposed.has(subscriber)) return;
48
+ cleanUp(state);
49
+ state.c = run(subscriber, fn);
50
+ if (state.d) return;
57
51
  }
58
52
  };
59
53
 
60
- let invalid = true, clean;
54
+ let invalid = true, c, state = { s: [], d: !invalid, c };
61
55
 
62
- if (stack) effects.get(stack).push(subscriber);
56
+ if (stack) effects.get(stack).s.push(subscriber);
63
57
 
64
- effects.set(subscriber, []);
58
+ effects.set(subscriber, state);
65
59
 
66
60
  loop();
67
61
 
68
62
  return () => {
69
- if (effects.has(subscriber)) {
70
- clean?.();
71
- drop(subscriber);
72
- }
63
+ if (!state.d) dispose(subscriber);
73
64
  };
74
65
  };