@webreflection/signals 0.1.5 → 0.1.6

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/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,f=new WeakMap,b=[],p=!1,T=t=>{let e=!p;e&&(p=!0);try{return t()}finally{if(e){p=!1;for(let[r,o]of b.splice(0))u.has(r)||o()}}},x=t=>{let e=f.get(t);if(e.length)for(let o of e.splice(0))h(o)},h=t=>{u.add(t),x(t),f.delete(t)},g=t=>{let e=()=>{o||u.has(e)||(o=!0,n||(p?b.push([e,r]):r()))},r=()=>{for(;o;)if(o=!1,x(e),s?.(),s=i(e,t),u.has(e))return},o=!0,s;return n&&f.get(n).push(e),f.set(e,[]),r(),()=>{f.has(e)&&(s?.(),h(e))}};var k=t=>{let e=new Set,r=!0,o,s=()=>{if(r)return;r=!0;let y=e;e=new Set;for(let S of y)S()},d=()=>{for(;r;)r=!1,o=i(s,t);return o};return{get value(){return a(e),d()},peek(){return d()}}};var w=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 A=t=>{let e=c;l(!1);try{return t()}finally{l(e)}};var I=t=>function(...r){let o,s=g(()=>{o??=t.apply(this,r)??this});return o[Symbol.dispose]=s,o};var m=new WeakSet,O=t=>{let e=k(t);return m.add(e),e},P=t=>m.has(t),Q=t=>{let e=w(t);return m.add(e),e};export{T as batch,O as computed,I as disposable,g as effect,P as isSignal,Q as signal,A as untracked};
1
+ var c=!0,l=t=>{c=t},n,i=t=>{c&&n&&t.add(n)},a=(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()}}},b=t=>{let e=p.get(t);if(e.length)for(let o of e.splice(0))x(o)},x=t=>{u.add(t),b(t),p.delete(t)},g=t=>{let e=()=>{o||u.has(e)||(o=!0,n||(f?f.push([e,r]):r()))},r=()=>{for(;o;)if(o=!1,b(e),s?.(),s=a(e,t),u.has(e))return},o=!0,s;return n&&p.get(n).push(e),p.set(e,[]),r(),()=>{p.has(e)&&(s?.(),x(e))}};var h=t=>{let e=new Set,r=!0,o,s=()=>{if(r)return;r=!0;let w=e;e=new Set;for(let y of w)y()},d=()=>{for(;r;)r=!1,o=a(s,t);return o};return{get value(){return i(e),d()},peek(){return d()}}};var k=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;l(!1);try{return t()}finally{l(e)}};var H=t=>function(...r){let o,s=g(()=>{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=k(t);return m.add(e),e};export{W as batch,N as computed,H as disposable,g as effect,O as isSignal,P as signal,z as untracked};
@@ -1 +1 @@
1
- var c=!0,p=t=>{c=t},n,i=t=>{c&&n&&t.add(n)},u=(t,e)=>{let r=n;n=t;try{return e()}finally{n=r}};var a=new WeakSet,f=new WeakMap,h=[],l=!1,v=t=>{let e=!l;e&&(l=!0);try{return t()}finally{if(e){l=!1;for(let[r,o]of h.splice(0))a.has(r)||o()}}},m=t=>{let e=f.get(t);if(e.length)for(let o of e.splice(0))d(o)},d=t=>{a.add(t),m(t),f.delete(t)},x=t=>{let e=()=>{o||a.has(e)||(o=!0,n||(l?h.push([e,r]):r()))},r=()=>{for(;o;)if(o=!1,m(e),s?.(),s=u(e,t),a.has(e))return},o=!0,s;return n&&f.get(n).push(e),f.set(e,[]),r(),()=>{f.has(e)&&(s?.(),d(e))}};var W=t=>{let e=new Set,r=!0,o,s=()=>{if(r)return;r=!0;let g=e;e=new Set;for(let k of g)k()},b=()=>{for(;r;)r=!1,o=u(s,t);return o};return{get value(){return i(e),b()},peek(){return b()}}};var j=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 A=t=>{let e=c;p(!1);try{return t()}finally{p(e)}};var I=t=>function(...r){let o,s=x(()=>{o??=t.apply(this,r)??this});return o[Symbol.dispose]=s,o};export{v as batch,W as computed,I as disposable,x as effect,j as signal,A as untracked};
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()}}},h=t=>{let e=u.get(t);if(e.length)for(let o of e.splice(0))m(o)},m=t=>{l.add(t),h(t),u.delete(t)},d=t=>{let e=()=>{o||l.has(e)||(o=!0,n||(f?f.push([e,r]):r()))},r=()=>{for(;o;)if(o=!1,h(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?.(),m(e))}};var T=t=>{let e=new Set,r=!0,o,s=()=>{if(r)return;r=!0;let x=e;e=new Set;for(let g of x)g()},b=()=>{for(;r;)r=!1,o=p(s,t);return o};return{get value(){return i(e),b()},peek(){return b()}}};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=d(()=>{o??=t.apply(this,r)??this});return o[Symbol.dispose]=s,o};export{y as batch,T as computed,H as disposable,d as effect,U as signal,z as untracked};
package/dist/signals.js CHANGED
@@ -1 +1 @@
1
- var c=!0,p=t=>{c=t},s,u=t=>{c&&s&&t.add(s)},i=(t,e)=>{let r=s;s=t;try{return e()}finally{s=r}};var l=new WeakSet,f=new WeakMap,h=[],a=!1,v=t=>{let e=!a;e&&(a=!0);try{return t()}finally{if(e){a=!1;for(let[r,o]of h.splice(0))l.has(r)||o()}}},g=t=>{let e=f.get(t);if(e.length)for(let o of e.splice(0))x(o)},x=t=>{l.add(t),g(t),f.delete(t)},y=t=>{let e=()=>{o||l.has(e)||(o=!0,s||(a?h.push([e,r]):r()))},r=()=>{for(;o;)if(o=!1,g(e),n?.(),n=i(e,t),l.has(e))return},o=!0,n;return s&&f.get(s).push(e),f.set(e,[]),r(),()=>{f.has(e)&&(n?.(),x(e))}};var W=t=>{let e=new Set,r=!0,o,n=()=>{if(r)return;r=!0;let d=e;e=new Set;for(let m of d)m()},b=()=>{for(;r;)r=!1,o=i(n,t);return o};return{get value(){return u(e),b()},peek(){return b()}}};var j=t=>{let e=new Set;return{get value(){return u(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 A=t=>{let e=c;p(!1);try{return t()}finally{p(e)}};export{v as batch,W as computed,y as effect,j as signal,A as untracked};
1
+ var c=!0,p=t=>{c=t},s,i=t=>{c&&s&&t.add(s)},a=(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()}}},h=t=>{let e=u.get(t);if(e.length)for(let o of e.splice(0))g(o)},g=t=>{l.add(t),h(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,h(e),n?.(),n=a(e,t),l.has(e))return},o=!0,n;return s&&u.get(s).push(e),u.set(e,[]),r(),()=>{u.has(e)&&(n?.(),g(e))}};var T=t=>{let e=new Set,r=!0,o,n=()=>{if(r)return;r=!0;let x=e;e=new Set;for(let d of x)d()},b=()=>{for(;r;)r=!1,o=a(n,t);return o};return{get value(){return i(e),b()},peek(){return b()}}};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 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};
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@webreflection/signals",
3
- "version": "0.1.5",
3
+ "version": "0.1.6",
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
@@ -2,19 +2,18 @@ import { run, stack } from './stack.js';
2
2
 
3
3
  const disposed = new WeakSet;
4
4
  const effects = new WeakMap;
5
- const batches = [];
6
5
 
7
- let batching = false;
6
+ let batches;
8
7
 
9
8
  /** @type {<T>(fn: () => T) => T} */
10
9
  export const batch = fn => {
11
- const handle = !batching;
12
- if (handle) batching = true;
10
+ let updates = batches;
11
+ if (!updates) batches = [];
13
12
  try { return fn() }
14
13
  finally {
15
- if (handle) {
16
- batching = false;
17
- for (const [subscriber, run] of batches.splice(0)) {
14
+ if (!updates) {
15
+ [updates, batches] = [batches, updates];
16
+ for (const [subscriber, run] of updates) {
18
17
  if (!disposed.has(subscriber)) run();
19
18
  }
20
19
  }
@@ -43,7 +42,7 @@ export const effect = fn => {
43
42
  if (invalid || disposed.has(subscriber)) return;
44
43
  invalid = true;
45
44
  if (!stack) {
46
- if (batching) batches.push([subscriber, loop]);
45
+ if (batches) batches.push([subscriber, loop]);
47
46
  else loop();
48
47
  }
49
48
  };