tinybase 7.0.0-beta.2 → 7.0.0

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.
Files changed (292) hide show
  1. package/@types/common/index.d.ts +1 -1
  2. package/@types/mergeable-store/index.d.ts +1 -1
  3. package/@types/mergeable-store/with-schemas/index.d.ts +1 -1
  4. package/@types/persisters/persister-cr-sqlite-wasm/index.d.ts +4 -0
  5. package/@types/persisters/persister-cr-sqlite-wasm/with-schemas/index.d.ts +4 -0
  6. package/@types/persisters/persister-durable-object-sql-storage/index.d.ts +4 -0
  7. package/@types/persisters/persister-durable-object-sql-storage/with-schemas/index.d.ts +4 -0
  8. package/@types/persisters/persister-electric-sql/index.d.ts +4 -0
  9. package/@types/persisters/persister-electric-sql/with-schemas/index.d.ts +4 -0
  10. package/@types/persisters/persister-expo-sqlite/index.d.ts +4 -0
  11. package/@types/persisters/persister-expo-sqlite/with-schemas/index.d.ts +4 -0
  12. package/@types/persisters/persister-libsql/index.d.ts +4 -0
  13. package/@types/persisters/persister-libsql/with-schemas/index.d.ts +4 -0
  14. package/@types/persisters/persister-pglite/index.d.ts +5 -1
  15. package/@types/persisters/persister-pglite/with-schemas/index.d.ts +5 -1
  16. package/@types/persisters/persister-postgres/index.d.ts +4 -0
  17. package/@types/persisters/persister-postgres/with-schemas/index.d.ts +4 -0
  18. package/@types/persisters/persister-powersync/index.d.ts +4 -0
  19. package/@types/persisters/persister-powersync/with-schemas/index.d.ts +4 -0
  20. package/@types/persisters/persister-react-native-sqlite/index.d.ts +4 -0
  21. package/@types/persisters/persister-react-native-sqlite/with-schemas/index.d.ts +4 -0
  22. package/@types/persisters/persister-sqlite-bun/index.d.ts +4 -0
  23. package/@types/persisters/persister-sqlite-bun/with-schemas/index.d.ts +4 -0
  24. package/@types/persisters/persister-sqlite-wasm/index.d.ts +4 -0
  25. package/@types/persisters/persister-sqlite-wasm/with-schemas/index.d.ts +4 -0
  26. package/@types/persisters/persister-sqlite3/index.d.ts +4 -0
  27. package/@types/persisters/persister-sqlite3/with-schemas/index.d.ts +4 -0
  28. package/@types/queries/index.d.ts +1 -1
  29. package/@types/store/index.d.ts +21 -19
  30. package/@types/store/with-schemas/index.d.ts +15 -13
  31. package/agents.md +62 -0
  32. package/checkpoints/index.js +8 -6
  33. package/checkpoints/with-schemas/index.js +8 -6
  34. package/common/index.js +4 -3
  35. package/common/with-schemas/index.js +4 -3
  36. package/index.js +60 -30
  37. package/indexes/index.js +7 -5
  38. package/indexes/with-schemas/index.js +7 -5
  39. package/mergeable-store/index.js +51 -21
  40. package/mergeable-store/with-schemas/index.js +51 -21
  41. package/metrics/index.js +7 -5
  42. package/metrics/with-schemas/index.js +7 -5
  43. package/min/checkpoints/index.js +1 -1
  44. package/min/checkpoints/index.js.gz +0 -0
  45. package/min/checkpoints/with-schemas/index.js +1 -1
  46. package/min/checkpoints/with-schemas/index.js.gz +0 -0
  47. package/min/common/index.js +1 -1
  48. package/min/common/index.js.gz +0 -0
  49. package/min/common/with-schemas/index.js +1 -1
  50. package/min/common/with-schemas/index.js.gz +0 -0
  51. package/min/index.js +1 -1
  52. package/min/index.js.gz +0 -0
  53. package/min/indexes/index.js +1 -1
  54. package/min/indexes/index.js.gz +0 -0
  55. package/min/indexes/with-schemas/index.js +1 -1
  56. package/min/indexes/with-schemas/index.js.gz +0 -0
  57. package/min/mergeable-store/index.js +1 -1
  58. package/min/mergeable-store/index.js.gz +0 -0
  59. package/min/mergeable-store/with-schemas/index.js +1 -1
  60. package/min/mergeable-store/with-schemas/index.js.gz +0 -0
  61. package/min/metrics/index.js +1 -1
  62. package/min/metrics/index.js.gz +0 -0
  63. package/min/metrics/with-schemas/index.js +1 -1
  64. package/min/metrics/with-schemas/index.js.gz +0 -0
  65. package/min/omni/index.js +1 -1
  66. package/min/omni/index.js.gz +0 -0
  67. package/min/omni/with-schemas/index.js +1 -1
  68. package/min/omni/with-schemas/index.js.gz +0 -0
  69. package/min/persisters/index.js +1 -1
  70. package/min/persisters/index.js.gz +0 -0
  71. package/min/persisters/persister-automerge/index.js +1 -1
  72. package/min/persisters/persister-automerge/index.js.gz +0 -0
  73. package/min/persisters/persister-automerge/with-schemas/index.js +1 -1
  74. package/min/persisters/persister-automerge/with-schemas/index.js.gz +0 -0
  75. package/min/persisters/persister-browser/index.js +1 -1
  76. package/min/persisters/persister-browser/index.js.gz +0 -0
  77. package/min/persisters/persister-browser/with-schemas/index.js +1 -1
  78. package/min/persisters/persister-browser/with-schemas/index.js.gz +0 -0
  79. package/min/persisters/persister-cr-sqlite-wasm/index.js +1 -1
  80. package/min/persisters/persister-cr-sqlite-wasm/index.js.gz +0 -0
  81. package/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.js +1 -1
  82. package/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.js.gz +0 -0
  83. package/min/persisters/persister-durable-object-sql-storage/index.js +1 -1
  84. package/min/persisters/persister-durable-object-sql-storage/index.js.gz +0 -0
  85. package/min/persisters/persister-durable-object-sql-storage/with-schemas/index.js +1 -1
  86. package/min/persisters/persister-durable-object-sql-storage/with-schemas/index.js.gz +0 -0
  87. package/min/persisters/persister-durable-object-storage/index.js +1 -1
  88. package/min/persisters/persister-durable-object-storage/index.js.gz +0 -0
  89. package/min/persisters/persister-durable-object-storage/with-schemas/index.js +1 -1
  90. package/min/persisters/persister-durable-object-storage/with-schemas/index.js.gz +0 -0
  91. package/min/persisters/persister-electric-sql/index.js +1 -1
  92. package/min/persisters/persister-electric-sql/index.js.gz +0 -0
  93. package/min/persisters/persister-electric-sql/with-schemas/index.js +1 -1
  94. package/min/persisters/persister-electric-sql/with-schemas/index.js.gz +0 -0
  95. package/min/persisters/persister-expo-sqlite/index.js +1 -1
  96. package/min/persisters/persister-expo-sqlite/index.js.gz +0 -0
  97. package/min/persisters/persister-expo-sqlite/with-schemas/index.js +1 -1
  98. package/min/persisters/persister-expo-sqlite/with-schemas/index.js.gz +0 -0
  99. package/min/persisters/persister-file/index.js +1 -1
  100. package/min/persisters/persister-file/index.js.gz +0 -0
  101. package/min/persisters/persister-file/with-schemas/index.js +1 -1
  102. package/min/persisters/persister-file/with-schemas/index.js.gz +0 -0
  103. package/min/persisters/persister-indexed-db/index.js +1 -1
  104. package/min/persisters/persister-indexed-db/index.js.gz +0 -0
  105. package/min/persisters/persister-indexed-db/with-schemas/index.js +1 -1
  106. package/min/persisters/persister-indexed-db/with-schemas/index.js.gz +0 -0
  107. package/min/persisters/persister-libsql/index.js +1 -1
  108. package/min/persisters/persister-libsql/index.js.gz +0 -0
  109. package/min/persisters/persister-libsql/with-schemas/index.js +1 -1
  110. package/min/persisters/persister-libsql/with-schemas/index.js.gz +0 -0
  111. package/min/persisters/persister-partykit-client/index.js +1 -1
  112. package/min/persisters/persister-partykit-client/index.js.gz +0 -0
  113. package/min/persisters/persister-partykit-client/with-schemas/index.js +1 -1
  114. package/min/persisters/persister-partykit-client/with-schemas/index.js.gz +0 -0
  115. package/min/persisters/persister-partykit-server/index.js +1 -1
  116. package/min/persisters/persister-partykit-server/index.js.gz +0 -0
  117. package/min/persisters/persister-partykit-server/with-schemas/index.js +1 -1
  118. package/min/persisters/persister-partykit-server/with-schemas/index.js.gz +0 -0
  119. package/min/persisters/persister-pglite/index.js +1 -1
  120. package/min/persisters/persister-pglite/index.js.gz +0 -0
  121. package/min/persisters/persister-pglite/with-schemas/index.js +1 -1
  122. package/min/persisters/persister-pglite/with-schemas/index.js.gz +0 -0
  123. package/min/persisters/persister-postgres/index.js +1 -1
  124. package/min/persisters/persister-postgres/index.js.gz +0 -0
  125. package/min/persisters/persister-postgres/with-schemas/index.js +1 -1
  126. package/min/persisters/persister-postgres/with-schemas/index.js.gz +0 -0
  127. package/min/persisters/persister-powersync/index.js +1 -1
  128. package/min/persisters/persister-powersync/index.js.gz +0 -0
  129. package/min/persisters/persister-powersync/with-schemas/index.js +1 -1
  130. package/min/persisters/persister-powersync/with-schemas/index.js.gz +0 -0
  131. package/min/persisters/persister-react-native-mmkv/index.js +1 -1
  132. package/min/persisters/persister-react-native-mmkv/index.js.gz +0 -0
  133. package/min/persisters/persister-react-native-mmkv/with-schemas/index.js +1 -1
  134. package/min/persisters/persister-react-native-mmkv/with-schemas/index.js.gz +0 -0
  135. package/min/persisters/persister-react-native-sqlite/index.js +1 -1
  136. package/min/persisters/persister-react-native-sqlite/index.js.gz +0 -0
  137. package/min/persisters/persister-react-native-sqlite/with-schemas/index.js +1 -1
  138. package/min/persisters/persister-react-native-sqlite/with-schemas/index.js.gz +0 -0
  139. package/min/persisters/persister-remote/index.js +1 -1
  140. package/min/persisters/persister-remote/index.js.gz +0 -0
  141. package/min/persisters/persister-remote/with-schemas/index.js +1 -1
  142. package/min/persisters/persister-remote/with-schemas/index.js.gz +0 -0
  143. package/min/persisters/persister-sqlite-bun/index.js +1 -1
  144. package/min/persisters/persister-sqlite-bun/index.js.gz +0 -0
  145. package/min/persisters/persister-sqlite-bun/with-schemas/index.js +1 -1
  146. package/min/persisters/persister-sqlite-bun/with-schemas/index.js.gz +0 -0
  147. package/min/persisters/persister-sqlite-wasm/index.js +1 -1
  148. package/min/persisters/persister-sqlite-wasm/index.js.gz +0 -0
  149. package/min/persisters/persister-sqlite-wasm/with-schemas/index.js +1 -1
  150. package/min/persisters/persister-sqlite-wasm/with-schemas/index.js.gz +0 -0
  151. package/min/persisters/persister-sqlite3/index.js +1 -1
  152. package/min/persisters/persister-sqlite3/index.js.gz +0 -0
  153. package/min/persisters/persister-sqlite3/with-schemas/index.js +1 -1
  154. package/min/persisters/persister-sqlite3/with-schemas/index.js.gz +0 -0
  155. package/min/persisters/persister-yjs/index.js +1 -1
  156. package/min/persisters/persister-yjs/index.js.gz +0 -0
  157. package/min/persisters/persister-yjs/with-schemas/index.js +1 -1
  158. package/min/persisters/persister-yjs/with-schemas/index.js.gz +0 -0
  159. package/min/persisters/with-schemas/index.js +1 -1
  160. package/min/persisters/with-schemas/index.js.gz +0 -0
  161. package/min/queries/index.js +1 -1
  162. package/min/queries/index.js.gz +0 -0
  163. package/min/queries/with-schemas/index.js +1 -1
  164. package/min/queries/with-schemas/index.js.gz +0 -0
  165. package/min/relationships/index.js +1 -1
  166. package/min/relationships/index.js.gz +0 -0
  167. package/min/relationships/with-schemas/index.js +1 -1
  168. package/min/relationships/with-schemas/index.js.gz +0 -0
  169. package/min/store/index.js +1 -1
  170. package/min/store/index.js.gz +0 -0
  171. package/min/store/with-schemas/index.js +1 -1
  172. package/min/store/with-schemas/index.js.gz +0 -0
  173. package/min/synchronizers/index.js +1 -1
  174. package/min/synchronizers/index.js.gz +0 -0
  175. package/min/synchronizers/synchronizer-broadcast-channel/index.js +1 -1
  176. package/min/synchronizers/synchronizer-broadcast-channel/index.js.gz +0 -0
  177. package/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js +1 -1
  178. package/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js.gz +0 -0
  179. package/min/synchronizers/synchronizer-local/index.js +1 -1
  180. package/min/synchronizers/synchronizer-local/index.js.gz +0 -0
  181. package/min/synchronizers/synchronizer-local/with-schemas/index.js +1 -1
  182. package/min/synchronizers/synchronizer-local/with-schemas/index.js.gz +0 -0
  183. package/min/synchronizers/synchronizer-ws-client/index.js +1 -1
  184. package/min/synchronizers/synchronizer-ws-client/index.js.gz +0 -0
  185. package/min/synchronizers/synchronizer-ws-client/with-schemas/index.js +1 -1
  186. package/min/synchronizers/synchronizer-ws-client/with-schemas/index.js.gz +0 -0
  187. package/min/synchronizers/synchronizer-ws-server/index.js +1 -1
  188. package/min/synchronizers/synchronizer-ws-server/index.js.gz +0 -0
  189. package/min/synchronizers/synchronizer-ws-server/with-schemas/index.js +1 -1
  190. package/min/synchronizers/synchronizer-ws-server/with-schemas/index.js.gz +0 -0
  191. package/min/synchronizers/synchronizer-ws-server-durable-object/index.js +1 -1
  192. package/min/synchronizers/synchronizer-ws-server-durable-object/index.js.gz +0 -0
  193. package/min/synchronizers/synchronizer-ws-server-durable-object/with-schemas/index.js +1 -1
  194. package/min/synchronizers/synchronizer-ws-server-durable-object/with-schemas/index.js.gz +0 -0
  195. package/min/synchronizers/synchronizer-ws-server-simple/index.js +1 -1
  196. package/min/synchronizers/synchronizer-ws-server-simple/index.js.gz +0 -0
  197. package/min/synchronizers/synchronizer-ws-server-simple/with-schemas/index.js +1 -1
  198. package/min/synchronizers/synchronizer-ws-server-simple/with-schemas/index.js.gz +0 -0
  199. package/min/synchronizers/with-schemas/index.js +1 -1
  200. package/min/synchronizers/with-schemas/index.js.gz +0 -0
  201. package/min/ui-react/index.js +1 -1
  202. package/min/ui-react/index.js.gz +0 -0
  203. package/min/ui-react/with-schemas/index.js +1 -1
  204. package/min/ui-react/with-schemas/index.js.gz +0 -0
  205. package/min/ui-react-dom/index.js +1 -1
  206. package/min/ui-react-dom/index.js.gz +0 -0
  207. package/min/ui-react-dom/with-schemas/index.js +1 -1
  208. package/min/ui-react-dom/with-schemas/index.js.gz +0 -0
  209. package/min/ui-react-inspector/index.js +1 -1
  210. package/min/ui-react-inspector/index.js.gz +0 -0
  211. package/min/ui-react-inspector/with-schemas/index.js +1 -1
  212. package/min/ui-react-inspector/with-schemas/index.js.gz +0 -0
  213. package/min/with-schemas/index.js +1 -1
  214. package/min/with-schemas/index.js.gz +0 -0
  215. package/omni/index.js +78 -46
  216. package/omni/with-schemas/index.js +78 -46
  217. package/package.json +3 -3
  218. package/persisters/index.js +14 -10
  219. package/persisters/persister-automerge/index.js +12 -8
  220. package/persisters/persister-automerge/with-schemas/index.js +12 -8
  221. package/persisters/persister-browser/index.js +12 -8
  222. package/persisters/persister-browser/with-schemas/index.js +12 -8
  223. package/persisters/persister-cr-sqlite-wasm/index.js +14 -10
  224. package/persisters/persister-cr-sqlite-wasm/with-schemas/index.js +14 -10
  225. package/persisters/persister-durable-object-sql-storage/index.js +14 -10
  226. package/persisters/persister-durable-object-sql-storage/with-schemas/index.js +14 -10
  227. package/persisters/persister-durable-object-storage/index.js +12 -8
  228. package/persisters/persister-durable-object-storage/with-schemas/index.js +12 -8
  229. package/persisters/persister-electric-sql/index.js +14 -10
  230. package/persisters/persister-electric-sql/with-schemas/index.js +14 -10
  231. package/persisters/persister-expo-sqlite/index.js +14 -10
  232. package/persisters/persister-expo-sqlite/with-schemas/index.js +14 -10
  233. package/persisters/persister-file/index.js +12 -8
  234. package/persisters/persister-file/with-schemas/index.js +12 -8
  235. package/persisters/persister-indexed-db/index.js +12 -8
  236. package/persisters/persister-indexed-db/with-schemas/index.js +12 -8
  237. package/persisters/persister-libsql/index.js +14 -10
  238. package/persisters/persister-libsql/with-schemas/index.js +14 -10
  239. package/persisters/persister-partykit-client/index.js +12 -8
  240. package/persisters/persister-partykit-client/with-schemas/index.js +12 -8
  241. package/persisters/persister-partykit-server/index.js +4 -3
  242. package/persisters/persister-partykit-server/with-schemas/index.js +4 -3
  243. package/persisters/persister-pglite/index.js +13 -9
  244. package/persisters/persister-pglite/with-schemas/index.js +13 -9
  245. package/persisters/persister-postgres/index.js +13 -9
  246. package/persisters/persister-postgres/with-schemas/index.js +13 -9
  247. package/persisters/persister-powersync/index.js +14 -10
  248. package/persisters/persister-powersync/with-schemas/index.js +14 -10
  249. package/persisters/persister-react-native-mmkv/index.js +12 -8
  250. package/persisters/persister-react-native-mmkv/with-schemas/index.js +12 -8
  251. package/persisters/persister-react-native-sqlite/index.js +14 -10
  252. package/persisters/persister-react-native-sqlite/with-schemas/index.js +14 -10
  253. package/persisters/persister-remote/index.js +14 -10
  254. package/persisters/persister-remote/with-schemas/index.js +14 -10
  255. package/persisters/persister-sqlite-bun/index.js +14 -10
  256. package/persisters/persister-sqlite-bun/with-schemas/index.js +14 -10
  257. package/persisters/persister-sqlite-wasm/index.js +14 -10
  258. package/persisters/persister-sqlite-wasm/with-schemas/index.js +14 -10
  259. package/persisters/persister-sqlite3/index.js +14 -10
  260. package/persisters/persister-sqlite3/with-schemas/index.js +14 -10
  261. package/persisters/persister-yjs/index.js +18 -12
  262. package/persisters/persister-yjs/with-schemas/index.js +18 -12
  263. package/persisters/with-schemas/index.js +14 -10
  264. package/queries/index.js +17 -12
  265. package/queries/with-schemas/index.js +17 -12
  266. package/readme.md +2 -2
  267. package/relationships/index.js +7 -5
  268. package/relationships/with-schemas/index.js +7 -5
  269. package/releases.md +100 -12
  270. package/store/index.js +48 -18
  271. package/store/with-schemas/index.js +48 -18
  272. package/synchronizers/index.js +13 -9
  273. package/synchronizers/synchronizer-broadcast-channel/index.js +14 -10
  274. package/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js +14 -10
  275. package/synchronizers/synchronizer-local/index.js +14 -10
  276. package/synchronizers/synchronizer-local/with-schemas/index.js +14 -10
  277. package/synchronizers/synchronizer-ws-client/index.js +13 -9
  278. package/synchronizers/synchronizer-ws-client/with-schemas/index.js +13 -9
  279. package/synchronizers/synchronizer-ws-server/index.js +13 -9
  280. package/synchronizers/synchronizer-ws-server/with-schemas/index.js +13 -9
  281. package/synchronizers/synchronizer-ws-server-durable-object/index.js +13 -9
  282. package/synchronizers/synchronizer-ws-server-durable-object/with-schemas/index.js +13 -9
  283. package/synchronizers/synchronizer-ws-server-simple/index.js +5 -4
  284. package/synchronizers/synchronizer-ws-server-simple/with-schemas/index.js +5 -4
  285. package/synchronizers/with-schemas/index.js +13 -9
  286. package/ui-react/index.js +9 -6
  287. package/ui-react/with-schemas/index.js +9 -6
  288. package/ui-react-dom/index.js +14 -7
  289. package/ui-react-dom/with-schemas/index.js +14 -7
  290. package/ui-react-inspector/index.js +53 -23
  291. package/ui-react-inspector/with-schemas/index.js +53 -23
  292. package/with-schemas/index.js +60 -30
