tinybase 7.3.2 → 7.3.3
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/min/omni/index.js +1 -1
- package/min/omni/index.js.gz +0 -0
- package/min/omni/with-schemas/index.js +1 -1
- package/min/omni/with-schemas/index.js.gz +0 -0
- package/min/persisters/index.js +1 -1
- package/min/persisters/index.js.gz +0 -0
- package/min/persisters/persister-browser/index.js +1 -1
- package/min/persisters/persister-browser/index.js.gz +0 -0
- package/min/persisters/persister-browser/with-schemas/index.js +1 -1
- package/min/persisters/persister-browser/with-schemas/index.js.gz +0 -0
- package/min/persisters/persister-cr-sqlite-wasm/index.js +1 -1
- package/min/persisters/persister-cr-sqlite-wasm/index.js.gz +0 -0
- package/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.js +1 -1
- package/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.js.gz +0 -0
- package/min/persisters/persister-durable-object-sql-storage/index.js +1 -1
- package/min/persisters/persister-durable-object-sql-storage/index.js.gz +0 -0
- package/min/persisters/persister-durable-object-sql-storage/with-schemas/index.js +1 -1
- package/min/persisters/persister-durable-object-sql-storage/with-schemas/index.js.gz +0 -0
- package/min/persisters/persister-electric-sql/index.js +1 -1
- package/min/persisters/persister-electric-sql/index.js.gz +0 -0
- package/min/persisters/persister-electric-sql/with-schemas/index.js +1 -1
- package/min/persisters/persister-electric-sql/with-schemas/index.js.gz +0 -0
- package/min/persisters/persister-expo-sqlite/index.js +1 -1
- package/min/persisters/persister-expo-sqlite/index.js.gz +0 -0
- package/min/persisters/persister-expo-sqlite/with-schemas/index.js +1 -1
- package/min/persisters/persister-expo-sqlite/with-schemas/index.js.gz +0 -0
- package/min/persisters/persister-file/index.js +1 -1
- package/min/persisters/persister-file/index.js.gz +0 -0
- package/min/persisters/persister-file/with-schemas/index.js +1 -1
- package/min/persisters/persister-file/with-schemas/index.js.gz +0 -0
- package/min/persisters/persister-libsql/index.js +1 -1
- package/min/persisters/persister-libsql/index.js.gz +0 -0
- package/min/persisters/persister-libsql/with-schemas/index.js +1 -1
- package/min/persisters/persister-libsql/with-schemas/index.js.gz +0 -0
- package/min/persisters/persister-partykit-client/index.js +1 -1
- package/min/persisters/persister-partykit-client/index.js.gz +0 -0
- package/min/persisters/persister-partykit-client/with-schemas/index.js +1 -1
- package/min/persisters/persister-partykit-client/with-schemas/index.js.gz +0 -0
- package/min/persisters/persister-partykit-server/index.js +1 -1
- package/min/persisters/persister-partykit-server/index.js.gz +0 -0
- package/min/persisters/persister-partykit-server/with-schemas/index.js +1 -1
- package/min/persisters/persister-partykit-server/with-schemas/index.js.gz +0 -0
- package/min/persisters/persister-pglite/index.js +1 -1
- package/min/persisters/persister-pglite/index.js.gz +0 -0
- package/min/persisters/persister-pglite/with-schemas/index.js +1 -1
- package/min/persisters/persister-pglite/with-schemas/index.js.gz +0 -0
- package/min/persisters/persister-postgres/index.js +1 -1
- package/min/persisters/persister-postgres/index.js.gz +0 -0
- package/min/persisters/persister-postgres/with-schemas/index.js +1 -1
- package/min/persisters/persister-postgres/with-schemas/index.js.gz +0 -0
- package/min/persisters/persister-powersync/index.js +1 -1
- package/min/persisters/persister-powersync/index.js.gz +0 -0
- package/min/persisters/persister-powersync/with-schemas/index.js +1 -1
- package/min/persisters/persister-powersync/with-schemas/index.js.gz +0 -0
- package/min/persisters/persister-react-native-sqlite/index.js +1 -1
- package/min/persisters/persister-react-native-sqlite/index.js.gz +0 -0
- package/min/persisters/persister-react-native-sqlite/with-schemas/index.js +1 -1
- package/min/persisters/persister-react-native-sqlite/with-schemas/index.js.gz +0 -0
- package/min/persisters/persister-sqlite-bun/index.js +1 -1
- package/min/persisters/persister-sqlite-bun/index.js.gz +0 -0
- package/min/persisters/persister-sqlite-bun/with-schemas/index.js +1 -1
- package/min/persisters/persister-sqlite-bun/with-schemas/index.js.gz +0 -0
- package/min/persisters/persister-sqlite-wasm/index.js +1 -1
- package/min/persisters/persister-sqlite-wasm/index.js.gz +0 -0
- package/min/persisters/persister-sqlite-wasm/with-schemas/index.js +1 -1
- package/min/persisters/persister-sqlite-wasm/with-schemas/index.js.gz +0 -0
- package/min/persisters/persister-sqlite3/index.js +1 -1
- package/min/persisters/persister-sqlite3/index.js.gz +0 -0
- package/min/persisters/persister-sqlite3/with-schemas/index.js +1 -1
- package/min/persisters/persister-sqlite3/with-schemas/index.js.gz +0 -0
- package/min/persisters/with-schemas/index.js +1 -1
- package/min/persisters/with-schemas/index.js.gz +0 -0
- package/min/synchronizers/synchronizer-ws-client/index.js +1 -1
- package/min/synchronizers/synchronizer-ws-client/index.js.gz +0 -0
- package/min/synchronizers/synchronizer-ws-client/with-schemas/index.js +1 -1
- package/min/synchronizers/synchronizer-ws-client/with-schemas/index.js.gz +0 -0
- package/min/synchronizers/synchronizer-ws-server/index.js +1 -1
- package/min/synchronizers/synchronizer-ws-server/index.js.gz +0 -0
- package/min/synchronizers/synchronizer-ws-server/with-schemas/index.js +1 -1
- package/min/synchronizers/synchronizer-ws-server/with-schemas/index.js.gz +0 -0
- package/min/synchronizers/synchronizer-ws-server-durable-object/index.js +1 -1
- package/min/synchronizers/synchronizer-ws-server-durable-object/index.js.gz +0 -0
- package/min/synchronizers/synchronizer-ws-server-durable-object/with-schemas/index.js +1 -1
- package/min/synchronizers/synchronizer-ws-server-durable-object/with-schemas/index.js.gz +0 -0
- package/min/ui-react-inspector/index.js +1 -1
- package/min/ui-react-inspector/index.js.gz +0 -0
- package/min/ui-react-inspector/with-schemas/index.js +1 -1
- package/min/ui-react-inspector/with-schemas/index.js.gz +0 -0
- package/omni/index.js +16 -3
- package/omni/with-schemas/index.js +16 -3
- package/package.json +13 -13
- package/persisters/index.js +10 -1
- package/persisters/persister-browser/index.js +17 -1
- package/persisters/persister-browser/with-schemas/index.js +17 -1
- package/persisters/persister-cr-sqlite-wasm/index.js +10 -1
- package/persisters/persister-cr-sqlite-wasm/with-schemas/index.js +10 -1
- package/persisters/persister-durable-object-sql-storage/index.js +10 -1
- package/persisters/persister-durable-object-sql-storage/with-schemas/index.js +10 -1
- package/persisters/persister-electric-sql/index.js +10 -1
- package/persisters/persister-electric-sql/with-schemas/index.js +10 -1
- package/persisters/persister-expo-sqlite/index.js +10 -1
- package/persisters/persister-expo-sqlite/with-schemas/index.js +10 -1
- package/persisters/persister-file/index.js +17 -1
- package/persisters/persister-file/with-schemas/index.js +17 -1
- package/persisters/persister-libsql/index.js +10 -1
- package/persisters/persister-libsql/with-schemas/index.js +10 -1
- package/persisters/persister-partykit-client/index.js +27 -2
- package/persisters/persister-partykit-client/with-schemas/index.js +27 -2
- package/persisters/persister-partykit-server/index.js +37 -2
- package/persisters/persister-partykit-server/with-schemas/index.js +37 -2
- package/persisters/persister-pglite/index.js +10 -1
- package/persisters/persister-pglite/with-schemas/index.js +10 -1
- package/persisters/persister-postgres/index.js +10 -1
- package/persisters/persister-postgres/with-schemas/index.js +10 -1
- package/persisters/persister-powersync/index.js +10 -1
- package/persisters/persister-powersync/with-schemas/index.js +10 -1
- package/persisters/persister-react-native-sqlite/index.js +10 -1
- package/persisters/persister-react-native-sqlite/with-schemas/index.js +10 -1
- package/persisters/persister-sqlite-bun/index.js +10 -1
- package/persisters/persister-sqlite-bun/with-schemas/index.js +10 -1
- package/persisters/persister-sqlite-wasm/index.js +10 -1
- package/persisters/persister-sqlite-wasm/with-schemas/index.js +10 -1
- package/persisters/persister-sqlite3/index.js +10 -1
- package/persisters/persister-sqlite3/with-schemas/index.js +10 -1
- package/persisters/with-schemas/index.js +10 -1
- package/readme.md +9 -1
- package/releases.md +1 -1
- package/synchronizers/synchronizer-ws-client/index.js +14 -1
- package/synchronizers/synchronizer-ws-client/with-schemas/index.js +14 -1
- package/synchronizers/synchronizer-ws-server/index.js +14 -1
- package/synchronizers/synchronizer-ws-server/with-schemas/index.js +14 -1
- package/synchronizers/synchronizer-ws-server-durable-object/index.js +14 -1
- package/synchronizers/synchronizer-ws-server-durable-object/with-schemas/index.js +14 -1
- package/ui-react-inspector/index.js +10 -1
- package/ui-react-inspector/with-schemas/index.js +10 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
const t=t=>(e,a,n)=>t(e)?n?.():a(e),e=globalThis.window,a=t=>null==t,n=t=>void 0===t,s=t=>null===t,r=t(a),o=t(n),i=t=>Array.isArray(t),c=t=>t.length,l=t=>{throw Error(t)},y=async(t,e,a)=>{try{return await t()}catch(t){e?.(t)}},g=(t,e)=>t.forEach(e),u=(t,...e)=>t.push(...e),
|
|
1
|
+
const t=t=>(e,a,n)=>t(e)?n?.():a(e),e=globalThis.window,a=t=>null==t,n=t=>void 0===t,s=t=>null===t,r=t(a),o=t(n),i=t=>Array.isArray(t),c=t=>t.length,l=t=>{throw Error(t)},y=async(t,e,a)=>{try{return await t()}catch(t){e?.(t)}},g=(t,e)=>t.forEach(e),u=(t,e)=>t.map(e),w=(t,...e)=>t.push(...e),d=t=>t.shift(),p=Object,v=t=>p.getPrototypeOf(t),h=p.entries,S=t=>!a(t)&&r(v(t),t=>t==p.prototype||a(v(t)),()=>!0),b=p.keys,f=p.freeze,A=t=>S(t)&&0==(t=>c(b(t)))(t),C=JSON.stringify,L=JSON.parse,m=t=>C(t,(t,e)=>n(e)?"":e),E=t=>M(L(t)),M=t=>""===t?void 0:i(t)?u(t,M):S(t)?((t,e)=>((t=[])=>p.fromEntries(t))(((t,e)=>u(h(t),([t,a])=>e(a,t)))(t,(t,a)=>[a,e(t,a)])))(t,M):t,O=t=>n(t)||0==(t=>t?.size??0)(t),P=(t,e)=>t?.forEach(e),T=(t,e)=>t?.delete(e),F=t=>new Map(t),N=(t,e)=>t?.get(e),k=(t,e,a)=>n(a)?(T(t,e),t):t?.set(e,a),x=(t,e,a,n)=>{var s,r;return s=t,r=e,s?.has(r)?n?.(N(t,e)):k(t,e,a()),N(t,e)},z=(t,e,a,n,s=0)=>o((a?x:N)(t,e[s],s>c(e)-2?a:F),r=>{if(s>c(e)-2)return n?.(r)&&k(t,e[s]),r;const o=z(r,e,a,n,s+1);return O(r)&&k(t,e[s]),o}),D=/^\d+$/,I=t=>new Set(i(t)||n(t)?t:[t]),J=F(),j=F(),H=(t,e,a,r,u,p,v,h={},S=0,b=[])=>{let C,L,m,E=0,M=0,H=0;x(J,b,()=>0),x(j,b,()=>[]);const V=F(),[W,$,q,B,G]=((t=1,e,a)=>1!=t&&e.isMergeable()?[1,e.getMergeableContent,()=>e.getTransactionMergeableChanges(!a),([[t],[e]])=>!A(t)||!A(e),e.setDefaultContent]:2!=t?[0,e.getContent,e.getTransactionChanges,([t,e])=>!A(t)||!A(e),e.setContent]:l("Store type not supported by this Persister"))(v,t,S),[K,Q,R]=(()=>{let t;const[e,a]=(()=>{const t=[];let e=0;return[a=>(a?d(t):null)??""+e++,e=>{D.test(e)&&c(t)<1e3&&w(t,e)}]})(),n=F();return[(a,s,r,o=[],i=()=>[])=>{t??=rt;const c=e(1);var l,y;return k(n,c,[a,s,r,o,i]),l=z(s,r??[""],I),y=c,l?.add(y),c},(e,a,...r)=>g(((t,e=[""])=>{const a=[],n=(t,r)=>r==c(e)?w(a,t):s(e[r])?P(t,t=>n(t,r+1)):g([e[r],null],e=>n(N(t,e),r+1));return n(t,0),a})(e,a),e=>P(e,e=>N(n,e)[0](t,...a??[],...r))),t=>o(N(n,t),([,e,s])=>(z(e,s??[""],void 0,e=>(T(e,t),O(e)?1:0)),k(n,t),a(t),s)),e=>o(N(n,e),([e,,a=[],n,r])=>{const o=(...i)=>{const l=c(i);l==c(a)?e(t,...i,...r(i)):s(a[l])?g(n[l]?.(...i)??[],t=>o(...i,t)):o(...i,a[l])};o()})]})(),U=t=>{t!=E&&(E=t,Q(V,void 0,E))},X=e=>{(W&&i(e?.[0])?1===e?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===e?.[2]?t.applyChanges:t.setContent)(e)},Y=async t=>(2!=E&&(U(1),M++,await st(async()=>{await y(async()=>{const a=await e();i(a)?X(a):t?G(t):l("Content is not an array: "+a)},()=>{t&&G(t)}),U(0)})),rt),Z=async t=>(_(),await Y(t),await y(async()=>L=await r(async(t,e)=>{e||t?2!=E&&(U(1),M++,X(e??t),U(0)):await Y()}),p),rt),_=async()=>(L&&(await y(()=>u(L),p),L=void 0),rt),tt=async t=>(1!=E&&(U(2),H++,await st(async()=>{await y(()=>a($,t),p),U(0)})),rt),et=async()=>(at(),await tt(),m=t.addDidFinishTransactionListener(()=>{const t=q();B(t)&&tt(t)}),rt),at=async()=>(m&&(t.delListener(m),m=void 0),rt),nt=async(t=!1)=>{const[e,a]=t?[at,_]:[_,at];return await e(),await a(),rt},st=async(...t)=>(w(N(j,b),...t),await(async()=>{if(!N(J,b)){for(k(J,b,1);!n(C=d(N(j,b)));)await y(C,p);k(J,b,0)}})(),rt),rt={load:Y,startAutoLoad:Z,stopAutoLoad:_,isAutoLoading:()=>!n(L),save:tt,startAutoSave:et,stopAutoSave:at,isAutoSaving:()=>!n(m),startAutoPersisting:async(t,e=!1)=>{const[a,n]=e?[et,Z]:[Z,et];return await a(t),await n(t),rt},stopAutoPersisting:nt,getStatus:()=>E,addStatusListener:t=>K(t,V),delListener:e=>(R(e),t),schedule:st,getStore:()=>t,destroy:()=>(N(j,b).splice(0,void 0),nt()),getStats:()=>({loads:M,saves:H}),...h};return f(rt)},V="storage",W=(t,a,n,s)=>H(t,async()=>E(n.getItem(a)),async t=>n.setItem(a,m(t())),t=>{const s=e=>{e.storageArea===n&&e.key===a&&y(()=>t(E(e.newValue)),t)};return e.addEventListener(V,s),s},t=>e.removeEventListener(V,t),s,3,{getStorageName:()=>a}),$=(t,e,a)=>W(t,e,localStorage,a),q=(t,e,a)=>W(t,e,sessionStorage,a),B=(t,e,a)=>H(t,async()=>E(await(await e.getFile()).text()),async t=>{const a=await e.createWritable();await a.write(m(t())),await a.close()},async t=>{const a=new FileSystemObserver(()=>t());return await a.observe(e),a},t=>t?.disconnect(),a,3,{getHandle:()=>e});export{$ as createLocalPersister,B as createOpfsPersister,q as createSessionPersister};
|
|
Binary file
|
|
@@ -1 +1 @@
|
|
|
1
|
-
const t=t=>(e,a,n)=>t(e)?n?.():a(e),e=globalThis.window,a=t=>null==t,n=t=>void 0===t,s=t=>null===t,r=t(a),o=t(n),i=t=>Array.isArray(t),c=t=>t.length,l=t=>{throw Error(t)},y=async(t,e,a)=>{try{return await t()}catch(t){e?.(t)}},g=(t,e)=>t.forEach(e),u=(t,...e)=>t.push(...e),
|
|
1
|
+
const t=t=>(e,a,n)=>t(e)?n?.():a(e),e=globalThis.window,a=t=>null==t,n=t=>void 0===t,s=t=>null===t,r=t(a),o=t(n),i=t=>Array.isArray(t),c=t=>t.length,l=t=>{throw Error(t)},y=async(t,e,a)=>{try{return await t()}catch(t){e?.(t)}},g=(t,e)=>t.forEach(e),u=(t,e)=>t.map(e),w=(t,...e)=>t.push(...e),d=t=>t.shift(),p=Object,v=t=>p.getPrototypeOf(t),h=p.entries,S=t=>!a(t)&&r(v(t),t=>t==p.prototype||a(v(t)),()=>!0),b=p.keys,f=p.freeze,A=t=>S(t)&&0==(t=>c(b(t)))(t),C=JSON.stringify,L=JSON.parse,m=t=>C(t,(t,e)=>n(e)?"":e),E=t=>M(L(t)),M=t=>""===t?void 0:i(t)?u(t,M):S(t)?((t,e)=>((t=[])=>p.fromEntries(t))(((t,e)=>u(h(t),([t,a])=>e(a,t)))(t,(t,a)=>[a,e(t,a)])))(t,M):t,O=t=>n(t)||0==(t=>t?.size??0)(t),P=(t,e)=>t?.forEach(e),T=(t,e)=>t?.delete(e),F=t=>new Map(t),N=(t,e)=>t?.get(e),k=(t,e,a)=>n(a)?(T(t,e),t):t?.set(e,a),x=(t,e,a,n)=>{var s,r;return s=t,r=e,s?.has(r)?n?.(N(t,e)):k(t,e,a()),N(t,e)},z=(t,e,a,n,s=0)=>o((a?x:N)(t,e[s],s>c(e)-2?a:F),r=>{if(s>c(e)-2)return n?.(r)&&k(t,e[s]),r;const o=z(r,e,a,n,s+1);return O(r)&&k(t,e[s]),o}),D=/^\d+$/,I=t=>new Set(i(t)||n(t)?t:[t]),J=F(),j=F(),H=(t,e,a,r,u,p,v,h={},S=0,b=[])=>{let C,L,m,E=0,M=0,H=0;x(J,b,()=>0),x(j,b,()=>[]);const V=F(),[W,$,q,B,G]=((t=1,e,a)=>1!=t&&e.isMergeable()?[1,e.getMergeableContent,()=>e.getTransactionMergeableChanges(!a),([[t],[e]])=>!A(t)||!A(e),e.setDefaultContent]:2!=t?[0,e.getContent,e.getTransactionChanges,([t,e])=>!A(t)||!A(e),e.setContent]:l("Store type not supported by this Persister"))(v,t,S),[K,Q,R]=(()=>{let t;const[e,a]=(()=>{const t=[];let e=0;return[a=>(a?d(t):null)??""+e++,e=>{D.test(e)&&c(t)<1e3&&w(t,e)}]})(),n=F();return[(a,s,r,o=[],i=()=>[])=>{t??=rt;const c=e(1);var l,y;return k(n,c,[a,s,r,o,i]),l=z(s,r??[""],I),y=c,l?.add(y),c},(e,a,...r)=>g(((t,e=[""])=>{const a=[],n=(t,r)=>r==c(e)?w(a,t):s(e[r])?P(t,t=>n(t,r+1)):g([e[r],null],e=>n(N(t,e),r+1));return n(t,0),a})(e,a),e=>P(e,e=>N(n,e)[0](t,...a??[],...r))),t=>o(N(n,t),([,e,s])=>(z(e,s??[""],void 0,e=>(T(e,t),O(e)?1:0)),k(n,t),a(t),s)),e=>o(N(n,e),([e,,a=[],n,r])=>{const o=(...i)=>{const l=c(i);l==c(a)?e(t,...i,...r(i)):s(a[l])?g(n[l]?.(...i)??[],t=>o(...i,t)):o(...i,a[l])};o()})]})(),U=t=>{t!=E&&(E=t,Q(V,void 0,E))},X=e=>{(W&&i(e?.[0])?1===e?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===e?.[2]?t.applyChanges:t.setContent)(e)},Y=async t=>(2!=E&&(U(1),M++,await st(async()=>{await y(async()=>{const a=await e();i(a)?X(a):t?G(t):l("Content is not an array: "+a)},()=>{t&&G(t)}),U(0)})),rt),Z=async t=>(_(),await Y(t),await y(async()=>L=await r(async(t,e)=>{e||t?2!=E&&(U(1),M++,X(e??t),U(0)):await Y()}),p),rt),_=async()=>(L&&(await y(()=>u(L),p),L=void 0),rt),tt=async t=>(1!=E&&(U(2),H++,await st(async()=>{await y(()=>a($,t),p),U(0)})),rt),et=async()=>(at(),await tt(),m=t.addDidFinishTransactionListener(()=>{const t=q();B(t)&&tt(t)}),rt),at=async()=>(m&&(t.delListener(m),m=void 0),rt),nt=async(t=!1)=>{const[e,a]=t?[at,_]:[_,at];return await e(),await a(),rt},st=async(...t)=>(w(N(j,b),...t),await(async()=>{if(!N(J,b)){for(k(J,b,1);!n(C=d(N(j,b)));)await y(C,p);k(J,b,0)}})(),rt),rt={load:Y,startAutoLoad:Z,stopAutoLoad:_,isAutoLoading:()=>!n(L),save:tt,startAutoSave:et,stopAutoSave:at,isAutoSaving:()=>!n(m),startAutoPersisting:async(t,e=!1)=>{const[a,n]=e?[et,Z]:[Z,et];return await a(t),await n(t),rt},stopAutoPersisting:nt,getStatus:()=>E,addStatusListener:t=>K(t,V),delListener:e=>(R(e),t),schedule:st,getStore:()=>t,destroy:()=>(N(j,b).splice(0,void 0),nt()),getStats:()=>({loads:M,saves:H}),...h};return f(rt)},V="storage",W=(t,a,n,s)=>H(t,async()=>E(n.getItem(a)),async t=>n.setItem(a,m(t())),t=>{const s=e=>{e.storageArea===n&&e.key===a&&y(()=>t(E(e.newValue)),t)};return e.addEventListener(V,s),s},t=>e.removeEventListener(V,t),s,3,{getStorageName:()=>a}),$=(t,e,a)=>W(t,e,localStorage,a),q=(t,e,a)=>W(t,e,sessionStorage,a),B=(t,e,a)=>H(t,async()=>E(await(await e.getFile()).text()),async t=>{const a=await e.createWritable();await a.write(m(t())),await a.close()},async t=>{const a=new FileSystemObserver(()=>t());return await a.observe(e),a},t=>t?.disconnect(),a,3,{getHandle:()=>e});export{$ as createLocalPersister,B as createOpfsPersister,q as createSessionPersister};
|
|
Binary file
|
|
@@ -1 +1 @@
|
|
|
1
|
-
const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),i="true",r=(a,t,e)=>a.replace(t,e),o=Promise,c=a=>(t,e,n)=>a(t)?n?.():e(t),l=clearInterval,w=a=>null==a,y=a=>void 0===a,u=a=>null===a,d=c(w),g=c(y),p=t=>a(t)==s,v=a=>Array.isArray(a),E=(a,t,e)=>a.slice(t,e),A=a=>a.length,N=()=>{},m=async a=>o.all(a),$=a=>{throw Error(a)},f=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},C=(a,t)=>a.forEach(t),O=(a,t="")=>a.join(t),T=(a,t)=>a.map(t),h=a=>0==A(a),b=(a,t)=>a.filter(t),D=(a,...t)=>a.push(...t),I=a=>a.shift(),S=(a,t)=>a?.has(t)??!1,L=a=>y(a)||0==(a=>a?.size??0)(a),R=a=>[...a?.values()??[]],P=(a,t)=>a?.forEach(t),M=(a,t)=>a?.delete(t),_="_",F="_id",U="SELECT",j="WHERE",x="TABLE",B="ALTER "+x,J="FROM",Y="DELETE "+J,k=U+"*"+J,z="pragma_",G="data_version",H="schema_version",K="pragma_table_",Q="CREATE "+x,V=a=>O(T(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${r(a,/"/g,'""')}"`),"."),W=(a,t=[1])=>O(T(a,()=>"$"+t[0]++),n),X=(a,t=i)=>j+`(${r(t,"$tableName",V(a))})`,q=Object,Z=a=>q.getPrototypeOf(a),aa=q.entries,ta=q.
|
|
1
|
+
const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),i="true",r=(a,t,e)=>a.replace(t,e),o=Promise,c=a=>(t,e,n)=>a(t)?n?.():e(t),l=clearInterval,w=a=>null==a,y=a=>void 0===a,u=a=>null===a,d=c(w),g=c(y),p=t=>a(t)==s,v=a=>Array.isArray(a),E=(a,t,e)=>a.slice(t,e),A=a=>a.length,N=()=>{},m=async a=>o.all(a),$=a=>{throw Error(a)},f=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},C=(a,t)=>a.forEach(t),O=(a,t="")=>a.join(t),T=(a,t)=>a.map(t),h=a=>0==A(a),b=(a,t)=>a.filter(t),D=(a,...t)=>a.push(...t),I=a=>a.shift(),S=(a,t)=>a?.has(t)??!1,L=a=>y(a)||0==(a=>a?.size??0)(a),R=a=>[...a?.values()??[]],P=(a,t)=>a?.forEach(t),M=(a,t)=>a?.delete(t),_="_",F="_id",U="SELECT",j="WHERE",x="TABLE",B="ALTER "+x,J="FROM",Y="DELETE "+J,k=U+"*"+J,z="pragma_",G="data_version",H="schema_version",K="pragma_table_",Q="CREATE "+x,V=a=>O(T(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${r(a,/"/g,'""')}"`),"."),W=(a,t=[1])=>O(T(a,()=>"$"+t[0]++),n),X=(a,t=i)=>j+`(${r(t,"$tableName",V(a))})`,q=Object,Z=a=>q.getPrototypeOf(a),aa=q.entries,ta=a=>!w(a)&&d(Z(a),a=>a==q.prototype||w(Z(a)),()=>!0),ea=q.keys,na=q.freeze,sa=(a=[])=>q.fromEntries(a),ia=(...a)=>q.assign({},...a),ra=(a,t)=>(delete a[t],a),oa=(a,t)=>T(aa(a),([a,e])=>t(e,a)),ca=(a,t)=>sa(oa(a,(a,e)=>[e,t(a,e)])),la=a=>q.values(a),wa=a=>A(ea(a)),ya=a=>ta(a)&&0==wa(a),ua=a=>new Map(a),da=(a,t)=>a?.get(t),ga=(a,t)=>T([...a?.entries()??[]],([a,e])=>t(e,a)),pa=(a,t,e)=>y(e)?(M(a,t),a):a?.set(t,e),va=(a,t,e,n)=>(S(a,t)?n?.(da(a,t)):pa(a,t,e()),da(a,t)),Ea=(a,t,e,n,s=0)=>g((e?va:da)(a,t[s],s>A(t)-2?e:ua),i=>{if(s>A(t)-2)return n?.(i)&&pa(a,t[s]),i;const r=Ea(i,t,e,n,s+1);return L(i)&&pa(a,t[s]),r}),Aa=a=>new Set(v(a)||y(a)?a:[a]),Na=(a,t)=>a?.add(t),ma="ColumnName",$a="store",fa="json",Ca=$a+"TableName",Oa=$a+"Id"+ma,Ta=$a+ma,ha="autoLoadIntervalSeconds",ba="rowId"+ma,Da="tableId",Ia="tableName",Sa="deleteEmptyColumns",La="deleteEmptyTable",Ra="condition",Pa={mode:fa,[ha]:1},Ma={load:0,save:0,[Ia]:t+"_values"},_a=(a,t,e,n,s)=>{const i=ua();return ca(a,(a,r)=>{const o=E(la(ia(t,p(a)?{[e]:a}:a)),0,wa(t));u(o[0])||n(r,o[0])||(s(r,o[0]),pa(i,r,o))}),i},Fa=JSON.stringify,Ua=JSON.parse,ja=a=>""===a?void 0:v(a)?T(a,ja):ta(a)?ca(a,ja):a,xa=/^\d+$/,Ba=ua(),Ja=ua(),Ya=(a,t,n,s,i,r,o,c={},l=0,w=[])=>{let d,p,E,N=0,m=0,O=0;va(Ba,w,()=>0),va(Ja,w,()=>[]);const T=ua(),[h,b,S,R,_]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!ya(a)||!ya(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!ya(a)||!ya(t),t.setContent]:$("Store type not supported by this Persister"))(o,a,l),[F,U,j]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?I(a):null)??e+t++,t=>{xa.test(t)&&A(a)<1e3&&D(a,t)}]})(),s=ua();return[(n,i,r,o=[],c=()=>[])=>{a??=V;const l=t(1);return pa(s,l,[n,i,r,o,c]),Na(Ea(i,r??[e],Aa),l),l},(t,n,...i)=>C(((a,t=[e])=>{const n=[],s=(a,e)=>e==A(t)?D(n,a):u(t[e])?P(a,a=>s(a,e+1)):C([t[e],null],t=>s(da(a,t),e+1));return s(a,0),n})(t,n),t=>P(t,t=>da(s,t)[0](a,...n??[],...i))),a=>g(da(s,a),([,t,i])=>(Ea(t,i??[e],void 0,t=>(M(t,a),L(t)?1:0)),pa(s,a),n(a),i)),t=>g(da(s,t),([t,,e=[],n,s])=>{const i=(...r)=>{const o=A(r);o==A(e)?t(a,...r,...s(r)):u(e[o])?C(n[o]?.(...r)??[],a=>i(...r,a)):i(...r,e[o])};i()})]})(),x=a=>{a!=N&&(N=a,U(T,void 0,N))},B=t=>{(h&&v(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},J=async a=>(2!=N&&(x(1),m++,await Q(async()=>{await f(async()=>{const e=await t();v(e)?B(e):a?_(a):$("Content is not an array: "+e)},()=>{a&&_(a)}),x(0)})),V),Y=async a=>(k(),await J(a),await f(async()=>p=await s(async(a,t)=>{t||a?2!=N&&(x(1),m++,B(t??a),x(0)):await J()}),r),V),k=async()=>(p&&(await f(()=>i(p),r),p=void 0),V),z=async a=>(1!=N&&(x(2),O++,await Q(async()=>{await f(()=>n(b,a),r),x(0)})),V),G=async()=>(H(),await z(),E=a.addDidFinishTransactionListener(()=>{const a=S();R(a)&&z(a)}),V),H=async()=>(E&&(a.delListener(E),E=void 0),V),K=async(a=!1)=>{const[t,e]=a?[H,k]:[k,H];return await t(),await e(),V},Q=async(...a)=>(D(da(Ja,w),...a),await(async()=>{if(!da(Ba,w)){for(pa(Ba,w,1);!y(d=I(da(Ja,w)));)await f(d,r);pa(Ba,w,0)}})(),V),V={load:J,startAutoLoad:Y,stopAutoLoad:k,isAutoLoading:()=>!y(p),save:z,startAutoSave:G,stopAutoSave:H,isAutoSaving:()=>!y(E),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[G,Y]:[Y,G];return await e(a),await n(a),V},stopAutoPersisting:K,getStatus:()=>N,addStatusListener:a=>F(a,T),delListener:t=>(j(t),a),schedule:Q,getStore:()=>a,destroy:()=>(da(Ja,w).splice(0,void 0),K()),getStats:()=>({loads:m,saves:O}),...c};return na(V)},ka=(a,t,e,s,r,o=za,c,l)=>{const w=ua();return[async()=>{w.clear(),T(await e(a,t),({tn:a,cn:t})=>Na(va(w,a,Aa),t))},async(t,e,n)=>((a,t)=>S(da(w,a),t))(t,e)?sa(b(T(await a(k+V(t)+X(t,n)),a=>[a[e],l?ca(ra(a,e),l):ra(a,e)]),([a,t])=>!y(a)&&!ya(t))):{},async(t,e,s,l,u,d=!1,g=i)=>{const p=Aa();ca(s??{},a=>T(ea(a??{}),a=>Na(p,a)));const v=R(p);if(!d&&u&&g==i&&h(v)&&S(w,t))return await a("DROP "+x+V(t)),void pa(w,t);const E=da(w,t),A=Aa(R(E));if(h(v)||(S(w,t)?await m(T([e,...v],async(n,s)=>{M(A,n)||(await a(B+V(t)+"ADD"+V(n)+r),0==s&&await a("CREATE UNIQUE INDEX pk ON "+V(t)+`(${V(e)})`),Na(E,n))})):(await a(Q+V(t)+`(${V(e)}${r} PRIMARY KEY${O(T(v,a=>n+V(a)+r))});`),pa(w,t,Aa([e,...v])))),await m([...!d&&l?T(R(A),async n=>{n!=e&&(await a(B+V(t)+"DROP"+V(n)),M(E,n))}):[]]),d)y(s)?await a(Y+V(t)+X(t,g)):await m(oa(s,async(n,s)=>{y(n)?await a(Y+V(t)+X(t,g)+`AND(${V(e)}=$1)`,[s]):h(v)||await o(a,t,e,ea(n),{[s]:c?T(la(n),c):la(n)},E)}));else if(h(v))S(w,t)&&await a(Y+V(t)+X(t,g));else{const n=b(R(da(w,t)),a=>a!=e),i={},r=[];ca(s??{},(a,t)=>{i[t]=T(n,t=>c?c(a?.[t]):a?.[t]),D(r,t)}),await o(a,t,e,n,i),await a(Y+V(t)+X(t,g)+`AND${V(e)}NOT IN(${W(r)})`,r)}},async t=>{let e;return await a("BEGIN"),await f(async()=>e=await t(),s),await a("END"),e}]},za=async(a,t,e,s,i)=>{const r=[1];await a("INSERT INTO"+V(t)+"("+((...a)=>O(T(a,V),n))(e,...s)+")VALUES"+O(oa(i,a=>"($"+r[0]+++","+W(a,r)+")"),n)+"ON CONFLICT("+V(e)+")DO UPDATE SET"+O(T(s,a=>V(a)+"=excluded."+V(a)),n),oa(i,(a,t)=>[t,...T(a,a=>a??null)]).flat())},Ga=(a,t,e,n,s,i,r,[o,c,l],w,u,d,g,p,v)=>{const[E,A,N,m]=ka(t,w,u,s,p,v),$=Ya(a,()=>m(async()=>{return await E(),a=(await A(o,c))[_]?.[l]??"null",ja(Ua(a));var a}),a=>m(async()=>{var t;await E(),await N(o,c,{[_]:{[l]:(t=a()??null,Fa(t,(a,t)=>y(t)?"":t))}},!0,!0)}),e,n,s,r,{[g]:()=>d,destroy:async()=>(await $.stopAutoPersisting(),i(),$)},0,d);return $},Ha=(a,t,e,n,s,i,r,[o,c,[l,w,u]],d,g,p,v,E,A,N,$)=>{const[f,C,O,T]=ka(t,d,g,s,E,A,N,$),h=(a,t)=>m(ga(c,async([e,n,s,i,r],o)=>{t&&!(o in a)||await O(e,n,a[o],s,i,t,r)})),D=async(a,t)=>w?await O(u,F,{[_]:a},!0,!0,t):null,I=Ya(a,()=>T(async()=>{await f();const a=await(async()=>sa(b(await m(ga(o,async([a,t,e],n)=>[a,await C(n,t,e)])),a=>!ya(a[1]))))(),t=await(async()=>l?(await C(u,F))[_]:{})();return ya(a)&&y(t)?void 0:[a,t]}),(a,t)=>T(async()=>{if(await f(),y(t)){const[t,e]=a();await h(t),await D(e)}else await h(t[0],!0),await D(t[1],!0)}),e,n,s,r,{[v]:()=>p,destroy:async()=>(await I.stopAutoPersisting(),i(),I)},0,p);return I},Ka=(a,n,s,r,o,c,y,u,d,g,v="getDb",A)=>{let N,m,$;const C=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,c),[O,T,h,b]=(a=>{const e=(a=>ia(Pa,p(a)?{[Ca]:a}:a??{}))(a),n=e[ha];if(e.mode==fa){const a=e[Ca]??t;return[1,n,[a,e[Oa]??F,e[Ta]??$a],Aa(a)]}const{tables:{load:s={},save:r={}}={},values:o={}}=e,c=E(la(ia(Ma,o)),0,wa(Ma)),l=c[2],w=Aa(l),y=Aa(l),u=_a(s,{[Da]:null,[ba]:F,[Ra]:i},Da,a=>S(y,a),a=>Na(w,a)),d=_a(r,{[Ia]:null,[ba]:F,[Sa]:0,[La]:0,[Ra]:null},Ia,(a,t)=>S(y,t),(a,t)=>Na(w,t));var g;return g=(a,t)=>t[4]??=da(u,t[0])?.[2]??i,P(d,(a,t)=>g(0,a)),[0,n,[u,d,c],w]})(n);return(O?Ga:Ha)(a,C,a=>{let t;const e=()=>t=setInterval(()=>f(async()=>{const[{d:t,s:e,c:n}]=await C(U+` ${G} d,${H} s,TOTAL_CHANGES() c FROM ${z}${G} JOIN ${z}${H}`);t==N&&e==m&&n==$||(w(N)||a(),N=t,m=e,$=n)}),1e3*T),n=()=>{N=m=$=null,l(t)},s=r(t=>{b.has(t)&&(n(),a(),e())});return e(),()=>{n(),o(s)}},a=>a(),y,u,d,h,R(b),async(a,t)=>await a(U+` t.name tn,c.name cn FROM ${K}list()t,${K}info(t.name)c ${j} t.schema='main'AND t.type IN('table','view')AND t.name IN(${W(t)})ORDER BY t.name,c.name`,t),g,v,e,A,a=>(a=>!0===a)(a)?1:(a=>!1===a)(a)?0:a,void 0)},Qa=(a,t,e,n,s)=>Ka(a,e,async(a,e=[])=>await t.execO(a,e),a=>t.onUpdate((t,e,n)=>a(n)),a=>a(),n,s,N,1,t);export{Qa as createCrSqliteWasmPersister};
|
|
Binary file
|
|
@@ -1 +1 @@
|
|
|
1
|
-
const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),i="true",r=(a,t,e)=>a.replace(t,e),o=Promise,c=a=>(t,e,n)=>a(t)?n?.():e(t),l=clearInterval,w=a=>null==a,y=a=>void 0===a,u=a=>null===a,d=c(w),g=c(y),p=t=>a(t)==s,v=a=>Array.isArray(a),E=(a,t,e)=>a.slice(t,e),A=a=>a.length,N=()=>{},m=async a=>o.all(a),$=a=>{throw Error(a)},f=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},C=(a,t)=>a.forEach(t),O=(a,t="")=>a.join(t),T=(a,t)=>a.map(t),h=a=>0==A(a),b=(a,t)=>a.filter(t),D=(a,...t)=>a.push(...t),I=a=>a.shift(),S=(a,t)=>a?.has(t)??!1,L=a=>y(a)||0==(a=>a?.size??0)(a),R=a=>[...a?.values()??[]],P=(a,t)=>a?.forEach(t),M=(a,t)=>a?.delete(t),_="_",F="_id",U="SELECT",j="WHERE",x="TABLE",B="ALTER "+x,J="FROM",Y="DELETE "+J,k=U+"*"+J,z="pragma_",G="data_version",H="schema_version",K="pragma_table_",Q="CREATE "+x,V=a=>O(T(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${r(a,/"/g,'""')}"`),"."),W=(a,t=[1])=>O(T(a,()=>"$"+t[0]++),n),X=(a,t=i)=>j+`(${r(t,"$tableName",V(a))})`,q=Object,Z=a=>q.getPrototypeOf(a),aa=q.entries,ta=q.
|
|
1
|
+
const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),i="true",r=(a,t,e)=>a.replace(t,e),o=Promise,c=a=>(t,e,n)=>a(t)?n?.():e(t),l=clearInterval,w=a=>null==a,y=a=>void 0===a,u=a=>null===a,d=c(w),g=c(y),p=t=>a(t)==s,v=a=>Array.isArray(a),E=(a,t,e)=>a.slice(t,e),A=a=>a.length,N=()=>{},m=async a=>o.all(a),$=a=>{throw Error(a)},f=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},C=(a,t)=>a.forEach(t),O=(a,t="")=>a.join(t),T=(a,t)=>a.map(t),h=a=>0==A(a),b=(a,t)=>a.filter(t),D=(a,...t)=>a.push(...t),I=a=>a.shift(),S=(a,t)=>a?.has(t)??!1,L=a=>y(a)||0==(a=>a?.size??0)(a),R=a=>[...a?.values()??[]],P=(a,t)=>a?.forEach(t),M=(a,t)=>a?.delete(t),_="_",F="_id",U="SELECT",j="WHERE",x="TABLE",B="ALTER "+x,J="FROM",Y="DELETE "+J,k=U+"*"+J,z="pragma_",G="data_version",H="schema_version",K="pragma_table_",Q="CREATE "+x,V=a=>O(T(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${r(a,/"/g,'""')}"`),"."),W=(a,t=[1])=>O(T(a,()=>"$"+t[0]++),n),X=(a,t=i)=>j+`(${r(t,"$tableName",V(a))})`,q=Object,Z=a=>q.getPrototypeOf(a),aa=q.entries,ta=a=>!w(a)&&d(Z(a),a=>a==q.prototype||w(Z(a)),()=>!0),ea=q.keys,na=q.freeze,sa=(a=[])=>q.fromEntries(a),ia=(...a)=>q.assign({},...a),ra=(a,t)=>(delete a[t],a),oa=(a,t)=>T(aa(a),([a,e])=>t(e,a)),ca=(a,t)=>sa(oa(a,(a,e)=>[e,t(a,e)])),la=a=>q.values(a),wa=a=>A(ea(a)),ya=a=>ta(a)&&0==wa(a),ua=a=>new Map(a),da=(a,t)=>a?.get(t),ga=(a,t)=>T([...a?.entries()??[]],([a,e])=>t(e,a)),pa=(a,t,e)=>y(e)?(M(a,t),a):a?.set(t,e),va=(a,t,e,n)=>(S(a,t)?n?.(da(a,t)):pa(a,t,e()),da(a,t)),Ea=(a,t,e,n,s=0)=>g((e?va:da)(a,t[s],s>A(t)-2?e:ua),i=>{if(s>A(t)-2)return n?.(i)&&pa(a,t[s]),i;const r=Ea(i,t,e,n,s+1);return L(i)&&pa(a,t[s]),r}),Aa=a=>new Set(v(a)||y(a)?a:[a]),Na=(a,t)=>a?.add(t),ma="ColumnName",$a="store",fa="json",Ca=$a+"TableName",Oa=$a+"Id"+ma,Ta=$a+ma,ha="autoLoadIntervalSeconds",ba="rowId"+ma,Da="tableId",Ia="tableName",Sa="deleteEmptyColumns",La="deleteEmptyTable",Ra="condition",Pa={mode:fa,[ha]:1},Ma={load:0,save:0,[Ia]:t+"_values"},_a=(a,t,e,n,s)=>{const i=ua();return ca(a,(a,r)=>{const o=E(la(ia(t,p(a)?{[e]:a}:a)),0,wa(t));u(o[0])||n(r,o[0])||(s(r,o[0]),pa(i,r,o))}),i},Fa=JSON.stringify,Ua=JSON.parse,ja=a=>""===a?void 0:v(a)?T(a,ja):ta(a)?ca(a,ja):a,xa=/^\d+$/,Ba=ua(),Ja=ua(),Ya=(a,t,n,s,i,r,o,c={},l=0,w=[])=>{let d,p,E,N=0,m=0,O=0;va(Ba,w,()=>0),va(Ja,w,()=>[]);const T=ua(),[h,b,S,R,_]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!ya(a)||!ya(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!ya(a)||!ya(t),t.setContent]:$("Store type not supported by this Persister"))(o,a,l),[F,U,j]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?I(a):null)??e+t++,t=>{xa.test(t)&&A(a)<1e3&&D(a,t)}]})(),s=ua();return[(n,i,r,o=[],c=()=>[])=>{a??=V;const l=t(1);return pa(s,l,[n,i,r,o,c]),Na(Ea(i,r??[e],Aa),l),l},(t,n,...i)=>C(((a,t=[e])=>{const n=[],s=(a,e)=>e==A(t)?D(n,a):u(t[e])?P(a,a=>s(a,e+1)):C([t[e],null],t=>s(da(a,t),e+1));return s(a,0),n})(t,n),t=>P(t,t=>da(s,t)[0](a,...n??[],...i))),a=>g(da(s,a),([,t,i])=>(Ea(t,i??[e],void 0,t=>(M(t,a),L(t)?1:0)),pa(s,a),n(a),i)),t=>g(da(s,t),([t,,e=[],n,s])=>{const i=(...r)=>{const o=A(r);o==A(e)?t(a,...r,...s(r)):u(e[o])?C(n[o]?.(...r)??[],a=>i(...r,a)):i(...r,e[o])};i()})]})(),x=a=>{a!=N&&(N=a,U(T,void 0,N))},B=t=>{(h&&v(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},J=async a=>(2!=N&&(x(1),m++,await Q(async()=>{await f(async()=>{const e=await t();v(e)?B(e):a?_(a):$("Content is not an array: "+e)},()=>{a&&_(a)}),x(0)})),V),Y=async a=>(k(),await J(a),await f(async()=>p=await s(async(a,t)=>{t||a?2!=N&&(x(1),m++,B(t??a),x(0)):await J()}),r),V),k=async()=>(p&&(await f(()=>i(p),r),p=void 0),V),z=async a=>(1!=N&&(x(2),O++,await Q(async()=>{await f(()=>n(b,a),r),x(0)})),V),G=async()=>(H(),await z(),E=a.addDidFinishTransactionListener(()=>{const a=S();R(a)&&z(a)}),V),H=async()=>(E&&(a.delListener(E),E=void 0),V),K=async(a=!1)=>{const[t,e]=a?[H,k]:[k,H];return await t(),await e(),V},Q=async(...a)=>(D(da(Ja,w),...a),await(async()=>{if(!da(Ba,w)){for(pa(Ba,w,1);!y(d=I(da(Ja,w)));)await f(d,r);pa(Ba,w,0)}})(),V),V={load:J,startAutoLoad:Y,stopAutoLoad:k,isAutoLoading:()=>!y(p),save:z,startAutoSave:G,stopAutoSave:H,isAutoSaving:()=>!y(E),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[G,Y]:[Y,G];return await e(a),await n(a),V},stopAutoPersisting:K,getStatus:()=>N,addStatusListener:a=>F(a,T),delListener:t=>(j(t),a),schedule:Q,getStore:()=>a,destroy:()=>(da(Ja,w).splice(0,void 0),K()),getStats:()=>({loads:m,saves:O}),...c};return na(V)},ka=(a,t,e,s,r,o=za,c,l)=>{const w=ua();return[async()=>{w.clear(),T(await e(a,t),({tn:a,cn:t})=>Na(va(w,a,Aa),t))},async(t,e,n)=>((a,t)=>S(da(w,a),t))(t,e)?sa(b(T(await a(k+V(t)+X(t,n)),a=>[a[e],l?ca(ra(a,e),l):ra(a,e)]),([a,t])=>!y(a)&&!ya(t))):{},async(t,e,s,l,u,d=!1,g=i)=>{const p=Aa();ca(s??{},a=>T(ea(a??{}),a=>Na(p,a)));const v=R(p);if(!d&&u&&g==i&&h(v)&&S(w,t))return await a("DROP "+x+V(t)),void pa(w,t);const E=da(w,t),A=Aa(R(E));if(h(v)||(S(w,t)?await m(T([e,...v],async(n,s)=>{M(A,n)||(await a(B+V(t)+"ADD"+V(n)+r),0==s&&await a("CREATE UNIQUE INDEX pk ON "+V(t)+`(${V(e)})`),Na(E,n))})):(await a(Q+V(t)+`(${V(e)}${r} PRIMARY KEY${O(T(v,a=>n+V(a)+r))});`),pa(w,t,Aa([e,...v])))),await m([...!d&&l?T(R(A),async n=>{n!=e&&(await a(B+V(t)+"DROP"+V(n)),M(E,n))}):[]]),d)y(s)?await a(Y+V(t)+X(t,g)):await m(oa(s,async(n,s)=>{y(n)?await a(Y+V(t)+X(t,g)+`AND(${V(e)}=$1)`,[s]):h(v)||await o(a,t,e,ea(n),{[s]:c?T(la(n),c):la(n)},E)}));else if(h(v))S(w,t)&&await a(Y+V(t)+X(t,g));else{const n=b(R(da(w,t)),a=>a!=e),i={},r=[];ca(s??{},(a,t)=>{i[t]=T(n,t=>c?c(a?.[t]):a?.[t]),D(r,t)}),await o(a,t,e,n,i),await a(Y+V(t)+X(t,g)+`AND${V(e)}NOT IN(${W(r)})`,r)}},async t=>{let e;return await a("BEGIN"),await f(async()=>e=await t(),s),await a("END"),e}]},za=async(a,t,e,s,i)=>{const r=[1];await a("INSERT INTO"+V(t)+"("+((...a)=>O(T(a,V),n))(e,...s)+")VALUES"+O(oa(i,a=>"($"+r[0]+++","+W(a,r)+")"),n)+"ON CONFLICT("+V(e)+")DO UPDATE SET"+O(T(s,a=>V(a)+"=excluded."+V(a)),n),oa(i,(a,t)=>[t,...T(a,a=>a??null)]).flat())},Ga=(a,t,e,n,s,i,r,[o,c,l],w,u,d,g,p,v)=>{const[E,A,N,m]=ka(t,w,u,s,p,v),$=Ya(a,()=>m(async()=>{return await E(),a=(await A(o,c))[_]?.[l]??"null",ja(Ua(a));var a}),a=>m(async()=>{var t;await E(),await N(o,c,{[_]:{[l]:(t=a()??null,Fa(t,(a,t)=>y(t)?"":t))}},!0,!0)}),e,n,s,r,{[g]:()=>d,destroy:async()=>(await $.stopAutoPersisting(),i(),$)},0,d);return $},Ha=(a,t,e,n,s,i,r,[o,c,[l,w,u]],d,g,p,v,E,A,N,$)=>{const[f,C,O,T]=ka(t,d,g,s,E,A,N,$),h=(a,t)=>m(ga(c,async([e,n,s,i,r],o)=>{t&&!(o in a)||await O(e,n,a[o],s,i,t,r)})),D=async(a,t)=>w?await O(u,F,{[_]:a},!0,!0,t):null,I=Ya(a,()=>T(async()=>{await f();const a=await(async()=>sa(b(await m(ga(o,async([a,t,e],n)=>[a,await C(n,t,e)])),a=>!ya(a[1]))))(),t=await(async()=>l?(await C(u,F))[_]:{})();return ya(a)&&y(t)?void 0:[a,t]}),(a,t)=>T(async()=>{if(await f(),y(t)){const[t,e]=a();await h(t),await D(e)}else await h(t[0],!0),await D(t[1],!0)}),e,n,s,r,{[v]:()=>p,destroy:async()=>(await I.stopAutoPersisting(),i(),I)},0,p);return I},Ka=(a,n,s,r,o,c,y,u,d,g,v="getDb",A)=>{let N,m,$;const C=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,c),[O,T,h,b]=(a=>{const e=(a=>ia(Pa,p(a)?{[Ca]:a}:a??{}))(a),n=e[ha];if(e.mode==fa){const a=e[Ca]??t;return[1,n,[a,e[Oa]??F,e[Ta]??$a],Aa(a)]}const{tables:{load:s={},save:r={}}={},values:o={}}=e,c=E(la(ia(Ma,o)),0,wa(Ma)),l=c[2],w=Aa(l),y=Aa(l),u=_a(s,{[Da]:null,[ba]:F,[Ra]:i},Da,a=>S(y,a),a=>Na(w,a)),d=_a(r,{[Ia]:null,[ba]:F,[Sa]:0,[La]:0,[Ra]:null},Ia,(a,t)=>S(y,t),(a,t)=>Na(w,t));var g;return g=(a,t)=>t[4]??=da(u,t[0])?.[2]??i,P(d,(a,t)=>g(0,a)),[0,n,[u,d,c],w]})(n);return(O?Ga:Ha)(a,C,a=>{let t;const e=()=>t=setInterval(()=>f(async()=>{const[{d:t,s:e,c:n}]=await C(U+` ${G} d,${H} s,TOTAL_CHANGES() c FROM ${z}${G} JOIN ${z}${H}`);t==N&&e==m&&n==$||(w(N)||a(),N=t,m=e,$=n)}),1e3*T),n=()=>{N=m=$=null,l(t)},s=r(t=>{b.has(t)&&(n(),a(),e())});return e(),()=>{n(),o(s)}},a=>a(),y,u,d,h,R(b),async(a,t)=>await a(U+` t.name tn,c.name cn FROM ${K}list()t,${K}info(t.name)c ${j} t.schema='main'AND t.type IN('table','view')AND t.name IN(${W(t)})ORDER BY t.name,c.name`,t),g,v,e,A,a=>(a=>!0===a)(a)?1:(a=>!1===a)(a)?0:a,void 0)},Qa=(a,t,e,n,s)=>Ka(a,e,async(a,e=[])=>await t.execO(a,e),a=>t.onUpdate((t,e,n)=>a(n)),a=>a(),n,s,N,1,t);export{Qa as createCrSqliteWasmPersister};
|
|
Binary file
|
|
@@ -1 +1 @@
|
|
|
1
|
-
const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),i="true",l="t",r=(a,t,e)=>a.replace(t,e),o=Promise,c=a=>(t,e,n)=>a(t)?n?.():e(t),d=clearInterval,u=a=>null==a,y=a=>void 0===a,E=a=>null===a,w=c(u),T=c(y),N=t=>a(t)==s,p=a=>Array.isArray(a),_=(a,t,e)=>a.slice(t,e),O=a=>a.length,m=()=>{},A=async a=>o.all(a),S=a=>{throw Error(a)},v=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},g=(a,t)=>a.forEach(t),L=(a,t="")=>a.join(t),R=(a,t)=>a.map(t),h=a=>0==O(a),f=(a,t)=>a.filter(t),I=(a,...t)=>a.push(...t),$=a=>a.shift(),b=Object,C=a=>b.getPrototypeOf(a),P=b.entries,D=b.keys,U=b.freeze,x=(a=[])=>b.fromEntries(a),M=(...a)=>b.assign({},...a),X=(a,t)=>t in a,J=(a,t)=>(delete a[t],a),F=(a,t)=>g(P(a),([a,e])=>t(e,a)),V=(a,t)=>R(P(a),([a,e])=>t(e,a)),B=(a,t)=>x(V(a,(a,e)=>[e,t(a,e)])),G=a=>b.values(a),Y=a=>O(D(a)),j=a=>(a=>!u(a)&&w(C(a),a=>a==b.prototype||u(C(a)),()=>!0))(a)&&0==Y(a),z=(a,t,e)=>(X(a,t)||(a[t]=e()),a[t]),k=JSON.stringify,q=JSON.parse,H=(a,t)=>a?.has(t)??!1,K=a=>y(a)||0==(a=>a?.size??0)(a),Q=a=>[...a?.values()??[]],W=(a,t)=>a?.forEach(t),Z=(a,t)=>a?.delete(t),aa=a=>new Map(a),ta=(a,t)=>a?.get(t),ea=(a,t)=>R([...a?.entries()??[]],([a,e])=>t(e,a)),na=(a,t,e)=>y(e)?(Z(a,t),a):a?.set(t,e),sa=(a,t,e,n)=>(H(a,t)?n?.(ta(a,t)):na(a,t,e()),ta(a,t)),ia=(a,t,e,n,s=0)=>T((e?sa:ta)(a,t[s],s>O(t)-2?e:aa),i=>{if(s>O(t)-2)return n?.(i)&&na(a,t[s]),i;const l=ia(i,t,e,n,s+1);return K(i)&&na(a,t[s]),l}),la=(a,t,e)=>{t>a[1]&&(a[1]=t),a[2]=e>>>0},ra=/^\d+$/,oa=a=>new Set(p(a)||y(a)?a:[a]),ca=(a,t)=>a?.add(t),da=aa(),ua=aa(),ya=(a,t,n,s,i,l,r,o={},c=0,d=[])=>{let u,w,N,_=0,m=0,A=0;sa(da,d,()=>0),sa(ua,d,()=>[]);const L=aa(),[R,h,f,b,C]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!j(a)||!j(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!j(a)||!j(t),t.setContent]:S("Store type not supported by this Persister"))(r,a,c),[P,D,x]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?$(a):null)??e+t++,t=>{ra.test(t)&&O(a)<1e3&&I(a,t)}]})(),s=aa();return[(n,i,l,r=[],o=()=>[])=>{a??=q;const c=t(1);return na(s,c,[n,i,l,r,o]),ca(ia(i,l??[e],oa),c),c},(t,n,...i)=>g(((a,t=[e])=>{const n=[],s=(a,e)=>e==O(t)?I(n,a):E(t[e])?W(a,a=>s(a,e+1)):g([t[e],null],t=>s(ta(a,t),e+1));return s(a,0),n})(t,n),t=>W(t,t=>ta(s,t)[0](a,...n??[],...i))),a=>T(ta(s,a),([,t,i])=>(ia(t,i??[e],void 0,t=>(Z(t,a),K(t)?1:0)),na(s,a),n(a),i)),t=>T(ta(s,t),([t,,e=[],n,s])=>{const i=(...l)=>{const r=O(l);r==O(e)?t(a,...l,...s(l)):E(e[r])?g(n[r]?.(...l)??[],a=>i(...l,a)):i(...l,e[r])};i()})]})(),M=a=>{a!=_&&(_=a,D(L,void 0,_))},X=t=>{(R&&p(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},J=async a=>(2!=_&&(M(1),m++,await k(async()=>{await v(async()=>{const e=await t();p(e)?X(e):a?C(a):S("Content is not an array: "+e)},()=>{a&&C(a)}),M(0)})),q),F=async a=>(V(),await J(a),await v(async()=>w=await s(async(a,t)=>{t||a?2!=_&&(M(1),m++,X(t??a),M(0)):await J()}),l),q),V=async()=>(w&&(await v(()=>i(w),l),w=void 0),q),B=async a=>(1!=_&&(M(2),A++,await k(async()=>{await v(()=>n(h,a),l),M(0)})),q),G=async()=>(Y(),await B(),N=a.addDidFinishTransactionListener(()=>{const a=f();b(a)&&B(a)}),q),Y=async()=>(N&&(a.delListener(N),N=void 0),q),z=async(a=!1)=>{const[t,e]=a?[Y,V]:[V,Y];return await t(),await e(),q},k=async(...a)=>(I(ta(ua,d),...a),await(async()=>{if(!ta(da,d)){for(na(da,d,1);!y(u=$(ta(ua,d)));)await v(u,l);na(da,d,0)}})(),q),q={load:J,startAutoLoad:F,stopAutoLoad:V,isAutoLoading:()=>!y(w),save:B,startAutoSave:G,stopAutoSave:Y,isAutoSaving:()=>!y(N),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[G,F]:[F,G];return await e(a),await n(a),q},stopAutoPersisting:z,getStatus:()=>_,addStatusListener:a=>P(a,L),delListener:t=>(x(t),a),schedule:k,getStore:()=>a,destroy:()=>(ta(ua,d).splice(0,void 0),z()),getStats:()=>({loads:m,saves:A}),...o};return U(q)},Ea="_",wa="_id",Ta="SELECT",Na="WHERE",pa="TABLE",_a="ALTER "+pa,Oa="FROM",ma="DELETE "+Oa,Aa=Ta+"*"+Oa,Sa="pragma_",va="data_version",ga="schema_version",La="pragma_table_",Ra="CREATE "+pa,ha=a=>L(R(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${r(a,/"/g,'""')}"`),"."),fa=(a,t=[1])=>L(R(a,()=>"$"+t[0]++),n),Ia=(a,t=i)=>Na+`(${r(t,"$tableName",ha(a))})`,$a="ColumnName",ba="store",Ca="json",Pa=ba+"TableName",Da=ba+"Id"+$a,Ua=ba+$a,xa="autoLoadIntervalSeconds",Ma="rowId"+$a,Xa="tableId",Ja="tableName",Fa="deleteEmptyColumns",Va="deleteEmptyTable",Ba="condition",Ga={mode:Ca,[xa]:1},Ya={load:0,save:0,[Ja]:t+"_values"},ja=(a,t,e,n,s)=>{const i=aa();return B(a,(a,l)=>{const r=_(G(M(t,N(a)?{[e]:a}:a)),0,Y(t));E(r[0])||n(l,r[0])||(s(l,r[0]),na(i,l,r))}),i},za=(a,t,e,s,l,r=ka,o,c)=>{const d=aa();return[async()=>{d.clear(),R(await e(a,t),({tn:a,cn:t})=>ca(sa(d,a,oa),t))},async(t,e,n)=>((a,t)=>H(ta(d,a),t))(t,e)?x(f(R(await a(Aa+ha(t)+Ia(t,n)),a=>[a[e],c?B(J(a,e),c):J(a,e)]),([a,t])=>!y(a)&&!j(t))):{},async(t,e,s,c,u,E=!1,w=i)=>{const T=oa();B(s??{},a=>R(D(a??{}),a=>ca(T,a)));const N=Q(T);if(!E&&u&&w==i&&h(N)&&H(d,t))return await a("DROP "+pa+ha(t)),void na(d,t);const p=ta(d,t),_=oa(Q(p));if(h(N)||(H(d,t)?await A(R([e,...N],async(n,s)=>{Z(_,n)||(await a(_a+ha(t)+"ADD"+ha(n)+l),0==s&&await a("CREATE UNIQUE INDEX pk ON "+ha(t)+`(${ha(e)})`),ca(p,n))})):(await a(Ra+ha(t)+`(${ha(e)}${l} PRIMARY KEY${L(R(N,a=>n+ha(a)+l))});`),na(d,t,oa([e,...N])))),await A([...!E&&c?R(Q(_),async n=>{n!=e&&(await a(_a+ha(t)+"DROP"+ha(n)),Z(p,n))}):[]]),E)y(s)?await a(ma+ha(t)+Ia(t,w)):await A(V(s,async(n,s)=>{y(n)?await a(ma+ha(t)+Ia(t,w)+`AND(${ha(e)}=$1)`,[s]):h(N)||await r(a,t,e,D(n),{[s]:o?R(G(n),o):G(n)},p)}));else if(h(N))H(d,t)&&await a(ma+ha(t)+Ia(t,w));else{const n=f(Q(ta(d,t)),a=>a!=e),i={},l=[];B(s??{},(a,t)=>{i[t]=R(n,t=>o?o(a?.[t]):a?.[t]),I(l,t)}),await r(a,t,e,n,i),await a(ma+ha(t)+Ia(t,w)+`AND${ha(e)}NOT IN(${fa(l)})`,l)}},async t=>{let e;return await a("BEGIN"),await v(async()=>e=await t(),s),await a("END"),e}]},ka=async(a,t,e,s,i)=>{const l=[1];await a("INSERT INTO"+ha(t)+"("+((...a)=>L(R(a,ha),n))(e,...s)+")VALUES"+L(V(i,a=>"($"+l[0]+++","+fa(a,l)+")"),n)+"ON CONFLICT("+ha(e)+")DO UPDATE SET"+L(R(s,a=>ha(a)+"=excluded."+ha(a)),n),V(i,(a,t)=>[t,...R(a,a=>a??null)]).flat())},qa=(a,t,e,n,s,i,l,[r,o,c],d,u,E,w,T,N)=>{const[p,_,O,m]=za(t,d,u,s,T,N),A=ya(a,()=>m(async()=>{return await p(),a=(await _(r,o))[Ea]?.[c]??"null",q(a,(a,t)=>""===t?void 0:t);var a}),a=>m(async()=>{var t;await p(),await O(r,o,{[Ea]:{[c]:(t=a()??null,k(t,(a,t)=>y(t)?"":t))}},!0,!0)}),e,n,s,l,{[w]:()=>E,destroy:async()=>(await A.stopAutoPersisting(),i(),A)},0,E);return A},Ha=(a,t,e,n,s,i,l,[r,o,[c,d,u]],E,w,T,N,p,_,O,m)=>{const[S,v,g,L]=za(t,E,w,s,p,_,O,m),R=(a,t)=>A(ea(o,async([e,n,s,i,l],r)=>{t&&!X(a,r)||await g(e,n,a[r],s,i,t,l)})),h=async(a,t)=>d?await g(u,wa,{[Ea]:a},!0,!0,t):null,I=ya(a,()=>L(async()=>{await S();const a=await(async()=>x(f(await A(ea(r,async([a,t,e],n)=>[a,await v(n,t,e)])),a=>!j(a[1]))))(),t=await(async()=>c?(await v(u,wa))[Ea]:{})();return j(a)&&y(t)?void 0:[a,t]}),(a,t)=>L(async()=>{if(await S(),y(t)){const[t,e]=a();await R(t),await h(e)}else await R(t[0],!0),await h(t[1],!0)}),e,n,s,l,{[N]:()=>T,destroy:async()=>(await I.stopAutoPersisting(),i(),I)},0,T);return I},Ka=(a,n,s,l,r,o,c,y,E,w,T="getDb",p)=>{let O,m,A;const S=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,o),[g,L,R,h]=(a=>{const e=(a=>M(Ga,N(a)?{[Pa]:a}:a??{}))(a),n=e[xa];if(e.mode==Ca){const a=e[Pa]??t;return[1,n,[a,e[Da]??wa,e[Ua]??ba],oa(a)]}const{tables:{load:s={},save:l={}}={},values:r={}}=e,o=_(G(M(Ya,r)),0,Y(Ya)),c=o[2],d=oa(c),u=oa(c),y=ja(s,{[Xa]:null,[Ma]:wa,[Ba]:i},Xa,a=>H(u,a),a=>ca(d,a)),E=ja(l,{[Ja]:null,[Ma]:wa,[Fa]:0,[Va]:0,[Ba]:null},Ja,(a,t)=>H(u,t),(a,t)=>ca(d,t));var w;return w=(a,t)=>t[4]??=ta(y,t[0])?.[2]??i,W(E,(a,t)=>w(0,a)),[0,n,[y,E,o],d]})(n);return(g?qa:Ha)(a,S,a=>{let t;const e=()=>t=setInterval(()=>v(async()=>{const[{d:t,s:e,c:n}]=await S(Ta+` ${va} d,${ga} s,TOTAL_CHANGES() c FROM ${Sa}${va} JOIN ${Sa}${ga}`);t==O&&e==m&&n==A||(u(O)||a(),O=t,m=e,A=n)}),1e3*L),n=()=>{O=m=A=null,d(t)},s=l(t=>{h.has(t)&&(n(),a(),e())});return e(),()=>{n(),r(s)}},a=>a(),c,y,E,R,Q(h),async(a,t)=>await a(Ta+` t.name tn,c.name cn FROM ${La}list()t,${La}info(t.name)c ${Na} t.schema='main'AND t.type IN('table','view')AND t.name IN(${fa(t)})ORDER BY t.name,c.name`,t),w,T,e,p,a=>(a=>!0===a)(a)?1:(a=>!1===a)(a)?0:a,void 0)},Qa=(a,t,n,s,i)=>"object"==typeof n&&"fragmented"===n.mode?Za(a,t,n?.storagePrefix??e,i):Ka(a,n,async(a,e=[])=>["BEGIN","END"].includes(a)?[]:(a=a.replace(/\$\d+/g,"?"),t.exec(a,...e).toArray()),()=>m,a=>a(),s,i,m,2,t,"getSqlStorage"),Wa=()=>[{},e,0],Za=(a,t,e="",n)=>{const s=e.replace(/[^a-zA-Z0-9_]/g,"_"),i=s+"tinybase_tables",r=s+"tinybase_values";return t.exec(`\n CREATE TABLE IF NOT EXISTS ${i} (\n type TEXT NOT NULL,\n table_id TEXT,\n row_id TEXT,\n cell_id TEXT,\n value_data TEXT NOT NULL,\n timestamp TEXT NOT NULL,\n hash INTEGER NOT NULL,\n PRIMARY KEY (type, table_id, row_id, cell_id)\n );\n \n CREATE TABLE IF NOT EXISTS ${r} (\n value_id TEXT,\n value_data TEXT NOT NULL,\n timestamp TEXT NOT NULL,\n hash INTEGER NOT NULL\n );\n `),ya(a,async()=>{const a=Wa(),e=Wa(),n=t.exec("SELECT * FROM "+i);for(const t of n.toArray()){const e=t.type+"",n=t.table_id?t.table_id+"":null,s=t.row_id?t.row_id+"":null,i=t.cell_id?t.cell_id+"":null,r=t.value_data+"",o=t.timestamp+"",c=Number(t.hash),[d]=JSON.parse(r);if(e===l)if(n&&s&&i){const t=z(a[0],n,Wa);z(t[0],s,Wa)[0][i]=[d,o,c]}else if(n&&s){const t=z(a[0],n,Wa),e=z(t[0],s,Wa);la(e,o,c)}else if(n){const t=z(a[0],n,Wa);la(t,o,c)}else la(a,o,c)}const s=t.exec("SELECT * FROM "+r);for(const a of s.toArray()){const t=a.value_id?a.value_id+"":null,n=a.value_data+"",s=a.timestamp+"",i=Number(a.hash),[l]=JSON.parse(n);t?e[0][t]=[l,s,i]:la(e,s,i)}return[a,e]},async(a,[[e,n,s],[o,c,d]]=a())=>{t.exec(`INSERT OR REPLACE INTO ${i} (type, table_id, row_id, cell_id, value_data, timestamp, hash) VALUES (?, ?, ?, ?, ?, ?, ?)`,l,null,null,null,JSON.stringify([0]),n,s),F(e,([a,e,n],s)=>{t.exec(`INSERT OR REPLACE INTO ${i} (type, table_id, row_id, cell_id, value_data, timestamp, hash) VALUES (?, ?, ?, ?, ?, ?, ?)`,l,s,null,null,JSON.stringify([0]),e,n),F(a,([a,e,n],r)=>{t.exec(`INSERT OR REPLACE INTO ${i} (type, table_id, row_id, cell_id, value_data, timestamp, hash) VALUES (?, ?, ?, ?, ?, ?, ?)`,l,s,r,null,JSON.stringify([0]),e,n),F(a,(a,e)=>{t.exec(`INSERT OR REPLACE INTO ${i} (type, table_id, row_id, cell_id, value_data, timestamp, hash) VALUES (?, ?, ?, ?, ?, ?, ?)`,l,s,r,e,JSON.stringify([a[0]]),a[1],a[2])})})}),t.exec(`INSERT OR REPLACE INTO ${r} (value_id, value_data, timestamp, hash) VALUES (?, ?, ?, ?)`,null,JSON.stringify([0]),c,d),F(o,(a,e)=>{t.exec(`INSERT OR REPLACE INTO ${r} (value_id, value_data, timestamp, hash) VALUES (?, ?, ?, ?)`,e,JSON.stringify([a[0]]),a[1],a[2])})},m,m,n,2,{getSqlStorage:()=>t})};export{Qa as createDurableObjectSqlStoragePersister};
|
|
1
|
+
const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),i="true",l="t",r=(a,t,e)=>a.replace(t,e),o=Promise,c=a=>(t,e,n)=>a(t)?n?.():e(t),d=clearInterval,u=a=>null==a,y=a=>void 0===a,E=a=>null===a,w=c(u),T=c(y),N=t=>a(t)==s,p=a=>Array.isArray(a),_=(a,t,e)=>a.slice(t,e),O=a=>a.length,m=()=>{},A=async a=>o.all(a),S=a=>{throw Error(a)},v=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},g=(a,t)=>a.forEach(t),L=(a,t="")=>a.join(t),R=(a,t)=>a.map(t),h=a=>0==O(a),f=(a,t)=>a.filter(t),I=(a,...t)=>a.push(...t),$=a=>a.shift(),b=Object,C=a=>b.getPrototypeOf(a),P=b.entries,D=a=>!u(a)&&w(C(a),a=>a==b.prototype||u(C(a)),()=>!0),U=b.keys,x=b.freeze,M=(a=[])=>b.fromEntries(a),X=(...a)=>b.assign({},...a),J=(a,t)=>t in a,F=(a,t)=>(delete a[t],a),V=(a,t)=>g(P(a),([a,e])=>t(e,a)),B=(a,t)=>R(P(a),([a,e])=>t(e,a)),G=(a,t)=>M(B(a,(a,e)=>[e,t(a,e)])),Y=a=>b.values(a),j=a=>O(U(a)),z=a=>D(a)&&0==j(a),k=(a,t,e)=>(J(a,t)||(a[t]=e()),a[t]),q=JSON.stringify,H=JSON.parse,K=a=>""===a?void 0:p(a)?R(a,K):D(a)?G(a,K):a,Q=(a,t)=>a?.has(t)??!1,W=a=>y(a)||0==(a=>a?.size??0)(a),Z=a=>[...a?.values()??[]],aa=(a,t)=>a?.forEach(t),ta=(a,t)=>a?.delete(t),ea=a=>new Map(a),na=(a,t)=>a?.get(t),sa=(a,t)=>R([...a?.entries()??[]],([a,e])=>t(e,a)),ia=(a,t,e)=>y(e)?(ta(a,t),a):a?.set(t,e),la=(a,t,e,n)=>(Q(a,t)?n?.(na(a,t)):ia(a,t,e()),na(a,t)),ra=(a,t,e,n,s=0)=>T((e?la:na)(a,t[s],s>O(t)-2?e:ea),i=>{if(s>O(t)-2)return n?.(i)&&ia(a,t[s]),i;const l=ra(i,t,e,n,s+1);return W(i)&&ia(a,t[s]),l}),oa=(a,t,e)=>{t>a[1]&&(a[1]=t),a[2]=e>>>0},ca=/^\d+$/,da=a=>new Set(p(a)||y(a)?a:[a]),ua=(a,t)=>a?.add(t),ya=ea(),Ea=ea(),wa=(a,t,n,s,i,l,r,o={},c=0,d=[])=>{let u,w,N,_=0,m=0,A=0;la(ya,d,()=>0),la(Ea,d,()=>[]);const L=ea(),[R,h,f,b,C]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!z(a)||!z(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!z(a)||!z(t),t.setContent]:S("Store type not supported by this Persister"))(r,a,c),[P,D,U]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?$(a):null)??e+t++,t=>{ca.test(t)&&O(a)<1e3&&I(a,t)}]})(),s=ea();return[(n,i,l,r=[],o=()=>[])=>{a??=q;const c=t(1);return ia(s,c,[n,i,l,r,o]),ua(ra(i,l??[e],da),c),c},(t,n,...i)=>g(((a,t=[e])=>{const n=[],s=(a,e)=>e==O(t)?I(n,a):E(t[e])?aa(a,a=>s(a,e+1)):g([t[e],null],t=>s(na(a,t),e+1));return s(a,0),n})(t,n),t=>aa(t,t=>na(s,t)[0](a,...n??[],...i))),a=>T(na(s,a),([,t,i])=>(ra(t,i??[e],void 0,t=>(ta(t,a),W(t)?1:0)),ia(s,a),n(a),i)),t=>T(na(s,t),([t,,e=[],n,s])=>{const i=(...l)=>{const r=O(l);r==O(e)?t(a,...l,...s(l)):E(e[r])?g(n[r]?.(...l)??[],a=>i(...l,a)):i(...l,e[r])};i()})]})(),M=a=>{a!=_&&(_=a,D(L,void 0,_))},X=t=>{(R&&p(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},J=async a=>(2!=_&&(M(1),m++,await k(async()=>{await v(async()=>{const e=await t();p(e)?X(e):a?C(a):S("Content is not an array: "+e)},()=>{a&&C(a)}),M(0)})),q),F=async a=>(V(),await J(a),await v(async()=>w=await s(async(a,t)=>{t||a?2!=_&&(M(1),m++,X(t??a),M(0)):await J()}),l),q),V=async()=>(w&&(await v(()=>i(w),l),w=void 0),q),B=async a=>(1!=_&&(M(2),A++,await k(async()=>{await v(()=>n(h,a),l),M(0)})),q),G=async()=>(Y(),await B(),N=a.addDidFinishTransactionListener(()=>{const a=f();b(a)&&B(a)}),q),Y=async()=>(N&&(a.delListener(N),N=void 0),q),j=async(a=!1)=>{const[t,e]=a?[Y,V]:[V,Y];return await t(),await e(),q},k=async(...a)=>(I(na(Ea,d),...a),await(async()=>{if(!na(ya,d)){for(ia(ya,d,1);!y(u=$(na(Ea,d)));)await v(u,l);ia(ya,d,0)}})(),q),q={load:J,startAutoLoad:F,stopAutoLoad:V,isAutoLoading:()=>!y(w),save:B,startAutoSave:G,stopAutoSave:Y,isAutoSaving:()=>!y(N),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[G,F]:[F,G];return await e(a),await n(a),q},stopAutoPersisting:j,getStatus:()=>_,addStatusListener:a=>P(a,L),delListener:t=>(U(t),a),schedule:k,getStore:()=>a,destroy:()=>(na(Ea,d).splice(0,void 0),j()),getStats:()=>({loads:m,saves:A}),...o};return x(q)},Ta="_",Na="_id",pa="SELECT",_a="WHERE",Oa="TABLE",ma="ALTER "+Oa,Aa="FROM",Sa="DELETE "+Aa,va=pa+"*"+Aa,ga="pragma_",La="data_version",Ra="schema_version",ha="pragma_table_",fa="CREATE "+Oa,Ia=a=>L(R(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${r(a,/"/g,'""')}"`),"."),$a=(a,t=[1])=>L(R(a,()=>"$"+t[0]++),n),ba=(a,t=i)=>_a+`(${r(t,"$tableName",Ia(a))})`,Ca="ColumnName",Pa="store",Da="json",Ua=Pa+"TableName",xa=Pa+"Id"+Ca,Ma=Pa+Ca,Xa="autoLoadIntervalSeconds",Ja="rowId"+Ca,Fa="tableId",Va="tableName",Ba="deleteEmptyColumns",Ga="deleteEmptyTable",Ya="condition",ja={mode:Da,[Xa]:1},za={load:0,save:0,[Va]:t+"_values"},ka=(a,t,e,n,s)=>{const i=ea();return G(a,(a,l)=>{const r=_(Y(X(t,N(a)?{[e]:a}:a)),0,j(t));E(r[0])||n(l,r[0])||(s(l,r[0]),ia(i,l,r))}),i},qa=(a,t,e,s,l,r=Ha,o,c)=>{const d=ea();return[async()=>{d.clear(),R(await e(a,t),({tn:a,cn:t})=>ua(la(d,a,da),t))},async(t,e,n)=>((a,t)=>Q(na(d,a),t))(t,e)?M(f(R(await a(va+Ia(t)+ba(t,n)),a=>[a[e],c?G(F(a,e),c):F(a,e)]),([a,t])=>!y(a)&&!z(t))):{},async(t,e,s,c,u,E=!1,w=i)=>{const T=da();G(s??{},a=>R(U(a??{}),a=>ua(T,a)));const N=Z(T);if(!E&&u&&w==i&&h(N)&&Q(d,t))return await a("DROP "+Oa+Ia(t)),void ia(d,t);const p=na(d,t),_=da(Z(p));if(h(N)||(Q(d,t)?await A(R([e,...N],async(n,s)=>{ta(_,n)||(await a(ma+Ia(t)+"ADD"+Ia(n)+l),0==s&&await a("CREATE UNIQUE INDEX pk ON "+Ia(t)+`(${Ia(e)})`),ua(p,n))})):(await a(fa+Ia(t)+`(${Ia(e)}${l} PRIMARY KEY${L(R(N,a=>n+Ia(a)+l))});`),ia(d,t,da([e,...N])))),await A([...!E&&c?R(Z(_),async n=>{n!=e&&(await a(ma+Ia(t)+"DROP"+Ia(n)),ta(p,n))}):[]]),E)y(s)?await a(Sa+Ia(t)+ba(t,w)):await A(B(s,async(n,s)=>{y(n)?await a(Sa+Ia(t)+ba(t,w)+`AND(${Ia(e)}=$1)`,[s]):h(N)||await r(a,t,e,U(n),{[s]:o?R(Y(n),o):Y(n)},p)}));else if(h(N))Q(d,t)&&await a(Sa+Ia(t)+ba(t,w));else{const n=f(Z(na(d,t)),a=>a!=e),i={},l=[];G(s??{},(a,t)=>{i[t]=R(n,t=>o?o(a?.[t]):a?.[t]),I(l,t)}),await r(a,t,e,n,i),await a(Sa+Ia(t)+ba(t,w)+`AND${Ia(e)}NOT IN(${$a(l)})`,l)}},async t=>{let e;return await a("BEGIN"),await v(async()=>e=await t(),s),await a("END"),e}]},Ha=async(a,t,e,s,i)=>{const l=[1];await a("INSERT INTO"+Ia(t)+"("+((...a)=>L(R(a,Ia),n))(e,...s)+")VALUES"+L(B(i,a=>"($"+l[0]+++","+$a(a,l)+")"),n)+"ON CONFLICT("+Ia(e)+")DO UPDATE SET"+L(R(s,a=>Ia(a)+"=excluded."+Ia(a)),n),B(i,(a,t)=>[t,...R(a,a=>a??null)]).flat())},Ka=(a,t,e,n,s,i,l,[r,o,c],d,u,E,w,T,N)=>{const[p,_,O,m]=qa(t,d,u,s,T,N),A=wa(a,()=>m(async()=>{return await p(),a=(await _(r,o))[Ta]?.[c]??"null",K(H(a));var a}),a=>m(async()=>{var t;await p(),await O(r,o,{[Ta]:{[c]:(t=a()??null,q(t,(a,t)=>y(t)?"":t))}},!0,!0)}),e,n,s,l,{[w]:()=>E,destroy:async()=>(await A.stopAutoPersisting(),i(),A)},0,E);return A},Qa=(a,t,e,n,s,i,l,[r,o,[c,d,u]],E,w,T,N,p,_,O,m)=>{const[S,v,g,L]=qa(t,E,w,s,p,_,O,m),R=(a,t)=>A(sa(o,async([e,n,s,i,l],r)=>{t&&!J(a,r)||await g(e,n,a[r],s,i,t,l)})),h=async(a,t)=>d?await g(u,Na,{[Ta]:a},!0,!0,t):null,I=wa(a,()=>L(async()=>{await S();const a=await(async()=>M(f(await A(sa(r,async([a,t,e],n)=>[a,await v(n,t,e)])),a=>!z(a[1]))))(),t=await(async()=>c?(await v(u,Na))[Ta]:{})();return z(a)&&y(t)?void 0:[a,t]}),(a,t)=>L(async()=>{if(await S(),y(t)){const[t,e]=a();await R(t),await h(e)}else await R(t[0],!0),await h(t[1],!0)}),e,n,s,l,{[N]:()=>T,destroy:async()=>(await I.stopAutoPersisting(),i(),I)},0,T);return I},Wa=(a,n,s,l,r,o,c,y,E,w,T="getDb",p)=>{let O,m,A;const S=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,o),[g,L,R,h]=(a=>{const e=(a=>X(ja,N(a)?{[Ua]:a}:a??{}))(a),n=e[Xa];if(e.mode==Da){const a=e[Ua]??t;return[1,n,[a,e[xa]??Na,e[Ma]??Pa],da(a)]}const{tables:{load:s={},save:l={}}={},values:r={}}=e,o=_(Y(X(za,r)),0,j(za)),c=o[2],d=da(c),u=da(c),y=ka(s,{[Fa]:null,[Ja]:Na,[Ya]:i},Fa,a=>Q(u,a),a=>ua(d,a)),E=ka(l,{[Va]:null,[Ja]:Na,[Ba]:0,[Ga]:0,[Ya]:null},Va,(a,t)=>Q(u,t),(a,t)=>ua(d,t));var w;return w=(a,t)=>t[4]??=na(y,t[0])?.[2]??i,aa(E,(a,t)=>w(0,a)),[0,n,[y,E,o],d]})(n);return(g?Ka:Qa)(a,S,a=>{let t;const e=()=>t=setInterval(()=>v(async()=>{const[{d:t,s:e,c:n}]=await S(pa+` ${La} d,${Ra} s,TOTAL_CHANGES() c FROM ${ga}${La} JOIN ${ga}${Ra}`);t==O&&e==m&&n==A||(u(O)||a(),O=t,m=e,A=n)}),1e3*L),n=()=>{O=m=A=null,d(t)},s=l(t=>{h.has(t)&&(n(),a(),e())});return e(),()=>{n(),r(s)}},a=>a(),c,y,E,R,Z(h),async(a,t)=>await a(pa+` t.name tn,c.name cn FROM ${ha}list()t,${ha}info(t.name)c ${_a} t.schema='main'AND t.type IN('table','view')AND t.name IN(${$a(t)})ORDER BY t.name,c.name`,t),w,T,e,p,a=>(a=>!0===a)(a)?1:(a=>!1===a)(a)?0:a,void 0)},Za=(a,t,n,s,i)=>"object"==typeof n&&"fragmented"===n.mode?tt(a,t,n?.storagePrefix??e,i):Wa(a,n,async(a,e=[])=>["BEGIN","END"].includes(a)?[]:(a=a.replace(/\$\d+/g,"?"),t.exec(a,...e).toArray()),()=>m,a=>a(),s,i,m,2,t,"getSqlStorage"),at=()=>[{},e,0],tt=(a,t,e="",n)=>{const s=e.replace(/[^a-zA-Z0-9_]/g,"_"),i=s+"tinybase_tables",r=s+"tinybase_values";return t.exec(`\n CREATE TABLE IF NOT EXISTS ${i} (\n type TEXT NOT NULL,\n table_id TEXT,\n row_id TEXT,\n cell_id TEXT,\n value_data TEXT NOT NULL,\n timestamp TEXT NOT NULL,\n hash INTEGER NOT NULL,\n PRIMARY KEY (type, table_id, row_id, cell_id)\n );\n \n CREATE TABLE IF NOT EXISTS ${r} (\n value_id TEXT,\n value_data TEXT NOT NULL,\n timestamp TEXT NOT NULL,\n hash INTEGER NOT NULL\n );\n `),wa(a,async()=>{const a=at(),e=at(),n=t.exec("SELECT * FROM "+i);for(const t of n.toArray()){const e=t.type+"",n=t.table_id?t.table_id+"":null,s=t.row_id?t.row_id+"":null,i=t.cell_id?t.cell_id+"":null,r=t.value_data+"",o=t.timestamp+"",c=Number(t.hash),[d]=JSON.parse(r);if(e===l)if(n&&s&&i){const t=k(a[0],n,at);k(t[0],s,at)[0][i]=[d,o,c]}else if(n&&s){const t=k(a[0],n,at),e=k(t[0],s,at);oa(e,o,c)}else if(n){const t=k(a[0],n,at);oa(t,o,c)}else oa(a,o,c)}const s=t.exec("SELECT * FROM "+r);for(const a of s.toArray()){const t=a.value_id?a.value_id+"":null,n=a.value_data+"",s=a.timestamp+"",i=Number(a.hash),[l]=JSON.parse(n);t?e[0][t]=[l,s,i]:oa(e,s,i)}return[a,e]},async(a,[[e,n,s],[o,c,d]]=a())=>{t.exec(`INSERT OR REPLACE INTO ${i} (type, table_id, row_id, cell_id, value_data, timestamp, hash) VALUES (?, ?, ?, ?, ?, ?, ?)`,l,null,null,null,JSON.stringify([0]),n,s),V(e,([a,e,n],s)=>{t.exec(`INSERT OR REPLACE INTO ${i} (type, table_id, row_id, cell_id, value_data, timestamp, hash) VALUES (?, ?, ?, ?, ?, ?, ?)`,l,s,null,null,JSON.stringify([0]),e,n),V(a,([a,e,n],r)=>{t.exec(`INSERT OR REPLACE INTO ${i} (type, table_id, row_id, cell_id, value_data, timestamp, hash) VALUES (?, ?, ?, ?, ?, ?, ?)`,l,s,r,null,JSON.stringify([0]),e,n),V(a,(a,e)=>{t.exec(`INSERT OR REPLACE INTO ${i} (type, table_id, row_id, cell_id, value_data, timestamp, hash) VALUES (?, ?, ?, ?, ?, ?, ?)`,l,s,r,e,JSON.stringify([a[0]]),a[1],a[2])})})}),t.exec(`INSERT OR REPLACE INTO ${r} (value_id, value_data, timestamp, hash) VALUES (?, ?, ?, ?)`,null,JSON.stringify([0]),c,d),V(o,(a,e)=>{t.exec(`INSERT OR REPLACE INTO ${r} (value_id, value_data, timestamp, hash) VALUES (?, ?, ?, ?)`,e,JSON.stringify([a[0]]),a[1],a[2])})},m,m,n,2,{getSqlStorage:()=>t})};export{Za as createDurableObjectSqlStoragePersister};
|
|
Binary file
|
|
@@ -1 +1 @@
|
|
|
1
|
-
const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),i="true",l="t",r=(a,t,e)=>a.replace(t,e),o=Promise,c=a=>(t,e,n)=>a(t)?n?.():e(t),d=clearInterval,u=a=>null==a,y=a=>void 0===a,E=a=>null===a,w=c(u),T=c(y),N=t=>a(t)==s,p=a=>Array.isArray(a),_=(a,t,e)=>a.slice(t,e),O=a=>a.length,m=()=>{},A=async a=>o.all(a),S=a=>{throw Error(a)},v=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},g=(a,t)=>a.forEach(t),L=(a,t="")=>a.join(t),R=(a,t)=>a.map(t),h=a=>0==O(a),f=(a,t)=>a.filter(t),I=(a,...t)=>a.push(...t),$=a=>a.shift(),b=Object,C=a=>b.getPrototypeOf(a),P=b.entries,D=b.keys,U=b.freeze,x=(a=[])=>b.fromEntries(a),M=(...a)=>b.assign({},...a),X=(a,t)=>t in a,J=(a,t)=>(delete a[t],a),F=(a,t)=>g(P(a),([a,e])=>t(e,a)),V=(a,t)=>R(P(a),([a,e])=>t(e,a)),B=(a,t)=>x(V(a,(a,e)=>[e,t(a,e)])),G=a=>b.values(a),Y=a=>O(D(a)),j=a=>(a=>!u(a)&&w(C(a),a=>a==b.prototype||u(C(a)),()=>!0))(a)&&0==Y(a),z=(a,t,e)=>(X(a,t)||(a[t]=e()),a[t]),k=JSON.stringify,q=JSON.parse,H=(a,t)=>a?.has(t)??!1,K=a=>y(a)||0==(a=>a?.size??0)(a),Q=a=>[...a?.values()??[]],W=(a,t)=>a?.forEach(t),Z=(a,t)=>a?.delete(t),aa=a=>new Map(a),ta=(a,t)=>a?.get(t),ea=(a,t)=>R([...a?.entries()??[]],([a,e])=>t(e,a)),na=(a,t,e)=>y(e)?(Z(a,t),a):a?.set(t,e),sa=(a,t,e,n)=>(H(a,t)?n?.(ta(a,t)):na(a,t,e()),ta(a,t)),ia=(a,t,e,n,s=0)=>T((e?sa:ta)(a,t[s],s>O(t)-2?e:aa),i=>{if(s>O(t)-2)return n?.(i)&&na(a,t[s]),i;const l=ia(i,t,e,n,s+1);return K(i)&&na(a,t[s]),l}),la=(a,t,e)=>{t>a[1]&&(a[1]=t),a[2]=e>>>0},ra=/^\d+$/,oa=a=>new Set(p(a)||y(a)?a:[a]),ca=(a,t)=>a?.add(t),da=aa(),ua=aa(),ya=(a,t,n,s,i,l,r,o={},c=0,d=[])=>{let u,w,N,_=0,m=0,A=0;sa(da,d,()=>0),sa(ua,d,()=>[]);const L=aa(),[R,h,f,b,C]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!j(a)||!j(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!j(a)||!j(t),t.setContent]:S("Store type not supported by this Persister"))(r,a,c),[P,D,x]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?$(a):null)??e+t++,t=>{ra.test(t)&&O(a)<1e3&&I(a,t)}]})(),s=aa();return[(n,i,l,r=[],o=()=>[])=>{a??=q;const c=t(1);return na(s,c,[n,i,l,r,o]),ca(ia(i,l??[e],oa),c),c},(t,n,...i)=>g(((a,t=[e])=>{const n=[],s=(a,e)=>e==O(t)?I(n,a):E(t[e])?W(a,a=>s(a,e+1)):g([t[e],null],t=>s(ta(a,t),e+1));return s(a,0),n})(t,n),t=>W(t,t=>ta(s,t)[0](a,...n??[],...i))),a=>T(ta(s,a),([,t,i])=>(ia(t,i??[e],void 0,t=>(Z(t,a),K(t)?1:0)),na(s,a),n(a),i)),t=>T(ta(s,t),([t,,e=[],n,s])=>{const i=(...l)=>{const r=O(l);r==O(e)?t(a,...l,...s(l)):E(e[r])?g(n[r]?.(...l)??[],a=>i(...l,a)):i(...l,e[r])};i()})]})(),M=a=>{a!=_&&(_=a,D(L,void 0,_))},X=t=>{(R&&p(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},J=async a=>(2!=_&&(M(1),m++,await k(async()=>{await v(async()=>{const e=await t();p(e)?X(e):a?C(a):S("Content is not an array: "+e)},()=>{a&&C(a)}),M(0)})),q),F=async a=>(V(),await J(a),await v(async()=>w=await s(async(a,t)=>{t||a?2!=_&&(M(1),m++,X(t??a),M(0)):await J()}),l),q),V=async()=>(w&&(await v(()=>i(w),l),w=void 0),q),B=async a=>(1!=_&&(M(2),A++,await k(async()=>{await v(()=>n(h,a),l),M(0)})),q),G=async()=>(Y(),await B(),N=a.addDidFinishTransactionListener(()=>{const a=f();b(a)&&B(a)}),q),Y=async()=>(N&&(a.delListener(N),N=void 0),q),z=async(a=!1)=>{const[t,e]=a?[Y,V]:[V,Y];return await t(),await e(),q},k=async(...a)=>(I(ta(ua,d),...a),await(async()=>{if(!ta(da,d)){for(na(da,d,1);!y(u=$(ta(ua,d)));)await v(u,l);na(da,d,0)}})(),q),q={load:J,startAutoLoad:F,stopAutoLoad:V,isAutoLoading:()=>!y(w),save:B,startAutoSave:G,stopAutoSave:Y,isAutoSaving:()=>!y(N),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[G,F]:[F,G];return await e(a),await n(a),q},stopAutoPersisting:z,getStatus:()=>_,addStatusListener:a=>P(a,L),delListener:t=>(x(t),a),schedule:k,getStore:()=>a,destroy:()=>(ta(ua,d).splice(0,void 0),z()),getStats:()=>({loads:m,saves:A}),...o};return U(q)},Ea="_",wa="_id",Ta="SELECT",Na="WHERE",pa="TABLE",_a="ALTER "+pa,Oa="FROM",ma="DELETE "+Oa,Aa=Ta+"*"+Oa,Sa="pragma_",va="data_version",ga="schema_version",La="pragma_table_",Ra="CREATE "+pa,ha=a=>L(R(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${r(a,/"/g,'""')}"`),"."),fa=(a,t=[1])=>L(R(a,()=>"$"+t[0]++),n),Ia=(a,t=i)=>Na+`(${r(t,"$tableName",ha(a))})`,$a="ColumnName",ba="store",Ca="json",Pa=ba+"TableName",Da=ba+"Id"+$a,Ua=ba+$a,xa="autoLoadIntervalSeconds",Ma="rowId"+$a,Xa="tableId",Ja="tableName",Fa="deleteEmptyColumns",Va="deleteEmptyTable",Ba="condition",Ga={mode:Ca,[xa]:1},Ya={load:0,save:0,[Ja]:t+"_values"},ja=(a,t,e,n,s)=>{const i=aa();return B(a,(a,l)=>{const r=_(G(M(t,N(a)?{[e]:a}:a)),0,Y(t));E(r[0])||n(l,r[0])||(s(l,r[0]),na(i,l,r))}),i},za=(a,t,e,s,l,r=ka,o,c)=>{const d=aa();return[async()=>{d.clear(),R(await e(a,t),({tn:a,cn:t})=>ca(sa(d,a,oa),t))},async(t,e,n)=>((a,t)=>H(ta(d,a),t))(t,e)?x(f(R(await a(Aa+ha(t)+Ia(t,n)),a=>[a[e],c?B(J(a,e),c):J(a,e)]),([a,t])=>!y(a)&&!j(t))):{},async(t,e,s,c,u,E=!1,w=i)=>{const T=oa();B(s??{},a=>R(D(a??{}),a=>ca(T,a)));const N=Q(T);if(!E&&u&&w==i&&h(N)&&H(d,t))return await a("DROP "+pa+ha(t)),void na(d,t);const p=ta(d,t),_=oa(Q(p));if(h(N)||(H(d,t)?await A(R([e,...N],async(n,s)=>{Z(_,n)||(await a(_a+ha(t)+"ADD"+ha(n)+l),0==s&&await a("CREATE UNIQUE INDEX pk ON "+ha(t)+`(${ha(e)})`),ca(p,n))})):(await a(Ra+ha(t)+`(${ha(e)}${l} PRIMARY KEY${L(R(N,a=>n+ha(a)+l))});`),na(d,t,oa([e,...N])))),await A([...!E&&c?R(Q(_),async n=>{n!=e&&(await a(_a+ha(t)+"DROP"+ha(n)),Z(p,n))}):[]]),E)y(s)?await a(ma+ha(t)+Ia(t,w)):await A(V(s,async(n,s)=>{y(n)?await a(ma+ha(t)+Ia(t,w)+`AND(${ha(e)}=$1)`,[s]):h(N)||await r(a,t,e,D(n),{[s]:o?R(G(n),o):G(n)},p)}));else if(h(N))H(d,t)&&await a(ma+ha(t)+Ia(t,w));else{const n=f(Q(ta(d,t)),a=>a!=e),i={},l=[];B(s??{},(a,t)=>{i[t]=R(n,t=>o?o(a?.[t]):a?.[t]),I(l,t)}),await r(a,t,e,n,i),await a(ma+ha(t)+Ia(t,w)+`AND${ha(e)}NOT IN(${fa(l)})`,l)}},async t=>{let e;return await a("BEGIN"),await v(async()=>e=await t(),s),await a("END"),e}]},ka=async(a,t,e,s,i)=>{const l=[1];await a("INSERT INTO"+ha(t)+"("+((...a)=>L(R(a,ha),n))(e,...s)+")VALUES"+L(V(i,a=>"($"+l[0]+++","+fa(a,l)+")"),n)+"ON CONFLICT("+ha(e)+")DO UPDATE SET"+L(R(s,a=>ha(a)+"=excluded."+ha(a)),n),V(i,(a,t)=>[t,...R(a,a=>a??null)]).flat())},qa=(a,t,e,n,s,i,l,[r,o,c],d,u,E,w,T,N)=>{const[p,_,O,m]=za(t,d,u,s,T,N),A=ya(a,()=>m(async()=>{return await p(),a=(await _(r,o))[Ea]?.[c]??"null",q(a,(a,t)=>""===t?void 0:t);var a}),a=>m(async()=>{var t;await p(),await O(r,o,{[Ea]:{[c]:(t=a()??null,k(t,(a,t)=>y(t)?"":t))}},!0,!0)}),e,n,s,l,{[w]:()=>E,destroy:async()=>(await A.stopAutoPersisting(),i(),A)},0,E);return A},Ha=(a,t,e,n,s,i,l,[r,o,[c,d,u]],E,w,T,N,p,_,O,m)=>{const[S,v,g,L]=za(t,E,w,s,p,_,O,m),R=(a,t)=>A(ea(o,async([e,n,s,i,l],r)=>{t&&!X(a,r)||await g(e,n,a[r],s,i,t,l)})),h=async(a,t)=>d?await g(u,wa,{[Ea]:a},!0,!0,t):null,I=ya(a,()=>L(async()=>{await S();const a=await(async()=>x(f(await A(ea(r,async([a,t,e],n)=>[a,await v(n,t,e)])),a=>!j(a[1]))))(),t=await(async()=>c?(await v(u,wa))[Ea]:{})();return j(a)&&y(t)?void 0:[a,t]}),(a,t)=>L(async()=>{if(await S(),y(t)){const[t,e]=a();await R(t),await h(e)}else await R(t[0],!0),await h(t[1],!0)}),e,n,s,l,{[N]:()=>T,destroy:async()=>(await I.stopAutoPersisting(),i(),I)},0,T);return I},Ka=(a,n,s,l,r,o,c,y,E,w,T="getDb",p)=>{let O,m,A;const S=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,o),[g,L,R,h]=(a=>{const e=(a=>M(Ga,N(a)?{[Pa]:a}:a??{}))(a),n=e[xa];if(e.mode==Ca){const a=e[Pa]??t;return[1,n,[a,e[Da]??wa,e[Ua]??ba],oa(a)]}const{tables:{load:s={},save:l={}}={},values:r={}}=e,o=_(G(M(Ya,r)),0,Y(Ya)),c=o[2],d=oa(c),u=oa(c),y=ja(s,{[Xa]:null,[Ma]:wa,[Ba]:i},Xa,a=>H(u,a),a=>ca(d,a)),E=ja(l,{[Ja]:null,[Ma]:wa,[Fa]:0,[Va]:0,[Ba]:null},Ja,(a,t)=>H(u,t),(a,t)=>ca(d,t));var w;return w=(a,t)=>t[4]??=ta(y,t[0])?.[2]??i,W(E,(a,t)=>w(0,a)),[0,n,[y,E,o],d]})(n);return(g?qa:Ha)(a,S,a=>{let t;const e=()=>t=setInterval(()=>v(async()=>{const[{d:t,s:e,c:n}]=await S(Ta+` ${va} d,${ga} s,TOTAL_CHANGES() c FROM ${Sa}${va} JOIN ${Sa}${ga}`);t==O&&e==m&&n==A||(u(O)||a(),O=t,m=e,A=n)}),1e3*L),n=()=>{O=m=A=null,d(t)},s=l(t=>{h.has(t)&&(n(),a(),e())});return e(),()=>{n(),r(s)}},a=>a(),c,y,E,R,Q(h),async(a,t)=>await a(Ta+` t.name tn,c.name cn FROM ${La}list()t,${La}info(t.name)c ${Na} t.schema='main'AND t.type IN('table','view')AND t.name IN(${fa(t)})ORDER BY t.name,c.name`,t),w,T,e,p,a=>(a=>!0===a)(a)?1:(a=>!1===a)(a)?0:a,void 0)},Qa=(a,t,n,s,i)=>"object"==typeof n&&"fragmented"===n.mode?Za(a,t,n?.storagePrefix??e,i):Ka(a,n,async(a,e=[])=>["BEGIN","END"].includes(a)?[]:(a=a.replace(/\$\d+/g,"?"),t.exec(a,...e).toArray()),()=>m,a=>a(),s,i,m,2,t,"getSqlStorage"),Wa=()=>[{},e,0],Za=(a,t,e="",n)=>{const s=e.replace(/[^a-zA-Z0-9_]/g,"_"),i=s+"tinybase_tables",r=s+"tinybase_values";return t.exec(`\n CREATE TABLE IF NOT EXISTS ${i} (\n type TEXT NOT NULL,\n table_id TEXT,\n row_id TEXT,\n cell_id TEXT,\n value_data TEXT NOT NULL,\n timestamp TEXT NOT NULL,\n hash INTEGER NOT NULL,\n PRIMARY KEY (type, table_id, row_id, cell_id)\n );\n \n CREATE TABLE IF NOT EXISTS ${r} (\n value_id TEXT,\n value_data TEXT NOT NULL,\n timestamp TEXT NOT NULL,\n hash INTEGER NOT NULL\n );\n `),ya(a,async()=>{const a=Wa(),e=Wa(),n=t.exec("SELECT * FROM "+i);for(const t of n.toArray()){const e=t.type+"",n=t.table_id?t.table_id+"":null,s=t.row_id?t.row_id+"":null,i=t.cell_id?t.cell_id+"":null,r=t.value_data+"",o=t.timestamp+"",c=Number(t.hash),[d]=JSON.parse(r);if(e===l)if(n&&s&&i){const t=z(a[0],n,Wa);z(t[0],s,Wa)[0][i]=[d,o,c]}else if(n&&s){const t=z(a[0],n,Wa),e=z(t[0],s,Wa);la(e,o,c)}else if(n){const t=z(a[0],n,Wa);la(t,o,c)}else la(a,o,c)}const s=t.exec("SELECT * FROM "+r);for(const a of s.toArray()){const t=a.value_id?a.value_id+"":null,n=a.value_data+"",s=a.timestamp+"",i=Number(a.hash),[l]=JSON.parse(n);t?e[0][t]=[l,s,i]:la(e,s,i)}return[a,e]},async(a,[[e,n,s],[o,c,d]]=a())=>{t.exec(`INSERT OR REPLACE INTO ${i} (type, table_id, row_id, cell_id, value_data, timestamp, hash) VALUES (?, ?, ?, ?, ?, ?, ?)`,l,null,null,null,JSON.stringify([0]),n,s),F(e,([a,e,n],s)=>{t.exec(`INSERT OR REPLACE INTO ${i} (type, table_id, row_id, cell_id, value_data, timestamp, hash) VALUES (?, ?, ?, ?, ?, ?, ?)`,l,s,null,null,JSON.stringify([0]),e,n),F(a,([a,e,n],r)=>{t.exec(`INSERT OR REPLACE INTO ${i} (type, table_id, row_id, cell_id, value_data, timestamp, hash) VALUES (?, ?, ?, ?, ?, ?, ?)`,l,s,r,null,JSON.stringify([0]),e,n),F(a,(a,e)=>{t.exec(`INSERT OR REPLACE INTO ${i} (type, table_id, row_id, cell_id, value_data, timestamp, hash) VALUES (?, ?, ?, ?, ?, ?, ?)`,l,s,r,e,JSON.stringify([a[0]]),a[1],a[2])})})}),t.exec(`INSERT OR REPLACE INTO ${r} (value_id, value_data, timestamp, hash) VALUES (?, ?, ?, ?)`,null,JSON.stringify([0]),c,d),F(o,(a,e)=>{t.exec(`INSERT OR REPLACE INTO ${r} (value_id, value_data, timestamp, hash) VALUES (?, ?, ?, ?)`,e,JSON.stringify([a[0]]),a[1],a[2])})},m,m,n,2,{getSqlStorage:()=>t})};export{Qa as createDurableObjectSqlStoragePersister};
|
|
1
|
+
const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),i="true",l="t",r=(a,t,e)=>a.replace(t,e),o=Promise,c=a=>(t,e,n)=>a(t)?n?.():e(t),d=clearInterval,u=a=>null==a,y=a=>void 0===a,E=a=>null===a,w=c(u),T=c(y),N=t=>a(t)==s,p=a=>Array.isArray(a),_=(a,t,e)=>a.slice(t,e),O=a=>a.length,m=()=>{},A=async a=>o.all(a),S=a=>{throw Error(a)},v=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},g=(a,t)=>a.forEach(t),L=(a,t="")=>a.join(t),R=(a,t)=>a.map(t),h=a=>0==O(a),f=(a,t)=>a.filter(t),I=(a,...t)=>a.push(...t),$=a=>a.shift(),b=Object,C=a=>b.getPrototypeOf(a),P=b.entries,D=a=>!u(a)&&w(C(a),a=>a==b.prototype||u(C(a)),()=>!0),U=b.keys,x=b.freeze,M=(a=[])=>b.fromEntries(a),X=(...a)=>b.assign({},...a),J=(a,t)=>t in a,F=(a,t)=>(delete a[t],a),V=(a,t)=>g(P(a),([a,e])=>t(e,a)),B=(a,t)=>R(P(a),([a,e])=>t(e,a)),G=(a,t)=>M(B(a,(a,e)=>[e,t(a,e)])),Y=a=>b.values(a),j=a=>O(U(a)),z=a=>D(a)&&0==j(a),k=(a,t,e)=>(J(a,t)||(a[t]=e()),a[t]),q=JSON.stringify,H=JSON.parse,K=a=>""===a?void 0:p(a)?R(a,K):D(a)?G(a,K):a,Q=(a,t)=>a?.has(t)??!1,W=a=>y(a)||0==(a=>a?.size??0)(a),Z=a=>[...a?.values()??[]],aa=(a,t)=>a?.forEach(t),ta=(a,t)=>a?.delete(t),ea=a=>new Map(a),na=(a,t)=>a?.get(t),sa=(a,t)=>R([...a?.entries()??[]],([a,e])=>t(e,a)),ia=(a,t,e)=>y(e)?(ta(a,t),a):a?.set(t,e),la=(a,t,e,n)=>(Q(a,t)?n?.(na(a,t)):ia(a,t,e()),na(a,t)),ra=(a,t,e,n,s=0)=>T((e?la:na)(a,t[s],s>O(t)-2?e:ea),i=>{if(s>O(t)-2)return n?.(i)&&ia(a,t[s]),i;const l=ra(i,t,e,n,s+1);return W(i)&&ia(a,t[s]),l}),oa=(a,t,e)=>{t>a[1]&&(a[1]=t),a[2]=e>>>0},ca=/^\d+$/,da=a=>new Set(p(a)||y(a)?a:[a]),ua=(a,t)=>a?.add(t),ya=ea(),Ea=ea(),wa=(a,t,n,s,i,l,r,o={},c=0,d=[])=>{let u,w,N,_=0,m=0,A=0;la(ya,d,()=>0),la(Ea,d,()=>[]);const L=ea(),[R,h,f,b,C]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!z(a)||!z(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!z(a)||!z(t),t.setContent]:S("Store type not supported by this Persister"))(r,a,c),[P,D,U]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?$(a):null)??e+t++,t=>{ca.test(t)&&O(a)<1e3&&I(a,t)}]})(),s=ea();return[(n,i,l,r=[],o=()=>[])=>{a??=q;const c=t(1);return ia(s,c,[n,i,l,r,o]),ua(ra(i,l??[e],da),c),c},(t,n,...i)=>g(((a,t=[e])=>{const n=[],s=(a,e)=>e==O(t)?I(n,a):E(t[e])?aa(a,a=>s(a,e+1)):g([t[e],null],t=>s(na(a,t),e+1));return s(a,0),n})(t,n),t=>aa(t,t=>na(s,t)[0](a,...n??[],...i))),a=>T(na(s,a),([,t,i])=>(ra(t,i??[e],void 0,t=>(ta(t,a),W(t)?1:0)),ia(s,a),n(a),i)),t=>T(na(s,t),([t,,e=[],n,s])=>{const i=(...l)=>{const r=O(l);r==O(e)?t(a,...l,...s(l)):E(e[r])?g(n[r]?.(...l)??[],a=>i(...l,a)):i(...l,e[r])};i()})]})(),M=a=>{a!=_&&(_=a,D(L,void 0,_))},X=t=>{(R&&p(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},J=async a=>(2!=_&&(M(1),m++,await k(async()=>{await v(async()=>{const e=await t();p(e)?X(e):a?C(a):S("Content is not an array: "+e)},()=>{a&&C(a)}),M(0)})),q),F=async a=>(V(),await J(a),await v(async()=>w=await s(async(a,t)=>{t||a?2!=_&&(M(1),m++,X(t??a),M(0)):await J()}),l),q),V=async()=>(w&&(await v(()=>i(w),l),w=void 0),q),B=async a=>(1!=_&&(M(2),A++,await k(async()=>{await v(()=>n(h,a),l),M(0)})),q),G=async()=>(Y(),await B(),N=a.addDidFinishTransactionListener(()=>{const a=f();b(a)&&B(a)}),q),Y=async()=>(N&&(a.delListener(N),N=void 0),q),j=async(a=!1)=>{const[t,e]=a?[Y,V]:[V,Y];return await t(),await e(),q},k=async(...a)=>(I(na(Ea,d),...a),await(async()=>{if(!na(ya,d)){for(ia(ya,d,1);!y(u=$(na(Ea,d)));)await v(u,l);ia(ya,d,0)}})(),q),q={load:J,startAutoLoad:F,stopAutoLoad:V,isAutoLoading:()=>!y(w),save:B,startAutoSave:G,stopAutoSave:Y,isAutoSaving:()=>!y(N),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[G,F]:[F,G];return await e(a),await n(a),q},stopAutoPersisting:j,getStatus:()=>_,addStatusListener:a=>P(a,L),delListener:t=>(U(t),a),schedule:k,getStore:()=>a,destroy:()=>(na(Ea,d).splice(0,void 0),j()),getStats:()=>({loads:m,saves:A}),...o};return x(q)},Ta="_",Na="_id",pa="SELECT",_a="WHERE",Oa="TABLE",ma="ALTER "+Oa,Aa="FROM",Sa="DELETE "+Aa,va=pa+"*"+Aa,ga="pragma_",La="data_version",Ra="schema_version",ha="pragma_table_",fa="CREATE "+Oa,Ia=a=>L(R(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${r(a,/"/g,'""')}"`),"."),$a=(a,t=[1])=>L(R(a,()=>"$"+t[0]++),n),ba=(a,t=i)=>_a+`(${r(t,"$tableName",Ia(a))})`,Ca="ColumnName",Pa="store",Da="json",Ua=Pa+"TableName",xa=Pa+"Id"+Ca,Ma=Pa+Ca,Xa="autoLoadIntervalSeconds",Ja="rowId"+Ca,Fa="tableId",Va="tableName",Ba="deleteEmptyColumns",Ga="deleteEmptyTable",Ya="condition",ja={mode:Da,[Xa]:1},za={load:0,save:0,[Va]:t+"_values"},ka=(a,t,e,n,s)=>{const i=ea();return G(a,(a,l)=>{const r=_(Y(X(t,N(a)?{[e]:a}:a)),0,j(t));E(r[0])||n(l,r[0])||(s(l,r[0]),ia(i,l,r))}),i},qa=(a,t,e,s,l,r=Ha,o,c)=>{const d=ea();return[async()=>{d.clear(),R(await e(a,t),({tn:a,cn:t})=>ua(la(d,a,da),t))},async(t,e,n)=>((a,t)=>Q(na(d,a),t))(t,e)?M(f(R(await a(va+Ia(t)+ba(t,n)),a=>[a[e],c?G(F(a,e),c):F(a,e)]),([a,t])=>!y(a)&&!z(t))):{},async(t,e,s,c,u,E=!1,w=i)=>{const T=da();G(s??{},a=>R(U(a??{}),a=>ua(T,a)));const N=Z(T);if(!E&&u&&w==i&&h(N)&&Q(d,t))return await a("DROP "+Oa+Ia(t)),void ia(d,t);const p=na(d,t),_=da(Z(p));if(h(N)||(Q(d,t)?await A(R([e,...N],async(n,s)=>{ta(_,n)||(await a(ma+Ia(t)+"ADD"+Ia(n)+l),0==s&&await a("CREATE UNIQUE INDEX pk ON "+Ia(t)+`(${Ia(e)})`),ua(p,n))})):(await a(fa+Ia(t)+`(${Ia(e)}${l} PRIMARY KEY${L(R(N,a=>n+Ia(a)+l))});`),ia(d,t,da([e,...N])))),await A([...!E&&c?R(Z(_),async n=>{n!=e&&(await a(ma+Ia(t)+"DROP"+Ia(n)),ta(p,n))}):[]]),E)y(s)?await a(Sa+Ia(t)+ba(t,w)):await A(B(s,async(n,s)=>{y(n)?await a(Sa+Ia(t)+ba(t,w)+`AND(${Ia(e)}=$1)`,[s]):h(N)||await r(a,t,e,U(n),{[s]:o?R(Y(n),o):Y(n)},p)}));else if(h(N))Q(d,t)&&await a(Sa+Ia(t)+ba(t,w));else{const n=f(Z(na(d,t)),a=>a!=e),i={},l=[];G(s??{},(a,t)=>{i[t]=R(n,t=>o?o(a?.[t]):a?.[t]),I(l,t)}),await r(a,t,e,n,i),await a(Sa+Ia(t)+ba(t,w)+`AND${Ia(e)}NOT IN(${$a(l)})`,l)}},async t=>{let e;return await a("BEGIN"),await v(async()=>e=await t(),s),await a("END"),e}]},Ha=async(a,t,e,s,i)=>{const l=[1];await a("INSERT INTO"+Ia(t)+"("+((...a)=>L(R(a,Ia),n))(e,...s)+")VALUES"+L(B(i,a=>"($"+l[0]+++","+$a(a,l)+")"),n)+"ON CONFLICT("+Ia(e)+")DO UPDATE SET"+L(R(s,a=>Ia(a)+"=excluded."+Ia(a)),n),B(i,(a,t)=>[t,...R(a,a=>a??null)]).flat())},Ka=(a,t,e,n,s,i,l,[r,o,c],d,u,E,w,T,N)=>{const[p,_,O,m]=qa(t,d,u,s,T,N),A=wa(a,()=>m(async()=>{return await p(),a=(await _(r,o))[Ta]?.[c]??"null",K(H(a));var a}),a=>m(async()=>{var t;await p(),await O(r,o,{[Ta]:{[c]:(t=a()??null,q(t,(a,t)=>y(t)?"":t))}},!0,!0)}),e,n,s,l,{[w]:()=>E,destroy:async()=>(await A.stopAutoPersisting(),i(),A)},0,E);return A},Qa=(a,t,e,n,s,i,l,[r,o,[c,d,u]],E,w,T,N,p,_,O,m)=>{const[S,v,g,L]=qa(t,E,w,s,p,_,O,m),R=(a,t)=>A(sa(o,async([e,n,s,i,l],r)=>{t&&!J(a,r)||await g(e,n,a[r],s,i,t,l)})),h=async(a,t)=>d?await g(u,Na,{[Ta]:a},!0,!0,t):null,I=wa(a,()=>L(async()=>{await S();const a=await(async()=>M(f(await A(sa(r,async([a,t,e],n)=>[a,await v(n,t,e)])),a=>!z(a[1]))))(),t=await(async()=>c?(await v(u,Na))[Ta]:{})();return z(a)&&y(t)?void 0:[a,t]}),(a,t)=>L(async()=>{if(await S(),y(t)){const[t,e]=a();await R(t),await h(e)}else await R(t[0],!0),await h(t[1],!0)}),e,n,s,l,{[N]:()=>T,destroy:async()=>(await I.stopAutoPersisting(),i(),I)},0,T);return I},Wa=(a,n,s,l,r,o,c,y,E,w,T="getDb",p)=>{let O,m,A;const S=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,o),[g,L,R,h]=(a=>{const e=(a=>X(ja,N(a)?{[Ua]:a}:a??{}))(a),n=e[Xa];if(e.mode==Da){const a=e[Ua]??t;return[1,n,[a,e[xa]??Na,e[Ma]??Pa],da(a)]}const{tables:{load:s={},save:l={}}={},values:r={}}=e,o=_(Y(X(za,r)),0,j(za)),c=o[2],d=da(c),u=da(c),y=ka(s,{[Fa]:null,[Ja]:Na,[Ya]:i},Fa,a=>Q(u,a),a=>ua(d,a)),E=ka(l,{[Va]:null,[Ja]:Na,[Ba]:0,[Ga]:0,[Ya]:null},Va,(a,t)=>Q(u,t),(a,t)=>ua(d,t));var w;return w=(a,t)=>t[4]??=na(y,t[0])?.[2]??i,aa(E,(a,t)=>w(0,a)),[0,n,[y,E,o],d]})(n);return(g?Ka:Qa)(a,S,a=>{let t;const e=()=>t=setInterval(()=>v(async()=>{const[{d:t,s:e,c:n}]=await S(pa+` ${La} d,${Ra} s,TOTAL_CHANGES() c FROM ${ga}${La} JOIN ${ga}${Ra}`);t==O&&e==m&&n==A||(u(O)||a(),O=t,m=e,A=n)}),1e3*L),n=()=>{O=m=A=null,d(t)},s=l(t=>{h.has(t)&&(n(),a(),e())});return e(),()=>{n(),r(s)}},a=>a(),c,y,E,R,Z(h),async(a,t)=>await a(pa+` t.name tn,c.name cn FROM ${ha}list()t,${ha}info(t.name)c ${_a} t.schema='main'AND t.type IN('table','view')AND t.name IN(${$a(t)})ORDER BY t.name,c.name`,t),w,T,e,p,a=>(a=>!0===a)(a)?1:(a=>!1===a)(a)?0:a,void 0)},Za=(a,t,n,s,i)=>"object"==typeof n&&"fragmented"===n.mode?tt(a,t,n?.storagePrefix??e,i):Wa(a,n,async(a,e=[])=>["BEGIN","END"].includes(a)?[]:(a=a.replace(/\$\d+/g,"?"),t.exec(a,...e).toArray()),()=>m,a=>a(),s,i,m,2,t,"getSqlStorage"),at=()=>[{},e,0],tt=(a,t,e="",n)=>{const s=e.replace(/[^a-zA-Z0-9_]/g,"_"),i=s+"tinybase_tables",r=s+"tinybase_values";return t.exec(`\n CREATE TABLE IF NOT EXISTS ${i} (\n type TEXT NOT NULL,\n table_id TEXT,\n row_id TEXT,\n cell_id TEXT,\n value_data TEXT NOT NULL,\n timestamp TEXT NOT NULL,\n hash INTEGER NOT NULL,\n PRIMARY KEY (type, table_id, row_id, cell_id)\n );\n \n CREATE TABLE IF NOT EXISTS ${r} (\n value_id TEXT,\n value_data TEXT NOT NULL,\n timestamp TEXT NOT NULL,\n hash INTEGER NOT NULL\n );\n `),wa(a,async()=>{const a=at(),e=at(),n=t.exec("SELECT * FROM "+i);for(const t of n.toArray()){const e=t.type+"",n=t.table_id?t.table_id+"":null,s=t.row_id?t.row_id+"":null,i=t.cell_id?t.cell_id+"":null,r=t.value_data+"",o=t.timestamp+"",c=Number(t.hash),[d]=JSON.parse(r);if(e===l)if(n&&s&&i){const t=k(a[0],n,at);k(t[0],s,at)[0][i]=[d,o,c]}else if(n&&s){const t=k(a[0],n,at),e=k(t[0],s,at);oa(e,o,c)}else if(n){const t=k(a[0],n,at);oa(t,o,c)}else oa(a,o,c)}const s=t.exec("SELECT * FROM "+r);for(const a of s.toArray()){const t=a.value_id?a.value_id+"":null,n=a.value_data+"",s=a.timestamp+"",i=Number(a.hash),[l]=JSON.parse(n);t?e[0][t]=[l,s,i]:oa(e,s,i)}return[a,e]},async(a,[[e,n,s],[o,c,d]]=a())=>{t.exec(`INSERT OR REPLACE INTO ${i} (type, table_id, row_id, cell_id, value_data, timestamp, hash) VALUES (?, ?, ?, ?, ?, ?, ?)`,l,null,null,null,JSON.stringify([0]),n,s),V(e,([a,e,n],s)=>{t.exec(`INSERT OR REPLACE INTO ${i} (type, table_id, row_id, cell_id, value_data, timestamp, hash) VALUES (?, ?, ?, ?, ?, ?, ?)`,l,s,null,null,JSON.stringify([0]),e,n),V(a,([a,e,n],r)=>{t.exec(`INSERT OR REPLACE INTO ${i} (type, table_id, row_id, cell_id, value_data, timestamp, hash) VALUES (?, ?, ?, ?, ?, ?, ?)`,l,s,r,null,JSON.stringify([0]),e,n),V(a,(a,e)=>{t.exec(`INSERT OR REPLACE INTO ${i} (type, table_id, row_id, cell_id, value_data, timestamp, hash) VALUES (?, ?, ?, ?, ?, ?, ?)`,l,s,r,e,JSON.stringify([a[0]]),a[1],a[2])})})}),t.exec(`INSERT OR REPLACE INTO ${r} (value_id, value_data, timestamp, hash) VALUES (?, ?, ?, ?)`,null,JSON.stringify([0]),c,d),V(o,(a,e)=>{t.exec(`INSERT OR REPLACE INTO ${r} (value_id, value_data, timestamp, hash) VALUES (?, ?, ?, ?)`,e,JSON.stringify([a[0]]),a[1],a[2])})},m,m,n,2,{getSqlStorage:()=>t})};export{Za as createDurableObjectSqlStoragePersister};
|
|
Binary file
|
|
@@ -1 +1 @@
|
|
|
1
|
-
const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),i="true",r=(a,t,e)=>a.replace(t,e),o=Promise,c=a=>(t,e,n)=>a(t)?n?.():e(t),l=clearInterval,w=a=>null==a,y=a=>void 0===a,u=a=>null===a,d=c(w),g=c(y),E=t=>a(t)==s,p=a=>Array.isArray(a),v=(a,t,e)=>a.slice(t,e),A=a=>a.length,m=()=>{},N=async a=>o.all(a),$=a=>{throw Error(a)},f=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},b=(a,t)=>a.forEach(t),C=(a,t="")=>a.join(t),T=(a,t)=>a.map(t),h=a=>0==A(a),D=(a,t)=>a.filter(t),O=(a,...t)=>a.push(...t),I=a=>a.shift(),S=(a,t)=>a?.has(t)??!1,L=a=>y(a)||0==(a=>a?.size??0)(a),R=a=>[...a?.values()??[]],P=(a,t)=>a?.forEach(t),M=(a,t)=>a?.delete(t),_="_",F="_id",U="SELECT",j="WHERE",B="TABLE",J="ALTER "+B,Y="FROM",k="DELETE "+Y,x=U+"*"+Y,z="pragma_",G="data_version",H="schema_version",q="pragma_table_",K="CREATE "+B,Q=a=>C(T(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${r(a,/"/g,'""')}"`),"."),V=(a,t=[1])=>C(T(a,()=>"$"+t[0]++),n),W=(a,t=i)=>j+`(${r(t,"$tableName",Q(a))})`,X=Object,Z=a=>X.getPrototypeOf(a),aa=X.entries,ta=X.
|
|
1
|
+
const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),i="true",r=(a,t,e)=>a.replace(t,e),o=Promise,c=a=>(t,e,n)=>a(t)?n?.():e(t),l=clearInterval,w=a=>null==a,y=a=>void 0===a,u=a=>null===a,d=c(w),g=c(y),E=t=>a(t)==s,p=a=>Array.isArray(a),v=(a,t,e)=>a.slice(t,e),A=a=>a.length,m=()=>{},N=async a=>o.all(a),$=a=>{throw Error(a)},f=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},b=(a,t)=>a.forEach(t),C=(a,t="")=>a.join(t),T=(a,t)=>a.map(t),h=a=>0==A(a),D=(a,t)=>a.filter(t),O=(a,...t)=>a.push(...t),I=a=>a.shift(),S=(a,t)=>a?.has(t)??!1,L=a=>y(a)||0==(a=>a?.size??0)(a),R=a=>[...a?.values()??[]],P=(a,t)=>a?.forEach(t),M=(a,t)=>a?.delete(t),_="_",F="_id",U="SELECT",j="WHERE",B="TABLE",J="ALTER "+B,Y="FROM",k="DELETE "+Y,x=U+"*"+Y,z="pragma_",G="data_version",H="schema_version",q="pragma_table_",K="CREATE "+B,Q=a=>C(T(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${r(a,/"/g,'""')}"`),"."),V=(a,t=[1])=>C(T(a,()=>"$"+t[0]++),n),W=(a,t=i)=>j+`(${r(t,"$tableName",Q(a))})`,X=Object,Z=a=>X.getPrototypeOf(a),aa=X.entries,ta=a=>!w(a)&&d(Z(a),a=>a==X.prototype||w(Z(a)),()=>!0),ea=X.keys,na=X.freeze,sa=(a=[])=>X.fromEntries(a),ia=(...a)=>X.assign({},...a),ra=(a,t)=>(delete a[t],a),oa=(a,t)=>T(aa(a),([a,e])=>t(e,a)),ca=(a,t)=>sa(oa(a,(a,e)=>[e,t(a,e)])),la=a=>X.values(a),wa=a=>A(ea(a)),ya=a=>ta(a)&&0==wa(a),ua=a=>new Map(a),da=(a,t)=>a?.get(t),ga=(a,t)=>T([...a?.entries()??[]],([a,e])=>t(e,a)),Ea=(a,t,e)=>y(e)?(M(a,t),a):a?.set(t,e),pa=(a,t,e,n)=>(S(a,t)?n?.(da(a,t)):Ea(a,t,e()),da(a,t)),va=(a,t,e,n,s=0)=>g((e?pa:da)(a,t[s],s>A(t)-2?e:ua),i=>{if(s>A(t)-2)return n?.(i)&&Ea(a,t[s]),i;const r=va(i,t,e,n,s+1);return L(i)&&Ea(a,t[s]),r}),Aa=a=>new Set(p(a)||y(a)?a:[a]),ma=(a,t)=>a?.add(t),Na="ColumnName",$a="store",fa="json",ba=$a+"TableName",Ca=$a+"Id"+Na,Ta=$a+Na,ha="autoLoadIntervalSeconds",Da="rowId"+Na,Oa="tableId",Ia="tableName",Sa="deleteEmptyColumns",La="deleteEmptyTable",Ra="condition",Pa={mode:fa,[ha]:1},Ma={load:0,save:0,[Ia]:t+"_values"},_a=(a,t,e,n,s)=>{const i=ua();return ca(a,(a,r)=>{const o=v(la(ia(t,E(a)?{[e]:a}:a)),0,wa(t));u(o[0])||n(r,o[0])||(s(r,o[0]),Ea(i,r,o))}),i},Fa=JSON.stringify,Ua=JSON.parse,ja=a=>""===a?void 0:p(a)?T(a,ja):ta(a)?ca(a,ja):a,Ba=/^\d+$/,Ja=ua(),Ya=ua(),ka=(a,t,n,s,i,r,o,c={},l=0,w=[])=>{let d,E,v,m=0,N=0,C=0;pa(Ja,w,()=>0),pa(Ya,w,()=>[]);const T=ua(),[h,D,S,R,_]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!ya(a)||!ya(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!ya(a)||!ya(t),t.setContent]:$("Store type not supported by this Persister"))(o,a,l),[F,U,j]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?I(a):null)??e+t++,t=>{Ba.test(t)&&A(a)<1e3&&O(a,t)}]})(),s=ua();return[(n,i,r,o=[],c=()=>[])=>{a??=Q;const l=t(1);return Ea(s,l,[n,i,r,o,c]),ma(va(i,r??[e],Aa),l),l},(t,n,...i)=>b(((a,t=[e])=>{const n=[],s=(a,e)=>e==A(t)?O(n,a):u(t[e])?P(a,a=>s(a,e+1)):b([t[e],null],t=>s(da(a,t),e+1));return s(a,0),n})(t,n),t=>P(t,t=>da(s,t)[0](a,...n??[],...i))),a=>g(da(s,a),([,t,i])=>(va(t,i??[e],void 0,t=>(M(t,a),L(t)?1:0)),Ea(s,a),n(a),i)),t=>g(da(s,t),([t,,e=[],n,s])=>{const i=(...r)=>{const o=A(r);o==A(e)?t(a,...r,...s(r)):u(e[o])?b(n[o]?.(...r)??[],a=>i(...r,a)):i(...r,e[o])};i()})]})(),B=a=>{a!=m&&(m=a,U(T,void 0,m))},J=t=>{(h&&p(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},Y=async a=>(2!=m&&(B(1),N++,await K(async()=>{await f(async()=>{const e=await t();p(e)?J(e):a?_(a):$("Content is not an array: "+e)},()=>{a&&_(a)}),B(0)})),Q),k=async a=>(x(),await Y(a),await f(async()=>E=await s(async(a,t)=>{t||a?2!=m&&(B(1),N++,J(t??a),B(0)):await Y()}),r),Q),x=async()=>(E&&(await f(()=>i(E),r),E=void 0),Q),z=async a=>(1!=m&&(B(2),C++,await K(async()=>{await f(()=>n(D,a),r),B(0)})),Q),G=async()=>(H(),await z(),v=a.addDidFinishTransactionListener(()=>{const a=S();R(a)&&z(a)}),Q),H=async()=>(v&&(a.delListener(v),v=void 0),Q),q=async(a=!1)=>{const[t,e]=a?[H,x]:[x,H];return await t(),await e(),Q},K=async(...a)=>(O(da(Ya,w),...a),await(async()=>{if(!da(Ja,w)){for(Ea(Ja,w,1);!y(d=I(da(Ya,w)));)await f(d,r);Ea(Ja,w,0)}})(),Q),Q={load:Y,startAutoLoad:k,stopAutoLoad:x,isAutoLoading:()=>!y(E),save:z,startAutoSave:G,stopAutoSave:H,isAutoSaving:()=>!y(v),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[G,k]:[k,G];return await e(a),await n(a),Q},stopAutoPersisting:q,getStatus:()=>m,addStatusListener:a=>F(a,T),delListener:t=>(j(t),a),schedule:K,getStore:()=>a,destroy:()=>(da(Ya,w).splice(0,void 0),q()),getStats:()=>({loads:N,saves:C}),...c};return na(Q)},xa=(a,t,e,s,r,o=za,c,l)=>{const w=ua();return[async()=>{w.clear(),T(await e(a,t),({tn:a,cn:t})=>ma(pa(w,a,Aa),t))},async(t,e,n)=>((a,t)=>S(da(w,a),t))(t,e)?sa(D(T(await a(x+Q(t)+W(t,n)),a=>[a[e],l?ca(ra(a,e),l):ra(a,e)]),([a,t])=>!y(a)&&!ya(t))):{},async(t,e,s,l,u,d=!1,g=i)=>{const E=Aa();ca(s??{},a=>T(ea(a??{}),a=>ma(E,a)));const p=R(E);if(!d&&u&&g==i&&h(p)&&S(w,t))return await a("DROP "+B+Q(t)),void Ea(w,t);const v=da(w,t),A=Aa(R(v));if(h(p)||(S(w,t)?await N(T([e,...p],async(n,s)=>{M(A,n)||(await a(J+Q(t)+"ADD"+Q(n)+r),0==s&&await a("CREATE UNIQUE INDEX pk ON "+Q(t)+`(${Q(e)})`),ma(v,n))})):(await a(K+Q(t)+`(${Q(e)}${r} PRIMARY KEY${C(T(p,a=>n+Q(a)+r))});`),Ea(w,t,Aa([e,...p])))),await N([...!d&&l?T(R(A),async n=>{n!=e&&(await a(J+Q(t)+"DROP"+Q(n)),M(v,n))}):[]]),d)y(s)?await a(k+Q(t)+W(t,g)):await N(oa(s,async(n,s)=>{y(n)?await a(k+Q(t)+W(t,g)+`AND(${Q(e)}=$1)`,[s]):h(p)||await o(a,t,e,ea(n),{[s]:c?T(la(n),c):la(n)},v)}));else if(h(p))S(w,t)&&await a(k+Q(t)+W(t,g));else{const n=D(R(da(w,t)),a=>a!=e),i={},r=[];ca(s??{},(a,t)=>{i[t]=T(n,t=>c?c(a?.[t]):a?.[t]),O(r,t)}),await o(a,t,e,n,i),await a(k+Q(t)+W(t,g)+`AND${Q(e)}NOT IN(${V(r)})`,r)}},async t=>{let e;return await a("BEGIN"),await f(async()=>e=await t(),s),await a("END"),e}]},za=async(a,t,e,s,i)=>{const r=[1];await a("INSERT INTO"+Q(t)+"("+((...a)=>C(T(a,Q),n))(e,...s)+")VALUES"+C(oa(i,a=>"($"+r[0]+++","+V(a,r)+")"),n)+"ON CONFLICT("+Q(e)+")DO UPDATE SET"+C(T(s,a=>Q(a)+"=excluded."+Q(a)),n),oa(i,(a,t)=>[t,...T(a,a=>a??null)]).flat())},Ga=(a,t,e,n,s,i,r,[o,c,l],w,u,d,g,E,p)=>{const[v,A,m,N]=xa(t,w,u,s,E,p),$=ka(a,()=>N(async()=>{return await v(),a=(await A(o,c))[_]?.[l]??"null",ja(Ua(a));var a}),a=>N(async()=>{var t;await v(),await m(o,c,{[_]:{[l]:(t=a()??null,Fa(t,(a,t)=>y(t)?"":t))}},!0,!0)}),e,n,s,r,{[g]:()=>d,destroy:async()=>(await $.stopAutoPersisting(),i(),$)},0,d);return $},Ha=(a,t,e,n,s,i,r,[o,c,[l,w,u]],d,g,E,p,v,A,m,$)=>{const[f,b,C,T]=xa(t,d,g,s,v,A,m,$),h=(a,t)=>N(ga(c,async([e,n,s,i,r],o)=>{t&&!(o in a)||await C(e,n,a[o],s,i,t,r)})),O=async(a,t)=>w?await C(u,F,{[_]:a},!0,!0,t):null,I=ka(a,()=>T(async()=>{await f();const a=await(async()=>sa(D(await N(ga(o,async([a,t,e],n)=>[a,await b(n,t,e)])),a=>!ya(a[1]))))(),t=await(async()=>l?(await b(u,F))[_]:{})();return ya(a)&&y(t)?void 0:[a,t]}),(a,t)=>T(async()=>{if(await f(),y(t)){const[t,e]=a();await h(t),await O(e)}else await h(t[0],!0),await O(t[1],!0)}),e,n,s,r,{[p]:()=>E,destroy:async()=>(await I.stopAutoPersisting(),i(),I)},0,E);return I},qa=(a,n,s,r,o,c,y,u,d,g,p="getDb",A)=>{let m,N,$;const b=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,c),[C,T,h,D]=(a=>{const e=(a=>ia(Pa,E(a)?{[ba]:a}:a??{}))(a),n=e[ha];if(e.mode==fa){const a=e[ba]??t;return[1,n,[a,e[Ca]??F,e[Ta]??$a],Aa(a)]}const{tables:{load:s={},save:r={}}={},values:o={}}=e,c=v(la(ia(Ma,o)),0,wa(Ma)),l=c[2],w=Aa(l),y=Aa(l),u=_a(s,{[Oa]:null,[Da]:F,[Ra]:i},Oa,a=>S(y,a),a=>ma(w,a)),d=_a(r,{[Ia]:null,[Da]:F,[Sa]:0,[La]:0,[Ra]:null},Ia,(a,t)=>S(y,t),(a,t)=>ma(w,t));var g;return g=(a,t)=>t[4]??=da(u,t[0])?.[2]??i,P(d,(a,t)=>g(0,a)),[0,n,[u,d,c],w]})(n);return(C?Ga:Ha)(a,b,a=>{let t;const e=()=>t=setInterval(()=>f(async()=>{const[{d:t,s:e,c:n}]=await b(U+` ${G} d,${H} s,TOTAL_CHANGES() c FROM ${z}${G} JOIN ${z}${H}`);t==m&&e==N&&n==$||(w(m)||a(),m=t,N=e,$=n)}),1e3*T),n=()=>{m=N=$=null,l(t)},s=r(t=>{D.has(t)&&(n(),a(),e())});return e(),()=>{n(),o(s)}},a=>a(),y,u,d,h,R(D),async(a,t)=>await a(U+` t.name tn,c.name cn FROM ${q}list()t,${q}info(t.name)c ${j} t.schema='main'AND t.type IN('table','view')AND t.name IN(${V(t)})ORDER BY t.name,c.name`,t),g,p,e,A,a=>(a=>!0===a)(a)?1:(a=>!1===a)(a)?0:a,void 0)},Ka=(a,t,e,n,s)=>qa(a,e,async(a,e=[])=>await t.db.raw({sql:a,args:e}),a=>t.notifier.subscribeToDataChanges(e=>b(t.notifier.alias(e),({tablename:t})=>a(t))),a=>a(),n,s,m,1,t,"getElectricClient");export{Ka as createElectricSqlPersister};
|
|
Binary file
|
|
@@ -1 +1 @@
|
|
|
1
|
-
const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),i="true",r=(a,t,e)=>a.replace(t,e),o=Promise,c=a=>(t,e,n)=>a(t)?n?.():e(t),l=clearInterval,w=a=>null==a,y=a=>void 0===a,u=a=>null===a,d=c(w),g=c(y),E=t=>a(t)==s,p=a=>Array.isArray(a),v=(a,t,e)=>a.slice(t,e),A=a=>a.length,m=()=>{},N=async a=>o.all(a),$=a=>{throw Error(a)},f=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},b=(a,t)=>a.forEach(t),C=(a,t="")=>a.join(t),T=(a,t)=>a.map(t),h=a=>0==A(a),D=(a,t)=>a.filter(t),O=(a,...t)=>a.push(...t),I=a=>a.shift(),S=(a,t)=>a?.has(t)??!1,L=a=>y(a)||0==(a=>a?.size??0)(a),R=a=>[...a?.values()??[]],P=(a,t)=>a?.forEach(t),M=(a,t)=>a?.delete(t),_="_",F="_id",U="SELECT",j="WHERE",B="TABLE",J="ALTER "+B,Y="FROM",k="DELETE "+Y,x=U+"*"+Y,z="pragma_",G="data_version",H="schema_version",q="pragma_table_",K="CREATE "+B,Q=a=>C(T(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${r(a,/"/g,'""')}"`),"."),V=(a,t=[1])=>C(T(a,()=>"$"+t[0]++),n),W=(a,t=i)=>j+`(${r(t,"$tableName",Q(a))})`,X=Object,Z=a=>X.getPrototypeOf(a),aa=X.entries,ta=X.
|
|
1
|
+
const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),i="true",r=(a,t,e)=>a.replace(t,e),o=Promise,c=a=>(t,e,n)=>a(t)?n?.():e(t),l=clearInterval,w=a=>null==a,y=a=>void 0===a,u=a=>null===a,d=c(w),g=c(y),E=t=>a(t)==s,p=a=>Array.isArray(a),v=(a,t,e)=>a.slice(t,e),A=a=>a.length,m=()=>{},N=async a=>o.all(a),$=a=>{throw Error(a)},f=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},b=(a,t)=>a.forEach(t),C=(a,t="")=>a.join(t),T=(a,t)=>a.map(t),h=a=>0==A(a),D=(a,t)=>a.filter(t),O=(a,...t)=>a.push(...t),I=a=>a.shift(),S=(a,t)=>a?.has(t)??!1,L=a=>y(a)||0==(a=>a?.size??0)(a),R=a=>[...a?.values()??[]],P=(a,t)=>a?.forEach(t),M=(a,t)=>a?.delete(t),_="_",F="_id",U="SELECT",j="WHERE",B="TABLE",J="ALTER "+B,Y="FROM",k="DELETE "+Y,x=U+"*"+Y,z="pragma_",G="data_version",H="schema_version",q="pragma_table_",K="CREATE "+B,Q=a=>C(T(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${r(a,/"/g,'""')}"`),"."),V=(a,t=[1])=>C(T(a,()=>"$"+t[0]++),n),W=(a,t=i)=>j+`(${r(t,"$tableName",Q(a))})`,X=Object,Z=a=>X.getPrototypeOf(a),aa=X.entries,ta=a=>!w(a)&&d(Z(a),a=>a==X.prototype||w(Z(a)),()=>!0),ea=X.keys,na=X.freeze,sa=(a=[])=>X.fromEntries(a),ia=(...a)=>X.assign({},...a),ra=(a,t)=>(delete a[t],a),oa=(a,t)=>T(aa(a),([a,e])=>t(e,a)),ca=(a,t)=>sa(oa(a,(a,e)=>[e,t(a,e)])),la=a=>X.values(a),wa=a=>A(ea(a)),ya=a=>ta(a)&&0==wa(a),ua=a=>new Map(a),da=(a,t)=>a?.get(t),ga=(a,t)=>T([...a?.entries()??[]],([a,e])=>t(e,a)),Ea=(a,t,e)=>y(e)?(M(a,t),a):a?.set(t,e),pa=(a,t,e,n)=>(S(a,t)?n?.(da(a,t)):Ea(a,t,e()),da(a,t)),va=(a,t,e,n,s=0)=>g((e?pa:da)(a,t[s],s>A(t)-2?e:ua),i=>{if(s>A(t)-2)return n?.(i)&&Ea(a,t[s]),i;const r=va(i,t,e,n,s+1);return L(i)&&Ea(a,t[s]),r}),Aa=a=>new Set(p(a)||y(a)?a:[a]),ma=(a,t)=>a?.add(t),Na="ColumnName",$a="store",fa="json",ba=$a+"TableName",Ca=$a+"Id"+Na,Ta=$a+Na,ha="autoLoadIntervalSeconds",Da="rowId"+Na,Oa="tableId",Ia="tableName",Sa="deleteEmptyColumns",La="deleteEmptyTable",Ra="condition",Pa={mode:fa,[ha]:1},Ma={load:0,save:0,[Ia]:t+"_values"},_a=(a,t,e,n,s)=>{const i=ua();return ca(a,(a,r)=>{const o=v(la(ia(t,E(a)?{[e]:a}:a)),0,wa(t));u(o[0])||n(r,o[0])||(s(r,o[0]),Ea(i,r,o))}),i},Fa=JSON.stringify,Ua=JSON.parse,ja=a=>""===a?void 0:p(a)?T(a,ja):ta(a)?ca(a,ja):a,Ba=/^\d+$/,Ja=ua(),Ya=ua(),ka=(a,t,n,s,i,r,o,c={},l=0,w=[])=>{let d,E,v,m=0,N=0,C=0;pa(Ja,w,()=>0),pa(Ya,w,()=>[]);const T=ua(),[h,D,S,R,_]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!ya(a)||!ya(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!ya(a)||!ya(t),t.setContent]:$("Store type not supported by this Persister"))(o,a,l),[F,U,j]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?I(a):null)??e+t++,t=>{Ba.test(t)&&A(a)<1e3&&O(a,t)}]})(),s=ua();return[(n,i,r,o=[],c=()=>[])=>{a??=Q;const l=t(1);return Ea(s,l,[n,i,r,o,c]),ma(va(i,r??[e],Aa),l),l},(t,n,...i)=>b(((a,t=[e])=>{const n=[],s=(a,e)=>e==A(t)?O(n,a):u(t[e])?P(a,a=>s(a,e+1)):b([t[e],null],t=>s(da(a,t),e+1));return s(a,0),n})(t,n),t=>P(t,t=>da(s,t)[0](a,...n??[],...i))),a=>g(da(s,a),([,t,i])=>(va(t,i??[e],void 0,t=>(M(t,a),L(t)?1:0)),Ea(s,a),n(a),i)),t=>g(da(s,t),([t,,e=[],n,s])=>{const i=(...r)=>{const o=A(r);o==A(e)?t(a,...r,...s(r)):u(e[o])?b(n[o]?.(...r)??[],a=>i(...r,a)):i(...r,e[o])};i()})]})(),B=a=>{a!=m&&(m=a,U(T,void 0,m))},J=t=>{(h&&p(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},Y=async a=>(2!=m&&(B(1),N++,await K(async()=>{await f(async()=>{const e=await t();p(e)?J(e):a?_(a):$("Content is not an array: "+e)},()=>{a&&_(a)}),B(0)})),Q),k=async a=>(x(),await Y(a),await f(async()=>E=await s(async(a,t)=>{t||a?2!=m&&(B(1),N++,J(t??a),B(0)):await Y()}),r),Q),x=async()=>(E&&(await f(()=>i(E),r),E=void 0),Q),z=async a=>(1!=m&&(B(2),C++,await K(async()=>{await f(()=>n(D,a),r),B(0)})),Q),G=async()=>(H(),await z(),v=a.addDidFinishTransactionListener(()=>{const a=S();R(a)&&z(a)}),Q),H=async()=>(v&&(a.delListener(v),v=void 0),Q),q=async(a=!1)=>{const[t,e]=a?[H,x]:[x,H];return await t(),await e(),Q},K=async(...a)=>(O(da(Ya,w),...a),await(async()=>{if(!da(Ja,w)){for(Ea(Ja,w,1);!y(d=I(da(Ya,w)));)await f(d,r);Ea(Ja,w,0)}})(),Q),Q={load:Y,startAutoLoad:k,stopAutoLoad:x,isAutoLoading:()=>!y(E),save:z,startAutoSave:G,stopAutoSave:H,isAutoSaving:()=>!y(v),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[G,k]:[k,G];return await e(a),await n(a),Q},stopAutoPersisting:q,getStatus:()=>m,addStatusListener:a=>F(a,T),delListener:t=>(j(t),a),schedule:K,getStore:()=>a,destroy:()=>(da(Ya,w).splice(0,void 0),q()),getStats:()=>({loads:N,saves:C}),...c};return na(Q)},xa=(a,t,e,s,r,o=za,c,l)=>{const w=ua();return[async()=>{w.clear(),T(await e(a,t),({tn:a,cn:t})=>ma(pa(w,a,Aa),t))},async(t,e,n)=>((a,t)=>S(da(w,a),t))(t,e)?sa(D(T(await a(x+Q(t)+W(t,n)),a=>[a[e],l?ca(ra(a,e),l):ra(a,e)]),([a,t])=>!y(a)&&!ya(t))):{},async(t,e,s,l,u,d=!1,g=i)=>{const E=Aa();ca(s??{},a=>T(ea(a??{}),a=>ma(E,a)));const p=R(E);if(!d&&u&&g==i&&h(p)&&S(w,t))return await a("DROP "+B+Q(t)),void Ea(w,t);const v=da(w,t),A=Aa(R(v));if(h(p)||(S(w,t)?await N(T([e,...p],async(n,s)=>{M(A,n)||(await a(J+Q(t)+"ADD"+Q(n)+r),0==s&&await a("CREATE UNIQUE INDEX pk ON "+Q(t)+`(${Q(e)})`),ma(v,n))})):(await a(K+Q(t)+`(${Q(e)}${r} PRIMARY KEY${C(T(p,a=>n+Q(a)+r))});`),Ea(w,t,Aa([e,...p])))),await N([...!d&&l?T(R(A),async n=>{n!=e&&(await a(J+Q(t)+"DROP"+Q(n)),M(v,n))}):[]]),d)y(s)?await a(k+Q(t)+W(t,g)):await N(oa(s,async(n,s)=>{y(n)?await a(k+Q(t)+W(t,g)+`AND(${Q(e)}=$1)`,[s]):h(p)||await o(a,t,e,ea(n),{[s]:c?T(la(n),c):la(n)},v)}));else if(h(p))S(w,t)&&await a(k+Q(t)+W(t,g));else{const n=D(R(da(w,t)),a=>a!=e),i={},r=[];ca(s??{},(a,t)=>{i[t]=T(n,t=>c?c(a?.[t]):a?.[t]),O(r,t)}),await o(a,t,e,n,i),await a(k+Q(t)+W(t,g)+`AND${Q(e)}NOT IN(${V(r)})`,r)}},async t=>{let e;return await a("BEGIN"),await f(async()=>e=await t(),s),await a("END"),e}]},za=async(a,t,e,s,i)=>{const r=[1];await a("INSERT INTO"+Q(t)+"("+((...a)=>C(T(a,Q),n))(e,...s)+")VALUES"+C(oa(i,a=>"($"+r[0]+++","+V(a,r)+")"),n)+"ON CONFLICT("+Q(e)+")DO UPDATE SET"+C(T(s,a=>Q(a)+"=excluded."+Q(a)),n),oa(i,(a,t)=>[t,...T(a,a=>a??null)]).flat())},Ga=(a,t,e,n,s,i,r,[o,c,l],w,u,d,g,E,p)=>{const[v,A,m,N]=xa(t,w,u,s,E,p),$=ka(a,()=>N(async()=>{return await v(),a=(await A(o,c))[_]?.[l]??"null",ja(Ua(a));var a}),a=>N(async()=>{var t;await v(),await m(o,c,{[_]:{[l]:(t=a()??null,Fa(t,(a,t)=>y(t)?"":t))}},!0,!0)}),e,n,s,r,{[g]:()=>d,destroy:async()=>(await $.stopAutoPersisting(),i(),$)},0,d);return $},Ha=(a,t,e,n,s,i,r,[o,c,[l,w,u]],d,g,E,p,v,A,m,$)=>{const[f,b,C,T]=xa(t,d,g,s,v,A,m,$),h=(a,t)=>N(ga(c,async([e,n,s,i,r],o)=>{t&&!(o in a)||await C(e,n,a[o],s,i,t,r)})),O=async(a,t)=>w?await C(u,F,{[_]:a},!0,!0,t):null,I=ka(a,()=>T(async()=>{await f();const a=await(async()=>sa(D(await N(ga(o,async([a,t,e],n)=>[a,await b(n,t,e)])),a=>!ya(a[1]))))(),t=await(async()=>l?(await b(u,F))[_]:{})();return ya(a)&&y(t)?void 0:[a,t]}),(a,t)=>T(async()=>{if(await f(),y(t)){const[t,e]=a();await h(t),await O(e)}else await h(t[0],!0),await O(t[1],!0)}),e,n,s,r,{[p]:()=>E,destroy:async()=>(await I.stopAutoPersisting(),i(),I)},0,E);return I},qa=(a,n,s,r,o,c,y,u,d,g,p="getDb",A)=>{let m,N,$;const b=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,c),[C,T,h,D]=(a=>{const e=(a=>ia(Pa,E(a)?{[ba]:a}:a??{}))(a),n=e[ha];if(e.mode==fa){const a=e[ba]??t;return[1,n,[a,e[Ca]??F,e[Ta]??$a],Aa(a)]}const{tables:{load:s={},save:r={}}={},values:o={}}=e,c=v(la(ia(Ma,o)),0,wa(Ma)),l=c[2],w=Aa(l),y=Aa(l),u=_a(s,{[Oa]:null,[Da]:F,[Ra]:i},Oa,a=>S(y,a),a=>ma(w,a)),d=_a(r,{[Ia]:null,[Da]:F,[Sa]:0,[La]:0,[Ra]:null},Ia,(a,t)=>S(y,t),(a,t)=>ma(w,t));var g;return g=(a,t)=>t[4]??=da(u,t[0])?.[2]??i,P(d,(a,t)=>g(0,a)),[0,n,[u,d,c],w]})(n);return(C?Ga:Ha)(a,b,a=>{let t;const e=()=>t=setInterval(()=>f(async()=>{const[{d:t,s:e,c:n}]=await b(U+` ${G} d,${H} s,TOTAL_CHANGES() c FROM ${z}${G} JOIN ${z}${H}`);t==m&&e==N&&n==$||(w(m)||a(),m=t,N=e,$=n)}),1e3*T),n=()=>{m=N=$=null,l(t)},s=r(t=>{D.has(t)&&(n(),a(),e())});return e(),()=>{n(),o(s)}},a=>a(),y,u,d,h,R(D),async(a,t)=>await a(U+` t.name tn,c.name cn FROM ${q}list()t,${q}info(t.name)c ${j} t.schema='main'AND t.type IN('table','view')AND t.name IN(${V(t)})ORDER BY t.name,c.name`,t),g,p,e,A,a=>(a=>!0===a)(a)?1:(a=>!1===a)(a)?0:a,void 0)},Ka=(a,t,e,n,s)=>qa(a,e,async(a,e=[])=>await t.db.raw({sql:a,args:e}),a=>t.notifier.subscribeToDataChanges(e=>b(t.notifier.alias(e),({tablename:t})=>a(t))),a=>a(),n,s,m,1,t,"getElectricClient");export{Ka as createElectricSqlPersister};
|
|
Binary file
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{addDatabaseChangeListener as a}from"expo-sqlite";const t=a=>typeof a,e="tinybase",n="",s=",",i=t(n),r="true",o=(a,t,e)=>a.replace(t,e),c=Promise,l=a=>(t,e,n)=>a(t)?n?.():e(t),w=clearInterval,y=a=>null==a,u=a=>void 0===a,d=a=>null===a,g=l(y),p=l(u),v=a=>t(a)==i,E=a=>Array.isArray(a),m=(a,t,e)=>a.slice(t,e),A=a=>a.length,N=()=>{},$=async a=>c.all(a),f=a=>{throw Error(a)},C=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},T=(a,t)=>a.forEach(t),b=(a,t="")=>a.join(t),h=(a,t)=>a.map(t),O=a=>0==A(a),D=(a,t)=>a.filter(t),I=(a,...t)=>a.push(...t),S=a=>a.shift(),L=(a,t)=>a?.has(t)??!1,R=a=>u(a)||0==(a=>a?.size??0)(a),P=a=>[...a?.values()??[]],M=(a,t)=>a?.forEach(t),_=(a,t)=>a?.delete(t),F="_",U="_id",j="SELECT",x="WHERE",B="TABLE",J="ALTER "+B,Y="FROM",k="DELETE "+Y,z=j+"*"+Y,G="pragma_",H="data_version",q="schema_version",K="pragma_table_",Q="CREATE "+B,V=a=>b(h(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${o(a,/"/g,'""')}"`),"."),W=(a,t=[1])=>b(h(a,()=>"$"+t[0]++),s),X=(a,t=r)=>x+`(${o(t,"$tableName",V(a))})`,Z=Object,aa=a=>Z.getPrototypeOf(a),ta=Z.entries,ea=Z.
|
|
1
|
+
import{addDatabaseChangeListener as a}from"expo-sqlite";const t=a=>typeof a,e="tinybase",n="",s=",",i=t(n),r="true",o=(a,t,e)=>a.replace(t,e),c=Promise,l=a=>(t,e,n)=>a(t)?n?.():e(t),w=clearInterval,y=a=>null==a,u=a=>void 0===a,d=a=>null===a,g=l(y),p=l(u),v=a=>t(a)==i,E=a=>Array.isArray(a),m=(a,t,e)=>a.slice(t,e),A=a=>a.length,N=()=>{},$=async a=>c.all(a),f=a=>{throw Error(a)},C=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},T=(a,t)=>a.forEach(t),b=(a,t="")=>a.join(t),h=(a,t)=>a.map(t),O=a=>0==A(a),D=(a,t)=>a.filter(t),I=(a,...t)=>a.push(...t),S=a=>a.shift(),L=(a,t)=>a?.has(t)??!1,R=a=>u(a)||0==(a=>a?.size??0)(a),P=a=>[...a?.values()??[]],M=(a,t)=>a?.forEach(t),_=(a,t)=>a?.delete(t),F="_",U="_id",j="SELECT",x="WHERE",B="TABLE",J="ALTER "+B,Y="FROM",k="DELETE "+Y,z=j+"*"+Y,G="pragma_",H="data_version",q="schema_version",K="pragma_table_",Q="CREATE "+B,V=a=>b(h(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${o(a,/"/g,'""')}"`),"."),W=(a,t=[1])=>b(h(a,()=>"$"+t[0]++),s),X=(a,t=r)=>x+`(${o(t,"$tableName",V(a))})`,Z=Object,aa=a=>Z.getPrototypeOf(a),ta=Z.entries,ea=a=>!y(a)&&g(aa(a),a=>a==Z.prototype||y(aa(a)),()=>!0),na=Z.keys,sa=Z.freeze,ia=(a=[])=>Z.fromEntries(a),ra=(...a)=>Z.assign({},...a),oa=(a,t)=>(delete a[t],a),ca=(a,t)=>h(ta(a),([a,e])=>t(e,a)),la=(a,t)=>ia(ca(a,(a,e)=>[e,t(a,e)])),wa=a=>Z.values(a),ya=a=>A(na(a)),ua=a=>ea(a)&&0==ya(a),da=a=>new Map(a),ga=(a,t)=>a?.get(t),pa=(a,t)=>h([...a?.entries()??[]],([a,e])=>t(e,a)),va=(a,t,e)=>u(e)?(_(a,t),a):a?.set(t,e),Ea=(a,t,e,n)=>(L(a,t)?n?.(ga(a,t)):va(a,t,e()),ga(a,t)),ma=(a,t,e,n,s=0)=>p((e?Ea:ga)(a,t[s],s>A(t)-2?e:da),i=>{if(s>A(t)-2)return n?.(i)&&va(a,t[s]),i;const r=ma(i,t,e,n,s+1);return R(i)&&va(a,t[s]),r}),Aa=a=>new Set(E(a)||u(a)?a:[a]),Na=(a,t)=>a?.add(t),$a="ColumnName",fa="store",Ca="json",Ta=fa+"TableName",ba=fa+"Id"+$a,ha=fa+$a,Oa="autoLoadIntervalSeconds",Da="rowId"+$a,Ia="tableId",Sa="tableName",La="deleteEmptyColumns",Ra="deleteEmptyTable",Pa="condition",Ma={mode:Ca,[Oa]:1},_a={load:0,save:0,[Sa]:e+"_values"},Fa=(a,t,e,n,s)=>{const i=da();return la(a,(a,r)=>{const o=m(wa(ra(t,v(a)?{[e]:a}:a)),0,ya(t));d(o[0])||n(r,o[0])||(s(r,o[0]),va(i,r,o))}),i},Ua=JSON.stringify,ja=JSON.parse,xa=a=>""===a?void 0:E(a)?h(a,xa):ea(a)?la(a,xa):a,Ba=/^\d+$/,Ja=da(),Ya=da(),ka=(a,t,e,s,i,r,o,c={},l=0,w=[])=>{let y,g,v,m=0,N=0,$=0;Ea(Ja,w,()=>0),Ea(Ya,w,()=>[]);const b=da(),[h,O,D,L,P]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!ua(a)||!ua(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!ua(a)||!ua(t),t.setContent]:f("Store type not supported by this Persister"))(o,a,l),[F,U,j]=(()=>{let a;const[t,e]=(()=>{const a=[];let t=0;return[e=>(e?S(a):null)??n+t++,t=>{Ba.test(t)&&A(a)<1e3&&I(a,t)}]})(),s=da();return[(e,i,r,o=[],c=()=>[])=>{a??=Q;const l=t(1);return va(s,l,[e,i,r,o,c]),Na(ma(i,r??[n],Aa),l),l},(t,e,...i)=>T(((a,t=[n])=>{const e=[],s=(a,n)=>n==A(t)?I(e,a):d(t[n])?M(a,a=>s(a,n+1)):T([t[n],null],t=>s(ga(a,t),n+1));return s(a,0),e})(t,e),t=>M(t,t=>ga(s,t)[0](a,...e??[],...i))),a=>p(ga(s,a),([,t,i])=>(ma(t,i??[n],void 0,t=>(_(t,a),R(t)?1:0)),va(s,a),e(a),i)),t=>p(ga(s,t),([t,,e=[],n,s])=>{const i=(...r)=>{const o=A(r);o==A(e)?t(a,...r,...s(r)):d(e[o])?T(n[o]?.(...r)??[],a=>i(...r,a)):i(...r,e[o])};i()})]})(),x=a=>{a!=m&&(m=a,U(b,void 0,m))},B=t=>{(h&&E(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},J=async a=>(2!=m&&(x(1),N++,await K(async()=>{await C(async()=>{const e=await t();E(e)?B(e):a?P(a):f("Content is not an array: "+e)},()=>{a&&P(a)}),x(0)})),Q),Y=async a=>(k(),await J(a),await C(async()=>g=await s(async(a,t)=>{t||a?2!=m&&(x(1),N++,B(t??a),x(0)):await J()}),r),Q),k=async()=>(g&&(await C(()=>i(g),r),g=void 0),Q),z=async a=>(1!=m&&(x(2),$++,await K(async()=>{await C(()=>e(O,a),r),x(0)})),Q),G=async()=>(H(),await z(),v=a.addDidFinishTransactionListener(()=>{const a=D();L(a)&&z(a)}),Q),H=async()=>(v&&(a.delListener(v),v=void 0),Q),q=async(a=!1)=>{const[t,e]=a?[H,k]:[k,H];return await t(),await e(),Q},K=async(...a)=>(I(ga(Ya,w),...a),await(async()=>{if(!ga(Ja,w)){for(va(Ja,w,1);!u(y=S(ga(Ya,w)));)await C(y,r);va(Ja,w,0)}})(),Q),Q={load:J,startAutoLoad:Y,stopAutoLoad:k,isAutoLoading:()=>!u(g),save:z,startAutoSave:G,stopAutoSave:H,isAutoSaving:()=>!u(v),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[G,Y]:[Y,G];return await e(a),await n(a),Q},stopAutoPersisting:q,getStatus:()=>m,addStatusListener:a=>F(a,b),delListener:t=>(j(t),a),schedule:K,getStore:()=>a,destroy:()=>(ga(Ya,w).splice(0,void 0),q()),getStats:()=>({loads:N,saves:$}),...c};return sa(Q)},za=(a,t,e,n,i,o=Ga,c,l)=>{const w=da();return[async()=>{w.clear(),h(await e(a,t),({tn:a,cn:t})=>Na(Ea(w,a,Aa),t))},async(t,e,n)=>((a,t)=>L(ga(w,a),t))(t,e)?ia(D(h(await a(z+V(t)+X(t,n)),a=>[a[e],l?la(oa(a,e),l):oa(a,e)]),([a,t])=>!u(a)&&!ua(t))):{},async(t,e,n,l,y,d=!1,g=r)=>{const p=Aa();la(n??{},a=>h(na(a??{}),a=>Na(p,a)));const v=P(p);if(!d&&y&&g==r&&O(v)&&L(w,t))return await a("DROP "+B+V(t)),void va(w,t);const E=ga(w,t),m=Aa(P(E));if(O(v)||(L(w,t)?await $(h([e,...v],async(n,s)=>{_(m,n)||(await a(J+V(t)+"ADD"+V(n)+i),0==s&&await a("CREATE UNIQUE INDEX pk ON "+V(t)+`(${V(e)})`),Na(E,n))})):(await a(Q+V(t)+`(${V(e)}${i} PRIMARY KEY${b(h(v,a=>s+V(a)+i))});`),va(w,t,Aa([e,...v])))),await $([...!d&&l?h(P(m),async n=>{n!=e&&(await a(J+V(t)+"DROP"+V(n)),_(E,n))}):[]]),d)u(n)?await a(k+V(t)+X(t,g)):await $(ca(n,async(n,s)=>{u(n)?await a(k+V(t)+X(t,g)+`AND(${V(e)}=$1)`,[s]):O(v)||await o(a,t,e,na(n),{[s]:c?h(wa(n),c):wa(n)},E)}));else if(O(v))L(w,t)&&await a(k+V(t)+X(t,g));else{const s=D(P(ga(w,t)),a=>a!=e),i={},r=[];la(n??{},(a,t)=>{i[t]=h(s,t=>c?c(a?.[t]):a?.[t]),I(r,t)}),await o(a,t,e,s,i),await a(k+V(t)+X(t,g)+`AND${V(e)}NOT IN(${W(r)})`,r)}},async t=>{let e;return await a("BEGIN"),await C(async()=>e=await t(),n),await a("END"),e}]},Ga=async(a,t,e,n,i)=>{const r=[1];await a("INSERT INTO"+V(t)+"("+((...a)=>b(h(a,V),s))(e,...n)+")VALUES"+b(ca(i,a=>"($"+r[0]+++","+W(a,r)+")"),s)+"ON CONFLICT("+V(e)+")DO UPDATE SET"+b(h(n,a=>V(a)+"=excluded."+V(a)),s),ca(i,(a,t)=>[t,...h(a,a=>a??null)]).flat())},Ha=(a,t,e,n,s,i,r,[o,c,l],w,y,d,g,p,v)=>{const[E,m,A,N]=za(t,w,y,s,p,v),$=ka(a,()=>N(async()=>{return await E(),a=(await m(o,c))[F]?.[l]??"null",xa(ja(a));var a}),a=>N(async()=>{var t;await E(),await A(o,c,{[F]:{[l]:(t=a()??null,Ua(t,(a,t)=>u(t)?"":t))}},!0,!0)}),e,n,s,r,{[g]:()=>d,destroy:async()=>(await $.stopAutoPersisting(),i(),$)},0,d);return $},qa=(a,t,e,n,s,i,r,[o,c,[l,w,y]],d,g,p,v,E,m,A,N)=>{const[f,C,T,b]=za(t,d,g,s,E,m,A,N),h=(a,t)=>$(pa(c,async([e,n,s,i,r],o)=>{t&&!(o in a)||await T(e,n,a[o],s,i,t,r)})),O=async(a,t)=>w?await T(y,U,{[F]:a},!0,!0,t):null,I=ka(a,()=>b(async()=>{await f();const a=await(async()=>ia(D(await $(pa(o,async([a,t,e],n)=>[a,await C(n,t,e)])),a=>!ua(a[1]))))(),t=await(async()=>l?(await C(y,U))[F]:{})();return ua(a)&&u(t)?void 0:[a,t]}),(a,t)=>b(async()=>{if(await f(),u(t)){const[t,e]=a();await h(t),await O(e)}else await h(t[0],!0),await O(t[1],!0)}),e,n,s,r,{[v]:()=>p,destroy:async()=>(await I.stopAutoPersisting(),i(),I)},0,p);return I},Ka=(a,t,s,i,o,c,l,u,d,g,p="getDb",E)=>{let A,N,$;const f=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,c),[T,b,h,O]=(a=>{const t=(a=>ra(Ma,v(a)?{[Ta]:a}:a??{}))(a),n=t[Oa];if(t.mode==Ca){const a=t[Ta]??e;return[1,n,[a,t[ba]??U,t[ha]??fa],Aa(a)]}const{tables:{load:s={},save:i={}}={},values:o={}}=t,c=m(wa(ra(_a,o)),0,ya(_a)),l=c[2],w=Aa(l),y=Aa(l),u=Fa(s,{[Ia]:null,[Da]:U,[Pa]:r},Ia,a=>L(y,a),a=>Na(w,a)),d=Fa(i,{[Sa]:null,[Da]:U,[La]:0,[Ra]:0,[Pa]:null},Sa,(a,t)=>L(y,t),(a,t)=>Na(w,t));var g;return g=(a,t)=>t[4]??=ga(u,t[0])?.[2]??r,M(d,(a,t)=>g(0,a)),[0,n,[u,d,c],w]})(t);return(T?Ha:qa)(a,f,a=>{let t;const e=()=>t=setInterval(()=>C(async()=>{const[{d:t,s:e,c:n}]=await f(j+` ${H} d,${q} s,TOTAL_CHANGES() c FROM ${G}${H} JOIN ${G}${q}`);t==A&&e==N&&n==$||(y(A)||a(),A=t,N=e,$=n)}),1e3*b),n=()=>{A=N=$=null,w(t)},s=i(t=>{O.has(t)&&(n(),a(),e())});return e(),()=>{n(),o(s)}},a=>a(),l,u,d,h,P(O),async(a,t)=>await a(j+` t.name tn,c.name cn FROM ${K}list()t,${K}info(t.name)c ${x} t.schema='main'AND t.type IN('table','view')AND t.name IN(${W(t)})ORDER BY t.name,c.name`,t),g,p,n,E,a=>(a=>!0===a)(a)?1:(a=>!1===a)(a)?0:a,void 0)},Qa=(t,e,n,s,i)=>Ka(t,n,async(a,t=[])=>await e.getAllAsync(a,t),t=>a(({tableName:a})=>t(a)),a=>a.remove(),s,i,N,3,e);export{Qa as createExpoSqlitePersister};
|
|
Binary file
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{addDatabaseChangeListener as a}from"expo-sqlite";const t=a=>typeof a,e="tinybase",n="",s=",",i=t(n),r="true",o=(a,t,e)=>a.replace(t,e),c=Promise,l=a=>(t,e,n)=>a(t)?n?.():e(t),w=clearInterval,y=a=>null==a,u=a=>void 0===a,d=a=>null===a,g=l(y),p=l(u),v=a=>t(a)==i,E=a=>Array.isArray(a),m=(a,t,e)=>a.slice(t,e),A=a=>a.length,N=()=>{},$=async a=>c.all(a),f=a=>{throw Error(a)},C=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},T=(a,t)=>a.forEach(t),b=(a,t="")=>a.join(t),h=(a,t)=>a.map(t),O=a=>0==A(a),D=(a,t)=>a.filter(t),I=(a,...t)=>a.push(...t),S=a=>a.shift(),L=(a,t)=>a?.has(t)??!1,R=a=>u(a)||0==(a=>a?.size??0)(a),P=a=>[...a?.values()??[]],M=(a,t)=>a?.forEach(t),_=(a,t)=>a?.delete(t),F="_",U="_id",j="SELECT",x="WHERE",B="TABLE",J="ALTER "+B,Y="FROM",k="DELETE "+Y,z=j+"*"+Y,G="pragma_",H="data_version",q="schema_version",K="pragma_table_",Q="CREATE "+B,V=a=>b(h(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${o(a,/"/g,'""')}"`),"."),W=(a,t=[1])=>b(h(a,()=>"$"+t[0]++),s),X=(a,t=r)=>x+`(${o(t,"$tableName",V(a))})`,Z=Object,aa=a=>Z.getPrototypeOf(a),ta=Z.entries,ea=Z.
|
|
1
|
+
import{addDatabaseChangeListener as a}from"expo-sqlite";const t=a=>typeof a,e="tinybase",n="",s=",",i=t(n),r="true",o=(a,t,e)=>a.replace(t,e),c=Promise,l=a=>(t,e,n)=>a(t)?n?.():e(t),w=clearInterval,y=a=>null==a,u=a=>void 0===a,d=a=>null===a,g=l(y),p=l(u),v=a=>t(a)==i,E=a=>Array.isArray(a),m=(a,t,e)=>a.slice(t,e),A=a=>a.length,N=()=>{},$=async a=>c.all(a),f=a=>{throw Error(a)},C=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},T=(a,t)=>a.forEach(t),b=(a,t="")=>a.join(t),h=(a,t)=>a.map(t),O=a=>0==A(a),D=(a,t)=>a.filter(t),I=(a,...t)=>a.push(...t),S=a=>a.shift(),L=(a,t)=>a?.has(t)??!1,R=a=>u(a)||0==(a=>a?.size??0)(a),P=a=>[...a?.values()??[]],M=(a,t)=>a?.forEach(t),_=(a,t)=>a?.delete(t),F="_",U="_id",j="SELECT",x="WHERE",B="TABLE",J="ALTER "+B,Y="FROM",k="DELETE "+Y,z=j+"*"+Y,G="pragma_",H="data_version",q="schema_version",K="pragma_table_",Q="CREATE "+B,V=a=>b(h(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${o(a,/"/g,'""')}"`),"."),W=(a,t=[1])=>b(h(a,()=>"$"+t[0]++),s),X=(a,t=r)=>x+`(${o(t,"$tableName",V(a))})`,Z=Object,aa=a=>Z.getPrototypeOf(a),ta=Z.entries,ea=a=>!y(a)&&g(aa(a),a=>a==Z.prototype||y(aa(a)),()=>!0),na=Z.keys,sa=Z.freeze,ia=(a=[])=>Z.fromEntries(a),ra=(...a)=>Z.assign({},...a),oa=(a,t)=>(delete a[t],a),ca=(a,t)=>h(ta(a),([a,e])=>t(e,a)),la=(a,t)=>ia(ca(a,(a,e)=>[e,t(a,e)])),wa=a=>Z.values(a),ya=a=>A(na(a)),ua=a=>ea(a)&&0==ya(a),da=a=>new Map(a),ga=(a,t)=>a?.get(t),pa=(a,t)=>h([...a?.entries()??[]],([a,e])=>t(e,a)),va=(a,t,e)=>u(e)?(_(a,t),a):a?.set(t,e),Ea=(a,t,e,n)=>(L(a,t)?n?.(ga(a,t)):va(a,t,e()),ga(a,t)),ma=(a,t,e,n,s=0)=>p((e?Ea:ga)(a,t[s],s>A(t)-2?e:da),i=>{if(s>A(t)-2)return n?.(i)&&va(a,t[s]),i;const r=ma(i,t,e,n,s+1);return R(i)&&va(a,t[s]),r}),Aa=a=>new Set(E(a)||u(a)?a:[a]),Na=(a,t)=>a?.add(t),$a="ColumnName",fa="store",Ca="json",Ta=fa+"TableName",ba=fa+"Id"+$a,ha=fa+$a,Oa="autoLoadIntervalSeconds",Da="rowId"+$a,Ia="tableId",Sa="tableName",La="deleteEmptyColumns",Ra="deleteEmptyTable",Pa="condition",Ma={mode:Ca,[Oa]:1},_a={load:0,save:0,[Sa]:e+"_values"},Fa=(a,t,e,n,s)=>{const i=da();return la(a,(a,r)=>{const o=m(wa(ra(t,v(a)?{[e]:a}:a)),0,ya(t));d(o[0])||n(r,o[0])||(s(r,o[0]),va(i,r,o))}),i},Ua=JSON.stringify,ja=JSON.parse,xa=a=>""===a?void 0:E(a)?h(a,xa):ea(a)?la(a,xa):a,Ba=/^\d+$/,Ja=da(),Ya=da(),ka=(a,t,e,s,i,r,o,c={},l=0,w=[])=>{let y,g,v,m=0,N=0,$=0;Ea(Ja,w,()=>0),Ea(Ya,w,()=>[]);const b=da(),[h,O,D,L,P]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!ua(a)||!ua(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!ua(a)||!ua(t),t.setContent]:f("Store type not supported by this Persister"))(o,a,l),[F,U,j]=(()=>{let a;const[t,e]=(()=>{const a=[];let t=0;return[e=>(e?S(a):null)??n+t++,t=>{Ba.test(t)&&A(a)<1e3&&I(a,t)}]})(),s=da();return[(e,i,r,o=[],c=()=>[])=>{a??=Q;const l=t(1);return va(s,l,[e,i,r,o,c]),Na(ma(i,r??[n],Aa),l),l},(t,e,...i)=>T(((a,t=[n])=>{const e=[],s=(a,n)=>n==A(t)?I(e,a):d(t[n])?M(a,a=>s(a,n+1)):T([t[n],null],t=>s(ga(a,t),n+1));return s(a,0),e})(t,e),t=>M(t,t=>ga(s,t)[0](a,...e??[],...i))),a=>p(ga(s,a),([,t,i])=>(ma(t,i??[n],void 0,t=>(_(t,a),R(t)?1:0)),va(s,a),e(a),i)),t=>p(ga(s,t),([t,,e=[],n,s])=>{const i=(...r)=>{const o=A(r);o==A(e)?t(a,...r,...s(r)):d(e[o])?T(n[o]?.(...r)??[],a=>i(...r,a)):i(...r,e[o])};i()})]})(),x=a=>{a!=m&&(m=a,U(b,void 0,m))},B=t=>{(h&&E(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},J=async a=>(2!=m&&(x(1),N++,await K(async()=>{await C(async()=>{const e=await t();E(e)?B(e):a?P(a):f("Content is not an array: "+e)},()=>{a&&P(a)}),x(0)})),Q),Y=async a=>(k(),await J(a),await C(async()=>g=await s(async(a,t)=>{t||a?2!=m&&(x(1),N++,B(t??a),x(0)):await J()}),r),Q),k=async()=>(g&&(await C(()=>i(g),r),g=void 0),Q),z=async a=>(1!=m&&(x(2),$++,await K(async()=>{await C(()=>e(O,a),r),x(0)})),Q),G=async()=>(H(),await z(),v=a.addDidFinishTransactionListener(()=>{const a=D();L(a)&&z(a)}),Q),H=async()=>(v&&(a.delListener(v),v=void 0),Q),q=async(a=!1)=>{const[t,e]=a?[H,k]:[k,H];return await t(),await e(),Q},K=async(...a)=>(I(ga(Ya,w),...a),await(async()=>{if(!ga(Ja,w)){for(va(Ja,w,1);!u(y=S(ga(Ya,w)));)await C(y,r);va(Ja,w,0)}})(),Q),Q={load:J,startAutoLoad:Y,stopAutoLoad:k,isAutoLoading:()=>!u(g),save:z,startAutoSave:G,stopAutoSave:H,isAutoSaving:()=>!u(v),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[G,Y]:[Y,G];return await e(a),await n(a),Q},stopAutoPersisting:q,getStatus:()=>m,addStatusListener:a=>F(a,b),delListener:t=>(j(t),a),schedule:K,getStore:()=>a,destroy:()=>(ga(Ya,w).splice(0,void 0),q()),getStats:()=>({loads:N,saves:$}),...c};return sa(Q)},za=(a,t,e,n,i,o=Ga,c,l)=>{const w=da();return[async()=>{w.clear(),h(await e(a,t),({tn:a,cn:t})=>Na(Ea(w,a,Aa),t))},async(t,e,n)=>((a,t)=>L(ga(w,a),t))(t,e)?ia(D(h(await a(z+V(t)+X(t,n)),a=>[a[e],l?la(oa(a,e),l):oa(a,e)]),([a,t])=>!u(a)&&!ua(t))):{},async(t,e,n,l,y,d=!1,g=r)=>{const p=Aa();la(n??{},a=>h(na(a??{}),a=>Na(p,a)));const v=P(p);if(!d&&y&&g==r&&O(v)&&L(w,t))return await a("DROP "+B+V(t)),void va(w,t);const E=ga(w,t),m=Aa(P(E));if(O(v)||(L(w,t)?await $(h([e,...v],async(n,s)=>{_(m,n)||(await a(J+V(t)+"ADD"+V(n)+i),0==s&&await a("CREATE UNIQUE INDEX pk ON "+V(t)+`(${V(e)})`),Na(E,n))})):(await a(Q+V(t)+`(${V(e)}${i} PRIMARY KEY${b(h(v,a=>s+V(a)+i))});`),va(w,t,Aa([e,...v])))),await $([...!d&&l?h(P(m),async n=>{n!=e&&(await a(J+V(t)+"DROP"+V(n)),_(E,n))}):[]]),d)u(n)?await a(k+V(t)+X(t,g)):await $(ca(n,async(n,s)=>{u(n)?await a(k+V(t)+X(t,g)+`AND(${V(e)}=$1)`,[s]):O(v)||await o(a,t,e,na(n),{[s]:c?h(wa(n),c):wa(n)},E)}));else if(O(v))L(w,t)&&await a(k+V(t)+X(t,g));else{const s=D(P(ga(w,t)),a=>a!=e),i={},r=[];la(n??{},(a,t)=>{i[t]=h(s,t=>c?c(a?.[t]):a?.[t]),I(r,t)}),await o(a,t,e,s,i),await a(k+V(t)+X(t,g)+`AND${V(e)}NOT IN(${W(r)})`,r)}},async t=>{let e;return await a("BEGIN"),await C(async()=>e=await t(),n),await a("END"),e}]},Ga=async(a,t,e,n,i)=>{const r=[1];await a("INSERT INTO"+V(t)+"("+((...a)=>b(h(a,V),s))(e,...n)+")VALUES"+b(ca(i,a=>"($"+r[0]+++","+W(a,r)+")"),s)+"ON CONFLICT("+V(e)+")DO UPDATE SET"+b(h(n,a=>V(a)+"=excluded."+V(a)),s),ca(i,(a,t)=>[t,...h(a,a=>a??null)]).flat())},Ha=(a,t,e,n,s,i,r,[o,c,l],w,y,d,g,p,v)=>{const[E,m,A,N]=za(t,w,y,s,p,v),$=ka(a,()=>N(async()=>{return await E(),a=(await m(o,c))[F]?.[l]??"null",xa(ja(a));var a}),a=>N(async()=>{var t;await E(),await A(o,c,{[F]:{[l]:(t=a()??null,Ua(t,(a,t)=>u(t)?"":t))}},!0,!0)}),e,n,s,r,{[g]:()=>d,destroy:async()=>(await $.stopAutoPersisting(),i(),$)},0,d);return $},qa=(a,t,e,n,s,i,r,[o,c,[l,w,y]],d,g,p,v,E,m,A,N)=>{const[f,C,T,b]=za(t,d,g,s,E,m,A,N),h=(a,t)=>$(pa(c,async([e,n,s,i,r],o)=>{t&&!(o in a)||await T(e,n,a[o],s,i,t,r)})),O=async(a,t)=>w?await T(y,U,{[F]:a},!0,!0,t):null,I=ka(a,()=>b(async()=>{await f();const a=await(async()=>ia(D(await $(pa(o,async([a,t,e],n)=>[a,await C(n,t,e)])),a=>!ua(a[1]))))(),t=await(async()=>l?(await C(y,U))[F]:{})();return ua(a)&&u(t)?void 0:[a,t]}),(a,t)=>b(async()=>{if(await f(),u(t)){const[t,e]=a();await h(t),await O(e)}else await h(t[0],!0),await O(t[1],!0)}),e,n,s,r,{[v]:()=>p,destroy:async()=>(await I.stopAutoPersisting(),i(),I)},0,p);return I},Ka=(a,t,s,i,o,c,l,u,d,g,p="getDb",E)=>{let A,N,$;const f=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,c),[T,b,h,O]=(a=>{const t=(a=>ra(Ma,v(a)?{[Ta]:a}:a??{}))(a),n=t[Oa];if(t.mode==Ca){const a=t[Ta]??e;return[1,n,[a,t[ba]??U,t[ha]??fa],Aa(a)]}const{tables:{load:s={},save:i={}}={},values:o={}}=t,c=m(wa(ra(_a,o)),0,ya(_a)),l=c[2],w=Aa(l),y=Aa(l),u=Fa(s,{[Ia]:null,[Da]:U,[Pa]:r},Ia,a=>L(y,a),a=>Na(w,a)),d=Fa(i,{[Sa]:null,[Da]:U,[La]:0,[Ra]:0,[Pa]:null},Sa,(a,t)=>L(y,t),(a,t)=>Na(w,t));var g;return g=(a,t)=>t[4]??=ga(u,t[0])?.[2]??r,M(d,(a,t)=>g(0,a)),[0,n,[u,d,c],w]})(t);return(T?Ha:qa)(a,f,a=>{let t;const e=()=>t=setInterval(()=>C(async()=>{const[{d:t,s:e,c:n}]=await f(j+` ${H} d,${q} s,TOTAL_CHANGES() c FROM ${G}${H} JOIN ${G}${q}`);t==A&&e==N&&n==$||(y(A)||a(),A=t,N=e,$=n)}),1e3*b),n=()=>{A=N=$=null,w(t)},s=i(t=>{O.has(t)&&(n(),a(),e())});return e(),()=>{n(),o(s)}},a=>a(),l,u,d,h,P(O),async(a,t)=>await a(j+` t.name tn,c.name cn FROM ${K}list()t,${K}info(t.name)c ${x} t.schema='main'AND t.type IN('table','view')AND t.name IN(${W(t)})ORDER BY t.name,c.name`,t),g,p,n,E,a=>(a=>!0===a)(a)?1:(a=>!1===a)(a)?0:a,void 0)},Qa=(t,e,n,s,i)=>Ka(t,n,async(a,t=[])=>await e.getAllAsync(a,t),t=>a(({tableName:a})=>t(a)),a=>a.remove(),s,i,N,3,e);export{Qa as createExpoSqlitePersister};
|
|
Binary file
|