@@ -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=clearInterval,l=a=>null==a,w=(a,t,e)=>l(a)?e?.():t(a),y=t=>a(t)==s,u=a=>Array.isArray(a),d=(a,t,e)=>a.slice(t,e),g=a=>a.length,p=()=>{},v=async a=>o.all(a),E=a=>{throw Error(a)},A=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},N=(a,t)=>a.forEach(t),m=(a,t="")=>a.join(t),$=(a,t)=>a.map(t),f=a=>0==g(a),C=(a,t)=>a.filter(t),T=(a,...t)=>a.push(...t),h=a=>a.shift(),O=(a,t)=>a?.has(t)??!1,b=a=>l(a)||0==(a=>a?.size??0)(a),D=a=>[...a?.values()??[]],I=(a,t)=>a?.forEach(t),S=(a,t)=>a?.delete(t),L="_",R="_id",P="SELECT",M="WHERE",_="TABLE",F="ALTER "+_,U="FROM",j="DELETE "+U,B=P+"*"+U,J="pragma_",Y="data_version",k="schema_version",x="pragma_table_",z="CREATE "+_,G=a=>m($(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${r(a,/"/g,'""')}"`),"."),H=(a,t=[1])=>m($(a,()=>"$"+t[0]++),n),q=(a,t=i)=>M+`(${r(t,"$tableName",G(a))})`,K=Object,Q=a=>K.getPrototypeOf(a),V=K.entries,W=K.keys,X=K.freeze,Z=(a=[])=>K.fromEntries(a),aa=(...a)=>K.assign({},...a),ta=(a,t)=>(delete a[t],a),ea=(a,t)=>$(V(a),([a,e])=>t(e,a)),na=(a,t)=>Z(ea(a,(a,e)=>[e,t(a,e)])),sa=a=>K.values(a),ia=a=>g(W(a)),ra=a=>(a=>!l(a)&&w(Q(a),a=>a==K.prototype||l(Q(a)),()=>!0))(a)&&0==ia(a),oa=a=>new Map(a),ca=(a,t)=>a?.get(t),la=(a,t)=>$([...a?.entries()??[]],([a,e])=>t(e,a)),wa=(a,t,e)=>l(e)?(S(a,t),a):a?.set(t,e),ya=(a,t,e,n)=>(O(a,t)?n?.(ca(a,t)):wa(a,t,e()),ca(a,t)),ua=(a,t,e,n,s=0)=>w((e?ya:ca)(a,t[s],s>g(t)-2?e:oa),i=>{if(s>g(t)-2)return n?.(i)&&wa(a,t[s]),i;const r=ua(i,t,e,n,s+1);return b(i)&&wa(a,t[s]),r}),da=a=>new Set(u(a)||l(a)?a:[a]),ga=(a,t)=>a?.add(t),pa="ColumnName",va="store",Ea="json",Aa=va+"TableName",Na=va+"Id"+pa,ma=va+pa,$a="autoLoadIntervalSeconds",fa="rowId"+pa,Ca="tableId",Ta="tableName",ha="deleteEmptyColumns",Oa="deleteEmptyTable",ba="condition",Da={mode:Ea,[$a]:1},Ia={load:0,save:0,[Ta]:t+"_values"},Sa=(a,t,e,n,s)=>{const i=oa();return na(a,(a,r)=>{const o=d(sa(aa(t,y(a)?{[e]:a}:a)),0,ia(t));l(o[0])||n(r,o[0])||(s(r,o[0]),wa(i,r,o))}),i},La=JSON.stringify,Ra=JSON.parse,Pa=/^\d+$/,Ma=oa(),_a=oa(),Fa=(a,t,n,s,i,r,o,c={},y=0,d=[])=>{let p,v,m,$=0,f=0,C=0;ya(Ma,d,()=>0),ya(_a,d,()=>[]);const O=oa(),[D,L,R,P,M]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!ra(a)||!ra(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!ra(a)||!ra(t),t.setContent]:E("Store type not supported by this Persister"))(o,a,y),[_,F,U]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?h(a):null)??e+t++,t=>{Pa.test(t)&&g(a)<1e3&&T(a,t)}]})(),s=oa();return[(n,i,r,o=[],c=()=>[])=>{a??=K;const l=t(1);return wa(s,l,[n,i,r,o,c]),ga(ua(i,r??[e],da),l),l},(t,n,...i)=>N(((a,t=[e])=>{const n=[],s=(a,e)=>e==g(t)?T(n,a):null===t[e]?I(a,a=>s(a,e+1)):N([t[e],null],t=>s(ca(a,t),e+1));return s(a,0),n})(t,n),t=>I(t,t=>ca(s,t)[0](a,...n??[],...i))),a=>w(ca(s,a),([,t,i])=>(ua(t,i??[e],void 0,t=>(S(t,a),b(t)?1:0)),wa(s,a),n(a),i)),t=>w(ca(s,t),([t,,e=[],n,s])=>{const i=(...r)=>{const o=g(r);o==g(e)?t(a,...r,...s(r)):l(e[o])?N(n[o]?.(...r)??[],a=>i(...r,a)):i(...r,e[o])};i()})]})(),j=a=>{a!=$&&($=a,F(O,void 0,$))},B=t=>{(D&&u(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},J=async a=>(2!=$&&(j(1),f++,await q(async()=>{await A(async()=>{const e=await t();u(e)?B(e):a?M(a):E("Content is not an array: "+e)},()=>{a&&M(a)}),j(0)})),K),Y=async a=>(k(),await J(a),await A(async()=>v=await s(async(a,t)=>{t||a?2!=$&&(j(1),f++,B(t??a),j(0)):await J()}),r),K),k=async()=>(v&&(await A(()=>i(v),r),v=void 0),K),x=async a=>(1!=$&&(j(2),C++,await q(async()=>{await A(()=>n(L,a),r),j(0)})),K),z=async()=>(G(),await x(),m=a.addDidFinishTransactionListener(()=>{const a=R();P(a)&&x(a)}),K),G=async()=>(m&&(a.delListener(m),m=void 0),K),H=async(a=!1)=>{const[t,e]=a?[G,k]:[k,G];return await t(),await e(),K},q=async(...a)=>(T(ca(_a,d),...a),await(async()=>{if(!ca(Ma,d)){for(wa(Ma,d,1);!l(p=h(ca(_a,d)));)await A(p,r);wa(Ma,d,0)}})(),K),K={load:J,startAutoLoad:Y,stopAutoLoad:k,isAutoLoading:()=>!l(v),save:x,startAutoSave:z,stopAutoSave:G,isAutoSaving:()=>!l(m),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[z,Y]:[Y,z];return await e(a),await n(a),K},stopAutoPersisting:H,getStatus:()=>$,addStatusListener:a=>_(a,O),delListener:t=>(U(t),a),schedule:q,getStore:()=>a,destroy:()=>(ca(_a,d).splice(0,void 0),H()),getStats:()=>({loads:f,saves:C}),...c};return X(K)},Ua=(a,t,e,s,r,o=ja,c,w)=>{const y=oa();return[async()=>{y.clear(),$(await e(a,t),({tn:a,cn:t})=>ga(ya(y,a,da),t))},async(t,e,n)=>((a,t)=>O(ca(y,a),t))(t,e)?Z(C($(await a(B+G(t)+q(t,n)),a=>[a[e],w?na(ta(a,e),w):ta(a,e)]),([a,t])=>!l(a)&&!ra(t))):{},async(t,e,s,w,u,d=!1,g=i)=>{const p=da();na(s??{},a=>$(W(a??{}),a=>ga(p,a)));const E=D(p);if(!d&&u&&g==i&&f(E)&&O(y,t))return await a("DROP "+_+G(t)),void wa(y,t);const A=ca(y,t),N=da(D(A));if(f(E)||(O(y,t)?await v($([e,...E],async(n,s)=>{S(N,n)||(await a(F+G(t)+"ADD"+G(n)+r),0==s&&await a("CREATE UNIQUE INDEX pk ON "+G(t)+`(${G(e)})`),ga(A,n))})):(await a(z+G(t)+`(${G(e)}${r} PRIMARY KEY${m($(E,a=>n+G(a)+r))});`),wa(y,t,da([e,...E])))),await v([...!d&&w?$(D(N),async n=>{n!=e&&(await a(F+G(t)+"DROP"+G(n)),S(A,n))}):[]]),d)l(s)?await a(j+G(t)+q(t,g)):await v(ea(s,async(n,s)=>{l(n)?await a(j+G(t)+q(t,g)+`AND(${G(e)}=$1)`,[s]):f(E)||await o(a,t,e,W(n),{[s]:c?$(sa(n),c):sa(n)},A)}));else if(f(E))O(y,t)&&await a(j+G(t)+q(t,g));else{const n=C(D(ca(y,t)),a=>a!=e),i={},r=[];na(s??{},(a,t)=>{i[t]=$(n,t=>c?c(a?.[t]):a?.[t]),T(r,t)}),await o(a,t,e,n,i),await a(j+G(t)+q(t,g)+`AND${G(e)}NOT IN(${H(r)})`,r)}},async t=>{let e;return await a("BEGIN"),await A(async()=>e=await t(),s),await a("END"),e}]},ja=async(a,t,e,s,i)=>{const r=[1];await a("INSERT INTO"+G(t)+"("+((...a)=>m($(a,G),n))(e,...s)+")VALUES"+m(ea(i,a=>"($"+r[0]+++","+H(a,r)+")"),n)+"ON CONFLICT("+G(e)+")DO UPDATE SET"+m($(s,a=>G(a)+"=excluded."+G(a)),n),ea(i,(a,t)=>[t,...$(a,a=>a??null)]).flat())},Ba=(a,t,e,n,s,i,r,[o,c,l],w,y,u,d,g,p)=>{const[v,E,A,N]=Ua(t,w,y,s,g,p),m=Fa(a,()=>N(async()=>{return await v(),a=(await E(o,c))[L]?.[l]??"null",Ra(a,(a,t)=>""===t?void 0:t);var a}),a=>N(async()=>{var t;await v(),await A(o,c,{[L]:{[l]:(t=a()??null,La(t,(a,t)=>void 0===t?"":t))}},!0,!0)}),e,n,s,r,{[d]:()=>u,destroy:async()=>(await m.stopAutoPersisting(),i(),m)},0,u);return m},Ja=(a,t,e,n,s,i,r,[o,c,[w,y,u]],d,g,p,E,A,N,m,$)=>{const[f,T,h,O]=Ua(t,d,g,s,A,N,m,$),b=(a,t)=>v(la(c,async([e,n,s,i,r],o)=>{t&&!(o in a)||await h(e,n,a[o],s,i,t,r)})),D=async(a,t)=>y?await h(u,R,{[L]:a},!0,!0,t):null,I=Fa(a,()=>O(async()=>{await f();const a=await(async()=>Z(C(await v(la(o,async([a,t,e],n)=>[a,await T(n,t,e)])),a=>!ra(a[1]))))(),t=await(async()=>w?(await T(u,R))[L]:{})();return ra(a)&&l(t)?void 0:[a,t]}),(a,t)=>O(async()=>{if(await f(),l(t)){const[t,e]=a();await b(t),await D(e)}else await b(t[0],!0),await D(t[1],!0)}),e,n,s,r,{[E]:()=>p,destroy:async()=>(await I.stopAutoPersisting(),i(),I)},0,p);return I},Ya=(a,n,s,r,o,l,w,u,g,p,v="getDb",E)=>{let N,m,$;const f=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,l),[C,T,h,b]=(a=>{const e=(a=>aa(Da,y(a)?{[Aa]:a}:a??{}))(a),n=e[$a];if(e.mode==Ea){const a=e[Aa]??t;return[1,n,[a,e[Na]??R,e[ma]??va],da(a)]}const{tables:{load:s={},save:r={}}={},values:o={}}=e,c=d(sa(aa(Ia,o)),0,ia(Ia)),l=c[2],w=da(l),u=da(l),g=Sa(s,{[Ca]:null,[fa]:R,[ba]:i},Ca,a=>O(u,a),a=>ga(w,a)),p=Sa(r,{[Ta]:null,[fa]:R,[ha]:0,[Oa]:0,[ba]:null},Ta,(a,t)=>O(u,t),(a,t)=>ga(w,t));var v;return v=(a,t)=>t[4]??=ca(g,t[0])?.[2]??i,I(p,(a,t)=>v(0,a)),[0,n,[g,p,c],w]})(n);return(C?Ba:Ja)(a,f,a=>{let t;const e=()=>t=setInterval(()=>A(async()=>{const[{d:t,s:e,c:n}]=await f(P+` ${Y} d,${k} s,TOTAL_CHANGES() c FROM ${J}${Y} JOIN ${J}${k}`);t==N&&e==m&&n==$||(null!=N&&a(),N=t,m=e,$=n)}),1e3*T),n=()=>{N=m=$=null,c(t)},s=r(t=>{b.has(t)&&(n(),a(),e())});return e(),()=>{n(),o(s)}},a=>a(),w,u,g,h,D(b),async(a,t)=>await a(P+` t.name tn,c.name cn FROM ${x}list()t,${x}info(t.name)c ${M} t.schema='main'AND t.type IN('table','view')AND t.name IN(${H(t)})ORDER BY t.name,c.name`,t),p,v,e,E,a=>!0===a?1:!1===a?0:a,void 0)},ka=(a,t,e,n,s)=>Ya(a,e,async(a,e=[])=>t.query(a).all(...e),()=>p,a=>a(),n,s,p,3,t);export{ka as createSqliteBunPersister};
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),v=c(y),g=t=>a(t)==s,p=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),T=(a,t="")=>a.join(t),h=(a,t)=>a.map(t),O=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",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=>T(h(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${r(a,/"/g,'""')}"`),"."),V=(a,t=[1])=>T(h(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.keys,ea=X.freeze,na=(a=[])=>X.fromEntries(a),sa=(...a)=>X.assign({},...a),ia=(a,t)=>(delete a[t],a),ra=(a,t)=>h(aa(a),([a,e])=>t(e,a)),oa=(a,t)=>na(ra(a,(a,e)=>[e,t(a,e)])),ca=a=>X.values(a),la=a=>A(ta(a)),wa=a=>(a=>!w(a)&&d(Z(a),a=>a==X.prototype||w(Z(a)),()=>!0))(a)&&0==la(a),ya=a=>new Map(a),ua=(a,t)=>a?.get(t),da=(a,t)=>h([...a?.entries()??[]],([a,e])=>t(e,a)),va=(a,t,e)=>void 0===e?(M(a,t),a):a?.set(t,e),ga=(a,t,e,n)=>(S(a,t)?n?.(ua(a,t)):va(a,t,e()),ua(a,t)),pa=(a,t,e,n,s=0)=>v((e?ga:ua)(a,t[s],s>A(t)-2?e:ya),i=>{if(s>A(t)-2)return n?.(i)&&va(a,t[s]),i;const r=pa(i,t,e,n,s+1);return L(i)&&va(a,t[s]),r}),Ea=a=>new Set(p(a)||y(a)?a:[a]),Aa=(a,t)=>a?.add(t),Na="ColumnName",ma="store",$a="json",fa=ma+"TableName",Ca=ma+"Id"+Na,Ta=ma+Na,ha="autoLoadIntervalSeconds",Oa="rowId"+Na,ba="tableId",Da="tableName",Ia="deleteEmptyColumns",Sa="deleteEmptyTable",La="condition",Ra={mode:$a,[ha]:1},Pa={load:0,save:0,[Da]:t+"_values"},Ma=(a,t,e,n,s)=>{const i=ya();return oa(a,(a,r)=>{const o=E(ca(sa(t,g(a)?{[e]:a}:a)),0,la(t));u(o[0])||n(r,o[0])||(s(r,o[0]),va(i,r,o))}),i},_a=JSON.stringify,Fa=JSON.parse,Ua=/^\d+$/,ja=ya(),Ba=ya(),Ja=(a,t,n,s,i,r,o,c={},l=0,w=[])=>{let d,g,E,N=0,m=0,T=0;ga(ja,w,()=>0),ga(Ba,w,()=>[]);const h=ya(),[O,b,S,R,_]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!wa(a)||!wa(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!wa(a)||!wa(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=>{Ua.test(t)&&A(a)<1e3&&D(a,t)}]})(),s=ya();return[(n,i,r,o=[],c=()=>[])=>{a??=Q;const l=t(1);return va(s,l,[n,i,r,o,c]),Aa(pa(i,r??[e],Ea),l),l},(t,n,...i)=>C(((a,t=[e])=>{const n=[],s=(a,e)=>e==A(t)?D(n,a):null===t[e]?P(a,a=>s(a,e+1)):C([t[e],null],t=>s(ua(a,t),e+1));return s(a,0),n})(t,n),t=>P(t,t=>ua(s,t)[0](a,...n??[],...i))),a=>v(ua(s,a),([,t,i])=>(pa(t,i??[e],void 0,t=>(M(t,a),L(t)?1:0)),va(s,a),n(a),i)),t=>v(ua(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()})]})(),B=a=>{a!=N&&(N=a,U(h,void 0,N))},J=t=>{(O&&p(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},Y=async a=>(2!=N&&(B(1),m++,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()=>g=await s(async(a,t)=>{t||a?2!=N&&(B(1),m++,J(t??a),B(0)):await Y()}),r),Q),x=async()=>(g&&(await f(()=>i(g),r),g=void 0),Q),z=async a=>(1!=N&&(B(2),T++,await K(async()=>{await f(()=>n(b,a),r),B(0)})),Q),G=async()=>(H(),await z(),E=a.addDidFinishTransactionListener(()=>{const a=S();R(a)&&z(a)}),Q),H=async()=>(E&&(a.delListener(E),E=void 0),Q),q=async(a=!1)=>{const[t,e]=a?[H,x]:[x,H];return await t(),await e(),Q},K=async(...a)=>(D(ua(Ba,w),...a),await(async()=>{if(!ua(ja,w)){for(va(ja,w,1);!y(d=I(ua(Ba,w)));)await f(d,r);va(ja,w,0)}})(),Q),Q={load:Y,startAutoLoad:k,stopAutoLoad:x,isAutoLoading:()=>!y(g),save:z,startAutoSave:G,stopAutoSave:H,isAutoSaving:()=>!y(E),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[G,k]:[k,G];return await e(a),await n(a),Q},stopAutoPersisting:q,getStatus:()=>N,addStatusListener:a=>F(a,h),delListener:t=>(j(t),a),schedule:K,getStore:()=>a,destroy:()=>(ua(Ba,w).splice(0,void 0),q()),getStats:()=>({loads:m,saves:T}),...c};return ea(Q)},Ya=(a,t,e,s,r,o=ka,c,l)=>{const w=ya();return[async()=>{w.clear(),h(await e(a,t),({tn:a,cn:t})=>Aa(ga(w,a,Ea),t))},async(t,e,n)=>((a,t)=>S(ua(w,a),t))(t,e)?na(b(h(await a(x+Q(t)+W(t,n)),a=>[a[e],l?oa(ia(a,e),l):ia(a,e)]),([a,t])=>!y(a)&&!wa(t))):{},async(t,e,s,l,u,d=!1,v=i)=>{const g=Ea();oa(s??{},a=>h(ta(a??{}),a=>Aa(g,a)));const p=R(g);if(!d&&u&&v==i&&O(p)&&S(w,t))return await a("DROP "+B+Q(t)),void va(w,t);const E=ua(w,t),A=Ea(R(E));if(O(p)||(S(w,t)?await m(h([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)})`),Aa(E,n))})):(await a(K+Q(t)+`(${Q(e)}${r} PRIMARY KEY${T(h(p,a=>n+Q(a)+r))});`),va(w,t,Ea([e,...p])))),await m([...!d&&l?h(R(A),async n=>{n!=e&&(await a(J+Q(t)+"DROP"+Q(n)),M(E,n))}):[]]),d)y(s)?await a(k+Q(t)+W(t,v)):await m(ra(s,async(n,s)=>{y(n)?await a(k+Q(t)+W(t,v)+`AND(${Q(e)}=$1)`,[s]):O(p)||await o(a,t,e,ta(n),{[s]:c?h(ca(n),c):ca(n)},E)}));else if(O(p))S(w,t)&&await a(k+Q(t)+W(t,v));else{const n=b(R(ua(w,t)),a=>a!=e),i={},r=[];oa(s??{},(a,t)=>{i[t]=h(n,t=>c?c(a?.[t]):a?.[t]),D(r,t)}),await o(a,t,e,n,i),await a(k+Q(t)+W(t,v)+`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}]},ka=async(a,t,e,s,i)=>{const r=[1];await a("INSERT INTO"+Q(t)+"("+((...a)=>T(h(a,Q),n))(e,...s)+")VALUES"+T(ra(i,a=>"($"+r[0]+++","+V(a,r)+")"),n)+"ON CONFLICT("+Q(e)+")DO UPDATE SET"+T(h(s,a=>Q(a)+"=excluded."+Q(a)),n),ra(i,(a,t)=>[t,...h(a,a=>a??null)]).flat())},xa=(a,t,e,n,s,i,r,[o,c,l],w,y,u,d,v,g)=>{const[p,E,A,N]=Ya(t,w,y,s,v,g),m=Ja(a,()=>N(async()=>{return await p(),a=(await E(o,c))[_]?.[l]??"null",Fa(a,(a,t)=>""===t?void 0:t);var a}),a=>N(async()=>{var t;await p(),await A(o,c,{[_]:{[l]:(t=a()??null,_a(t,(a,t)=>void 0===t?"":t))}},!0,!0)}),e,n,s,r,{[d]:()=>u,destroy:async()=>(await m.stopAutoPersisting(),i(),m)},0,u);return m},za=(a,t,e,n,s,i,r,[o,c,[l,w,u]],d,v,g,p,E,A,N,$)=>{const[f,C,T,h]=Ya(t,d,v,s,E,A,N,$),O=(a,t)=>m(da(c,async([e,n,s,i,r],o)=>{t&&!(o in a)||await T(e,n,a[o],s,i,t,r)})),D=async(a,t)=>w?await T(u,F,{[_]:a},!0,!0,t):null,I=Ja(a,()=>h(async()=>{await f();const a=await(async()=>na(b(await m(da(o,async([a,t,e],n)=>[a,await C(n,t,e)])),a=>!wa(a[1]))))(),t=await(async()=>l?(await C(u,F))[_]:{})();return wa(a)&&y(t)?void 0:[a,t]}),(a,t)=>h(async()=>{if(await f(),y(t)){const[t,e]=a();await O(t),await D(e)}else await O(t[0],!0),await D(t[1],!0)}),e,n,s,r,{[p]:()=>g,destroy:async()=>(await I.stopAutoPersisting(),i(),I)},0,g);return I},Ga=(a,n,s,r,o,c,y,u,d,v,p="getDb",A)=>{let N,m,$;const C=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,c),[T,h,O,b]=(a=>{const e=(a=>sa(Ra,g(a)?{[fa]:a}:a??{}))(a),n=e[ha];if(e.mode==$a){const a=e[fa]??t;return[1,n,[a,e[Ca]??F,e[Ta]??ma],Ea(a)]}const{tables:{load:s={},save:r={}}={},values:o={}}=e,c=E(ca(sa(Pa,o)),0,la(Pa)),l=c[2],w=Ea(l),y=Ea(l),u=Ma(s,{[ba]:null,[Oa]:F,[La]:i},ba,a=>S(y,a),a=>Aa(w,a)),d=Ma(r,{[Da]:null,[Oa]:F,[Ia]:0,[Sa]:0,[La]:null},Da,(a,t)=>S(y,t),(a,t)=>Aa(w,t));var v;return v=(a,t)=>t[4]??=ua(u,t[0])?.[2]??i,P(d,(a,t)=>v(0,a)),[0,n,[u,d,c],w]})(n);return(T?xa:za)(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*h),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,O,R(b),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),v,p,e,A,a=>!0===a?1:!1===a?0:a,void 0)},Ha=(a,t,e,n,s)=>Ga(a,e,async(a,e=[])=>t.query(a).all(...e),()=>N,a=>a(),n,s,N,3,t);export{Ha as createSqliteBunPersister};
@@ -1 +1 @@
1
- const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),i="true",o=(a,t,e)=>a.replace(t,e),r=Promise,c=clearInterval,l=a=>null==a,w=(a,t,e)=>l(a)?e?.():t(a),u=t=>a(t)==s,y=a=>Array.isArray(a),d=(a,t,e)=>a.slice(t,e),p=a=>a.length,g=()=>{},v=async a=>r.all(a),E=a=>{throw Error(a)},A=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},m=(a,t)=>a.forEach(t),N=(a,t="")=>a.join(t),$=(a,t)=>a.map(t),f=a=>0==p(a),h=(a,t)=>a.filter(t),b=(a,...t)=>a.push(...t),C=a=>a.shift(),T=(a,t)=>a?.has(t)??!1,O=a=>l(a)||0==(a=>a?.size??0)(a),D=a=>[...a?.values()??[]],I=(a,t)=>a?.forEach(t),S=(a,t)=>a?.delete(t),L="_",R="_id",_="SELECT",M="WHERE",P="TABLE",F="ALTER "+P,j="FROM",k="DELETE "+j,U=_+"*"+j,x="pragma_",B="data_version",J="schema_version",Y="pragma_table_",q="CREATE "+P,z=a=>N($(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${o(a,/"/g,'""')}"`),"."),G=(a,t=[1])=>N($(a,()=>"$"+t[0]++),n),H=(a,t=i)=>M+`(${o(t,"$tableName",z(a))})`,V=Object,K=a=>V.getPrototypeOf(a),Q=V.entries,W=V.keys,X=V.freeze,Z=(a=[])=>V.fromEntries(a),aa=(...a)=>V.assign({},...a),ta=(a,t)=>(delete a[t],a),ea=(a,t)=>$(Q(a),([a,e])=>t(e,a)),na=(a,t)=>Z(ea(a,(a,e)=>[e,t(a,e)])),sa=a=>V.values(a),ia=a=>p(W(a)),oa=a=>(a=>!l(a)&&w(K(a),a=>a==V.prototype||l(K(a)),()=>!0))(a)&&0==ia(a),ra=a=>new Map(a),ca=(a,t)=>a?.get(t),la=(a,t)=>$([...a?.entries()??[]],([a,e])=>t(e,a)),wa=(a,t,e)=>l(e)?(S(a,t),a):a?.set(t,e),ua=(a,t,e,n)=>(T(a,t)?n?.(ca(a,t)):wa(a,t,e()),ca(a,t)),ya=(a,t,e,n,s=0)=>w((e?ua:ca)(a,t[s],s>p(t)-2?e:ra),i=>{if(s>p(t)-2)return n?.(i)&&wa(a,t[s]),i;const o=ya(i,t,e,n,s+1);return O(i)&&wa(a,t[s]),o}),da=a=>new Set(y(a)||l(a)?a:[a]),pa=(a,t)=>a?.add(t),ga="ColumnName",va="store",Ea="json",Aa=va+"TableName",ma=va+"Id"+ga,Na=va+ga,$a="autoLoadIntervalSeconds",fa="rowId"+ga,ha="tableId",ba="tableName",Ca="deleteEmptyColumns",Ta="deleteEmptyTable",Oa="condition",Da={mode:Ea,[$a]:1},Ia={load:0,save:0,[ba]:t+"_values"},Sa=(a,t,e,n,s)=>{const i=ra();return na(a,(a,o)=>{const r=d(sa(aa(t,u(a)?{[e]:a}:a)),0,ia(t));l(r[0])||n(o,r[0])||(s(o,r[0]),wa(i,o,r))}),i},La=JSON.stringify,Ra=JSON.parse,_a=/^\d+$/,Ma=ra(),Pa=ra(),Fa=(a,t,n,s,i,o,r,c={},u=0,d=[])=>{let g,v,N,$=0,f=0,h=0;ua(Ma,d,()=>0),ua(Pa,d,()=>[]);const T=ra(),[D,L,R,_,M]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!oa(a)||!oa(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!oa(a)||!oa(t),t.setContent]:E("Store type not supported by this Persister"))(r,a,u),[P,F,j]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?C(a):null)??e+t++,t=>{_a.test(t)&&p(a)<1e3&&b(a,t)}]})(),s=ra();return[(n,i,o,r=[],c=()=>[])=>{a??=V;const l=t(1);return wa(s,l,[n,i,o,r,c]),pa(ya(i,o??[e],da),l),l},(t,n,...i)=>m(((a,t=[e])=>{const n=[],s=(a,e)=>e==p(t)?b(n,a):null===t[e]?I(a,a=>s(a,e+1)):m([t[e],null],t=>s(ca(a,t),e+1));return s(a,0),n})(t,n),t=>I(t,t=>ca(s,t)[0](a,...n??[],...i))),a=>w(ca(s,a),([,t,i])=>(ya(t,i??[e],void 0,t=>(S(t,a),O(t)?1:0)),wa(s,a),n(a),i)),t=>w(ca(s,t),([t,,e=[],n,s])=>{const i=(...o)=>{const r=p(o);r==p(e)?t(a,...o,...s(o)):l(e[r])?m(n[r]?.(...o)??[],a=>i(...o,a)):i(...o,e[r])};i()})]})(),k=a=>{a!=$&&($=a,F(T,void 0,$))},U=t=>{(D&&y(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},x=async a=>(2!=$&&(k(1),f++,await H(async()=>{await A(async()=>{const e=await t();y(e)?U(e):a?M(a):E("Content is not an array: "+e)},()=>{a&&M(a)}),k(0)})),V),B=async a=>(J(),await x(a),await A(async()=>v=await s(async(a,t)=>{t||a?2!=$&&(k(1),f++,U(t??a),k(0)):await x()}),o),V),J=async()=>(v&&(await A(()=>i(v),o),v=void 0),V),Y=async a=>(1!=$&&(k(2),h++,await H(async()=>{await A(()=>n(L,a),o),k(0)})),V),q=async()=>(z(),await Y(),N=a.addDidFinishTransactionListener(()=>{const a=R();_(a)&&Y(a)}),V),z=async()=>(N&&(a.delListener(N),N=void 0),V),G=async(a=!1)=>{const[t,e]=a?[z,J]:[J,z];return await t(),await e(),V},H=async(...a)=>(b(ca(Pa,d),...a),await(async()=>{if(!ca(Ma,d)){for(wa(Ma,d,1);!l(g=C(ca(Pa,d)));)await A(g,o);wa(Ma,d,0)}})(),V),V={load:x,startAutoLoad:B,stopAutoLoad:J,isAutoLoading:()=>!l(v),save:Y,startAutoSave:q,stopAutoSave:z,isAutoSaving:()=>!l(N),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[q,B]:[B,q];return await e(a),await n(a),V},stopAutoPersisting:G,getStatus:()=>$,addStatusListener:a=>P(a,T),delListener:t=>(j(t),a),schedule:H,getStore:()=>a,destroy:()=>(ca(Pa,d).splice(0,void 0),G()),getStats:()=>({loads:f,saves:h}),...c};return X(V)},ja=(a,t,e,s,o,r=ka,c,w)=>{const u=ra();return[async()=>{u.clear(),$(await e(a,t),({tn:a,cn:t})=>pa(ua(u,a,da),t))},async(t,e,n)=>((a,t)=>T(ca(u,a),t))(t,e)?Z(h($(await a(U+z(t)+H(t,n)),a=>[a[e],w?na(ta(a,e),w):ta(a,e)]),([a,t])=>!l(a)&&!oa(t))):{},async(t,e,s,w,y,d=!1,p=i)=>{const g=da();na(s??{},a=>$(W(a??{}),a=>pa(g,a)));const E=D(g);if(!d&&y&&p==i&&f(E)&&T(u,t))return await a("DROP "+P+z(t)),void wa(u,t);const A=ca(u,t),m=da(D(A));if(f(E)||(T(u,t)?await v($([e,...E],async(n,s)=>{S(m,n)||(await a(F+z(t)+"ADD"+z(n)+o),0==s&&await a("CREATE UNIQUE INDEX pk ON "+z(t)+`(${z(e)})`),pa(A,n))})):(await a(q+z(t)+`(${z(e)}${o} PRIMARY KEY${N($(E,a=>n+z(a)+o))});`),wa(u,t,da([e,...E])))),await v([...!d&&w?$(D(m),async n=>{n!=e&&(await a(F+z(t)+"DROP"+z(n)),S(A,n))}):[]]),d)l(s)?await a(k+z(t)+H(t,p)):await v(ea(s,async(n,s)=>{l(n)?await a(k+z(t)+H(t,p)+`AND(${z(e)}=$1)`,[s]):f(E)||await r(a,t,e,W(n),{[s]:c?$(sa(n),c):sa(n)},A)}));else if(f(E))T(u,t)&&await a(k+z(t)+H(t,p));else{const n=h(D(ca(u,t)),a=>a!=e),i={},o=[];na(s??{},(a,t)=>{i[t]=$(n,t=>c?c(a?.[t]):a?.[t]),b(o,t)}),await r(a,t,e,n,i),await a(k+z(t)+H(t,p)+`AND${z(e)}NOT IN(${G(o)})`,o)}},async t=>{let e;return await a("BEGIN"),await A(async()=>e=await t(),s),await a("END"),e}]},ka=async(a,t,e,s,i)=>{const o=[1];await a("INSERT INTO"+z(t)+"("+((...a)=>N($(a,z),n))(e,...s)+")VALUES"+N(ea(i,a=>"($"+o[0]+++","+G(a,o)+")"),n)+"ON CONFLICT("+z(e)+")DO UPDATE SET"+N($(s,a=>z(a)+"=excluded."+z(a)),n),ea(i,(a,t)=>[t,...$(a,a=>a??null)]).flat())},Ua=(a,t,e,n,s,i,o,[r,c,l],w,u,y,d,p,g)=>{const[v,E,A,m]=ja(t,w,u,s,p,g),N=Fa(a,()=>m(async()=>{return await v(),a=(await E(r,c))[L]?.[l]??"null",Ra(a,(a,t)=>""===t?void 0:t);var a}),a=>m(async()=>{var t;await v(),await A(r,c,{[L]:{[l]:(t=a()??null,La(t,(a,t)=>void 0===t?"":t))}},!0,!0)}),e,n,s,o,{[d]:()=>y,destroy:async()=>(await N.stopAutoPersisting(),i(),N)},0,y);return N},xa=(a,t,e,n,s,i,o,[r,c,[w,u,y]],d,p,g,E,A,m,N,$)=>{const[f,b,C,T]=ja(t,d,p,s,A,m,N,$),O=(a,t)=>v(la(c,async([e,n,s,i,o],r)=>{t&&!(r in a)||await C(e,n,a[r],s,i,t,o)})),D=async(a,t)=>u?await C(y,R,{[L]:a},!0,!0,t):null,I=Fa(a,()=>T(async()=>{await f();const a=await(async()=>Z(h(await v(la(r,async([a,t,e],n)=>[a,await b(n,t,e)])),a=>!oa(a[1]))))(),t=await(async()=>w?(await b(y,R))[L]:{})();return oa(a)&&l(t)?void 0:[a,t]}),(a,t)=>T(async()=>{if(await f(),l(t)){const[t,e]=a();await O(t),await D(e)}else await O(t[0],!0),await D(t[1],!0)}),e,n,s,o,{[E]:()=>g,destroy:async()=>(await I.stopAutoPersisting(),i(),I)},0,g);return I},Ba=(a,n,s,o,r,l,w,y,p,g,v="getDb",E)=>{let m,N,$;const f=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,l),[h,b,C,O]=(a=>{const e=(a=>aa(Da,u(a)?{[Aa]:a}:a??{}))(a),n=e[$a];if(e.mode==Ea){const a=e[Aa]??t;return[1,n,[a,e[ma]??R,e[Na]??va],da(a)]}const{tables:{load:s={},save:o={}}={},values:r={}}=e,c=d(sa(aa(Ia,r)),0,ia(Ia)),l=c[2],w=da(l),y=da(l),p=Sa(s,{[ha]:null,[fa]:R,[Oa]:i},ha,a=>T(y,a),a=>pa(w,a)),g=Sa(o,{[ba]:null,[fa]:R,[Ca]:0,[Ta]:0,[Oa]:null},ba,(a,t)=>T(y,t),(a,t)=>pa(w,t));var v;return v=(a,t)=>t[4]??=ca(p,t[0])?.[2]??i,I(g,(a,t)=>v(0,a)),[0,n,[p,g,c],w]})(n);return(h?Ua:xa)(a,f,a=>{let t;const e=()=>t=setInterval(()=>A(async()=>{const[{d:t,s:e,c:n}]=await f(_+` ${B} d,${J} s,TOTAL_CHANGES() c FROM ${x}${B} JOIN ${x}${J}`);t==m&&e==N&&n==$||(null!=m&&a(),m=t,N=e,$=n)}),1e3*b),n=()=>{m=N=$=null,c(t)},s=o(t=>{O.has(t)&&(n(),a(),e())});return e(),()=>{n(),r(s)}},a=>a(),w,y,p,C,D(O),async(a,t)=>await a(_+` t.name tn,c.name cn FROM ${Y}list()t,${Y}info(t.name)c ${M} t.schema='main'AND t.type IN('table','view')AND t.name IN(${G(t)})ORDER BY t.name,c.name`,t),g,v,e,E,a=>!0===a?1:!1===a?0:a,void 0)},Ja=(a,t,e,n,s,i)=>Ba(a,n,async(a,t=[])=>e.exec(a,{bind:t,rowMode:"object",returnValue:"resultRows"}).map(a=>({...a})),a=>t.capi.sqlite3_update_hook(e,(t,e,n,s)=>a(s),0),()=>t.capi.sqlite3_update_hook(e,g,0),s,i,g,3,e);export{Ja as createSqliteWasmPersister};
1
+ const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),i="true",o=(a,t,e)=>a.replace(t,e),r=Promise,c=a=>(t,e,n)=>a(t)?n?.():e(t),l=clearInterval,w=a=>null==a,u=a=>void 0===a,y=a=>null===a,d=c(w),p=c(u),v=t=>a(t)==s,g=a=>Array.isArray(a),E=(a,t,e)=>a.slice(t,e),A=a=>a.length,m=()=>{},N=async a=>r.all(a),$=a=>{throw Error(a)},f=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},h=(a,t)=>a.forEach(t),b=(a,t="")=>a.join(t),C=(a,t)=>a.map(t),T=a=>0==A(a),O=(a,t)=>a.filter(t),D=(a,...t)=>a.push(...t),I=a=>a.shift(),S=(a,t)=>a?.has(t)??!1,L=a=>u(a)||0==(a=>a?.size??0)(a),R=a=>[...a?.values()??[]],_=(a,t)=>a?.forEach(t),M=(a,t)=>a?.delete(t),P="_",F="_id",j="SELECT",k="WHERE",U="TABLE",x="ALTER "+U,B="FROM",J="DELETE "+B,Y=j+"*"+B,q="pragma_",z="data_version",G="schema_version",H="pragma_table_",V="CREATE "+U,K=a=>b(C(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${o(a,/"/g,'""')}"`),"."),Q=(a,t=[1])=>b(C(a,()=>"$"+t[0]++),n),W=(a,t=i)=>k+`(${o(t,"$tableName",K(a))})`,X=Object,Z=a=>X.getPrototypeOf(a),aa=X.entries,ta=X.keys,ea=X.freeze,na=(a=[])=>X.fromEntries(a),sa=(...a)=>X.assign({},...a),ia=(a,t)=>(delete a[t],a),oa=(a,t)=>C(aa(a),([a,e])=>t(e,a)),ra=(a,t)=>na(oa(a,(a,e)=>[e,t(a,e)])),ca=a=>X.values(a),la=a=>A(ta(a)),wa=a=>(a=>!w(a)&&d(Z(a),a=>a==X.prototype||w(Z(a)),()=>!0))(a)&&0==la(a),ua=a=>new Map(a),ya=(a,t)=>a?.get(t),da=(a,t)=>C([...a?.entries()??[]],([a,e])=>t(e,a)),pa=(a,t,e)=>void 0===e?(M(a,t),a):a?.set(t,e),va=(a,t,e,n)=>(S(a,t)?n?.(ya(a,t)):pa(a,t,e()),ya(a,t)),ga=(a,t,e,n,s=0)=>p((e?va:ya)(a,t[s],s>A(t)-2?e:ua),i=>{if(s>A(t)-2)return n?.(i)&&pa(a,t[s]),i;const o=ga(i,t,e,n,s+1);return L(i)&&pa(a,t[s]),o}),Ea=a=>new Set(g(a)||u(a)?a:[a]),Aa=(a,t)=>a?.add(t),ma="ColumnName",Na="store",$a="json",fa=Na+"TableName",ha=Na+"Id"+ma,ba=Na+ma,Ca="autoLoadIntervalSeconds",Ta="rowId"+ma,Oa="tableId",Da="tableName",Ia="deleteEmptyColumns",Sa="deleteEmptyTable",La="condition",Ra={mode:$a,[Ca]:1},_a={load:0,save:0,[Da]:t+"_values"},Ma=(a,t,e,n,s)=>{const i=ua();return ra(a,(a,o)=>{const r=E(ca(sa(t,v(a)?{[e]:a}:a)),0,la(t));y(r[0])||n(o,r[0])||(s(o,r[0]),pa(i,o,r))}),i},Pa=JSON.stringify,Fa=JSON.parse,ja=/^\d+$/,ka=ua(),Ua=ua(),xa=(a,t,n,s,i,o,r,c={},l=0,w=[])=>{let d,v,E,m=0,N=0,b=0;va(ka,w,()=>0),va(Ua,w,()=>[]);const C=ua(),[T,O,S,R,P]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!wa(a)||!wa(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!wa(a)||!wa(t),t.setContent]:$("Store type not supported by this Persister"))(r,a,l),[F,j,k]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?I(a):null)??e+t++,t=>{ja.test(t)&&A(a)<1e3&&D(a,t)}]})(),s=ua();return[(n,i,o,r=[],c=()=>[])=>{a??=K;const l=t(1);return pa(s,l,[n,i,o,r,c]),Aa(ga(i,o??[e],Ea),l),l},(t,n,...i)=>h(((a,t=[e])=>{const n=[],s=(a,e)=>e==A(t)?D(n,a):null===t[e]?_(a,a=>s(a,e+1)):h([t[e],null],t=>s(ya(a,t),e+1));return s(a,0),n})(t,n),t=>_(t,t=>ya(s,t)[0](a,...n??[],...i))),a=>p(ya(s,a),([,t,i])=>(ga(t,i??[e],void 0,t=>(M(t,a),L(t)?1:0)),pa(s,a),n(a),i)),t=>p(ya(s,t),([t,,e=[],n,s])=>{const i=(...o)=>{const r=A(o);r==A(e)?t(a,...o,...s(o)):y(e[r])?h(n[r]?.(...o)??[],a=>i(...o,a)):i(...o,e[r])};i()})]})(),U=a=>{a!=m&&(m=a,j(C,void 0,m))},x=t=>{(T&&g(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},B=async a=>(2!=m&&(U(1),N++,await V(async()=>{await f(async()=>{const e=await t();g(e)?x(e):a?P(a):$("Content is not an array: "+e)},()=>{a&&P(a)}),U(0)})),K),J=async a=>(Y(),await B(a),await f(async()=>v=await s(async(a,t)=>{t||a?2!=m&&(U(1),N++,x(t??a),U(0)):await B()}),o),K),Y=async()=>(v&&(await f(()=>i(v),o),v=void 0),K),q=async a=>(1!=m&&(U(2),b++,await V(async()=>{await f(()=>n(O,a),o),U(0)})),K),z=async()=>(G(),await q(),E=a.addDidFinishTransactionListener(()=>{const a=S();R(a)&&q(a)}),K),G=async()=>(E&&(a.delListener(E),E=void 0),K),H=async(a=!1)=>{const[t,e]=a?[G,Y]:[Y,G];return await t(),await e(),K},V=async(...a)=>(D(ya(Ua,w),...a),await(async()=>{if(!ya(ka,w)){for(pa(ka,w,1);!u(d=I(ya(Ua,w)));)await f(d,o);pa(ka,w,0)}})(),K),K={load:B,startAutoLoad:J,stopAutoLoad:Y,isAutoLoading:()=>!u(v),save:q,startAutoSave:z,stopAutoSave:G,isAutoSaving:()=>!u(E),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[z,J]:[J,z];return await e(a),await n(a),K},stopAutoPersisting:H,getStatus:()=>m,addStatusListener:a=>F(a,C),delListener:t=>(k(t),a),schedule:V,getStore:()=>a,destroy:()=>(ya(Ua,w).splice(0,void 0),H()),getStats:()=>({loads:N,saves:b}),...c};return ea(K)},Ba=(a,t,e,s,o,r=Ja,c,l)=>{const w=ua();return[async()=>{w.clear(),C(await e(a,t),({tn:a,cn:t})=>Aa(va(w,a,Ea),t))},async(t,e,n)=>((a,t)=>S(ya(w,a),t))(t,e)?na(O(C(await a(Y+K(t)+W(t,n)),a=>[a[e],l?ra(ia(a,e),l):ia(a,e)]),([a,t])=>!u(a)&&!wa(t))):{},async(t,e,s,l,y,d=!1,p=i)=>{const v=Ea();ra(s??{},a=>C(ta(a??{}),a=>Aa(v,a)));const g=R(v);if(!d&&y&&p==i&&T(g)&&S(w,t))return await a("DROP "+U+K(t)),void pa(w,t);const E=ya(w,t),A=Ea(R(E));if(T(g)||(S(w,t)?await N(C([e,...g],async(n,s)=>{M(A,n)||(await a(x+K(t)+"ADD"+K(n)+o),0==s&&await a("CREATE UNIQUE INDEX pk ON "+K(t)+`(${K(e)})`),Aa(E,n))})):(await a(V+K(t)+`(${K(e)}${o} PRIMARY KEY${b(C(g,a=>n+K(a)+o))});`),pa(w,t,Ea([e,...g])))),await N([...!d&&l?C(R(A),async n=>{n!=e&&(await a(x+K(t)+"DROP"+K(n)),M(E,n))}):[]]),d)u(s)?await a(J+K(t)+W(t,p)):await N(oa(s,async(n,s)=>{u(n)?await a(J+K(t)+W(t,p)+`AND(${K(e)}=$1)`,[s]):T(g)||await r(a,t,e,ta(n),{[s]:c?C(ca(n),c):ca(n)},E)}));else if(T(g))S(w,t)&&await a(J+K(t)+W(t,p));else{const n=O(R(ya(w,t)),a=>a!=e),i={},o=[];ra(s??{},(a,t)=>{i[t]=C(n,t=>c?c(a?.[t]):a?.[t]),D(o,t)}),await r(a,t,e,n,i),await a(J+K(t)+W(t,p)+`AND${K(e)}NOT IN(${Q(o)})`,o)}},async t=>{let e;return await a("BEGIN"),await f(async()=>e=await t(),s),await a("END"),e}]},Ja=async(a,t,e,s,i)=>{const o=[1];await a("INSERT INTO"+K(t)+"("+((...a)=>b(C(a,K),n))(e,...s)+")VALUES"+b(oa(i,a=>"($"+o[0]+++","+Q(a,o)+")"),n)+"ON CONFLICT("+K(e)+")DO UPDATE SET"+b(C(s,a=>K(a)+"=excluded."+K(a)),n),oa(i,(a,t)=>[t,...C(a,a=>a??null)]).flat())},Ya=(a,t,e,n,s,i,o,[r,c,l],w,u,y,d,p,v)=>{const[g,E,A,m]=Ba(t,w,u,s,p,v),N=xa(a,()=>m(async()=>{return await g(),a=(await E(r,c))[P]?.[l]??"null",Fa(a,(a,t)=>""===t?void 0:t);var a}),a=>m(async()=>{var t;await g(),await A(r,c,{[P]:{[l]:(t=a()??null,Pa(t,(a,t)=>void 0===t?"":t))}},!0,!0)}),e,n,s,o,{[d]:()=>y,destroy:async()=>(await N.stopAutoPersisting(),i(),N)},0,y);return N},qa=(a,t,e,n,s,i,o,[r,c,[l,w,y]],d,p,v,g,E,A,m,$)=>{const[f,h,b,C]=Ba(t,d,p,s,E,A,m,$),T=(a,t)=>N(da(c,async([e,n,s,i,o],r)=>{t&&!(r in a)||await b(e,n,a[r],s,i,t,o)})),D=async(a,t)=>w?await b(y,F,{[P]:a},!0,!0,t):null,I=xa(a,()=>C(async()=>{await f();const a=await(async()=>na(O(await N(da(r,async([a,t,e],n)=>[a,await h(n,t,e)])),a=>!wa(a[1]))))(),t=await(async()=>l?(await h(y,F))[P]:{})();return wa(a)&&u(t)?void 0:[a,t]}),(a,t)=>C(async()=>{if(await f(),u(t)){const[t,e]=a();await T(t),await D(e)}else await T(t[0],!0),await D(t[1],!0)}),e,n,s,o,{[g]:()=>v,destroy:async()=>(await I.stopAutoPersisting(),i(),I)},0,v);return I},za=(a,n,s,o,r,c,u,y,d,p,g="getDb",A)=>{let m,N,$;const h=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,c),[b,C,T,O]=(a=>{const e=(a=>sa(Ra,v(a)?{[fa]:a}:a??{}))(a),n=e[Ca];if(e.mode==$a){const a=e[fa]??t;return[1,n,[a,e[ha]??F,e[ba]??Na],Ea(a)]}const{tables:{load:s={},save:o={}}={},values:r={}}=e,c=E(ca(sa(_a,r)),0,la(_a)),l=c[2],w=Ea(l),u=Ea(l),y=Ma(s,{[Oa]:null,[Ta]:F,[La]:i},Oa,a=>S(u,a),a=>Aa(w,a)),d=Ma(o,{[Da]:null,[Ta]:F,[Ia]:0,[Sa]:0,[La]:null},Da,(a,t)=>S(u,t),(a,t)=>Aa(w,t));var p;return p=(a,t)=>t[4]??=ya(y,t[0])?.[2]??i,_(d,(a,t)=>p(0,a)),[0,n,[y,d,c],w]})(n);return(b?Ya:qa)(a,h,a=>{let t;const e=()=>t=setInterval(()=>f(async()=>{const[{d:t,s:e,c:n}]=await h(j+` ${z} d,${G} s,TOTAL_CHANGES() c FROM ${q}${z} JOIN ${q}${G}`);t==m&&e==N&&n==$||(w(m)||a(),m=t,N=e,$=n)}),1e3*C),n=()=>{m=N=$=null,l(t)},s=o(t=>{O.has(t)&&(n(),a(),e())});return e(),()=>{n(),r(s)}},a=>a(),u,y,d,T,R(O),async(a,t)=>await a(j+` t.name tn,c.name cn FROM ${H}list()t,${H}info(t.name)c ${k} t.schema='main'AND t.type IN('table','view')AND t.name IN(${Q(t)})ORDER BY t.name,c.name`,t),p,g,e,A,a=>!0===a?1:!1===a?0:a,void 0)},Ga=(a,t,e,n,s,i)=>za(a,n,async(a,t=[])=>e.exec(a,{bind:t,rowMode:"object",returnValue:"resultRows"}).map(a=>({...a})),a=>t.capi.sqlite3_update_hook(e,(t,e,n,s)=>a(s),0),()=>t.capi.sqlite3_update_hook(e,m,0),s,i,m,3,e);export{Ga as createSqliteWasmPersister};
@@ -1 +1 @@
1
- const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),i="true",o=(a,t,e)=>a.replace(t,e),r=Promise,c=clearInterval,l=a=>null==a,w=(a,t,e)=>l(a)?e?.():t(a),u=t=>a(t)==s,y=a=>Array.isArray(a),d=(a,t,e)=>a.slice(t,e),p=a=>a.length,g=()=>{},v=async a=>r.all(a),E=a=>{throw Error(a)},A=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},m=(a,t)=>a.forEach(t),N=(a,t="")=>a.join(t),$=(a,t)=>a.map(t),f=a=>0==p(a),h=(a,t)=>a.filter(t),b=(a,...t)=>a.push(...t),C=a=>a.shift(),T=(a,t)=>a?.has(t)??!1,O=a=>l(a)||0==(a=>a?.size??0)(a),D=a=>[...a?.values()??[]],I=(a,t)=>a?.forEach(t),S=(a,t)=>a?.delete(t),L="_",R="_id",_="SELECT",M="WHERE",P="TABLE",F="ALTER "+P,j="FROM",k="DELETE "+j,U=_+"*"+j,x="pragma_",B="data_version",J="schema_version",Y="pragma_table_",q="CREATE "+P,z=a=>N($(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${o(a,/"/g,'""')}"`),"."),G=(a,t=[1])=>N($(a,()=>"$"+t[0]++),n),H=(a,t=i)=>M+`(${o(t,"$tableName",z(a))})`,V=Object,K=a=>V.getPrototypeOf(a),Q=V.entries,W=V.keys,X=V.freeze,Z=(a=[])=>V.fromEntries(a),aa=(...a)=>V.assign({},...a),ta=(a,t)=>(delete a[t],a),ea=(a,t)=>$(Q(a),([a,e])=>t(e,a)),na=(a,t)=>Z(ea(a,(a,e)=>[e,t(a,e)])),sa=a=>V.values(a),ia=a=>p(W(a)),oa=a=>(a=>!l(a)&&w(K(a),a=>a==V.prototype||l(K(a)),()=>!0))(a)&&0==ia(a),ra=a=>new Map(a),ca=(a,t)=>a?.get(t),la=(a,t)=>$([...a?.entries()??[]],([a,e])=>t(e,a)),wa=(a,t,e)=>l(e)?(S(a,t),a):a?.set(t,e),ua=(a,t,e,n)=>(T(a,t)?n?.(ca(a,t)):wa(a,t,e()),ca(a,t)),ya=(a,t,e,n,s=0)=>w((e?ua:ca)(a,t[s],s>p(t)-2?e:ra),i=>{if(s>p(t)-2)return n?.(i)&&wa(a,t[s]),i;const o=ya(i,t,e,n,s+1);return O(i)&&wa(a,t[s]),o}),da=a=>new Set(y(a)||l(a)?a:[a]),pa=(a,t)=>a?.add(t),ga="ColumnName",va="store",Ea="json",Aa=va+"TableName",ma=va+"Id"+ga,Na=va+ga,$a="autoLoadIntervalSeconds",fa="rowId"+ga,ha="tableId",ba="tableName",Ca="deleteEmptyColumns",Ta="deleteEmptyTable",Oa="condition",Da={mode:Ea,[$a]:1},Ia={load:0,save:0,[ba]:t+"_values"},Sa=(a,t,e,n,s)=>{const i=ra();return na(a,(a,o)=>{const r=d(sa(aa(t,u(a)?{[e]:a}:a)),0,ia(t));l(r[0])||n(o,r[0])||(s(o,r[0]),wa(i,o,r))}),i},La=JSON.stringify,Ra=JSON.parse,_a=/^\d+$/,Ma=ra(),Pa=ra(),Fa=(a,t,n,s,i,o,r,c={},u=0,d=[])=>{let g,v,N,$=0,f=0,h=0;ua(Ma,d,()=>0),ua(Pa,d,()=>[]);const T=ra(),[D,L,R,_,M]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!oa(a)||!oa(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!oa(a)||!oa(t),t.setContent]:E("Store type not supported by this Persister"))(r,a,u),[P,F,j]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?C(a):null)??e+t++,t=>{_a.test(t)&&p(a)<1e3&&b(a,t)}]})(),s=ra();return[(n,i,o,r=[],c=()=>[])=>{a??=V;const l=t(1);return wa(s,l,[n,i,o,r,c]),pa(ya(i,o??[e],da),l),l},(t,n,...i)=>m(((a,t=[e])=>{const n=[],s=(a,e)=>e==p(t)?b(n,a):null===t[e]?I(a,a=>s(a,e+1)):m([t[e],null],t=>s(ca(a,t),e+1));return s(a,0),n})(t,n),t=>I(t,t=>ca(s,t)[0](a,...n??[],...i))),a=>w(ca(s,a),([,t,i])=>(ya(t,i??[e],void 0,t=>(S(t,a),O(t)?1:0)),wa(s,a),n(a),i)),t=>w(ca(s,t),([t,,e=[],n,s])=>{const i=(...o)=>{const r=p(o);r==p(e)?t(a,...o,...s(o)):l(e[r])?m(n[r]?.(...o)??[],a=>i(...o,a)):i(...o,e[r])};i()})]})(),k=a=>{a!=$&&($=a,F(T,void 0,$))},U=t=>{(D&&y(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},x=async a=>(2!=$&&(k(1),f++,await H(async()=>{await A(async()=>{const e=await t();y(e)?U(e):a?M(a):E("Content is not an array: "+e)},()=>{a&&M(a)}),k(0)})),V),B=async a=>(J(),await x(a),await A(async()=>v=await s(async(a,t)=>{t||a?2!=$&&(k(1),f++,U(t??a),k(0)):await x()}),o),V),J=async()=>(v&&(await A(()=>i(v),o),v=void 0),V),Y=async a=>(1!=$&&(k(2),h++,await H(async()=>{await A(()=>n(L,a),o),k(0)})),V),q=async()=>(z(),await Y(),N=a.addDidFinishTransactionListener(()=>{const a=R();_(a)&&Y(a)}),V),z=async()=>(N&&(a.delListener(N),N=void 0),V),G=async(a=!1)=>{const[t,e]=a?[z,J]:[J,z];return await t(),await e(),V},H=async(...a)=>(b(ca(Pa,d),...a),await(async()=>{if(!ca(Ma,d)){for(wa(Ma,d,1);!l(g=C(ca(Pa,d)));)await A(g,o);wa(Ma,d,0)}})(),V),V={load:x,startAutoLoad:B,stopAutoLoad:J,isAutoLoading:()=>!l(v),save:Y,startAutoSave:q,stopAutoSave:z,isAutoSaving:()=>!l(N),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[q,B]:[B,q];return await e(a),await n(a),V},stopAutoPersisting:G,getStatus:()=>$,addStatusListener:a=>P(a,T),delListener:t=>(j(t),a),schedule:H,getStore:()=>a,destroy:()=>(ca(Pa,d).splice(0,void 0),G()),getStats:()=>({loads:f,saves:h}),...c};return X(V)},ja=(a,t,e,s,o,r=ka,c,w)=>{const u=ra();return[async()=>{u.clear(),$(await e(a,t),({tn:a,cn:t})=>pa(ua(u,a,da),t))},async(t,e,n)=>((a,t)=>T(ca(u,a),t))(t,e)?Z(h($(await a(U+z(t)+H(t,n)),a=>[a[e],w?na(ta(a,e),w):ta(a,e)]),([a,t])=>!l(a)&&!oa(t))):{},async(t,e,s,w,y,d=!1,p=i)=>{const g=da();na(s??{},a=>$(W(a??{}),a=>pa(g,a)));const E=D(g);if(!d&&y&&p==i&&f(E)&&T(u,t))return await a("DROP "+P+z(t)),void wa(u,t);const A=ca(u,t),m=da(D(A));if(f(E)||(T(u,t)?await v($([e,...E],async(n,s)=>{S(m,n)||(await a(F+z(t)+"ADD"+z(n)+o),0==s&&await a("CREATE UNIQUE INDEX pk ON "+z(t)+`(${z(e)})`),pa(A,n))})):(await a(q+z(t)+`(${z(e)}${o} PRIMARY KEY${N($(E,a=>n+z(a)+o))});`),wa(u,t,da([e,...E])))),await v([...!d&&w?$(D(m),async n=>{n!=e&&(await a(F+z(t)+"DROP"+z(n)),S(A,n))}):[]]),d)l(s)?await a(k+z(t)+H(t,p)):await v(ea(s,async(n,s)=>{l(n)?await a(k+z(t)+H(t,p)+`AND(${z(e)}=$1)`,[s]):f(E)||await r(a,t,e,W(n),{[s]:c?$(sa(n),c):sa(n)},A)}));else if(f(E))T(u,t)&&await a(k+z(t)+H(t,p));else{const n=h(D(ca(u,t)),a=>a!=e),i={},o=[];na(s??{},(a,t)=>{i[t]=$(n,t=>c?c(a?.[t]):a?.[t]),b(o,t)}),await r(a,t,e,n,i),await a(k+z(t)+H(t,p)+`AND${z(e)}NOT IN(${G(o)})`,o)}},async t=>{let e;return await a("BEGIN"),await A(async()=>e=await t(),s),await a("END"),e}]},ka=async(a,t,e,s,i)=>{const o=[1];await a("INSERT INTO"+z(t)+"("+((...a)=>N($(a,z),n))(e,...s)+")VALUES"+N(ea(i,a=>"($"+o[0]+++","+G(a,o)+")"),n)+"ON CONFLICT("+z(e)+")DO UPDATE SET"+N($(s,a=>z(a)+"=excluded."+z(a)),n),ea(i,(a,t)=>[t,...$(a,a=>a??null)]).flat())},Ua=(a,t,e,n,s,i,o,[r,c,l],w,u,y,d,p,g)=>{const[v,E,A,m]=ja(t,w,u,s,p,g),N=Fa(a,()=>m(async()=>{return await v(),a=(await E(r,c))[L]?.[l]??"null",Ra(a,(a,t)=>""===t?void 0:t);var a}),a=>m(async()=>{var t;await v(),await A(r,c,{[L]:{[l]:(t=a()??null,La(t,(a,t)=>void 0===t?"":t))}},!0,!0)}),e,n,s,o,{[d]:()=>y,destroy:async()=>(await N.stopAutoPersisting(),i(),N)},0,y);return N},xa=(a,t,e,n,s,i,o,[r,c,[w,u,y]],d,p,g,E,A,m,N,$)=>{const[f,b,C,T]=ja(t,d,p,s,A,m,N,$),O=(a,t)=>v(la(c,async([e,n,s,i,o],r)=>{t&&!(r in a)||await C(e,n,a[r],s,i,t,o)})),D=async(a,t)=>u?await C(y,R,{[L]:a},!0,!0,t):null,I=Fa(a,()=>T(async()=>{await f();const a=await(async()=>Z(h(await v(la(r,async([a,t,e],n)=>[a,await b(n,t,e)])),a=>!oa(a[1]))))(),t=await(async()=>w?(await b(y,R))[L]:{})();return oa(a)&&l(t)?void 0:[a,t]}),(a,t)=>T(async()=>{if(await f(),l(t)){const[t,e]=a();await O(t),await D(e)}else await O(t[0],!0),await D(t[1],!0)}),e,n,s,o,{[E]:()=>g,destroy:async()=>(await I.stopAutoPersisting(),i(),I)},0,g);return I},Ba=(a,n,s,o,r,l,w,y,p,g,v="getDb",E)=>{let m,N,$;const f=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,l),[h,b,C,O]=(a=>{const e=(a=>aa(Da,u(a)?{[Aa]:a}:a??{}))(a),n=e[$a];if(e.mode==Ea){const a=e[Aa]??t;return[1,n,[a,e[ma]??R,e[Na]??va],da(a)]}const{tables:{load:s={},save:o={}}={},values:r={}}=e,c=d(sa(aa(Ia,r)),0,ia(Ia)),l=c[2],w=da(l),y=da(l),p=Sa(s,{[ha]:null,[fa]:R,[Oa]:i},ha,a=>T(y,a),a=>pa(w,a)),g=Sa(o,{[ba]:null,[fa]:R,[Ca]:0,[Ta]:0,[Oa]:null},ba,(a,t)=>T(y,t),(a,t)=>pa(w,t));var v;return v=(a,t)=>t[4]??=ca(p,t[0])?.[2]??i,I(g,(a,t)=>v(0,a)),[0,n,[p,g,c],w]})(n);return(h?Ua:xa)(a,f,a=>{let t;const e=()=>t=setInterval(()=>A(async()=>{const[{d:t,s:e,c:n}]=await f(_+` ${B} d,${J} s,TOTAL_CHANGES() c FROM ${x}${B} JOIN ${x}${J}`);t==m&&e==N&&n==$||(null!=m&&a(),m=t,N=e,$=n)}),1e3*b),n=()=>{m=N=$=null,c(t)},s=o(t=>{O.has(t)&&(n(),a(),e())});return e(),()=>{n(),r(s)}},a=>a(),w,y,p,C,D(O),async(a,t)=>await a(_+` t.name tn,c.name cn FROM ${Y}list()t,${Y}info(t.name)c ${M} t.schema='main'AND t.type IN('table','view')AND t.name IN(${G(t)})ORDER BY t.name,c.name`,t),g,v,e,E,a=>!0===a?1:!1===a?0:a,void 0)},Ja=(a,t,e,n,s,i)=>Ba(a,n,async(a,t=[])=>e.exec(a,{bind:t,rowMode:"object",returnValue:"resultRows"}).map(a=>({...a})),a=>t.capi.sqlite3_update_hook(e,(t,e,n,s)=>a(s),0),()=>t.capi.sqlite3_update_hook(e,g,0),s,i,g,3,e);export{Ja as createSqliteWasmPersister};
1
+ const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),i="true",o=(a,t,e)=>a.replace(t,e),r=Promise,c=a=>(t,e,n)=>a(t)?n?.():e(t),l=clearInterval,w=a=>null==a,u=a=>void 0===a,y=a=>null===a,d=c(w),p=c(u),v=t=>a(t)==s,g=a=>Array.isArray(a),E=(a,t,e)=>a.slice(t,e),A=a=>a.length,m=()=>{},N=async a=>r.all(a),$=a=>{throw Error(a)},f=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},h=(a,t)=>a.forEach(t),b=(a,t="")=>a.join(t),C=(a,t)=>a.map(t),T=a=>0==A(a),O=(a,t)=>a.filter(t),D=(a,...t)=>a.push(...t),I=a=>a.shift(),S=(a,t)=>a?.has(t)??!1,L=a=>u(a)||0==(a=>a?.size??0)(a),R=a=>[...a?.values()??[]],_=(a,t)=>a?.forEach(t),M=(a,t)=>a?.delete(t),P="_",F="_id",j="SELECT",k="WHERE",U="TABLE",x="ALTER "+U,B="FROM",J="DELETE "+B,Y=j+"*"+B,q="pragma_",z="data_version",G="schema_version",H="pragma_table_",V="CREATE "+U,K=a=>b(C(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${o(a,/"/g,'""')}"`),"."),Q=(a,t=[1])=>b(C(a,()=>"$"+t[0]++),n),W=(a,t=i)=>k+`(${o(t,"$tableName",K(a))})`,X=Object,Z=a=>X.getPrototypeOf(a),aa=X.entries,ta=X.keys,ea=X.freeze,na=(a=[])=>X.fromEntries(a),sa=(...a)=>X.assign({},...a),ia=(a,t)=>(delete a[t],a),oa=(a,t)=>C(aa(a),([a,e])=>t(e,a)),ra=(a,t)=>na(oa(a,(a,e)=>[e,t(a,e)])),ca=a=>X.values(a),la=a=>A(ta(a)),wa=a=>(a=>!w(a)&&d(Z(a),a=>a==X.prototype||w(Z(a)),()=>!0))(a)&&0==la(a),ua=a=>new Map(a),ya=(a,t)=>a?.get(t),da=(a,t)=>C([...a?.entries()??[]],([a,e])=>t(e,a)),pa=(a,t,e)=>void 0===e?(M(a,t),a):a?.set(t,e),va=(a,t,e,n)=>(S(a,t)?n?.(ya(a,t)):pa(a,t,e()),ya(a,t)),ga=(a,t,e,n,s=0)=>p((e?va:ya)(a,t[s],s>A(t)-2?e:ua),i=>{if(s>A(t)-2)return n?.(i)&&pa(a,t[s]),i;const o=ga(i,t,e,n,s+1);return L(i)&&pa(a,t[s]),o}),Ea=a=>new Set(g(a)||u(a)?a:[a]),Aa=(a,t)=>a?.add(t),ma="ColumnName",Na="store",$a="json",fa=Na+"TableName",ha=Na+"Id"+ma,ba=Na+ma,Ca="autoLoadIntervalSeconds",Ta="rowId"+ma,Oa="tableId",Da="tableName",Ia="deleteEmptyColumns",Sa="deleteEmptyTable",La="condition",Ra={mode:$a,[Ca]:1},_a={load:0,save:0,[Da]:t+"_values"},Ma=(a,t,e,n,s)=>{const i=ua();return ra(a,(a,o)=>{const r=E(ca(sa(t,v(a)?{[e]:a}:a)),0,la(t));y(r[0])||n(o,r[0])||(s(o,r[0]),pa(i,o,r))}),i},Pa=JSON.stringify,Fa=JSON.parse,ja=/^\d+$/,ka=ua(),Ua=ua(),xa=(a,t,n,s,i,o,r,c={},l=0,w=[])=>{let d,v,E,m=0,N=0,b=0;va(ka,w,()=>0),va(Ua,w,()=>[]);const C=ua(),[T,O,S,R,P]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!wa(a)||!wa(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!wa(a)||!wa(t),t.setContent]:$("Store type not supported by this Persister"))(r,a,l),[F,j,k]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?I(a):null)??e+t++,t=>{ja.test(t)&&A(a)<1e3&&D(a,t)}]})(),s=ua();return[(n,i,o,r=[],c=()=>[])=>{a??=K;const l=t(1);return pa(s,l,[n,i,o,r,c]),Aa(ga(i,o??[e],Ea),l),l},(t,n,...i)=>h(((a,t=[e])=>{const n=[],s=(a,e)=>e==A(t)?D(n,a):null===t[e]?_(a,a=>s(a,e+1)):h([t[e],null],t=>s(ya(a,t),e+1));return s(a,0),n})(t,n),t=>_(t,t=>ya(s,t)[0](a,...n??[],...i))),a=>p(ya(s,a),([,t,i])=>(ga(t,i??[e],void 0,t=>(M(t,a),L(t)?1:0)),pa(s,a),n(a),i)),t=>p(ya(s,t),([t,,e=[],n,s])=>{const i=(...o)=>{const r=A(o);r==A(e)?t(a,...o,...s(o)):y(e[r])?h(n[r]?.(...o)??[],a=>i(...o,a)):i(...o,e[r])};i()})]})(),U=a=>{a!=m&&(m=a,j(C,void 0,m))},x=t=>{(T&&g(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},B=async a=>(2!=m&&(U(1),N++,await V(async()=>{await f(async()=>{const e=await t();g(e)?x(e):a?P(a):$("Content is not an array: "+e)},()=>{a&&P(a)}),U(0)})),K),J=async a=>(Y(),await B(a),await f(async()=>v=await s(async(a,t)=>{t||a?2!=m&&(U(1),N++,x(t??a),U(0)):await B()}),o),K),Y=async()=>(v&&(await f(()=>i(v),o),v=void 0),K),q=async a=>(1!=m&&(U(2),b++,await V(async()=>{await f(()=>n(O,a),o),U(0)})),K),z=async()=>(G(),await q(),E=a.addDidFinishTransactionListener(()=>{const a=S();R(a)&&q(a)}),K),G=async()=>(E&&(a.delListener(E),E=void 0),K),H=async(a=!1)=>{const[t,e]=a?[G,Y]:[Y,G];return await t(),await e(),K},V=async(...a)=>(D(ya(Ua,w),...a),await(async()=>{if(!ya(ka,w)){for(pa(ka,w,1);!u(d=I(ya(Ua,w)));)await f(d,o);pa(ka,w,0)}})(),K),K={load:B,startAutoLoad:J,stopAutoLoad:Y,isAutoLoading:()=>!u(v),save:q,startAutoSave:z,stopAutoSave:G,isAutoSaving:()=>!u(E),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[z,J]:[J,z];return await e(a),await n(a),K},stopAutoPersisting:H,getStatus:()=>m,addStatusListener:a=>F(a,C),delListener:t=>(k(t),a),schedule:V,getStore:()=>a,destroy:()=>(ya(Ua,w).splice(0,void 0),H()),getStats:()=>({loads:N,saves:b}),...c};return ea(K)},Ba=(a,t,e,s,o,r=Ja,c,l)=>{const w=ua();return[async()=>{w.clear(),C(await e(a,t),({tn:a,cn:t})=>Aa(va(w,a,Ea),t))},async(t,e,n)=>((a,t)=>S(ya(w,a),t))(t,e)?na(O(C(await a(Y+K(t)+W(t,n)),a=>[a[e],l?ra(ia(a,e),l):ia(a,e)]),([a,t])=>!u(a)&&!wa(t))):{},async(t,e,s,l,y,d=!1,p=i)=>{const v=Ea();ra(s??{},a=>C(ta(a??{}),a=>Aa(v,a)));const g=R(v);if(!d&&y&&p==i&&T(g)&&S(w,t))return await a("DROP "+U+K(t)),void pa(w,t);const E=ya(w,t),A=Ea(R(E));if(T(g)||(S(w,t)?await N(C([e,...g],async(n,s)=>{M(A,n)||(await a(x+K(t)+"ADD"+K(n)+o),0==s&&await a("CREATE UNIQUE INDEX pk ON "+K(t)+`(${K(e)})`),Aa(E,n))})):(await a(V+K(t)+`(${K(e)}${o} PRIMARY KEY${b(C(g,a=>n+K(a)+o))});`),pa(w,t,Ea([e,...g])))),await N([...!d&&l?C(R(A),async n=>{n!=e&&(await a(x+K(t)+"DROP"+K(n)),M(E,n))}):[]]),d)u(s)?await a(J+K(t)+W(t,p)):await N(oa(s,async(n,s)=>{u(n)?await a(J+K(t)+W(t,p)+`AND(${K(e)}=$1)`,[s]):T(g)||await r(a,t,e,ta(n),{[s]:c?C(ca(n),c):ca(n)},E)}));else if(T(g))S(w,t)&&await a(J+K(t)+W(t,p));else{const n=O(R(ya(w,t)),a=>a!=e),i={},o=[];ra(s??{},(a,t)=>{i[t]=C(n,t=>c?c(a?.[t]):a?.[t]),D(o,t)}),await r(a,t,e,n,i),await a(J+K(t)+W(t,p)+`AND${K(e)}NOT IN(${Q(o)})`,o)}},async t=>{let e;return await a("BEGIN"),await f(async()=>e=await t(),s),await a("END"),e}]},Ja=async(a,t,e,s,i)=>{const o=[1];await a("INSERT INTO"+K(t)+"("+((...a)=>b(C(a,K),n))(e,...s)+")VALUES"+b(oa(i,a=>"($"+o[0]+++","+Q(a,o)+")"),n)+"ON CONFLICT("+K(e)+")DO UPDATE SET"+b(C(s,a=>K(a)+"=excluded."+K(a)),n),oa(i,(a,t)=>[t,...C(a,a=>a??null)]).flat())},Ya=(a,t,e,n,s,i,o,[r,c,l],w,u,y,d,p,v)=>{const[g,E,A,m]=Ba(t,w,u,s,p,v),N=xa(a,()=>m(async()=>{return await g(),a=(await E(r,c))[P]?.[l]??"null",Fa(a,(a,t)=>""===t?void 0:t);var a}),a=>m(async()=>{var t;await g(),await A(r,c,{[P]:{[l]:(t=a()??null,Pa(t,(a,t)=>void 0===t?"":t))}},!0,!0)}),e,n,s,o,{[d]:()=>y,destroy:async()=>(await N.stopAutoPersisting(),i(),N)},0,y);return N},qa=(a,t,e,n,s,i,o,[r,c,[l,w,y]],d,p,v,g,E,A,m,$)=>{const[f,h,b,C]=Ba(t,d,p,s,E,A,m,$),T=(a,t)=>N(da(c,async([e,n,s,i,o],r)=>{t&&!(r in a)||await b(e,n,a[r],s,i,t,o)})),D=async(a,t)=>w?await b(y,F,{[P]:a},!0,!0,t):null,I=xa(a,()=>C(async()=>{await f();const a=await(async()=>na(O(await N(da(r,async([a,t,e],n)=>[a,await h(n,t,e)])),a=>!wa(a[1]))))(),t=await(async()=>l?(await h(y,F))[P]:{})();return wa(a)&&u(t)?void 0:[a,t]}),(a,t)=>C(async()=>{if(await f(),u(t)){const[t,e]=a();await T(t),await D(e)}else await T(t[0],!0),await D(t[1],!0)}),e,n,s,o,{[g]:()=>v,destroy:async()=>(await I.stopAutoPersisting(),i(),I)},0,v);return I},za=(a,n,s,o,r,c,u,y,d,p,g="getDb",A)=>{let m,N,$;const h=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,c),[b,C,T,O]=(a=>{const e=(a=>sa(Ra,v(a)?{[fa]:a}:a??{}))(a),n=e[Ca];if(e.mode==$a){const a=e[fa]??t;return[1,n,[a,e[ha]??F,e[ba]??Na],Ea(a)]}const{tables:{load:s={},save:o={}}={},values:r={}}=e,c=E(ca(sa(_a,r)),0,la(_a)),l=c[2],w=Ea(l),u=Ea(l),y=Ma(s,{[Oa]:null,[Ta]:F,[La]:i},Oa,a=>S(u,a),a=>Aa(w,a)),d=Ma(o,{[Da]:null,[Ta]:F,[Ia]:0,[Sa]:0,[La]:null},Da,(a,t)=>S(u,t),(a,t)=>Aa(w,t));var p;return p=(a,t)=>t[4]??=ya(y,t[0])?.[2]??i,_(d,(a,t)=>p(0,a)),[0,n,[y,d,c],w]})(n);return(b?Ya:qa)(a,h,a=>{let t;const e=()=>t=setInterval(()=>f(async()=>{const[{d:t,s:e,c:n}]=await h(j+` ${z} d,${G} s,TOTAL_CHANGES() c FROM ${q}${z} JOIN ${q}${G}`);t==m&&e==N&&n==$||(w(m)||a(),m=t,N=e,$=n)}),1e3*C),n=()=>{m=N=$=null,l(t)},s=o(t=>{O.has(t)&&(n(),a(),e())});return e(),()=>{n(),r(s)}},a=>a(),u,y,d,T,R(O),async(a,t)=>await a(j+` t.name tn,c.name cn FROM ${H}list()t,${H}info(t.name)c ${k} t.schema='main'AND t.type IN('table','view')AND t.name IN(${Q(t)})ORDER BY t.name,c.name`,t),p,g,e,A,a=>!0===a?1:!1===a?0:a,void 0)},Ga=(a,t,e,n,s,i)=>za(a,n,async(a,t=[])=>e.exec(a,{bind:t,rowMode:"object",returnValue:"resultRows"}).map(a=>({...a})),a=>t.capi.sqlite3_update_hook(e,(t,e,n,s)=>a(s),0),()=>t.capi.sqlite3_update_hook(e,m,0),s,i,m,3,e);export{Ga as createSqliteWasmPersister};
@@ -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=clearInterval,l=a=>null==a,w=(a,t,e)=>l(a)?e?.():t(a),u=t=>a(t)==s,y=a=>Array.isArray(a),d=(a,t,e)=>a.slice(t,e),g=a=>a.length,v=()=>{},p=async a=>o.all(a),E=a=>{throw Error(a)},A=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},N=(a,t)=>a.forEach(t),m=(a,t="")=>a.join(t),$=(a,t)=>a.map(t),f=a=>0==g(a),h=(a,t)=>a.filter(t),C=(a,...t)=>a.push(...t),T=a=>a.shift(),O=(a,t)=>a?.has(t)??!1,b=a=>l(a)||0==(a=>a?.size??0)(a),D=a=>[...a?.values()??[]],I=(a,t)=>a?.forEach(t),S=(a,t)=>a?.delete(t),L="_",R="_id",P="SELECT",M="WHERE",_="TABLE",F="ALTER "+_,U="FROM",j="DELETE "+U,B=P+"*"+U,J="pragma_",Y="data_version",k="schema_version",x="pragma_table_",z="CREATE "+_,G=a=>m($(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${r(a,/"/g,'""')}"`),"."),H=(a,t=[1])=>m($(a,()=>"$"+t[0]++),n),K=(a,t=i)=>M+`(${r(t,"$tableName",G(a))})`,Q=Object,V=a=>Q.getPrototypeOf(a),W=Q.entries,X=Q.keys,q=Q.freeze,Z=(a=[])=>Q.fromEntries(a),aa=(...a)=>Q.assign({},...a),ta=(a,t)=>(delete a[t],a),ea=(a,t)=>$(W(a),([a,e])=>t(e,a)),na=(a,t)=>Z(ea(a,(a,e)=>[e,t(a,e)])),sa=a=>Q.values(a),ia=a=>g(X(a)),ra=a=>(a=>!l(a)&&w(V(a),a=>a==Q.prototype||l(V(a)),()=>!0))(a)&&0==ia(a),oa=a=>new Map(a),ca=(a,t)=>a?.get(t),la=(a,t)=>$([...a?.entries()??[]],([a,e])=>t(e,a)),wa=(a,t,e)=>l(e)?(S(a,t),a):a?.set(t,e),ua=(a,t,e,n)=>(O(a,t)?n?.(ca(a,t)):wa(a,t,e()),ca(a,t)),ya=(a,t,e,n,s=0)=>w((e?ua:ca)(a,t[s],s>g(t)-2?e:oa),i=>{if(s>g(t)-2)return n?.(i)&&wa(a,t[s]),i;const r=ya(i,t,e,n,s+1);return b(i)&&wa(a,t[s]),r}),da=a=>new Set(y(a)||l(a)?a:[a]),ga=(a,t)=>a?.add(t),va="ColumnName",pa="store",Ea="json",Aa=pa+"TableName",Na=pa+"Id"+va,ma=pa+va,$a="autoLoadIntervalSeconds",fa="rowId"+va,ha="tableId",Ca="tableName",Ta="deleteEmptyColumns",Oa="deleteEmptyTable",ba="condition",Da={mode:Ea,[$a]:1},Ia={load:0,save:0,[Ca]:t+"_values"},Sa=(a,t,e,n,s)=>{const i=oa();return na(a,(a,r)=>{const o=d(sa(aa(t,u(a)?{[e]:a}:a)),0,ia(t));l(o[0])||n(r,o[0])||(s(r,o[0]),wa(i,r,o))}),i},La=JSON.stringify,Ra=JSON.parse,Pa=/^\d+$/,Ma=oa(),_a=oa(),Fa=(a,t,n,s,i,r,o,c={},u=0,d=[])=>{let v,p,m,$=0,f=0,h=0;ua(Ma,d,()=>0),ua(_a,d,()=>[]);const O=oa(),[D,L,R,P,M]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!ra(a)||!ra(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!ra(a)||!ra(t),t.setContent]:E("Store type not supported by this Persister"))(o,a,u),[_,F,U]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?T(a):null)??e+t++,t=>{Pa.test(t)&&g(a)<1e3&&C(a,t)}]})(),s=oa();return[(n,i,r,o=[],c=()=>[])=>{a??=Q;const l=t(1);return wa(s,l,[n,i,r,o,c]),ga(ya(i,r??[e],da),l),l},(t,n,...i)=>N(((a,t=[e])=>{const n=[],s=(a,e)=>e==g(t)?C(n,a):null===t[e]?I(a,a=>s(a,e+1)):N([t[e],null],t=>s(ca(a,t),e+1));return s(a,0),n})(t,n),t=>I(t,t=>ca(s,t)[0](a,...n??[],...i))),a=>w(ca(s,a),([,t,i])=>(ya(t,i??[e],void 0,t=>(S(t,a),b(t)?1:0)),wa(s,a),n(a),i)),t=>w(ca(s,t),([t,,e=[],n,s])=>{const i=(...r)=>{const o=g(r);o==g(e)?t(a,...r,...s(r)):l(e[o])?N(n[o]?.(...r)??[],a=>i(...r,a)):i(...r,e[o])};i()})]})(),j=a=>{a!=$&&($=a,F(O,void 0,$))},B=t=>{(D&&y(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},J=async a=>(2!=$&&(j(1),f++,await K(async()=>{await A(async()=>{const e=await t();y(e)?B(e):a?M(a):E("Content is not an array: "+e)},()=>{a&&M(a)}),j(0)})),Q),Y=async a=>(k(),await J(a),await A(async()=>p=await s(async(a,t)=>{t||a?2!=$&&(j(1),f++,B(t??a),j(0)):await J()}),r),Q),k=async()=>(p&&(await A(()=>i(p),r),p=void 0),Q),x=async a=>(1!=$&&(j(2),h++,await K(async()=>{await A(()=>n(L,a),r),j(0)})),Q),z=async()=>(G(),await x(),m=a.addDidFinishTransactionListener(()=>{const a=R();P(a)&&x(a)}),Q),G=async()=>(m&&(a.delListener(m),m=void 0),Q),H=async(a=!1)=>{const[t,e]=a?[G,k]:[k,G];return await t(),await e(),Q},K=async(...a)=>(C(ca(_a,d),...a),await(async()=>{if(!ca(Ma,d)){for(wa(Ma,d,1);!l(v=T(ca(_a,d)));)await A(v,r);wa(Ma,d,0)}})(),Q),Q={load:J,startAutoLoad:Y,stopAutoLoad:k,isAutoLoading:()=>!l(p),save:x,startAutoSave:z,stopAutoSave:G,isAutoSaving:()=>!l(m),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[z,Y]:[Y,z];return await e(a),await n(a),Q},stopAutoPersisting:H,getStatus:()=>$,addStatusListener:a=>_(a,O),delListener:t=>(U(t),a),schedule:K,getStore:()=>a,destroy:()=>(ca(_a,d).splice(0,void 0),H()),getStats:()=>({loads:f,saves:h}),...c};return q(Q)},Ua=(a,t,e,s,r,o=ja,c,w)=>{const u=oa();return[async()=>{u.clear(),$(await e(a,t),({tn:a,cn:t})=>ga(ua(u,a,da),t))},async(t,e,n)=>((a,t)=>O(ca(u,a),t))(t,e)?Z(h($(await a(B+G(t)+K(t,n)),a=>[a[e],w?na(ta(a,e),w):ta(a,e)]),([a,t])=>!l(a)&&!ra(t))):{},async(t,e,s,w,y,d=!1,g=i)=>{const v=da();na(s??{},a=>$(X(a??{}),a=>ga(v,a)));const E=D(v);if(!d&&y&&g==i&&f(E)&&O(u,t))return await a("DROP "+_+G(t)),void wa(u,t);const A=ca(u,t),N=da(D(A));if(f(E)||(O(u,t)?await p($([e,...E],async(n,s)=>{S(N,n)||(await a(F+G(t)+"ADD"+G(n)+r),0==s&&await a("CREATE UNIQUE INDEX pk ON "+G(t)+`(${G(e)})`),ga(A,n))})):(await a(z+G(t)+`(${G(e)}${r} PRIMARY KEY${m($(E,a=>n+G(a)+r))});`),wa(u,t,da([e,...E])))),await p([...!d&&w?$(D(N),async n=>{n!=e&&(await a(F+G(t)+"DROP"+G(n)),S(A,n))}):[]]),d)l(s)?await a(j+G(t)+K(t,g)):await p(ea(s,async(n,s)=>{l(n)?await a(j+G(t)+K(t,g)+`AND(${G(e)}=$1)`,[s]):f(E)||await o(a,t,e,X(n),{[s]:c?$(sa(n),c):sa(n)},A)}));else if(f(E))O(u,t)&&await a(j+G(t)+K(t,g));else{const n=h(D(ca(u,t)),a=>a!=e),i={},r=[];na(s??{},(a,t)=>{i[t]=$(n,t=>c?c(a?.[t]):a?.[t]),C(r,t)}),await o(a,t,e,n,i),await a(j+G(t)+K(t,g)+`AND${G(e)}NOT IN(${H(r)})`,r)}},async t=>{let e;return await a("BEGIN"),await A(async()=>e=await t(),s),await a("END"),e}]},ja=async(a,t,e,s,i)=>{const r=[1];await a("INSERT INTO"+G(t)+"("+((...a)=>m($(a,G),n))(e,...s)+")VALUES"+m(ea(i,a=>"($"+r[0]+++","+H(a,r)+")"),n)+"ON CONFLICT("+G(e)+")DO UPDATE SET"+m($(s,a=>G(a)+"=excluded."+G(a)),n),ea(i,(a,t)=>[t,...$(a,a=>a??null)]).flat())},Ba=(a,t,e,n,s,i,r,[o,c,l],w,u,y,d,g,v)=>{const[p,E,A,N]=Ua(t,w,u,s,g,v),m=Fa(a,()=>N(async()=>{return await p(),a=(await E(o,c))[L]?.[l]??"null",Ra(a,(a,t)=>""===t?void 0:t);var a}),a=>N(async()=>{var t;await p(),await A(o,c,{[L]:{[l]:(t=a()??null,La(t,(a,t)=>void 0===t?"":t))}},!0,!0)}),e,n,s,r,{[d]:()=>y,destroy:async()=>(await m.stopAutoPersisting(),i(),m)},0,y);return m},Ja=(a,t,e,n,s,i,r,[o,c,[w,u,y]],d,g,v,E,A,N,m,$)=>{const[f,C,T,O]=Ua(t,d,g,s,A,N,m,$),b=(a,t)=>p(la(c,async([e,n,s,i,r],o)=>{t&&!(o in a)||await T(e,n,a[o],s,i,t,r)})),D=async(a,t)=>u?await T(y,R,{[L]:a},!0,!0,t):null,I=Fa(a,()=>O(async()=>{await f();const a=await(async()=>Z(h(await p(la(o,async([a,t,e],n)=>[a,await C(n,t,e)])),a=>!ra(a[1]))))(),t=await(async()=>w?(await C(y,R))[L]:{})();return ra(a)&&l(t)?void 0:[a,t]}),(a,t)=>O(async()=>{if(await f(),l(t)){const[t,e]=a();await b(t),await D(e)}else await b(t[0],!0),await D(t[1],!0)}),e,n,s,r,{[E]:()=>v,destroy:async()=>(await I.stopAutoPersisting(),i(),I)},0,v);return I},Ya=(a,n,s,r,o,l,w,y,g,v,p="getDb",E)=>{let N,m,$;const f=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,l),[h,C,T,b]=(a=>{const e=(a=>aa(Da,u(a)?{[Aa]:a}:a??{}))(a),n=e[$a];if(e.mode==Ea){const a=e[Aa]??t;return[1,n,[a,e[Na]??R,e[ma]??pa],da(a)]}const{tables:{load:s={},save:r={}}={},values:o={}}=e,c=d(sa(aa(Ia,o)),0,ia(Ia)),l=c[2],w=da(l),y=da(l),g=Sa(s,{[ha]:null,[fa]:R,[ba]:i},ha,a=>O(y,a),a=>ga(w,a)),v=Sa(r,{[Ca]:null,[fa]:R,[Ta]:0,[Oa]:0,[ba]:null},Ca,(a,t)=>O(y,t),(a,t)=>ga(w,t));var p;return p=(a,t)=>t[4]??=ca(g,t[0])?.[2]??i,I(v,(a,t)=>p(0,a)),[0,n,[g,v,c],w]})(n);return(h?Ba:Ja)(a,f,a=>{let t;const e=()=>t=setInterval(()=>A(async()=>{const[{d:t,s:e,c:n}]=await f(P+` ${Y} d,${k} s,TOTAL_CHANGES() c FROM ${J}${Y} JOIN ${J}${k}`);t==N&&e==m&&n==$||(null!=N&&a(),N=t,m=e,$=n)}),1e3*C),n=()=>{N=m=$=null,c(t)},s=r(t=>{b.has(t)&&(n(),a(),e())});return e(),()=>{n(),o(s)}},a=>a(),w,y,g,T,D(b),async(a,t)=>await a(P+` t.name tn,c.name cn FROM ${x}list()t,${x}info(t.name)c ${M} t.schema='main'AND t.type IN('table','view')AND t.name IN(${H(t)})ORDER BY t.name,c.name`,t),v,p,e,E,a=>!0===a?1:!1===a?0:a,void 0)},ka="change",xa=(a,t,e,n,s)=>Ya(a,e,async(a,e=[])=>{return await(n=(n,s)=>t.all(a,e,(a,t)=>a?s(a):n(t)),new o(n));var n},a=>{const e=(t,e,n)=>a(n);return t.on(ka,e),e},a=>t.off(ka,a),n,s,v,3,t);export{xa as createSqlite3Persister};
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,u=a=>void 0===a,y=a=>null===a,d=c(w),v=c(u),g=t=>a(t)==s,p=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)}},h=(a,t)=>a.forEach(t),C=(a,t="")=>a.join(t),T=(a,t)=>a.map(t),O=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=>u(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",K="pragma_table_",Q="CREATE "+B,V=a=>C(T(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${r(a,/"/g,'""')}"`),"."),W=(a,t=[1])=>C(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.keys,ea=q.freeze,na=(a=[])=>q.fromEntries(a),sa=(...a)=>q.assign({},...a),ia=(a,t)=>(delete a[t],a),ra=(a,t)=>T(aa(a),([a,e])=>t(e,a)),oa=(a,t)=>na(ra(a,(a,e)=>[e,t(a,e)])),ca=a=>q.values(a),la=a=>A(ta(a)),wa=a=>(a=>!w(a)&&d(Z(a),a=>a==q.prototype||w(Z(a)),()=>!0))(a)&&0==la(a),ua=a=>new Map(a),ya=(a,t)=>a?.get(t),da=(a,t)=>T([...a?.entries()??[]],([a,e])=>t(e,a)),va=(a,t,e)=>void 0===e?(M(a,t),a):a?.set(t,e),ga=(a,t,e,n)=>(S(a,t)?n?.(ya(a,t)):va(a,t,e()),ya(a,t)),pa=(a,t,e,n,s=0)=>v((e?ga:ya)(a,t[s],s>A(t)-2?e:ua),i=>{if(s>A(t)-2)return n?.(i)&&va(a,t[s]),i;const r=pa(i,t,e,n,s+1);return L(i)&&va(a,t[s]),r}),Ea=a=>new Set(p(a)||u(a)?a:[a]),Aa=(a,t)=>a?.add(t),Na="ColumnName",ma="store",$a="json",fa=ma+"TableName",ha=ma+"Id"+Na,Ca=ma+Na,Ta="autoLoadIntervalSeconds",Oa="rowId"+Na,ba="tableId",Da="tableName",Ia="deleteEmptyColumns",Sa="deleteEmptyTable",La="condition",Ra={mode:$a,[Ta]:1},Pa={load:0,save:0,[Da]:t+"_values"},Ma=(a,t,e,n,s)=>{const i=ua();return oa(a,(a,r)=>{const o=E(ca(sa(t,g(a)?{[e]:a}:a)),0,la(t));y(o[0])||n(r,o[0])||(s(r,o[0]),va(i,r,o))}),i},_a=JSON.stringify,Fa=JSON.parse,Ua=/^\d+$/,ja=ua(),Ba=ua(),Ja=(a,t,n,s,i,r,o,c={},l=0,w=[])=>{let d,g,E,N=0,m=0,C=0;ga(ja,w,()=>0),ga(Ba,w,()=>[]);const T=ua(),[O,b,S,R,_]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!wa(a)||!wa(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!wa(a)||!wa(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=>{Ua.test(t)&&A(a)<1e3&&D(a,t)}]})(),s=ua();return[(n,i,r,o=[],c=()=>[])=>{a??=V;const l=t(1);return va(s,l,[n,i,r,o,c]),Aa(pa(i,r??[e],Ea),l),l},(t,n,...i)=>h(((a,t=[e])=>{const n=[],s=(a,e)=>e==A(t)?D(n,a):null===t[e]?P(a,a=>s(a,e+1)):h([t[e],null],t=>s(ya(a,t),e+1));return s(a,0),n})(t,n),t=>P(t,t=>ya(s,t)[0](a,...n??[],...i))),a=>v(ya(s,a),([,t,i])=>(pa(t,i??[e],void 0,t=>(M(t,a),L(t)?1:0)),va(s,a),n(a),i)),t=>v(ya(s,t),([t,,e=[],n,s])=>{const i=(...r)=>{const o=A(r);o==A(e)?t(a,...r,...s(r)):y(e[o])?h(n[o]?.(...r)??[],a=>i(...r,a)):i(...r,e[o])};i()})]})(),B=a=>{a!=N&&(N=a,U(T,void 0,N))},J=t=>{(O&&p(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},Y=async a=>(2!=N&&(B(1),m++,await Q(async()=>{await f(async()=>{const e=await t();p(e)?J(e):a?_(a):$("Content is not an array: "+e)},()=>{a&&_(a)}),B(0)})),V),k=async a=>(x(),await Y(a),await f(async()=>g=await s(async(a,t)=>{t||a?2!=N&&(B(1),m++,J(t??a),B(0)):await Y()}),r),V),x=async()=>(g&&(await f(()=>i(g),r),g=void 0),V),z=async a=>(1!=N&&(B(2),C++,await Q(async()=>{await f(()=>n(b,a),r),B(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,x]:[x,H];return await t(),await e(),V},Q=async(...a)=>(D(ya(Ba,w),...a),await(async()=>{if(!ya(ja,w)){for(va(ja,w,1);!u(d=I(ya(Ba,w)));)await f(d,r);va(ja,w,0)}})(),V),V={load:Y,startAutoLoad:k,stopAutoLoad:x,isAutoLoading:()=>!u(g),save:z,startAutoSave:G,stopAutoSave:H,isAutoSaving:()=>!u(E),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[G,k]:[k,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:()=>(ya(Ba,w).splice(0,void 0),K()),getStats:()=>({loads:m,saves:C}),...c};return ea(V)},Ya=(a,t,e,s,r,o=ka,c,l)=>{const w=ua();return[async()=>{w.clear(),T(await e(a,t),({tn:a,cn:t})=>Aa(ga(w,a,Ea),t))},async(t,e,n)=>((a,t)=>S(ya(w,a),t))(t,e)?na(b(T(await a(x+V(t)+X(t,n)),a=>[a[e],l?oa(ia(a,e),l):ia(a,e)]),([a,t])=>!u(a)&&!wa(t))):{},async(t,e,s,l,y,d=!1,v=i)=>{const g=Ea();oa(s??{},a=>T(ta(a??{}),a=>Aa(g,a)));const p=R(g);if(!d&&y&&v==i&&O(p)&&S(w,t))return await a("DROP "+B+V(t)),void va(w,t);const E=ya(w,t),A=Ea(R(E));if(O(p)||(S(w,t)?await m(T([e,...p],async(n,s)=>{M(A,n)||(await a(J+V(t)+"ADD"+V(n)+r),0==s&&await a("CREATE UNIQUE INDEX pk ON "+V(t)+`(${V(e)})`),Aa(E,n))})):(await a(Q+V(t)+`(${V(e)}${r} PRIMARY KEY${C(T(p,a=>n+V(a)+r))});`),va(w,t,Ea([e,...p])))),await m([...!d&&l?T(R(A),async n=>{n!=e&&(await a(J+V(t)+"DROP"+V(n)),M(E,n))}):[]]),d)u(s)?await a(k+V(t)+X(t,v)):await m(ra(s,async(n,s)=>{u(n)?await a(k+V(t)+X(t,v)+`AND(${V(e)}=$1)`,[s]):O(p)||await o(a,t,e,ta(n),{[s]:c?T(ca(n),c):ca(n)},E)}));else if(O(p))S(w,t)&&await a(k+V(t)+X(t,v));else{const n=b(R(ya(w,t)),a=>a!=e),i={},r=[];oa(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(k+V(t)+X(t,v)+`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}]},ka=async(a,t,e,s,i)=>{const r=[1];await a("INSERT INTO"+V(t)+"("+((...a)=>C(T(a,V),n))(e,...s)+")VALUES"+C(ra(i,a=>"($"+r[0]+++","+W(a,r)+")"),n)+"ON CONFLICT("+V(e)+")DO UPDATE SET"+C(T(s,a=>V(a)+"=excluded."+V(a)),n),ra(i,(a,t)=>[t,...T(a,a=>a??null)]).flat())},xa=(a,t,e,n,s,i,r,[o,c,l],w,u,y,d,v,g)=>{const[p,E,A,N]=Ya(t,w,u,s,v,g),m=Ja(a,()=>N(async()=>{return await p(),a=(await E(o,c))[_]?.[l]??"null",Fa(a,(a,t)=>""===t?void 0:t);var a}),a=>N(async()=>{var t;await p(),await A(o,c,{[_]:{[l]:(t=a()??null,_a(t,(a,t)=>void 0===t?"":t))}},!0,!0)}),e,n,s,r,{[d]:()=>y,destroy:async()=>(await m.stopAutoPersisting(),i(),m)},0,y);return m},za=(a,t,e,n,s,i,r,[o,c,[l,w,y]],d,v,g,p,E,A,N,$)=>{const[f,h,C,T]=Ya(t,d,v,s,E,A,N,$),O=(a,t)=>m(da(c,async([e,n,s,i,r],o)=>{t&&!(o in a)||await C(e,n,a[o],s,i,t,r)})),D=async(a,t)=>w?await C(y,F,{[_]:a},!0,!0,t):null,I=Ja(a,()=>T(async()=>{await f();const a=await(async()=>na(b(await m(da(o,async([a,t,e],n)=>[a,await h(n,t,e)])),a=>!wa(a[1]))))(),t=await(async()=>l?(await h(y,F))[_]:{})();return wa(a)&&u(t)?void 0:[a,t]}),(a,t)=>T(async()=>{if(await f(),u(t)){const[t,e]=a();await O(t),await D(e)}else await O(t[0],!0),await D(t[1],!0)}),e,n,s,r,{[p]:()=>g,destroy:async()=>(await I.stopAutoPersisting(),i(),I)},0,g);return I},Ga=(a,n,s,r,o,c,u,y,d,v,p="getDb",A)=>{let N,m,$;const h=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,c),[C,T,O,b]=(a=>{const e=(a=>sa(Ra,g(a)?{[fa]:a}:a??{}))(a),n=e[Ta];if(e.mode==$a){const a=e[fa]??t;return[1,n,[a,e[ha]??F,e[Ca]??ma],Ea(a)]}const{tables:{load:s={},save:r={}}={},values:o={}}=e,c=E(ca(sa(Pa,o)),0,la(Pa)),l=c[2],w=Ea(l),u=Ea(l),y=Ma(s,{[ba]:null,[Oa]:F,[La]:i},ba,a=>S(u,a),a=>Aa(w,a)),d=Ma(r,{[Da]:null,[Oa]:F,[Ia]:0,[Sa]:0,[La]:null},Da,(a,t)=>S(u,t),(a,t)=>Aa(w,t));var v;return v=(a,t)=>t[4]??=ya(y,t[0])?.[2]??i,P(d,(a,t)=>v(0,a)),[0,n,[y,d,c],w]})(n);return(C?xa:za)(a,h,a=>{let t;const e=()=>t=setInterval(()=>f(async()=>{const[{d:t,s:e,c:n}]=await h(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(),u,y,d,O,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),v,p,e,A,a=>!0===a?1:!1===a?0:a,void 0)},Ha="change",Ka=(a,t,e,n,s)=>Ga(a,e,async(a,e=[])=>{return await(n=(n,s)=>t.all(a,e,(a,t)=>a?s(a):n(t)),new o(n));var n},a=>{const e=(t,e,n)=>a(n);return t.on(Ha,e),e},a=>t.off(Ha,a),n,s,N,3,t);export{Ka as createSqlite3Persister};
@@ -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=clearInterval,l=a=>null==a,w=(a,t,e)=>l(a)?e?.():t(a),u=t=>a(t)==s,y=a=>Array.isArray(a),d=(a,t,e)=>a.slice(t,e),g=a=>a.length,v=()=>{},p=async a=>o.all(a),E=a=>{throw Error(a)},A=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},N=(a,t)=>a.forEach(t),m=(a,t="")=>a.join(t),$=(a,t)=>a.map(t),f=a=>0==g(a),h=(a,t)=>a.filter(t),C=(a,...t)=>a.push(...t),T=a=>a.shift(),O=(a,t)=>a?.has(t)??!1,b=a=>l(a)||0==(a=>a?.size??0)(a),D=a=>[...a?.values()??[]],I=(a,t)=>a?.forEach(t),S=(a,t)=>a?.delete(t),L="_",R="_id",P="SELECT",M="WHERE",_="TABLE",F="ALTER "+_,U="FROM",j="DELETE "+U,B=P+"*"+U,J="pragma_",Y="data_version",k="schema_version",x="pragma_table_",z="CREATE "+_,G=a=>m($(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${r(a,/"/g,'""')}"`),"."),H=(a,t=[1])=>m($(a,()=>"$"+t[0]++),n),K=(a,t=i)=>M+`(${r(t,"$tableName",G(a))})`,Q=Object,V=a=>Q.getPrototypeOf(a),W=Q.entries,X=Q.keys,q=Q.freeze,Z=(a=[])=>Q.fromEntries(a),aa=(...a)=>Q.assign({},...a),ta=(a,t)=>(delete a[t],a),ea=(a,t)=>$(W(a),([a,e])=>t(e,a)),na=(a,t)=>Z(ea(a,(a,e)=>[e,t(a,e)])),sa=a=>Q.values(a),ia=a=>g(X(a)),ra=a=>(a=>!l(a)&&w(V(a),a=>a==Q.prototype||l(V(a)),()=>!0))(a)&&0==ia(a),oa=a=>new Map(a),ca=(a,t)=>a?.get(t),la=(a,t)=>$([...a?.entries()??[]],([a,e])=>t(e,a)),wa=(a,t,e)=>l(e)?(S(a,t),a):a?.set(t,e),ua=(a,t,e,n)=>(O(a,t)?n?.(ca(a,t)):wa(a,t,e()),ca(a,t)),ya=(a,t,e,n,s=0)=>w((e?ua:ca)(a,t[s],s>g(t)-2?e:oa),i=>{if(s>g(t)-2)return n?.(i)&&wa(a,t[s]),i;const r=ya(i,t,e,n,s+1);return b(i)&&wa(a,t[s]),r}),da=a=>new Set(y(a)||l(a)?a:[a]),ga=(a,t)=>a?.add(t),va="ColumnName",pa="store",Ea="json",Aa=pa+"TableName",Na=pa+"Id"+va,ma=pa+va,$a="autoLoadIntervalSeconds",fa="rowId"+va,ha="tableId",Ca="tableName",Ta="deleteEmptyColumns",Oa="deleteEmptyTable",ba="condition",Da={mode:Ea,[$a]:1},Ia={load:0,save:0,[Ca]:t+"_values"},Sa=(a,t,e,n,s)=>{const i=oa();return na(a,(a,r)=>{const o=d(sa(aa(t,u(a)?{[e]:a}:a)),0,ia(t));l(o[0])||n(r,o[0])||(s(r,o[0]),wa(i,r,o))}),i},La=JSON.stringify,Ra=JSON.parse,Pa=/^\d+$/,Ma=oa(),_a=oa(),Fa=(a,t,n,s,i,r,o,c={},u=0,d=[])=>{let v,p,m,$=0,f=0,h=0;ua(Ma,d,()=>0),ua(_a,d,()=>[]);const O=oa(),[D,L,R,P,M]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!ra(a)||!ra(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!ra(a)||!ra(t),t.setContent]:E("Store type not supported by this Persister"))(o,a,u),[_,F,U]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?T(a):null)??e+t++,t=>{Pa.test(t)&&g(a)<1e3&&C(a,t)}]})(),s=oa();return[(n,i,r,o=[],c=()=>[])=>{a??=Q;const l=t(1);return wa(s,l,[n,i,r,o,c]),ga(ya(i,r??[e],da),l),l},(t,n,...i)=>N(((a,t=[e])=>{const n=[],s=(a,e)=>e==g(t)?C(n,a):null===t[e]?I(a,a=>s(a,e+1)):N([t[e],null],t=>s(ca(a,t),e+1));return s(a,0),n})(t,n),t=>I(t,t=>ca(s,t)[0](a,...n??[],...i))),a=>w(ca(s,a),([,t,i])=>(ya(t,i??[e],void 0,t=>(S(t,a),b(t)?1:0)),wa(s,a),n(a),i)),t=>w(ca(s,t),([t,,e=[],n,s])=>{const i=(...r)=>{const o=g(r);o==g(e)?t(a,...r,...s(r)):l(e[o])?N(n[o]?.(...r)??[],a=>i(...r,a)):i(...r,e[o])};i()})]})(),j=a=>{a!=$&&($=a,F(O,void 0,$))},B=t=>{(D&&y(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},J=async a=>(2!=$&&(j(1),f++,await K(async()=>{await A(async()=>{const e=await t();y(e)?B(e):a?M(a):E("Content is not an array: "+e)},()=>{a&&M(a)}),j(0)})),Q),Y=async a=>(k(),await J(a),await A(async()=>p=await s(async(a,t)=>{t||a?2!=$&&(j(1),f++,B(t??a),j(0)):await J()}),r),Q),k=async()=>(p&&(await A(()=>i(p),r),p=void 0),Q),x=async a=>(1!=$&&(j(2),h++,await K(async()=>{await A(()=>n(L,a),r),j(0)})),Q),z=async()=>(G(),await x(),m=a.addDidFinishTransactionListener(()=>{const a=R();P(a)&&x(a)}),Q),G=async()=>(m&&(a.delListener(m),m=void 0),Q),H=async(a=!1)=>{const[t,e]=a?[G,k]:[k,G];return await t(),await e(),Q},K=async(...a)=>(C(ca(_a,d),...a),await(async()=>{if(!ca(Ma,d)){for(wa(Ma,d,1);!l(v=T(ca(_a,d)));)await A(v,r);wa(Ma,d,0)}})(),Q),Q={load:J,startAutoLoad:Y,stopAutoLoad:k,isAutoLoading:()=>!l(p),save:x,startAutoSave:z,stopAutoSave:G,isAutoSaving:()=>!l(m),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[z,Y]:[Y,z];return await e(a),await n(a),Q},stopAutoPersisting:H,getStatus:()=>$,addStatusListener:a=>_(a,O),delListener:t=>(U(t),a),schedule:K,getStore:()=>a,destroy:()=>(ca(_a,d).splice(0,void 0),H()),getStats:()=>({loads:f,saves:h}),...c};return q(Q)},Ua=(a,t,e,s,r,o=ja,c,w)=>{const u=oa();return[async()=>{u.clear(),$(await e(a,t),({tn:a,cn:t})=>ga(ua(u,a,da),t))},async(t,e,n)=>((a,t)=>O(ca(u,a),t))(t,e)?Z(h($(await a(B+G(t)+K(t,n)),a=>[a[e],w?na(ta(a,e),w):ta(a,e)]),([a,t])=>!l(a)&&!ra(t))):{},async(t,e,s,w,y,d=!1,g=i)=>{const v=da();na(s??{},a=>$(X(a??{}),a=>ga(v,a)));const E=D(v);if(!d&&y&&g==i&&f(E)&&O(u,t))return await a("DROP "+_+G(t)),void wa(u,t);const A=ca(u,t),N=da(D(A));if(f(E)||(O(u,t)?await p($([e,...E],async(n,s)=>{S(N,n)||(await a(F+G(t)+"ADD"+G(n)+r),0==s&&await a("CREATE UNIQUE INDEX pk ON "+G(t)+`(${G(e)})`),ga(A,n))})):(await a(z+G(t)+`(${G(e)}${r} PRIMARY KEY${m($(E,a=>n+G(a)+r))});`),wa(u,t,da([e,...E])))),await p([...!d&&w?$(D(N),async n=>{n!=e&&(await a(F+G(t)+"DROP"+G(n)),S(A,n))}):[]]),d)l(s)?await a(j+G(t)+K(t,g)):await p(ea(s,async(n,s)=>{l(n)?await a(j+G(t)+K(t,g)+`AND(${G(e)}=$1)`,[s]):f(E)||await o(a,t,e,X(n),{[s]:c?$(sa(n),c):sa(n)},A)}));else if(f(E))O(u,t)&&await a(j+G(t)+K(t,g));else{const n=h(D(ca(u,t)),a=>a!=e),i={},r=[];na(s??{},(a,t)=>{i[t]=$(n,t=>c?c(a?.[t]):a?.[t]),C(r,t)}),await o(a,t,e,n,i),await a(j+G(t)+K(t,g)+`AND${G(e)}NOT IN(${H(r)})`,r)}},async t=>{let e;return await a("BEGIN"),await A(async()=>e=await t(),s),await a("END"),e}]},ja=async(a,t,e,s,i)=>{const r=[1];await a("INSERT INTO"+G(t)+"("+((...a)=>m($(a,G),n))(e,...s)+")VALUES"+m(ea(i,a=>"($"+r[0]+++","+H(a,r)+")"),n)+"ON CONFLICT("+G(e)+")DO UPDATE SET"+m($(s,a=>G(a)+"=excluded."+G(a)),n),ea(i,(a,t)=>[t,...$(a,a=>a??null)]).flat())},Ba=(a,t,e,n,s,i,r,[o,c,l],w,u,y,d,g,v)=>{const[p,E,A,N]=Ua(t,w,u,s,g,v),m=Fa(a,()=>N(async()=>{return await p(),a=(await E(o,c))[L]?.[l]??"null",Ra(a,(a,t)=>""===t?void 0:t);var a}),a=>N(async()=>{var t;await p(),await A(o,c,{[L]:{[l]:(t=a()??null,La(t,(a,t)=>void 0===t?"":t))}},!0,!0)}),e,n,s,r,{[d]:()=>y,destroy:async()=>(await m.stopAutoPersisting(),i(),m)},0,y);return m},Ja=(a,t,e,n,s,i,r,[o,c,[w,u,y]],d,g,v,E,A,N,m,$)=>{const[f,C,T,O]=Ua(t,d,g,s,A,N,m,$),b=(a,t)=>p(la(c,async([e,n,s,i,r],o)=>{t&&!(o in a)||await T(e,n,a[o],s,i,t,r)})),D=async(a,t)=>u?await T(y,R,{[L]:a},!0,!0,t):null,I=Fa(a,()=>O(async()=>{await f();const a=await(async()=>Z(h(await p(la(o,async([a,t,e],n)=>[a,await C(n,t,e)])),a=>!ra(a[1]))))(),t=await(async()=>w?(await C(y,R))[L]:{})();return ra(a)&&l(t)?void 0:[a,t]}),(a,t)=>O(async()=>{if(await f(),l(t)){const[t,e]=a();await b(t),await D(e)}else await b(t[0],!0),await D(t[1],!0)}),e,n,s,r,{[E]:()=>v,destroy:async()=>(await I.stopAutoPersisting(),i(),I)},0,v);return I},Ya=(a,n,s,r,o,l,w,y,g,v,p="getDb",E)=>{let N,m,$;const f=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,l),[h,C,T,b]=(a=>{const e=(a=>aa(Da,u(a)?{[Aa]:a}:a??{}))(a),n=e[$a];if(e.mode==Ea){const a=e[Aa]??t;return[1,n,[a,e[Na]??R,e[ma]??pa],da(a)]}const{tables:{load:s={},save:r={}}={},values:o={}}=e,c=d(sa(aa(Ia,o)),0,ia(Ia)),l=c[2],w=da(l),y=da(l),g=Sa(s,{[ha]:null,[fa]:R,[ba]:i},ha,a=>O(y,a),a=>ga(w,a)),v=Sa(r,{[Ca]:null,[fa]:R,[Ta]:0,[Oa]:0,[ba]:null},Ca,(a,t)=>O(y,t),(a,t)=>ga(w,t));var p;return p=(a,t)=>t[4]??=ca(g,t[0])?.[2]??i,I(v,(a,t)=>p(0,a)),[0,n,[g,v,c],w]})(n);return(h?Ba:Ja)(a,f,a=>{let t;const e=()=>t=setInterval(()=>A(async()=>{const[{d:t,s:e,c:n}]=await f(P+` ${Y} d,${k} s,TOTAL_CHANGES() c FROM ${J}${Y} JOIN ${J}${k}`);t==N&&e==m&&n==$||(null!=N&&a(),N=t,m=e,$=n)}),1e3*C),n=()=>{N=m=$=null,c(t)},s=r(t=>{b.has(t)&&(n(),a(),e())});return e(),()=>{n(),o(s)}},a=>a(),w,y,g,T,D(b),async(a,t)=>await a(P+` t.name tn,c.name cn FROM ${x}list()t,${x}info(t.name)c ${M} t.schema='main'AND t.type IN('table','view')AND t.name IN(${H(t)})ORDER BY t.name,c.name`,t),v,p,e,E,a=>!0===a?1:!1===a?0:a,void 0)},ka="change",xa=(a,t,e,n,s)=>Ya(a,e,async(a,e=[])=>{return await(n=(n,s)=>t.all(a,e,(a,t)=>a?s(a):n(t)),new o(n));var n},a=>{const e=(t,e,n)=>a(n);return t.on(ka,e),e},a=>t.off(ka,a),n,s,v,3,t);export{xa as createSqlite3Persister};
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,u=a=>void 0===a,y=a=>null===a,d=c(w),v=c(u),g=t=>a(t)==s,p=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)}},h=(a,t)=>a.forEach(t),C=(a,t="")=>a.join(t),T=(a,t)=>a.map(t),O=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=>u(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",K="pragma_table_",Q="CREATE "+B,V=a=>C(T(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${r(a,/"/g,'""')}"`),"."),W=(a,t=[1])=>C(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.keys,ea=q.freeze,na=(a=[])=>q.fromEntries(a),sa=(...a)=>q.assign({},...a),ia=(a,t)=>(delete a[t],a),ra=(a,t)=>T(aa(a),([a,e])=>t(e,a)),oa=(a,t)=>na(ra(a,(a,e)=>[e,t(a,e)])),ca=a=>q.values(a),la=a=>A(ta(a)),wa=a=>(a=>!w(a)&&d(Z(a),a=>a==q.prototype||w(Z(a)),()=>!0))(a)&&0==la(a),ua=a=>new Map(a),ya=(a,t)=>a?.get(t),da=(a,t)=>T([...a?.entries()??[]],([a,e])=>t(e,a)),va=(a,t,e)=>void 0===e?(M(a,t),a):a?.set(t,e),ga=(a,t,e,n)=>(S(a,t)?n?.(ya(a,t)):va(a,t,e()),ya(a,t)),pa=(a,t,e,n,s=0)=>v((e?ga:ya)(a,t[s],s>A(t)-2?e:ua),i=>{if(s>A(t)-2)return n?.(i)&&va(a,t[s]),i;const r=pa(i,t,e,n,s+1);return L(i)&&va(a,t[s]),r}),Ea=a=>new Set(p(a)||u(a)?a:[a]),Aa=(a,t)=>a?.add(t),Na="ColumnName",ma="store",$a="json",fa=ma+"TableName",ha=ma+"Id"+Na,Ca=ma+Na,Ta="autoLoadIntervalSeconds",Oa="rowId"+Na,ba="tableId",Da="tableName",Ia="deleteEmptyColumns",Sa="deleteEmptyTable",La="condition",Ra={mode:$a,[Ta]:1},Pa={load:0,save:0,[Da]:t+"_values"},Ma=(a,t,e,n,s)=>{const i=ua();return oa(a,(a,r)=>{const o=E(ca(sa(t,g(a)?{[e]:a}:a)),0,la(t));y(o[0])||n(r,o[0])||(s(r,o[0]),va(i,r,o))}),i},_a=JSON.stringify,Fa=JSON.parse,Ua=/^\d+$/,ja=ua(),Ba=ua(),Ja=(a,t,n,s,i,r,o,c={},l=0,w=[])=>{let d,g,E,N=0,m=0,C=0;ga(ja,w,()=>0),ga(Ba,w,()=>[]);const T=ua(),[O,b,S,R,_]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!wa(a)||!wa(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!wa(a)||!wa(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=>{Ua.test(t)&&A(a)<1e3&&D(a,t)}]})(),s=ua();return[(n,i,r,o=[],c=()=>[])=>{a??=V;const l=t(1);return va(s,l,[n,i,r,o,c]),Aa(pa(i,r??[e],Ea),l),l},(t,n,...i)=>h(((a,t=[e])=>{const n=[],s=(a,e)=>e==A(t)?D(n,a):null===t[e]?P(a,a=>s(a,e+1)):h([t[e],null],t=>s(ya(a,t),e+1));return s(a,0),n})(t,n),t=>P(t,t=>ya(s,t)[0](a,...n??[],...i))),a=>v(ya(s,a),([,t,i])=>(pa(t,i??[e],void 0,t=>(M(t,a),L(t)?1:0)),va(s,a),n(a),i)),t=>v(ya(s,t),([t,,e=[],n,s])=>{const i=(...r)=>{const o=A(r);o==A(e)?t(a,...r,...s(r)):y(e[o])?h(n[o]?.(...r)??[],a=>i(...r,a)):i(...r,e[o])};i()})]})(),B=a=>{a!=N&&(N=a,U(T,void 0,N))},J=t=>{(O&&p(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},Y=async a=>(2!=N&&(B(1),m++,await Q(async()=>{await f(async()=>{const e=await t();p(e)?J(e):a?_(a):$("Content is not an array: "+e)},()=>{a&&_(a)}),B(0)})),V),k=async a=>(x(),await Y(a),await f(async()=>g=await s(async(a,t)=>{t||a?2!=N&&(B(1),m++,J(t??a),B(0)):await Y()}),r),V),x=async()=>(g&&(await f(()=>i(g),r),g=void 0),V),z=async a=>(1!=N&&(B(2),C++,await Q(async()=>{await f(()=>n(b,a),r),B(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,x]:[x,H];return await t(),await e(),V},Q=async(...a)=>(D(ya(Ba,w),...a),await(async()=>{if(!ya(ja,w)){for(va(ja,w,1);!u(d=I(ya(Ba,w)));)await f(d,r);va(ja,w,0)}})(),V),V={load:Y,startAutoLoad:k,stopAutoLoad:x,isAutoLoading:()=>!u(g),save:z,startAutoSave:G,stopAutoSave:H,isAutoSaving:()=>!u(E),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[G,k]:[k,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:()=>(ya(Ba,w).splice(0,void 0),K()),getStats:()=>({loads:m,saves:C}),...c};return ea(V)},Ya=(a,t,e,s,r,o=ka,c,l)=>{const w=ua();return[async()=>{w.clear(),T(await e(a,t),({tn:a,cn:t})=>Aa(ga(w,a,Ea),t))},async(t,e,n)=>((a,t)=>S(ya(w,a),t))(t,e)?na(b(T(await a(x+V(t)+X(t,n)),a=>[a[e],l?oa(ia(a,e),l):ia(a,e)]),([a,t])=>!u(a)&&!wa(t))):{},async(t,e,s,l,y,d=!1,v=i)=>{const g=Ea();oa(s??{},a=>T(ta(a??{}),a=>Aa(g,a)));const p=R(g);if(!d&&y&&v==i&&O(p)&&S(w,t))return await a("DROP "+B+V(t)),void va(w,t);const E=ya(w,t),A=Ea(R(E));if(O(p)||(S(w,t)?await m(T([e,...p],async(n,s)=>{M(A,n)||(await a(J+V(t)+"ADD"+V(n)+r),0==s&&await a("CREATE UNIQUE INDEX pk ON "+V(t)+`(${V(e)})`),Aa(E,n))})):(await a(Q+V(t)+`(${V(e)}${r} PRIMARY KEY${C(T(p,a=>n+V(a)+r))});`),va(w,t,Ea([e,...p])))),await m([...!d&&l?T(R(A),async n=>{n!=e&&(await a(J+V(t)+"DROP"+V(n)),M(E,n))}):[]]),d)u(s)?await a(k+V(t)+X(t,v)):await m(ra(s,async(n,s)=>{u(n)?await a(k+V(t)+X(t,v)+`AND(${V(e)}=$1)`,[s]):O(p)||await o(a,t,e,ta(n),{[s]:c?T(ca(n),c):ca(n)},E)}));else if(O(p))S(w,t)&&await a(k+V(t)+X(t,v));else{const n=b(R(ya(w,t)),a=>a!=e),i={},r=[];oa(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(k+V(t)+X(t,v)+`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}]},ka=async(a,t,e,s,i)=>{const r=[1];await a("INSERT INTO"+V(t)+"("+((...a)=>C(T(a,V),n))(e,...s)+")VALUES"+C(ra(i,a=>"($"+r[0]+++","+W(a,r)+")"),n)+"ON CONFLICT("+V(e)+")DO UPDATE SET"+C(T(s,a=>V(a)+"=excluded."+V(a)),n),ra(i,(a,t)=>[t,...T(a,a=>a??null)]).flat())},xa=(a,t,e,n,s,i,r,[o,c,l],w,u,y,d,v,g)=>{const[p,E,A,N]=Ya(t,w,u,s,v,g),m=Ja(a,()=>N(async()=>{return await p(),a=(await E(o,c))[_]?.[l]??"null",Fa(a,(a,t)=>""===t?void 0:t);var a}),a=>N(async()=>{var t;await p(),await A(o,c,{[_]:{[l]:(t=a()??null,_a(t,(a,t)=>void 0===t?"":t))}},!0,!0)}),e,n,s,r,{[d]:()=>y,destroy:async()=>(await m.stopAutoPersisting(),i(),m)},0,y);return m},za=(a,t,e,n,s,i,r,[o,c,[l,w,y]],d,v,g,p,E,A,N,$)=>{const[f,h,C,T]=Ya(t,d,v,s,E,A,N,$),O=(a,t)=>m(da(c,async([e,n,s,i,r],o)=>{t&&!(o in a)||await C(e,n,a[o],s,i,t,r)})),D=async(a,t)=>w?await C(y,F,{[_]:a},!0,!0,t):null,I=Ja(a,()=>T(async()=>{await f();const a=await(async()=>na(b(await m(da(o,async([a,t,e],n)=>[a,await h(n,t,e)])),a=>!wa(a[1]))))(),t=await(async()=>l?(await h(y,F))[_]:{})();return wa(a)&&u(t)?void 0:[a,t]}),(a,t)=>T(async()=>{if(await f(),u(t)){const[t,e]=a();await O(t),await D(e)}else await O(t[0],!0),await D(t[1],!0)}),e,n,s,r,{[p]:()=>g,destroy:async()=>(await I.stopAutoPersisting(),i(),I)},0,g);return I},Ga=(a,n,s,r,o,c,u,y,d,v,p="getDb",A)=>{let N,m,$;const h=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,c),[C,T,O,b]=(a=>{const e=(a=>sa(Ra,g(a)?{[fa]:a}:a??{}))(a),n=e[Ta];if(e.mode==$a){const a=e[fa]??t;return[1,n,[a,e[ha]??F,e[Ca]??ma],Ea(a)]}const{tables:{load:s={},save:r={}}={},values:o={}}=e,c=E(ca(sa(Pa,o)),0,la(Pa)),l=c[2],w=Ea(l),u=Ea(l),y=Ma(s,{[ba]:null,[Oa]:F,[La]:i},ba,a=>S(u,a),a=>Aa(w,a)),d=Ma(r,{[Da]:null,[Oa]:F,[Ia]:0,[Sa]:0,[La]:null},Da,(a,t)=>S(u,t),(a,t)=>Aa(w,t));var v;return v=(a,t)=>t[4]??=ya(y,t[0])?.[2]??i,P(d,(a,t)=>v(0,a)),[0,n,[y,d,c],w]})(n);return(C?xa:za)(a,h,a=>{let t;const e=()=>t=setInterval(()=>f(async()=>{const[{d:t,s:e,c:n}]=await h(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(),u,y,d,O,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),v,p,e,A,a=>!0===a?1:!1===a?0:a,void 0)},Ha="change",Ka=(a,t,e,n,s)=>Ga(a,e,async(a,e=[])=>{return await(n=(n,s)=>t.all(a,e,(a,t)=>a?s(a):n(t)),new o(n));var n},a=>{const e=(t,e,n)=>a(n);return t.on(Ha,e),e},a=>t.off(Ha,a),n,s,N,3,t);export{Ka as createSqlite3Persister};
@@ -1 +1 @@
1
- import{Map as t}from"yjs";const e="t",a="v",n=t=>null==t,s=(t,e,a)=>n(t)?a?.():e(t),o=t=>Array.isArray(t),r=t=>t.length,i=t=>{throw Error(t)},c=async(t,e,a)=>{try{return await t()}catch(t){e?.(t)}},l=(t,e)=>t.forEach(e),g=(t,...e)=>t.push(...e),u=t=>t.shift(),d=t=>n(t)||0==(t=>t?.size??0)(t),y=(t,e)=>t?.forEach(e),p=(t,e)=>t?.delete(e),w=Object,v=t=>w.getPrototypeOf(t),h=w.entries,f=w.keys,S=w.freeze,C=(t=[])=>w.fromEntries(t),b=(t,e)=>e in t,A=(t,e)=>C(((t,e)=>((t,e)=>t.map(e))(h(t),([t,a])=>e(a,t)))(t,(t,a)=>[a,e(t,a)])),M=t=>(t=>!n(t)&&s(v(t),t=>t==w.prototype||n(v(t)),()=>!0))(t)&&0==(t=>r(f(t)))(t),O=(t,e,a)=>(b(t,e)||(t[e]=a()),t[e]),L=t=>new Map(t),J=(t,e)=>t?.get(e),N=(t,e)=>y(t,(t,a)=>e(a,t)),z=(t,e,a)=>n(a)?(p(t,e),t):t?.set(e,a),D=(t,e,a,n)=>{var s,o;return s=t,o=e,s?.has(o)?n?.(J(t,e)):z(t,e,a()),J(t,e)},E=(t,e,a,n,o=0)=>s((a?D:J)(t,e[o],o>r(e)-2?a:L),s=>{if(o>r(e)-2)return n?.(s)&&z(t,e[o]),s;const i=E(s,e,a,n,o+1);return d(s)&&z(t,e[o]),i}),m=/^\d+$/,P=t=>new Set(o(t)||n(t)?t:[t]),T=L(),j=L(),k=(t,e,a,w,v,h,f,C={},b=0,A=[])=>{let O,N,k,x=0,F=0,Y=0;D(T,A,()=>0),D(j,A,()=>[]);const $=L(),[q,B,G,H,I]=((t=1,e,a)=>1!=t&&e.isMergeable()?[1,e.getMergeableContent,()=>e.getTransactionMergeableChanges(!a),([[t],[e]])=>!M(t)||!M(e),e.setDefaultContent]:2!=t?[0,e.getContent,e.getTransactionChanges,([t,e])=>!M(t)||!M(e),e.setContent]:i("Store type not supported by this Persister"))(f,t,b),[K,Q,R]=(()=>{let t;const[e,a]=(()=>{const t=[];let e=0;return[a=>(a?u(t):null)??""+e++,e=>{m.test(e)&&r(t)<1e3&&g(t,e)}]})(),o=L();return[(a,n,s,r=[],i=()=>[])=>{t??=st;const c=e(1);var l,g;return z(o,c,[a,n,s,r,i]),l=E(n,s??[""],P),g=c,l?.add(g),c},(e,a,...n)=>l(((t,e=[""])=>{const a=[],n=(t,s)=>s==r(e)?g(a,t):null===e[s]?y(t,t=>n(t,s+1)):l([e[s],null],e=>n(J(t,e),s+1));return n(t,0),a})(e,a),e=>y(e,e=>J(o,e)[0](t,...a??[],...n))),t=>s(J(o,t),([,e,n])=>(E(e,n??[""],void 0,e=>(p(e,t),d(e)?1:0)),z(o,t),a(t),n)),e=>s(J(o,e),([e,,a=[],s,o])=>{const i=(...c)=>{const g=r(c);g==r(a)?e(t,...c,...o(c)):n(a[g])?l(s[g]?.(...c)??[],t=>i(...c,t)):i(...c,a[g])};i()})]})(),U=t=>{t!=x&&(x=t,Q($,void 0,x))},V=e=>{(q&&o(e?.[0])?1===e?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===e?.[2]?t.applyChanges:t.setContent)(e)},W=async t=>(2!=x&&(U(1),F++,await nt(async()=>{await c(async()=>{const a=await e();o(a)?V(a):t?I(t):i("Content is not an array: "+a)},()=>{t&&I(t)}),U(0)})),st),X=async t=>(Z(),await W(t),await c(async()=>N=await w(async(t,e)=>{e||t?2!=x&&(U(1),F++,V(e??t),U(0)):await W()}),h),st),Z=async()=>(N&&(await c(()=>v(N),h),N=void 0),st),_=async t=>(1!=x&&(U(2),Y++,await nt(async()=>{await c(()=>a(B,t),h),U(0)})),st),tt=async()=>(et(),await _(),k=t.addDidFinishTransactionListener(()=>{const t=G();H(t)&&_(t)}),st),et=async()=>(k&&(t.delListener(k),k=void 0),st),at=async(t=!1)=>{const[e,a]=t?[et,Z]:[Z,et];return await e(),await a(),st},nt=async(...t)=>(g(J(j,A),...t),await(async()=>{if(!J(T,A)){for(z(T,A,1);!n(O=u(J(j,A)));)await c(O,h);z(T,A,0)}})(),st),st={load:W,startAutoLoad:X,stopAutoLoad:Z,isAutoLoading:()=>!n(N),save:_,startAutoSave:tt,stopAutoSave:et,isAutoSaving:()=>!n(k),startAutoPersisting:async(t,e=!1)=>{const[a,n]=e?[tt,X]:[X,tt];return await a(t),await n(t),st},stopAutoPersisting:at,getStatus:()=>x,addStatusListener:t=>K(t,$),delListener:e=>(R(e),t),schedule:nt,getStore:()=>t,destroy:()=>(J(j,A).splice(0,void 0),at()),getStats:()=>({loads:F,saves:Y}),...C};return S(st)},x="delete",F=t=>[t.get(e),t.get(a)],Y=(e,a,s,o)=>{const r=n(a)?e:e.get(a)??e.set(a,new t);let i;return A(s,(t,e)=>{o(r,e,t)&&(i=1)}),r.forEach((t,e)=>{b(s,e)||(r.delete(e),i=1)}),n(a)||r.size||e.delete(a),i},$=(o,i,c="tinybase",g)=>{const d=i.getMap(c);return k(o,async()=>d.size?[d.get(e).toJSON(),d.get(a).toJSON()]:void 0,async(o,r)=>i.transact(()=>((o,r,i)=>{o.size||(o.set(e,new t),o.set(a,new t));const[c,l]=F(o),g=()=>{u=1};let u=1;if(s(i,([t,e])=>{u=0,A(t,(t,e)=>u?0:n(t)?c.delete(e):s(c.get(e),e=>A(t,(t,a)=>u?0:n(t)?e.delete(a):s(e.get(a),e=>A(t,(t,a)=>n(t)?e.delete(a):e.set(a,t)),g)),g)),A(e,(t,e)=>u?0:n(t)?l.delete(e):l.set(e,t))}),u){const[t,e]=r();Y(c,void 0,t,(t,e,a)=>Y(c,e,a,(t,e,a)=>Y(t,e,a,(t,e,a)=>{if(t.get(e)!==a)return t.set(e,a),1}))),Y(l,void 0,e,(t,e,a)=>{l.get(e)!==a&&l.set(e,a)})}})(d,o,r)),t=>{const n=n=>t(void 0,((t,n)=>{if(1==r(n)&&(o=n[0].path,0==r(o)))return[t.get(e).toJSON(),t.get(a).toJSON(),1];var o;const[i,c]=F(t),g={},d={};return l(n,({path:t,changes:{keys:a}})=>u(t)==e?s(u(t),e=>{const n=O(g,e,C),o=i.get(e);s(u(t),t=>{const e=O(n,t,C),s=o.get(t);N(a,(t,{action:a})=>e[t]=a==x?null:s.get(t))},()=>N(a,(t,{action:e})=>n[t]=e==x?null:o.get(t)?.toJSON()))},()=>N(a,(t,{action:e})=>g[t]=e==x?null:i.get(t)?.toJSON())):N(a,(t,{action:e})=>d[t]=e==x?null:c.get(t))),[g,d,1]})(d,n));return d.observeDeep(n),n},t=>{d.unobserveDeep(t)},g,1,{getYDoc:()=>i})};export{$ as createYjsPersister};
1
+ import{Map as t}from"yjs";const e="t",a="v",n=t=>(e,a,n)=>t(e)?n?.():a(e),s=t=>null==t,o=t=>void 0===t,r=n(s),i=n(o),c=t=>Array.isArray(t),g=t=>t.length,d=t=>{throw Error(t)},l=async(t,e,a)=>{try{return await t()}catch(t){e?.(t)}},u=(t,e)=>t.forEach(e),y=(t,...e)=>t.push(...e),v=t=>t.shift(),p=t=>o(t)||0==(t=>t?.size??0)(t),w=(t,e)=>t?.forEach(e),h=(t,e)=>t?.delete(e),f=Object,S=t=>f.getPrototypeOf(t),C=f.entries,b=f.keys,A=f.freeze,M=(t=[])=>f.fromEntries(t),O=(t,e)=>e in t,L=(t,e)=>M(((t,e)=>((t,e)=>t.map(e))(C(t),([t,a])=>e(a,t)))(t,(t,a)=>[a,e(t,a)])),J=t=>(t=>!s(t)&&r(S(t),t=>t==f.prototype||s(S(t)),()=>!0))(t)&&0==(t=>g(b(t)))(t),N=(t,e,a)=>(O(t,e)||(t[e]=a()),t[e]),z=t=>new Map(t),D=(t,e)=>t?.get(e),E=(t,e)=>w(t,(t,a)=>e(a,t)),m=(t,e,a)=>void 0===a?(h(t,e),t):t?.set(e,a),P=(t,e,a,n)=>{var s,o;return s=t,o=e,s?.has(o)?n?.(D(t,e)):m(t,e,a()),D(t,e)},T=(t,e,a,n,s=0)=>i((a?P:D)(t,e[s],s>g(e)-2?a:z),o=>{if(s>g(e)-2)return n?.(o)&&m(t,e[s]),o;const r=T(o,e,a,n,s+1);return p(o)&&m(t,e[s]),r}),j=/^\d+$/,k=t=>new Set(c(t)||o(t)?t:[t]),x=z(),F=z(),Y=(t,e,a,n,s,r,f,S={},C=0,b=[])=>{let M,O,L,N=0,E=0,Y=0;P(x,b,()=>0),P(F,b,()=>[]);const $=z(),[q,B,G,H,I]=((t=1,e,a)=>1!=t&&e.isMergeable()?[1,e.getMergeableContent,()=>e.getTransactionMergeableChanges(!a),([[t],[e]])=>!J(t)||!J(e),e.setDefaultContent]:2!=t?[0,e.getContent,e.getTransactionChanges,([t,e])=>!J(t)||!J(e),e.setContent]:d("Store type not supported by this Persister"))(f,t,C),[K,Q,R]=(()=>{let t;const[e,a]=(()=>{const t=[];let e=0;return[a=>(a?v(t):null)??""+e++,e=>{j.test(e)&&g(t)<1e3&&y(t,e)}]})(),n=z();return[(a,s,o,r=[],i=()=>[])=>{t??=st;const c=e(1);var g,d;return m(n,c,[a,s,o,r,i]),g=T(s,o??[""],k),d=c,g?.add(d),c},(e,a,...s)=>u(((t,e=[""])=>{const a=[],n=(t,s)=>s==g(e)?y(a,t):null===e[s]?w(t,t=>n(t,s+1)):u([e[s],null],e=>n(D(t,e),s+1));return n(t,0),a})(e,a),e=>w(e,e=>D(n,e)[0](t,...a??[],...s))),t=>i(D(n,t),([,e,s])=>(T(e,s??[""],void 0,e=>(h(e,t),p(e)?1:0)),m(n,t),a(t),s)),e=>i(D(n,e),([e,,a=[],n,s])=>{const o=(...r)=>{const i=g(r);i==g(a)?e(t,...r,...s(r)):(t=>null===t)(a[i])?u(n[i]?.(...r)??[],t=>o(...r,t)):o(...r,a[i])};o()})]})(),U=t=>{t!=N&&(N=t,Q($,void 0,N))},V=e=>{(q&&c(e?.[0])?1===e?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===e?.[2]?t.applyChanges:t.setContent)(e)},W=async t=>(2!=N&&(U(1),E++,await nt(async()=>{await l(async()=>{const a=await e();c(a)?V(a):t?I(t):d("Content is not an array: "+a)},()=>{t&&I(t)}),U(0)})),st),X=async t=>(Z(),await W(t),await l(async()=>O=await n(async(t,e)=>{e||t?2!=N&&(U(1),E++,V(e??t),U(0)):await W()}),r),st),Z=async()=>(O&&(await l(()=>s(O),r),O=void 0),st),_=async t=>(1!=N&&(U(2),Y++,await nt(async()=>{await l(()=>a(B,t),r),U(0)})),st),tt=async()=>(et(),await _(),L=t.addDidFinishTransactionListener(()=>{const t=G();H(t)&&_(t)}),st),et=async()=>(L&&(t.delListener(L),L=void 0),st),at=async(t=!1)=>{const[e,a]=t?[et,Z]:[Z,et];return await e(),await a(),st},nt=async(...t)=>(y(D(F,b),...t),await(async()=>{if(!D(x,b)){for(m(x,b,1);!o(M=v(D(F,b)));)await l(M,r);m(x,b,0)}})(),st),st={load:W,startAutoLoad:X,stopAutoLoad:Z,isAutoLoading:()=>!o(O),save:_,startAutoSave:tt,stopAutoSave:et,isAutoSaving:()=>!o(L),startAutoPersisting:async(t,e=!1)=>{const[a,n]=e?[tt,X]:[X,tt];return await a(t),await n(t),st},stopAutoPersisting:at,getStatus:()=>N,addStatusListener:t=>K(t,$),delListener:e=>(R(e),t),schedule:nt,getStore:()=>t,destroy:()=>(D(F,b).splice(0,void 0),at()),getStats:()=>({loads:E,saves:Y}),...S};return A(st)},$="delete",q=t=>[t.get(e),t.get(a)],B=(e,a,n,s)=>{const r=o(a)?e:e.get(a)??e.set(a,new t);let i;return L(n,(t,e)=>{s(r,e,t)&&(i=1)}),r.forEach((t,e)=>{O(n,e)||(r.delete(e),i=1)}),o(a)||r.size||e.delete(a),i},G=(n,s,r="tinybase",c)=>{const d=s.getMap(r);return Y(n,async()=>d.size?[d.get(e).toJSON(),d.get(a).toJSON()]:void 0,async(n,r)=>s.transact(()=>((n,s,r)=>{n.size||(n.set(e,new t),n.set(a,new t));const[c,g]=q(n),d=()=>{l=1};let l=1;if(i(r,([t,e])=>{l=0,L(t,(t,e)=>l?0:o(t)?c.delete(e):i(c.get(e),e=>L(t,(t,a)=>l?0:o(t)?e.delete(a):i(e.get(a),e=>L(t,(t,a)=>o(t)?e.delete(a):e.set(a,t)),d)),d)),L(e,(t,e)=>l?0:o(t)?g.delete(e):g.set(e,t))}),l){const[t,e]=s();B(c,void 0,t,(t,e,a)=>B(c,e,a,(t,e,a)=>B(t,e,a,(t,e,a)=>{if(t.get(e)!==a)return t.set(e,a),1}))),B(g,void 0,e,(t,e,a)=>{g.get(e)!==a&&g.set(e,a)})}})(d,n,r)),t=>{const n=n=>t(void 0,((t,n)=>{if(1==g(n)&&(s=n[0].path,0==g(s)))return[t.get(e).toJSON(),t.get(a).toJSON(),1];var s;const[o,r]=q(t),c={},d={};return u(n,({path:t,changes:{keys:a}})=>v(t)==e?i(v(t),e=>{const n=N(c,e,M),s=o.get(e);i(v(t),t=>{const e=N(n,t,M),o=s.get(t);E(a,(t,{action:a})=>e[t]=a==$?void 0:o.get(t))},()=>E(a,(t,{action:e})=>n[t]=e==$?void 0:s.get(t)?.toJSON()))},()=>E(a,(t,{action:e})=>c[t]=e==$?void 0:o.get(t)?.toJSON())):E(a,(t,{action:e})=>d[t]=e==$?void 0:r.get(t))),[c,d,1]})(d,n));return d.observeDeep(n),n},t=>{d.unobserveDeep(t)},c,1,{getYDoc:()=>s})};export{G as createYjsPersister};
@@ -1 +1 @@
1
- import{Map as t}from"yjs";const e="t",a="v",n=t=>null==t,s=(t,e,a)=>n(t)?a?.():e(t),o=t=>Array.isArray(t),r=t=>t.length,i=t=>{throw Error(t)},c=async(t,e,a)=>{try{return await t()}catch(t){e?.(t)}},l=(t,e)=>t.forEach(e),g=(t,...e)=>t.push(...e),u=t=>t.shift(),d=t=>n(t)||0==(t=>t?.size??0)(t),y=(t,e)=>t?.forEach(e),p=(t,e)=>t?.delete(e),w=Object,v=t=>w.getPrototypeOf(t),h=w.entries,f=w.keys,S=w.freeze,C=(t=[])=>w.fromEntries(t),b=(t,e)=>e in t,A=(t,e)=>C(((t,e)=>((t,e)=>t.map(e))(h(t),([t,a])=>e(a,t)))(t,(t,a)=>[a,e(t,a)])),M=t=>(t=>!n(t)&&s(v(t),t=>t==w.prototype||n(v(t)),()=>!0))(t)&&0==(t=>r(f(t)))(t),O=(t,e,a)=>(b(t,e)||(t[e]=a()),t[e]),L=t=>new Map(t),J=(t,e)=>t?.get(e),N=(t,e)=>y(t,(t,a)=>e(a,t)),z=(t,e,a)=>n(a)?(p(t,e),t):t?.set(e,a),D=(t,e,a,n)=>{var s,o;return s=t,o=e,s?.has(o)?n?.(J(t,e)):z(t,e,a()),J(t,e)},E=(t,e,a,n,o=0)=>s((a?D:J)(t,e[o],o>r(e)-2?a:L),s=>{if(o>r(e)-2)return n?.(s)&&z(t,e[o]),s;const i=E(s,e,a,n,o+1);return d(s)&&z(t,e[o]),i}),m=/^\d+$/,P=t=>new Set(o(t)||n(t)?t:[t]),T=L(),j=L(),k=(t,e,a,w,v,h,f,C={},b=0,A=[])=>{let O,N,k,x=0,F=0,Y=0;D(T,A,()=>0),D(j,A,()=>[]);const $=L(),[q,B,G,H,I]=((t=1,e,a)=>1!=t&&e.isMergeable()?[1,e.getMergeableContent,()=>e.getTransactionMergeableChanges(!a),([[t],[e]])=>!M(t)||!M(e),e.setDefaultContent]:2!=t?[0,e.getContent,e.getTransactionChanges,([t,e])=>!M(t)||!M(e),e.setContent]:i("Store type not supported by this Persister"))(f,t,b),[K,Q,R]=(()=>{let t;const[e,a]=(()=>{const t=[];let e=0;return[a=>(a?u(t):null)??""+e++,e=>{m.test(e)&&r(t)<1e3&&g(t,e)}]})(),o=L();return[(a,n,s,r=[],i=()=>[])=>{t??=st;const c=e(1);var l,g;return z(o,c,[a,n,s,r,i]),l=E(n,s??[""],P),g=c,l?.add(g),c},(e,a,...n)=>l(((t,e=[""])=>{const a=[],n=(t,s)=>s==r(e)?g(a,t):null===e[s]?y(t,t=>n(t,s+1)):l([e[s],null],e=>n(J(t,e),s+1));return n(t,0),a})(e,a),e=>y(e,e=>J(o,e)[0](t,...a??[],...n))),t=>s(J(o,t),([,e,n])=>(E(e,n??[""],void 0,e=>(p(e,t),d(e)?1:0)),z(o,t),a(t),n)),e=>s(J(o,e),([e,,a=[],s,o])=>{const i=(...c)=>{const g=r(c);g==r(a)?e(t,...c,...o(c)):n(a[g])?l(s[g]?.(...c)??[],t=>i(...c,t)):i(...c,a[g])};i()})]})(),U=t=>{t!=x&&(x=t,Q($,void 0,x))},V=e=>{(q&&o(e?.[0])?1===e?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===e?.[2]?t.applyChanges:t.setContent)(e)},W=async t=>(2!=x&&(U(1),F++,await nt(async()=>{await c(async()=>{const a=await e();o(a)?V(a):t?I(t):i("Content is not an array: "+a)},()=>{t&&I(t)}),U(0)})),st),X=async t=>(Z(),await W(t),await c(async()=>N=await w(async(t,e)=>{e||t?2!=x&&(U(1),F++,V(e??t),U(0)):await W()}),h),st),Z=async()=>(N&&(await c(()=>v(N),h),N=void 0),st),_=async t=>(1!=x&&(U(2),Y++,await nt(async()=>{await c(()=>a(B,t),h),U(0)})),st),tt=async()=>(et(),await _(),k=t.addDidFinishTransactionListener(()=>{const t=G();H(t)&&_(t)}),st),et=async()=>(k&&(t.delListener(k),k=void 0),st),at=async(t=!1)=>{const[e,a]=t?[et,Z]:[Z,et];return await e(),await a(),st},nt=async(...t)=>(g(J(j,A),...t),await(async()=>{if(!J(T,A)){for(z(T,A,1);!n(O=u(J(j,A)));)await c(O,h);z(T,A,0)}})(),st),st={load:W,startAutoLoad:X,stopAutoLoad:Z,isAutoLoading:()=>!n(N),save:_,startAutoSave:tt,stopAutoSave:et,isAutoSaving:()=>!n(k),startAutoPersisting:async(t,e=!1)=>{const[a,n]=e?[tt,X]:[X,tt];return await a(t),await n(t),st},stopAutoPersisting:at,getStatus:()=>x,addStatusListener:t=>K(t,$),delListener:e=>(R(e),t),schedule:nt,getStore:()=>t,destroy:()=>(J(j,A).splice(0,void 0),at()),getStats:()=>({loads:F,saves:Y}),...C};return S(st)},x="delete",F=t=>[t.get(e),t.get(a)],Y=(e,a,s,o)=>{const r=n(a)?e:e.get(a)??e.set(a,new t);let i;return A(s,(t,e)=>{o(r,e,t)&&(i=1)}),r.forEach((t,e)=>{b(s,e)||(r.delete(e),i=1)}),n(a)||r.size||e.delete(a),i},$=(o,i,c="tinybase",g)=>{const d=i.getMap(c);return k(o,async()=>d.size?[d.get(e).toJSON(),d.get(a).toJSON()]:void 0,async(o,r)=>i.transact(()=>((o,r,i)=>{o.size||(o.set(e,new t),o.set(a,new t));const[c,l]=F(o),g=()=>{u=1};let u=1;if(s(i,([t,e])=>{u=0,A(t,(t,e)=>u?0:n(t)?c.delete(e):s(c.get(e),e=>A(t,(t,a)=>u?0:n(t)?e.delete(a):s(e.get(a),e=>A(t,(t,a)=>n(t)?e.delete(a):e.set(a,t)),g)),g)),A(e,(t,e)=>u?0:n(t)?l.delete(e):l.set(e,t))}),u){const[t,e]=r();Y(c,void 0,t,(t,e,a)=>Y(c,e,a,(t,e,a)=>Y(t,e,a,(t,e,a)=>{if(t.get(e)!==a)return t.set(e,a),1}))),Y(l,void 0,e,(t,e,a)=>{l.get(e)!==a&&l.set(e,a)})}})(d,o,r)),t=>{const n=n=>t(void 0,((t,n)=>{if(1==r(n)&&(o=n[0].path,0==r(o)))return[t.get(e).toJSON(),t.get(a).toJSON(),1];var o;const[i,c]=F(t),g={},d={};return l(n,({path:t,changes:{keys:a}})=>u(t)==e?s(u(t),e=>{const n=O(g,e,C),o=i.get(e);s(u(t),t=>{const e=O(n,t,C),s=o.get(t);N(a,(t,{action:a})=>e[t]=a==x?null:s.get(t))},()=>N(a,(t,{action:e})=>n[t]=e==x?null:o.get(t)?.toJSON()))},()=>N(a,(t,{action:e})=>g[t]=e==x?null:i.get(t)?.toJSON())):N(a,(t,{action:e})=>d[t]=e==x?null:c.get(t))),[g,d,1]})(d,n));return d.observeDeep(n),n},t=>{d.unobserveDeep(t)},g,1,{getYDoc:()=>i})};export{$ as createYjsPersister};
1
+ import{Map as t}from"yjs";const e="t",a="v",n=t=>(e,a,n)=>t(e)?n?.():a(e),s=t=>null==t,o=t=>void 0===t,r=n(s),i=n(o),c=t=>Array.isArray(t),g=t=>t.length,d=t=>{throw Error(t)},l=async(t,e,a)=>{try{return await t()}catch(t){e?.(t)}},u=(t,e)=>t.forEach(e),y=(t,...e)=>t.push(...e),v=t=>t.shift(),p=t=>o(t)||0==(t=>t?.size??0)(t),w=(t,e)=>t?.forEach(e),h=(t,e)=>t?.delete(e),f=Object,S=t=>f.getPrototypeOf(t),C=f.entries,b=f.keys,A=f.freeze,M=(t=[])=>f.fromEntries(t),O=(t,e)=>e in t,L=(t,e)=>M(((t,e)=>((t,e)=>t.map(e))(C(t),([t,a])=>e(a,t)))(t,(t,a)=>[a,e(t,a)])),J=t=>(t=>!s(t)&&r(S(t),t=>t==f.prototype||s(S(t)),()=>!0))(t)&&0==(t=>g(b(t)))(t),N=(t,e,a)=>(O(t,e)||(t[e]=a()),t[e]),z=t=>new Map(t),D=(t,e)=>t?.get(e),E=(t,e)=>w(t,(t,a)=>e(a,t)),m=(t,e,a)=>void 0===a?(h(t,e),t):t?.set(e,a),P=(t,e,a,n)=>{var s,o;return s=t,o=e,s?.has(o)?n?.(D(t,e)):m(t,e,a()),D(t,e)},T=(t,e,a,n,s=0)=>i((a?P:D)(t,e[s],s>g(e)-2?a:z),o=>{if(s>g(e)-2)return n?.(o)&&m(t,e[s]),o;const r=T(o,e,a,n,s+1);return p(o)&&m(t,e[s]),r}),j=/^\d+$/,k=t=>new Set(c(t)||o(t)?t:[t]),x=z(),F=z(),Y=(t,e,a,n,s,r,f,S={},C=0,b=[])=>{let M,O,L,N=0,E=0,Y=0;P(x,b,()=>0),P(F,b,()=>[]);const $=z(),[q,B,G,H,I]=((t=1,e,a)=>1!=t&&e.isMergeable()?[1,e.getMergeableContent,()=>e.getTransactionMergeableChanges(!a),([[t],[e]])=>!J(t)||!J(e),e.setDefaultContent]:2!=t?[0,e.getContent,e.getTransactionChanges,([t,e])=>!J(t)||!J(e),e.setContent]:d("Store type not supported by this Persister"))(f,t,C),[K,Q,R]=(()=>{let t;const[e,a]=(()=>{const t=[];let e=0;return[a=>(a?v(t):null)??""+e++,e=>{j.test(e)&&g(t)<1e3&&y(t,e)}]})(),n=z();return[(a,s,o,r=[],i=()=>[])=>{t??=st;const c=e(1);var g,d;return m(n,c,[a,s,o,r,i]),g=T(s,o??[""],k),d=c,g?.add(d),c},(e,a,...s)=>u(((t,e=[""])=>{const a=[],n=(t,s)=>s==g(e)?y(a,t):null===e[s]?w(t,t=>n(t,s+1)):u([e[s],null],e=>n(D(t,e),s+1));return n(t,0),a})(e,a),e=>w(e,e=>D(n,e)[0](t,...a??[],...s))),t=>i(D(n,t),([,e,s])=>(T(e,s??[""],void 0,e=>(h(e,t),p(e)?1:0)),m(n,t),a(t),s)),e=>i(D(n,e),([e,,a=[],n,s])=>{const o=(...r)=>{const i=g(r);i==g(a)?e(t,...r,...s(r)):(t=>null===t)(a[i])?u(n[i]?.(...r)??[],t=>o(...r,t)):o(...r,a[i])};o()})]})(),U=t=>{t!=N&&(N=t,Q($,void 0,N))},V=e=>{(q&&c(e?.[0])?1===e?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===e?.[2]?t.applyChanges:t.setContent)(e)},W=async t=>(2!=N&&(U(1),E++,await nt(async()=>{await l(async()=>{const a=await e();c(a)?V(a):t?I(t):d("Content is not an array: "+a)},()=>{t&&I(t)}),U(0)})),st),X=async t=>(Z(),await W(t),await l(async()=>O=await n(async(t,e)=>{e||t?2!=N&&(U(1),E++,V(e??t),U(0)):await W()}),r),st),Z=async()=>(O&&(await l(()=>s(O),r),O=void 0),st),_=async t=>(1!=N&&(U(2),Y++,await nt(async()=>{await l(()=>a(B,t),r),U(0)})),st),tt=async()=>(et(),await _(),L=t.addDidFinishTransactionListener(()=>{const t=G();H(t)&&_(t)}),st),et=async()=>(L&&(t.delListener(L),L=void 0),st),at=async(t=!1)=>{const[e,a]=t?[et,Z]:[Z,et];return await e(),await a(),st},nt=async(...t)=>(y(D(F,b),...t),await(async()=>{if(!D(x,b)){for(m(x,b,1);!o(M=v(D(F,b)));)await l(M,r);m(x,b,0)}})(),st),st={load:W,startAutoLoad:X,stopAutoLoad:Z,isAutoLoading:()=>!o(O),save:_,startAutoSave:tt,stopAutoSave:et,isAutoSaving:()=>!o(L),startAutoPersisting:async(t,e=!1)=>{const[a,n]=e?[tt,X]:[X,tt];return await a(t),await n(t),st},stopAutoPersisting:at,getStatus:()=>N,addStatusListener:t=>K(t,$),delListener:e=>(R(e),t),schedule:nt,getStore:()=>t,destroy:()=>(D(F,b).splice(0,void 0),at()),getStats:()=>({loads:E,saves:Y}),...S};return A(st)},$="delete",q=t=>[t.get(e),t.get(a)],B=(e,a,n,s)=>{const r=o(a)?e:e.get(a)??e.set(a,new t);let i;return L(n,(t,e)=>{s(r,e,t)&&(i=1)}),r.forEach((t,e)=>{O(n,e)||(r.delete(e),i=1)}),o(a)||r.size||e.delete(a),i},G=(n,s,r="tinybase",c)=>{const d=s.getMap(r);return Y(n,async()=>d.size?[d.get(e).toJSON(),d.get(a).toJSON()]:void 0,async(n,r)=>s.transact(()=>((n,s,r)=>{n.size||(n.set(e,new t),n.set(a,new t));const[c,g]=q(n),d=()=>{l=1};let l=1;if(i(r,([t,e])=>{l=0,L(t,(t,e)=>l?0:o(t)?c.delete(e):i(c.get(e),e=>L(t,(t,a)=>l?0:o(t)?e.delete(a):i(e.get(a),e=>L(t,(t,a)=>o(t)?e.delete(a):e.set(a,t)),d)),d)),L(e,(t,e)=>l?0:o(t)?g.delete(e):g.set(e,t))}),l){const[t,e]=s();B(c,void 0,t,(t,e,a)=>B(c,e,a,(t,e,a)=>B(t,e,a,(t,e,a)=>{if(t.get(e)!==a)return t.set(e,a),1}))),B(g,void 0,e,(t,e,a)=>{g.get(e)!==a&&g.set(e,a)})}})(d,n,r)),t=>{const n=n=>t(void 0,((t,n)=>{if(1==g(n)&&(s=n[0].path,0==g(s)))return[t.get(e).toJSON(),t.get(a).toJSON(),1];var s;const[o,r]=q(t),c={},d={};return u(n,({path:t,changes:{keys:a}})=>v(t)==e?i(v(t),e=>{const n=N(c,e,M),s=o.get(e);i(v(t),t=>{const e=N(n,t,M),o=s.get(t);E(a,(t,{action:a})=>e[t]=a==$?void 0:o.get(t))},()=>E(a,(t,{action:e})=>n[t]=e==$?void 0:s.get(t)?.toJSON()))},()=>E(a,(t,{action:e})=>c[t]=e==$?void 0:o.get(t)?.toJSON())):E(a,(t,{action:e})=>d[t]=e==$?void 0:r.get(t))),[c,d,1]})(d,n));return d.observeDeep(n),n},t=>{d.unobserveDeep(t)},c,1,{getYDoc:()=>s})};export{G as createYjsPersister};
@@ -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=globalThis,l=clearInterval,w=a=>null==a,y=(a,t,e)=>w(a)?e?.():t(a),d=t=>a(t)==s,u=a=>Array.isArray(a),E=(a,t,e)=>a.slice(t,e),N=a=>a.length,g=async a=>o.all(a),$=a=>{throw Error(a)},A=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},O=(a,t)=>a.forEach(t),m=(a,t="")=>a.join(t),T=(a,t)=>a.map(t),R=a=>0==N(a),p=(a,t)=>a.filter(t),v=(a,...t)=>a.push(...t),I=a=>a.shift(),S=(a,t)=>a?.has(t)??!1,_=a=>w(a)||0==(a=>a?.size??0)(a),C=a=>[...a?.values()??[]],b=(a,t)=>a?.forEach(t),L=(a,t)=>a?.delete(t),D=Object,f=a=>D.getPrototypeOf(a),h=D.entries,P=D.keys,M=D.freeze,F=(a=[])=>D.fromEntries(a),U=(...a)=>D.assign({},...a),G=(a,t)=>(delete a[t],a),j=(a,t)=>T(h(a),([a,e])=>t(e,a)),x=(a,t)=>F(j(a,(a,e)=>[e,t(a,e)])),B=a=>D.values(a),H=a=>N(P(a)),W=a=>(a=>!w(a)&&y(f(a),a=>a==D.prototype||w(f(a)),()=>!0))(a)&&0==H(a),Y=a=>new Map(a),X=(a,t)=>a?.get(t),J=(a,t)=>T([...a?.entries()??[]],([a,e])=>t(e,a)),k=(a,t,e)=>w(e)?(L(a,t),a):a?.set(t,e),z=(a,t,e,n)=>(S(a,t)?n?.(X(a,t)):k(a,t,e()),X(a,t)),K=(a,t,e,n,s=0)=>y((e?z:X)(a,t[s],s>N(t)-2?e:Y),i=>{if(s>N(t)-2)return n?.(i)&&k(a,t[s]),i;const r=K(i,t,e,n,s+1);return _(i)&&k(a,t[s]),r}),V=/^\d+$/,q=a=>new Set(u(a)||w(a)?a:[a]),Q=(a,t)=>a?.add(t),Z={Idle:0,Loading:1,Saving:2},aa={StoreOnly:1,MergeableStoreOnly:2,StoreOrMergeableStore:3},ta=Y(),ea=Y(),na=(a,t,n,s,i,r,o,c={},l=0,d=[])=>{let E,g,m,T=0,R=0,p=0;z(ta,d,()=>0),z(ea,d,()=>[]);const S=Y(),[C,D,f,h,P]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!W(a)||!W(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!W(a)||!W(t),t.setContent]:$("Store type not supported by this Persister"))(o,a,l),[F,U,G]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?I(a):null)??e+t++,t=>{V.test(t)&&N(a)<1e3&&v(a,t)}]})(),s=Y();return[(n,i,r,o=[],c=()=>[])=>{a??=ra;const l=t(1);return k(s,l,[n,i,r,o,c]),Q(K(i,r??[e],q),l),l},(t,n,...i)=>O(((a,t=[e])=>{const n=[],s=(a,e)=>e==N(t)?v(n,a):null===t[e]?b(a,a=>s(a,e+1)):O([t[e],null],t=>s(X(a,t),e+1));return s(a,0),n})(t,n),t=>b(t,t=>X(s,t)[0](a,...n??[],...i))),a=>y(X(s,a),([,t,i])=>(K(t,i??[e],void 0,t=>(L(t,a),_(t)?1:0)),k(s,a),n(a),i)),t=>y(X(s,t),([t,,e=[],n,s])=>{const i=(...r)=>{const o=N(r);o==N(e)?t(a,...r,...s(r)):w(e[o])?O(n[o]?.(...r)??[],a=>i(...r,a)):i(...r,e[o])};i()})]})(),j=a=>{a!=T&&(T=a,U(S,void 0,T))},x=t=>{(C&&u(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},B=async a=>(2!=T&&(j(1),R++,await ia(async()=>{await A(async()=>{const e=await t();u(e)?x(e):a?P(a):$("Content is not an array: "+e)},()=>{a&&P(a)}),j(0)})),ra),H=async a=>(J(),await B(a),await A(async()=>g=await s(async(a,t)=>{t||a?2!=T&&(j(1),R++,x(t??a),j(0)):await B()}),r),ra),J=async()=>(g&&(await A(()=>i(g),r),g=void 0),ra),Z=async a=>(1!=T&&(j(2),p++,await ia(async()=>{await A(()=>n(D,a),r),j(0)})),ra),aa=async()=>(na(),await Z(),m=a.addDidFinishTransactionListener(()=>{const a=f();h(a)&&Z(a)}),ra),na=async()=>(m&&(a.delListener(m),m=void 0),ra),sa=async(a=!1)=>{const[t,e]=a?[na,J]:[J,na];return await t(),await e(),ra},ia=async(...a)=>(v(X(ea,d),...a),await(async()=>{if(!X(ta,d)){for(k(ta,d,1);!w(E=I(X(ea,d)));)await A(E,r);k(ta,d,0)}})(),ra),ra={load:B,startAutoLoad:H,stopAutoLoad:J,isAutoLoading:()=>!w(g),save:Z,startAutoSave:aa,stopAutoSave:na,isAutoSaving:()=>!w(m),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[aa,H]:[H,aa];return await e(a),await n(a),ra},stopAutoPersisting:sa,getStatus:()=>T,addStatusListener:a=>F(a,S),delListener:t=>(G(t),a),schedule:ia,getStore:()=>a,destroy:()=>(X(ea,d).splice(0,void 0),sa()),getStats:()=>({loads:R,saves:p}),...c};return M(ra)},sa=JSON.stringify,ia=JSON.parse,ra=a=>sa(a,(a,t)=>void 0===t?"":t),oa=new c.TextEncoder,ca="_",la="_id",wa="SELECT",ya="WHERE",da="TABLE",ua="INSERT",Ea="DELETE",Na="UPDATE",ga="ALTER "+da,$a="FROM",Aa=Ea+" "+$a,Oa=wa+"*"+$a,ma="pragma_",Ta="data_version",Ra="schema_version",pa="pragma_table_",va="CREATE ",Ia=va+da,Sa="OR REPLACE ",_a="FUNCTION",Ca="$tableName",ba=(a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a,La=a=>m(T(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${r(a,/"/g,'""')}"`),"."),Da=(...a)=>La(m(a,"_")),fa=(a,t=[1])=>m(T(a,()=>"$"+t[0]++),n),ha=(a,t=i)=>ya+`(${r(t,Ca,La(a))})`,Pa="ColumnName",Ma="store",Fa="json",Ua=Ma+"TableName",Ga=Ma+"Id"+Pa,ja=Ma+Pa,xa="autoLoadIntervalSeconds",Ba="rowId"+Pa,Ha="tableId",Wa="tableName",Ya="deleteEmptyColumns",Xa="deleteEmptyTable",Ja="condition",ka={mode:Fa,[xa]:1},za={load:0,save:0,[Wa]:t+"_values"},Ka=(a,t,e,n,s)=>{const i=Y();return x(a,(a,r)=>{const o=E(B(U(t,d(a)?{[e]:a}:a)),0,H(t));w(o[0])||n(r,o[0])||(s(r,o[0]),k(i,r,o))}),i},Va=a=>{const e=(a=>U(ka,d(a)?{[Ua]:a}:a??{}))(a),n=e[xa];if(e.mode==Fa){const a=e[Ua]??t;return[1,n,[a,e[Ga]??la,e[ja]??Ma],q(a)]}const{tables:{load:s={},save:r={}}={},values:o={}}=e,c=E(B(U(za,o)),0,H(za)),l=c[2],w=q(l),y=q(l),u=Ka(s,{[Ha]:null,[Ba]:la,[Ja]:i},Ha,a=>S(y,a),a=>Q(w,a)),N=Ka(r,{[Wa]:null,[Ba]:la,[Ya]:0,[Xa]:0,[Ja]:null},Wa,(a,t)=>S(y,t),(a,t)=>Q(w,t));var g;return g=(a,t)=>t[4]??=X(u,t[0])?.[2]??i,b(N,(a,t)=>g(0,a)),[0,n,[u,N,c],w]},qa=(a,t,e,s,r,o=Qa,c,l)=>{const y=Y();return[async()=>{y.clear(),T(await e(a,t),({tn:a,cn:t})=>Q(z(y,a,q),t))},async(t,e,n)=>((a,t)=>S(X(y,a),t))(t,e)?F(p(T(await a(Oa+La(t)+ha(t,n)),a=>[a[e],l?x(G(a,e),l):G(a,e)]),([a,t])=>!w(a)&&!W(t))):{},async(t,e,s,l,d,u=!1,E=i)=>{const N=q();x(s??{},a=>T(P(a??{}),a=>Q(N,a)));const $=C(N);if(!u&&d&&E==i&&R($)&&S(y,t))return await a("DROP "+da+La(t)),void k(y,t);const A=X(y,t),O=q(C(A));if(R($)||(S(y,t)?await g(T([e,...$],async(n,s)=>{L(O,n)||(await a(ga+La(t)+"ADD"+La(n)+r),0==s&&await a("CREATE UNIQUE INDEX pk ON "+La(t)+`(${La(e)})`),Q(A,n))})):(await a(Ia+La(t)+`(${La(e)}${r} PRIMARY KEY${m(T($,a=>n+La(a)+r))});`),k(y,t,q([e,...$])))),await g([...!u&&l?T(C(O),async n=>{n!=e&&(await a(ga+La(t)+"DROP"+La(n)),L(A,n))}):[]]),u)w(s)?await a(Aa+La(t)+ha(t,E)):await g(j(s,async(n,s)=>{w(n)?await a(Aa+La(t)+ha(t,E)+`AND(${La(e)}=$1)`,[s]):R($)||await o(a,t,e,P(n),{[s]:c?T(B(n),c):B(n)},A)}));else if(R($))S(y,t)&&await a(Aa+La(t)+ha(t,E));else{const n=p(C(X(y,t)),a=>a!=e),i={},r=[];x(s??{},(a,t)=>{i[t]=T(n,t=>c?c(a?.[t]):a?.[t]),v(r,t)}),await o(a,t,e,n,i),await a(Aa+La(t)+ha(t,E)+`AND${La(e)}NOT IN(${fa(r)})`,r)}},async t=>{let e;return await a("BEGIN"),await A(async()=>e=await t(),s),await a("END"),e}]},Qa=async(a,t,e,s,i)=>{const r=[1];await a(ua+" INTO"+La(t)+"("+((...a)=>m(T(a,La),n))(e,...s)+")VALUES"+m(j(i,a=>"($"+r[0]+++","+fa(a,r)+")"),n)+"ON CONFLICT("+La(e)+`)DO ${Na} SET`+m(T(s,a=>La(a)+"=excluded."+La(a)),n),j(i,(a,t)=>[t,...T(a,a=>a??null)]).flat())},Za=(a,t,e,n,s,i,r,[o,c,l],w,y,d,u,E,N)=>{const[g,$,A,O]=qa(t,w,y,s,E,N),m=na(a,()=>O(async()=>{return await g(),a=(await $(o,c))[ca]?.[l]??"null",ia(a,(a,t)=>""===t?void 0:t);var a}),a=>O(async()=>{await g(),await A(o,c,{[ca]:{[l]:ra(a()??null)}},!0,!0)}),e,n,s,r,{[u]:()=>d,destroy:async()=>(await m.stopAutoPersisting(),i(),m)},0,d);return m},at=(a,t,e,n,s,i,r,[o,c,[l,y,d]],u,E,N,$,A,O,m,T)=>{const[R,v,I,S]=qa(t,u,E,s,A,O,m,T),_=(a,t)=>g(J(c,async([e,n,s,i,r],o)=>{t&&!(o in a)||await I(e,n,a[o],s,i,t,r)})),C=async(a,t)=>y?await I(d,la,{[ca]:a},!0,!0,t):null,b=na(a,()=>S(async()=>{await R();const a=await(async()=>F(p(await g(J(o,async([a,t,e],n)=>[a,await v(n,t,e)])),a=>!W(a[1]))))(),t=await(async()=>l?(await v(d,la))[ca]:{})();return W(a)&&w(t)?void 0:[a,t]}),(a,t)=>S(async()=>{if(await R(),w(t)){const[t,e]=a();await _(t),await C(e)}else await _(t[0],!0),await C(t[1],!0)}),e,n,s,r,{[$]:()=>N,destroy:async()=>(await b.stopAutoPersisting(),i(),b)},0,N);return b},tt=/^([cd]:)(.+)/,et=(a,n,s,o,c,l,w,d,u,E,N="getDb")=>{const $=ba(s,l),[A,,R,p]=Va(n),v=e+(a=>{let t=2166136261;return O(oa.encode(a),a=>{t^=a,t+=(t<<1)+(t<<4)+(t<<7)+(t<<8)+(t<<24)}),t>>>0})(ra(R)),I=t+"_"+v,_=async(a,e,n="",s="")=>{const i=Da(t,a,v);return await $(va+Sa+_a+i+`()RETURNS ${n}trigger AS $$ ${s}BEGIN ${e}END;$$ LANGUAGE plpgsql;`),i},b=async(a,t,e,n)=>(await $(va+a+"TRIGGER"+t+e+"EXECUTE "+_a+n+"()"),t),L=a=>`PERFORM pg_notify('${I}',${a});`,D=(a,t)=>A?i:2===t?D(a,0)+" OR "+D(a,1):r(X(R[0],a)?.[2]??i,Ca,0==t?"NEW":"OLD"),f=(a,e)=>g(T([ua,Ea,Na],(n,s)=>b(Sa,Da(t,"d",v,a,n),`AFTER ${n} ON${La(a)}FOR EACH ROW WHEN(${D(a,s)})`,e)));return(A?Za:at)(a,$,async a=>{const e=await _("c",`FOR row IN SELECT object_identity FROM pg_event_trigger_ddl_commands()${ya} command_tag='${Ia}' LOOP ${L("'c:'||SPLIT_PART(row.object_identity,'.',2)")}END LOOP;`,"event_","DECLARE row record;");await b("EVENT ",Da(t,"c",v),`ON ddl_command_end WHEN TAG IN('${Ia}')`,e);const n=await _("d",L("'d:'||TG_TABLE_NAME")+"RETURN NULL;");return await g(T(C(p),async a=>(await $(Ia+` IF NOT EXISTS${La(a)}("_id"text PRIMARY KEY)`),await f(a,n)))),[await o(I,t=>{return y((e=t,s=tt,e?.match(s)),async([,t,e])=>{S(p,e)&&("c:"==t&&await f(e,n),a())});var e,s}),[e,n]]},async([a,t])=>{c(a),await $(`DROP FUNCTION IF EXISTS${m(t,",")}CASCADE`)},w,d,u,R,C(p),async(a,t)=>await a(wa+` table_name tn,column_name cn FROM information_schema.columns ${ya} table_schema='public'AND table_name IN(${fa(t)})`,t),E,N,"text",void 0,a=>sa(a),a=>ia(a))},nt=(a,t,n,s,i,r,o,c,w,y,d="getDb",u)=>{let E,N,g;const $=ba(n,r),[O,m,T,R]=Va(t);return(O?Za:at)(a,$,a=>{let t;const e=()=>t=setInterval(()=>A(async()=>{const[{d:t,s:e,c:n}]=await $(wa+` ${Ta} d,${Ra} s,TOTAL_CHANGES() c FROM ${ma}${Ta} JOIN ${ma}${Ra}`);t==E&&e==N&&n==g||(null!=E&&a(),E=t,N=e,g=n)}),1e3*m),n=()=>{E=N=g=null,l(t)},r=s(t=>{R.has(t)&&(n(),a(),e())});return e(),()=>{n(),i(r)}},a=>a(),o,c,w,T,C(R),async(a,t)=>await a(wa+` t.name tn,c.name cn FROM ${pa}list()t,${pa}info(t.name)c ${ya} t.schema='main'AND t.type IN('table','view')AND t.name IN(${fa(t)})ORDER BY t.name,c.name`,t),y,d,e,u,a=>!0===a?1:!1===a?0:a,void 0)};export{aa as Persists,Z as Status,na as createCustomPersister,et as createCustomPostgreSqlPersister,nt as createCustomSqlitePersister};
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=globalThis,w=clearInterval,d=a=>null==a,y=a=>void 0===a,u=a=>null===a,E=c(d),N=c(y),g=t=>a(t)==s,$=a=>Array.isArray(a),A=(a,t,e)=>a.slice(t,e),O=a=>a.length,m=async a=>o.all(a),T=a=>{throw Error(a)},v=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},R=(a,t)=>a.forEach(t),p=(a,t="")=>a.join(t),I=(a,t)=>a.map(t),S=a=>0==O(a),_=(a,t)=>a.filter(t),C=(a,...t)=>a.push(...t),b=a=>a.shift(),L=(a,t)=>a?.has(t)??!1,D=a=>y(a)||0==(a=>a?.size??0)(a),f=a=>[...a?.values()??[]],h=(a,t)=>a?.forEach(t),P=(a,t)=>a?.delete(t),M=Object,F=a=>M.getPrototypeOf(a),U=M.entries,G=M.keys,j=M.freeze,x=(a=[])=>M.fromEntries(a),B=(...a)=>M.assign({},...a),H=(a,t)=>(delete a[t],a),W=(a,t)=>I(U(a),([a,e])=>t(e,a)),Y=(a,t)=>x(W(a,(a,e)=>[e,t(a,e)])),X=a=>M.values(a),J=a=>O(G(a)),k=a=>(a=>!d(a)&&E(F(a),a=>a==M.prototype||d(F(a)),()=>!0))(a)&&0==J(a),z=a=>new Map(a),K=(a,t)=>a?.get(t),V=(a,t)=>I([...a?.entries()??[]],([a,e])=>t(e,a)),q=(a,t,e)=>void 0===e?(P(a,t),a):a?.set(t,e),Q=(a,t,e,n)=>(L(a,t)?n?.(K(a,t)):q(a,t,e()),K(a,t)),Z=(a,t,e,n,s=0)=>N((e?Q:K)(a,t[s],s>O(t)-2?e:z),i=>{if(s>O(t)-2)return n?.(i)&&q(a,t[s]),i;const r=Z(i,t,e,n,s+1);return D(i)&&q(a,t[s]),r}),aa=/^\d+$/,ta=a=>new Set($(a)||y(a)?a:[a]),ea=(a,t)=>a?.add(t),na={Idle:0,Loading:1,Saving:2},sa={StoreOnly:1,MergeableStoreOnly:2,StoreOrMergeableStore:3},ia=z(),ra=z(),oa=(a,t,n,s,i,r,o,c={},l=0,w=[])=>{let d,E,g,A=0,m=0,p=0;Q(ia,w,()=>0),Q(ra,w,()=>[]);const I=z(),[S,_,L,f,M]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!k(a)||!k(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!k(a)||!k(t),t.setContent]:T("Store type not supported by this Persister"))(o,a,l),[F,U,G]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?b(a):null)??e+t++,t=>{aa.test(t)&&O(a)<1e3&&C(a,t)}]})(),s=z();return[(n,i,r,o=[],c=()=>[])=>{a??=oa;const l=t(1);return q(s,l,[n,i,r,o,c]),ea(Z(i,r??[e],ta),l),l},(t,n,...i)=>R(((a,t=[e])=>{const n=[],s=(a,e)=>e==O(t)?C(n,a):null===t[e]?h(a,a=>s(a,e+1)):R([t[e],null],t=>s(K(a,t),e+1));return s(a,0),n})(t,n),t=>h(t,t=>K(s,t)[0](a,...n??[],...i))),a=>N(K(s,a),([,t,i])=>(Z(t,i??[e],void 0,t=>(P(t,a),D(t)?1:0)),q(s,a),n(a),i)),t=>N(K(s,t),([t,,e=[],n,s])=>{const i=(...r)=>{const o=O(r);o==O(e)?t(a,...r,...s(r)):u(e[o])?R(n[o]?.(...r)??[],a=>i(...r,a)):i(...r,e[o])};i()})]})(),x=a=>{a!=A&&(A=a,U(I,void 0,A))},B=t=>{(S&&$(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},H=async a=>(2!=A&&(x(1),m++,await sa(async()=>{await v(async()=>{const e=await t();$(e)?B(e):a?M(a):T("Content is not an array: "+e)},()=>{a&&M(a)}),x(0)})),oa),W=async a=>(Y(),await H(a),await v(async()=>E=await s(async(a,t)=>{t||a?2!=A&&(x(1),m++,B(t??a),x(0)):await H()}),r),oa),Y=async()=>(E&&(await v(()=>i(E),r),E=void 0),oa),X=async a=>(1!=A&&(x(2),p++,await sa(async()=>{await v(()=>n(_,a),r),x(0)})),oa),J=async()=>(V(),await X(),g=a.addDidFinishTransactionListener(()=>{const a=L();f(a)&&X(a)}),oa),V=async()=>(g&&(a.delListener(g),g=void 0),oa),na=async(a=!1)=>{const[t,e]=a?[V,Y]:[Y,V];return await t(),await e(),oa},sa=async(...a)=>(C(K(ra,w),...a),await(async()=>{if(!K(ia,w)){for(q(ia,w,1);!y(d=b(K(ra,w)));)await v(d,r);q(ia,w,0)}})(),oa),oa={load:H,startAutoLoad:W,stopAutoLoad:Y,isAutoLoading:()=>!y(E),save:X,startAutoSave:J,stopAutoSave:V,isAutoSaving:()=>!y(g),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[J,W]:[W,J];return await e(a),await n(a),oa},stopAutoPersisting:na,getStatus:()=>A,addStatusListener:a=>F(a,I),delListener:t=>(G(t),a),schedule:sa,getStore:()=>a,destroy:()=>(K(ra,w).splice(0,void 0),na()),getStats:()=>({loads:m,saves:p}),...c};return j(oa)},ca=JSON.stringify,la=JSON.parse,wa=a=>ca(a,(a,t)=>void 0===t?"":t),da=new l.TextEncoder,ya="_",ua="_id",Ea="SELECT",Na="WHERE",ga="TABLE",$a="INSERT",Aa="DELETE",Oa="UPDATE",ma="ALTER "+ga,Ta="FROM",va=Aa+" "+Ta,Ra=Ea+"*"+Ta,pa="pragma_",Ia="data_version",Sa="schema_version",_a="pragma_table_",Ca="CREATE ",ba=Ca+ga,La="OR REPLACE ",Da="FUNCTION",fa="$tableName",ha=(a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a,Pa=a=>p(I(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${r(a,/"/g,'""')}"`),"."),Ma=(...a)=>Pa(p(a,"_")),Fa=(a,t=[1])=>p(I(a,()=>"$"+t[0]++),n),Ua=(a,t=i)=>Na+`(${r(t,fa,Pa(a))})`,Ga="ColumnName",ja="store",xa="json",Ba=ja+"TableName",Ha=ja+"Id"+Ga,Wa=ja+Ga,Ya="autoLoadIntervalSeconds",Xa="rowId"+Ga,Ja="tableId",ka="tableName",za="deleteEmptyColumns",Ka="deleteEmptyTable",Va="condition",qa={mode:xa,[Ya]:1},Qa={load:0,save:0,[ka]:t+"_values"},Za=(a,t,e,n,s)=>{const i=z();return Y(a,(a,r)=>{const o=A(X(B(t,g(a)?{[e]:a}:a)),0,J(t));u(o[0])||n(r,o[0])||(s(r,o[0]),q(i,r,o))}),i},at=a=>{const e=(a=>B(qa,g(a)?{[Ba]:a}:a??{}))(a),n=e[Ya];if(e.mode==xa){const a=e[Ba]??t;return[1,n,[a,e[Ha]??ua,e[Wa]??ja],ta(a)]}const{tables:{load:s={},save:r={}}={},values:o={}}=e,c=A(X(B(Qa,o)),0,J(Qa)),l=c[2],w=ta(l),d=ta(l),y=Za(s,{[Ja]:null,[Xa]:ua,[Va]:i},Ja,a=>L(d,a),a=>ea(w,a)),u=Za(r,{[ka]:null,[Xa]:ua,[za]:0,[Ka]:0,[Va]:null},ka,(a,t)=>L(d,t),(a,t)=>ea(w,t));var E;return E=(a,t)=>t[4]??=K(y,t[0])?.[2]??i,h(u,(a,t)=>E(0,a)),[0,n,[y,u,c],w]},tt=(a,t,e,s,r,o=et,c,l)=>{const w=z();return[async()=>{w.clear(),I(await e(a,t),({tn:a,cn:t})=>ea(Q(w,a,ta),t))},async(t,e,n)=>((a,t)=>L(K(w,a),t))(t,e)?x(_(I(await a(Ra+Pa(t)+Ua(t,n)),a=>[a[e],l?Y(H(a,e),l):H(a,e)]),([a,t])=>!y(a)&&!k(t))):{},async(t,e,s,l,d,u=!1,E=i)=>{const N=ta();Y(s??{},a=>I(G(a??{}),a=>ea(N,a)));const g=f(N);if(!u&&d&&E==i&&S(g)&&L(w,t))return await a("DROP "+ga+Pa(t)),void q(w,t);const $=K(w,t),A=ta(f($));if(S(g)||(L(w,t)?await m(I([e,...g],async(n,s)=>{P(A,n)||(await a(ma+Pa(t)+"ADD"+Pa(n)+r),0==s&&await a("CREATE UNIQUE INDEX pk ON "+Pa(t)+`(${Pa(e)})`),ea($,n))})):(await a(ba+Pa(t)+`(${Pa(e)}${r} PRIMARY KEY${p(I(g,a=>n+Pa(a)+r))});`),q(w,t,ta([e,...g])))),await m([...!u&&l?I(f(A),async n=>{n!=e&&(await a(ma+Pa(t)+"DROP"+Pa(n)),P($,n))}):[]]),u)y(s)?await a(va+Pa(t)+Ua(t,E)):await m(W(s,async(n,s)=>{y(n)?await a(va+Pa(t)+Ua(t,E)+`AND(${Pa(e)}=$1)`,[s]):S(g)||await o(a,t,e,G(n),{[s]:c?I(X(n),c):X(n)},$)}));else if(S(g))L(w,t)&&await a(va+Pa(t)+Ua(t,E));else{const n=_(f(K(w,t)),a=>a!=e),i={},r=[];Y(s??{},(a,t)=>{i[t]=I(n,t=>c?c(a?.[t]):a?.[t]),C(r,t)}),await o(a,t,e,n,i),await a(va+Pa(t)+Ua(t,E)+`AND${Pa(e)}NOT IN(${Fa(r)})`,r)}},async t=>{let e;return await a("BEGIN"),await v(async()=>e=await t(),s),await a("END"),e}]},et=async(a,t,e,s,i)=>{const r=[1];await a($a+" INTO"+Pa(t)+"("+((...a)=>p(I(a,Pa),n))(e,...s)+")VALUES"+p(W(i,a=>"($"+r[0]+++","+Fa(a,r)+")"),n)+"ON CONFLICT("+Pa(e)+`)DO ${Oa} SET`+p(I(s,a=>Pa(a)+"=excluded."+Pa(a)),n),W(i,(a,t)=>[t,...I(a,a=>a??null)]).flat())},nt=(a,t,e,n,s,i,r,[o,c,l],w,d,y,u,E,N)=>{const[g,$,A,O]=tt(t,w,d,s,E,N),m=oa(a,()=>O(async()=>{return await g(),a=(await $(o,c))[ya]?.[l]??"null",la(a,(a,t)=>""===t?void 0:t);var a}),a=>O(async()=>{await g(),await A(o,c,{[ya]:{[l]:wa(a()??null)}},!0,!0)}),e,n,s,r,{[u]:()=>y,destroy:async()=>(await m.stopAutoPersisting(),i(),m)},0,y);return m},st=(a,t,e,n,s,i,r,[o,c,[l,w,d]],u,E,N,g,$,A,O,T)=>{const[v,R,p,I]=tt(t,u,E,s,$,A,O,T),S=(a,t)=>m(V(c,async([e,n,s,i,r],o)=>{t&&!(o in a)||await p(e,n,a[o],s,i,t,r)})),C=async(a,t)=>w?await p(d,ua,{[ya]:a},!0,!0,t):null,b=oa(a,()=>I(async()=>{await v();const a=await(async()=>x(_(await m(V(o,async([a,t,e],n)=>[a,await R(n,t,e)])),a=>!k(a[1]))))(),t=await(async()=>l?(await R(d,ua))[ya]:{})();return k(a)&&y(t)?void 0:[a,t]}),(a,t)=>I(async()=>{if(await v(),y(t)){const[t,e]=a();await S(t),await C(e)}else await S(t[0],!0),await C(t[1],!0)}),e,n,s,r,{[g]:()=>N,destroy:async()=>(await b.stopAutoPersisting(),i(),b)},0,N);return b},it=/^([cd]:)(.+)/,rt=(a,n,s,o,c,l,w,d,y,u,E="getDb")=>{const g=ha(s,l),[$,,A,O]=at(n),T=e+(a=>{let t=2166136261;return R(da.encode(a),a=>{t^=a,t+=(t<<1)+(t<<4)+(t<<7)+(t<<8)+(t<<24)}),t>>>0})(wa(A)),v=t+"_"+T,S=async(a,e,n="",s="")=>{const i=Ma(t,a,T);return await g(Ca+La+Da+i+`()RETURNS ${n}trigger AS $$ ${s}BEGIN ${e}END;$$ LANGUAGE plpgsql;`),i},_=async(a,t,e,n)=>(await g(Ca+a+"TRIGGER"+t+e+"EXECUTE "+Da+n+"()"),t),C=a=>`PERFORM pg_notify('${v}',${a});`,b=(a,t)=>$?i:2===t?b(a,0)+" OR "+b(a,1):r(K(A[0],a)?.[2]??i,fa,0==t?"NEW":"OLD"),D=(a,e)=>m(I([$a,Aa,Oa],(n,s)=>_(La,Ma(t,"d",T,a,n),`AFTER ${n} ON${Pa(a)}FOR EACH ROW WHEN(${b(a,s)})`,e)));return($?nt:st)(a,g,async a=>{const e=await S("c",`FOR row IN SELECT object_identity FROM pg_event_trigger_ddl_commands()${Na} command_tag='${ba}' LOOP ${C("'c:'||SPLIT_PART(row.object_identity,'.',2)")}END LOOP;`,"event_","DECLARE row record;");await _("EVENT ",Ma(t,"c",T),`ON ddl_command_end WHEN TAG IN('${ba}')`,e);const n=await S("d",C("'d:'||TG_TABLE_NAME")+"RETURN NULL;");return await m(I(f(O),async a=>(await g(ba+` IF NOT EXISTS${Pa(a)}("_id"text PRIMARY KEY)`),await D(a,n)))),[await o(v,t=>{return N((e=t,s=it,e?.match(s)),async([,t,e])=>{L(O,e)&&("c:"==t&&await D(e,n),a())});var e,s}),[e,n]]},async([a,t])=>{c(a),await g(`DROP FUNCTION IF EXISTS${p(t,",")}CASCADE`)},w,d,y,A,f(O),async(a,t)=>await a(Ea+` table_name tn,column_name cn FROM information_schema.columns ${Na} table_schema='public'AND table_name IN(${Fa(t)})`,t),u,E,"text",void 0,a=>ca(a),a=>la(a))},ot=(a,t,n,s,i,r,o,c,l,y,u="getDb",E)=>{let N,g,$;const A=ha(n,r),[O,m,T,R]=at(t);return(O?nt:st)(a,A,a=>{let t;const e=()=>t=setInterval(()=>v(async()=>{const[{d:t,s:e,c:n}]=await A(Ea+` ${Ia} d,${Sa} s,TOTAL_CHANGES() c FROM ${pa}${Ia} JOIN ${pa}${Sa}`);t==N&&e==g&&n==$||(d(N)||a(),N=t,g=e,$=n)}),1e3*m),n=()=>{N=g=$=null,w(t)},r=s(t=>{R.has(t)&&(n(),a(),e())});return e(),()=>{n(),i(r)}},a=>a(),o,c,l,T,f(R),async(a,t)=>await a(Ea+` t.name tn,c.name cn FROM ${_a}list()t,${_a}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),y,u,e,E,a=>!0===a?1:!1===a?0:a,void 0)};export{sa as Persists,na as Status,oa as createCustomPersister,rt as createCustomPostgreSqlPersister,ot as createCustomSqlitePersister};