drizzle-orm 0.34.0-ff1e9a5 → 0.34.1

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 (701) hide show
  1. package/aws-data-api/common/index.d.cts +1 -1
  2. package/aws-data-api/common/index.d.ts +1 -1
  3. package/aws-data-api/pg/driver.cjs +9 -8
  4. package/aws-data-api/pg/driver.cjs.map +1 -1
  5. package/aws-data-api/pg/driver.d.cts +1 -1
  6. package/aws-data-api/pg/driver.d.ts +1 -1
  7. package/aws-data-api/pg/driver.js +3 -2
  8. package/aws-data-api/pg/driver.js.map +1 -1
  9. package/better-sqlite3/driver.cjs +1 -1
  10. package/better-sqlite3/driver.cjs.map +1 -1
  11. package/better-sqlite3/driver.js +1 -1
  12. package/better-sqlite3/driver.js.map +1 -1
  13. package/bun-sqlite/driver.cjs +1 -1
  14. package/bun-sqlite/driver.cjs.map +1 -1
  15. package/bun-sqlite/driver.js +1 -1
  16. package/bun-sqlite/driver.js.map +1 -1
  17. package/casing.cjs +85 -0
  18. package/casing.cjs.map +1 -0
  19. package/casing.d.cts +14 -0
  20. package/casing.d.ts +14 -0
  21. package/casing.js +59 -0
  22. package/casing.js.map +1 -0
  23. package/column-builder.cjs +7 -0
  24. package/column-builder.cjs.map +1 -1
  25. package/column-builder.d.cts +7 -2
  26. package/column-builder.d.ts +7 -2
  27. package/column-builder.js +7 -0
  28. package/column-builder.js.map +1 -1
  29. package/column.cjs +2 -0
  30. package/column.cjs.map +1 -1
  31. package/column.d.cts +1 -0
  32. package/column.d.ts +1 -0
  33. package/column.js +2 -0
  34. package/column.js.map +1 -1
  35. package/connect.cjs +25 -0
  36. package/connect.cjs.map +1 -0
  37. package/connect.d.cts +2 -0
  38. package/connect.d.ts +2 -0
  39. package/connect.js +3 -0
  40. package/connect.js.map +1 -0
  41. package/d1/driver.cjs +1 -1
  42. package/d1/driver.cjs.map +1 -1
  43. package/d1/driver.js +1 -1
  44. package/d1/driver.js.map +1 -1
  45. package/expo-sqlite/driver.cjs +1 -1
  46. package/expo-sqlite/driver.cjs.map +1 -1
  47. package/expo-sqlite/driver.js +1 -1
  48. package/expo-sqlite/driver.js.map +1 -1
  49. package/expo-sqlite/query.cjs +8 -6
  50. package/expo-sqlite/query.cjs.map +1 -1
  51. package/expo-sqlite/query.js +3 -1
  52. package/expo-sqlite/query.js.map +1 -1
  53. package/index.cjs +0 -4
  54. package/index.cjs.map +1 -1
  55. package/index.d.cts +0 -2
  56. package/index.d.ts +0 -2
  57. package/index.js +0 -2
  58. package/index.js.map +1 -1
  59. package/libsql/driver.cjs +1 -1
  60. package/libsql/driver.cjs.map +1 -1
  61. package/libsql/driver.js +1 -1
  62. package/libsql/driver.js.map +1 -1
  63. package/monodriver.cjs +14 -14
  64. package/monodriver.cjs.map +1 -1
  65. package/monodriver.js +14 -14
  66. package/monodriver.js.map +1 -1
  67. package/monomigrator.cjs +14 -14
  68. package/monomigrator.cjs.map +1 -1
  69. package/monomigrator.js +14 -14
  70. package/monomigrator.js.map +1 -1
  71. package/mysql-core/columns/all.cjs +80 -0
  72. package/mysql-core/columns/all.cjs.map +1 -0
  73. package/mysql-core/columns/all.d.cts +51 -0
  74. package/mysql-core/columns/all.d.ts +51 -0
  75. package/mysql-core/columns/all.js +56 -0
  76. package/mysql-core/columns/all.js.map +1 -0
  77. package/mysql-core/columns/bigint.cjs +3 -1
  78. package/mysql-core/columns/bigint.cjs.map +1 -1
  79. package/mysql-core/columns/bigint.d.cts +2 -2
  80. package/mysql-core/columns/bigint.d.ts +2 -2
  81. package/mysql-core/columns/bigint.js +3 -1
  82. package/mysql-core/columns/bigint.js.map +1 -1
  83. package/mysql-core/columns/binary.cjs +3 -1
  84. package/mysql-core/columns/binary.cjs.map +1 -1
  85. package/mysql-core/columns/binary.d.cts +2 -0
  86. package/mysql-core/columns/binary.d.ts +2 -0
  87. package/mysql-core/columns/binary.js +3 -1
  88. package/mysql-core/columns/binary.js.map +1 -1
  89. package/mysql-core/columns/boolean.cjs +1 -1
  90. package/mysql-core/columns/boolean.cjs.map +1 -1
  91. package/mysql-core/columns/boolean.d.cts +1 -0
  92. package/mysql-core/columns/boolean.d.ts +1 -0
  93. package/mysql-core/columns/boolean.js +1 -1
  94. package/mysql-core/columns/boolean.js.map +1 -1
  95. package/mysql-core/columns/char.cjs +3 -1
  96. package/mysql-core/columns/char.cjs.map +1 -1
  97. package/mysql-core/columns/char.d.cts +4 -2
  98. package/mysql-core/columns/char.d.ts +4 -2
  99. package/mysql-core/columns/char.js +3 -1
  100. package/mysql-core/columns/char.js.map +1 -1
  101. package/mysql-core/columns/custom.cjs +4 -2
  102. package/mysql-core/columns/custom.cjs.map +1 -1
  103. package/mysql-core/columns/custom.d.cts +10 -3
  104. package/mysql-core/columns/custom.d.ts +10 -3
  105. package/mysql-core/columns/custom.js +4 -2
  106. package/mysql-core/columns/custom.js.map +1 -1
  107. package/mysql-core/columns/date.cjs +4 -2
  108. package/mysql-core/columns/date.cjs.map +1 -1
  109. package/mysql-core/columns/date.d.cts +3 -1
  110. package/mysql-core/columns/date.d.ts +3 -1
  111. package/mysql-core/columns/date.js +4 -2
  112. package/mysql-core/columns/date.js.map +1 -1
  113. package/mysql-core/columns/datetime.cjs +4 -2
  114. package/mysql-core/columns/datetime.cjs.map +1 -1
  115. package/mysql-core/columns/datetime.d.cts +3 -1
  116. package/mysql-core/columns/datetime.d.ts +3 -1
  117. package/mysql-core/columns/datetime.js +4 -2
  118. package/mysql-core/columns/datetime.js.map +1 -1
  119. package/mysql-core/columns/decimal.cjs +3 -1
  120. package/mysql-core/columns/decimal.cjs.map +1 -1
  121. package/mysql-core/columns/decimal.d.cts +2 -0
  122. package/mysql-core/columns/decimal.d.ts +2 -0
  123. package/mysql-core/columns/decimal.js +3 -1
  124. package/mysql-core/columns/decimal.js.map +1 -1
  125. package/mysql-core/columns/double.cjs +3 -1
  126. package/mysql-core/columns/double.cjs.map +1 -1
  127. package/mysql-core/columns/double.d.cts +2 -0
  128. package/mysql-core/columns/double.d.ts +2 -0
  129. package/mysql-core/columns/double.js +3 -1
  130. package/mysql-core/columns/double.js.map +1 -1
  131. package/mysql-core/columns/enum.cjs +3 -1
  132. package/mysql-core/columns/enum.cjs.map +1 -1
  133. package/mysql-core/columns/enum.d.cts +2 -1
  134. package/mysql-core/columns/enum.d.ts +2 -1
  135. package/mysql-core/columns/enum.js +3 -1
  136. package/mysql-core/columns/enum.js.map +1 -1
  137. package/mysql-core/columns/float.cjs +1 -1
  138. package/mysql-core/columns/float.cjs.map +1 -1
  139. package/mysql-core/columns/float.d.cts +1 -0
  140. package/mysql-core/columns/float.d.ts +1 -0
  141. package/mysql-core/columns/float.js +1 -1
  142. package/mysql-core/columns/float.js.map +1 -1
  143. package/mysql-core/columns/int.cjs +3 -1
  144. package/mysql-core/columns/int.cjs.map +1 -1
  145. package/mysql-core/columns/int.d.cts +2 -0
  146. package/mysql-core/columns/int.d.ts +2 -0
  147. package/mysql-core/columns/int.js +3 -1
  148. package/mysql-core/columns/int.js.map +1 -1
  149. package/mysql-core/columns/json.cjs +1 -1
  150. package/mysql-core/columns/json.cjs.map +1 -1
  151. package/mysql-core/columns/json.d.cts +1 -0
  152. package/mysql-core/columns/json.d.ts +1 -0
  153. package/mysql-core/columns/json.js +1 -1
  154. package/mysql-core/columns/json.js.map +1 -1
  155. package/mysql-core/columns/mediumint.cjs +3 -1
  156. package/mysql-core/columns/mediumint.cjs.map +1 -1
  157. package/mysql-core/columns/mediumint.d.cts +2 -0
  158. package/mysql-core/columns/mediumint.d.ts +2 -0
  159. package/mysql-core/columns/mediumint.js +3 -1
  160. package/mysql-core/columns/mediumint.js.map +1 -1
  161. package/mysql-core/columns/real.cjs +3 -1
  162. package/mysql-core/columns/real.cjs.map +1 -1
  163. package/mysql-core/columns/real.d.cts +2 -0
  164. package/mysql-core/columns/real.d.ts +2 -0
  165. package/mysql-core/columns/real.js +3 -1
  166. package/mysql-core/columns/real.js.map +1 -1
  167. package/mysql-core/columns/serial.cjs +1 -1
  168. package/mysql-core/columns/serial.cjs.map +1 -1
  169. package/mysql-core/columns/serial.d.cts +1 -0
  170. package/mysql-core/columns/serial.d.ts +1 -0
  171. package/mysql-core/columns/serial.js +1 -1
  172. package/mysql-core/columns/serial.js.map +1 -1
  173. package/mysql-core/columns/smallint.cjs +3 -1
  174. package/mysql-core/columns/smallint.cjs.map +1 -1
  175. package/mysql-core/columns/smallint.d.cts +2 -0
  176. package/mysql-core/columns/smallint.d.ts +2 -0
  177. package/mysql-core/columns/smallint.js +3 -1
  178. package/mysql-core/columns/smallint.js.map +1 -1
  179. package/mysql-core/columns/text.cjs +9 -4
  180. package/mysql-core/columns/text.cjs.map +1 -1
  181. package/mysql-core/columns/text.d.cts +10 -2
  182. package/mysql-core/columns/text.d.ts +10 -2
  183. package/mysql-core/columns/text.js +9 -4
  184. package/mysql-core/columns/text.js.map +1 -1
  185. package/mysql-core/columns/time.cjs +3 -1
  186. package/mysql-core/columns/time.cjs.map +1 -1
  187. package/mysql-core/columns/time.d.cts +2 -0
  188. package/mysql-core/columns/time.d.ts +2 -0
  189. package/mysql-core/columns/time.js +3 -1
  190. package/mysql-core/columns/time.js.map +1 -1
  191. package/mysql-core/columns/timestamp.cjs +4 -2
  192. package/mysql-core/columns/timestamp.cjs.map +1 -1
  193. package/mysql-core/columns/timestamp.d.cts +3 -1
  194. package/mysql-core/columns/timestamp.d.ts +3 -1
  195. package/mysql-core/columns/timestamp.js +4 -2
  196. package/mysql-core/columns/timestamp.js.map +1 -1
  197. package/mysql-core/columns/tinyint.cjs +3 -1
  198. package/mysql-core/columns/tinyint.cjs.map +1 -1
  199. package/mysql-core/columns/tinyint.d.cts +2 -0
  200. package/mysql-core/columns/tinyint.d.ts +2 -0
  201. package/mysql-core/columns/tinyint.js +3 -1
  202. package/mysql-core/columns/tinyint.js.map +1 -1
  203. package/mysql-core/columns/varbinary.cjs +4 -2
  204. package/mysql-core/columns/varbinary.cjs.map +1 -1
  205. package/mysql-core/columns/varbinary.d.cts +2 -1
  206. package/mysql-core/columns/varbinary.d.ts +2 -1
  207. package/mysql-core/columns/varbinary.js +4 -2
  208. package/mysql-core/columns/varbinary.js.map +1 -1
  209. package/mysql-core/columns/varchar.cjs +3 -1
  210. package/mysql-core/columns/varchar.cjs.map +1 -1
  211. package/mysql-core/columns/varchar.d.cts +3 -2
  212. package/mysql-core/columns/varchar.d.ts +3 -2
  213. package/mysql-core/columns/varchar.js +3 -1
  214. package/mysql-core/columns/varchar.js.map +1 -1
  215. package/mysql-core/columns/year.cjs +1 -1
  216. package/mysql-core/columns/year.cjs.map +1 -1
  217. package/mysql-core/columns/year.d.cts +1 -0
  218. package/mysql-core/columns/year.d.ts +1 -0
  219. package/mysql-core/columns/year.js +1 -1
  220. package/mysql-core/columns/year.js.map +1 -1
  221. package/mysql-core/db.cjs +2 -1
  222. package/mysql-core/db.cjs.map +1 -1
  223. package/mysql-core/db.js +2 -1
  224. package/mysql-core/db.js.map +1 -1
  225. package/mysql-core/dialect.cjs +14 -7
  226. package/mysql-core/dialect.cjs.map +1 -1
  227. package/mysql-core/dialect.d.cts +5 -1
  228. package/mysql-core/dialect.d.ts +5 -1
  229. package/mysql-core/dialect.js +14 -7
  230. package/mysql-core/dialect.js.map +1 -1
  231. package/mysql-core/foreign-keys.cjs +3 -3
  232. package/mysql-core/foreign-keys.cjs.map +1 -1
  233. package/mysql-core/foreign-keys.d.cts +1 -1
  234. package/mysql-core/foreign-keys.d.ts +1 -1
  235. package/mysql-core/foreign-keys.js +3 -3
  236. package/mysql-core/foreign-keys.js.map +1 -1
  237. package/mysql-core/query-builders/count.cjs +4 -4
  238. package/mysql-core/query-builders/count.cjs.map +1 -1
  239. package/mysql-core/query-builders/count.d.cts +2 -3
  240. package/mysql-core/query-builders/count.d.ts +2 -3
  241. package/mysql-core/query-builders/count.js +2 -2
  242. package/mysql-core/query-builders/count.js.map +1 -1
  243. package/mysql-core/query-builders/query-builder.cjs +6 -1
  244. package/mysql-core/query-builders/query-builder.cjs.map +1 -1
  245. package/mysql-core/query-builders/query-builder.d.cts +4 -0
  246. package/mysql-core/query-builders/query-builder.d.ts +4 -0
  247. package/mysql-core/query-builders/query-builder.js +7 -2
  248. package/mysql-core/query-builders/query-builder.js.map +1 -1
  249. package/mysql-core/table.cjs +4 -1
  250. package/mysql-core/table.cjs.map +1 -1
  251. package/mysql-core/table.d.cts +8 -1
  252. package/mysql-core/table.d.ts +8 -1
  253. package/mysql-core/table.js +4 -1
  254. package/mysql-core/table.js.map +1 -1
  255. package/mysql-core/unique-constraint.cjs +2 -2
  256. package/mysql-core/unique-constraint.cjs.map +1 -1
  257. package/mysql-core/unique-constraint.d.cts +1 -1
  258. package/mysql-core/unique-constraint.d.ts +1 -1
  259. package/mysql-core/unique-constraint.js +2 -2
  260. package/mysql-core/unique-constraint.js.map +1 -1
  261. package/mysql-proxy/driver.cjs +1 -1
  262. package/mysql-proxy/driver.cjs.map +1 -1
  263. package/mysql-proxy/driver.js +1 -1
  264. package/mysql-proxy/driver.js.map +1 -1
  265. package/mysql2/driver.cjs +3 -3
  266. package/mysql2/driver.cjs.map +1 -1
  267. package/mysql2/driver.js +2 -2
  268. package/mysql2/driver.js.map +1 -1
  269. package/neon-http/driver.cjs +1 -1
  270. package/neon-http/driver.cjs.map +1 -1
  271. package/neon-http/driver.js +1 -1
  272. package/neon-http/driver.js.map +1 -1
  273. package/neon-serverless/driver.cjs +1 -1
  274. package/neon-serverless/driver.cjs.map +1 -1
  275. package/neon-serverless/driver.js +1 -1
  276. package/neon-serverless/driver.js.map +1 -1
  277. package/node-postgres/driver.cjs +1 -1
  278. package/node-postgres/driver.cjs.map +1 -1
  279. package/node-postgres/driver.js +1 -1
  280. package/node-postgres/driver.js.map +1 -1
  281. package/op-sqlite/driver.cjs +1 -1
  282. package/op-sqlite/driver.cjs.map +1 -1
  283. package/op-sqlite/driver.js +1 -1
  284. package/op-sqlite/driver.js.map +1 -1
  285. package/package.json +121 -49
  286. package/pg-core/columns/all.cjs +96 -0
  287. package/pg-core/columns/all.cjs.map +1 -0
  288. package/pg-core/columns/all.d.cts +67 -0
  289. package/pg-core/columns/all.d.ts +67 -0
  290. package/pg-core/columns/all.js +72 -0
  291. package/pg-core/columns/all.js.map +1 -0
  292. package/pg-core/columns/bigint.cjs +3 -1
  293. package/pg-core/columns/bigint.cjs.map +1 -1
  294. package/pg-core/columns/bigint.d.cts +2 -2
  295. package/pg-core/columns/bigint.d.ts +2 -2
  296. package/pg-core/columns/bigint.js +3 -1
  297. package/pg-core/columns/bigint.js.map +1 -1
  298. package/pg-core/columns/bigserial.cjs +4 -2
  299. package/pg-core/columns/bigserial.cjs.map +1 -1
  300. package/pg-core/columns/bigserial.d.cts +2 -2
  301. package/pg-core/columns/bigserial.d.ts +2 -2
  302. package/pg-core/columns/bigserial.js +4 -2
  303. package/pg-core/columns/bigserial.js.map +1 -1
  304. package/pg-core/columns/boolean.cjs +1 -1
  305. package/pg-core/columns/boolean.cjs.map +1 -1
  306. package/pg-core/columns/boolean.d.cts +1 -0
  307. package/pg-core/columns/boolean.d.ts +1 -0
  308. package/pg-core/columns/boolean.js +1 -1
  309. package/pg-core/columns/boolean.js.map +1 -1
  310. package/pg-core/columns/char.cjs +3 -1
  311. package/pg-core/columns/char.cjs.map +1 -1
  312. package/pg-core/columns/char.d.cts +5 -3
  313. package/pg-core/columns/char.d.ts +5 -3
  314. package/pg-core/columns/char.js +3 -1
  315. package/pg-core/columns/char.js.map +1 -1
  316. package/pg-core/columns/cidr.cjs +1 -1
  317. package/pg-core/columns/cidr.cjs.map +1 -1
  318. package/pg-core/columns/cidr.d.cts +1 -0
  319. package/pg-core/columns/cidr.d.ts +1 -0
  320. package/pg-core/columns/cidr.js +1 -1
  321. package/pg-core/columns/cidr.js.map +1 -1
  322. package/pg-core/columns/common.cjs +3 -1
  323. package/pg-core/columns/common.cjs.map +1 -1
  324. package/pg-core/columns/common.d.cts +3 -2
  325. package/pg-core/columns/common.d.ts +3 -2
  326. package/pg-core/columns/common.js +3 -1
  327. package/pg-core/columns/common.js.map +1 -1
  328. package/pg-core/columns/custom.cjs +4 -2
  329. package/pg-core/columns/custom.cjs.map +1 -1
  330. package/pg-core/columns/custom.d.cts +10 -3
  331. package/pg-core/columns/custom.d.ts +10 -3
  332. package/pg-core/columns/custom.js +4 -2
  333. package/pg-core/columns/custom.js.map +1 -1
  334. package/pg-core/columns/date.cjs +3 -1
  335. package/pg-core/columns/date.cjs.map +1 -1
  336. package/pg-core/columns/date.d.cts +7 -6
  337. package/pg-core/columns/date.d.ts +7 -6
  338. package/pg-core/columns/date.js +3 -1
  339. package/pg-core/columns/date.js.map +1 -1
  340. package/pg-core/columns/double-precision.cjs +1 -1
  341. package/pg-core/columns/double-precision.cjs.map +1 -1
  342. package/pg-core/columns/double-precision.d.cts +1 -0
  343. package/pg-core/columns/double-precision.d.ts +1 -0
  344. package/pg-core/columns/double-precision.js +1 -1
  345. package/pg-core/columns/double-precision.js.map +1 -1
  346. package/pg-core/columns/enum.cjs +1 -1
  347. package/pg-core/columns/enum.cjs.map +1 -1
  348. package/pg-core/columns/enum.d.cts +3 -1
  349. package/pg-core/columns/enum.d.ts +3 -1
  350. package/pg-core/columns/enum.js +1 -1
  351. package/pg-core/columns/enum.js.map +1 -1
  352. package/pg-core/columns/index.cjs +2 -0
  353. package/pg-core/columns/index.cjs.map +1 -1
  354. package/pg-core/columns/index.d.cts +1 -0
  355. package/pg-core/columns/index.d.ts +1 -0
  356. package/pg-core/columns/index.js +1 -0
  357. package/pg-core/columns/index.js.map +1 -1
  358. package/pg-core/columns/inet.cjs +1 -1
  359. package/pg-core/columns/inet.cjs.map +1 -1
  360. package/pg-core/columns/inet.d.cts +1 -0
  361. package/pg-core/columns/inet.d.ts +1 -0
  362. package/pg-core/columns/inet.js +1 -1
  363. package/pg-core/columns/inet.js.map +1 -1
  364. package/pg-core/columns/integer.cjs +1 -1
  365. package/pg-core/columns/integer.cjs.map +1 -1
  366. package/pg-core/columns/integer.d.cts +1 -0
  367. package/pg-core/columns/integer.d.ts +1 -0
  368. package/pg-core/columns/integer.js +1 -1
  369. package/pg-core/columns/integer.js.map +1 -1
  370. package/pg-core/columns/interval.cjs +3 -1
  371. package/pg-core/columns/interval.cjs.map +1 -1
  372. package/pg-core/columns/interval.d.cts +2 -0
  373. package/pg-core/columns/interval.d.ts +2 -0
  374. package/pg-core/columns/interval.js +3 -1
  375. package/pg-core/columns/interval.js.map +1 -1
  376. package/pg-core/columns/json.cjs +1 -1
  377. package/pg-core/columns/json.cjs.map +1 -1
  378. package/pg-core/columns/json.d.cts +1 -0
  379. package/pg-core/columns/json.d.ts +1 -0
  380. package/pg-core/columns/json.js +1 -1
  381. package/pg-core/columns/json.js.map +1 -1
  382. package/pg-core/columns/jsonb.cjs +1 -1
  383. package/pg-core/columns/jsonb.cjs.map +1 -1
  384. package/pg-core/columns/jsonb.d.cts +1 -0
  385. package/pg-core/columns/jsonb.d.ts +1 -0
  386. package/pg-core/columns/jsonb.js +1 -1
  387. package/pg-core/columns/jsonb.js.map +1 -1
  388. package/pg-core/columns/line.cjs +3 -1
  389. package/pg-core/columns/line.cjs.map +1 -1
  390. package/pg-core/columns/line.d.cts +3 -1
  391. package/pg-core/columns/line.d.ts +3 -1
  392. package/pg-core/columns/line.js +3 -1
  393. package/pg-core/columns/line.js.map +1 -1
  394. package/pg-core/columns/macaddr.cjs +1 -1
  395. package/pg-core/columns/macaddr.cjs.map +1 -1
  396. package/pg-core/columns/macaddr.d.cts +1 -0
  397. package/pg-core/columns/macaddr.d.ts +1 -0
  398. package/pg-core/columns/macaddr.js +1 -1
  399. package/pg-core/columns/macaddr.js.map +1 -1
  400. package/pg-core/columns/macaddr8.cjs +1 -1
  401. package/pg-core/columns/macaddr8.cjs.map +1 -1
  402. package/pg-core/columns/macaddr8.d.cts +1 -0
  403. package/pg-core/columns/macaddr8.d.ts +1 -0
  404. package/pg-core/columns/macaddr8.js +1 -1
  405. package/pg-core/columns/macaddr8.js.map +1 -1
  406. package/pg-core/columns/numeric.cjs +3 -1
  407. package/pg-core/columns/numeric.cjs.map +1 -1
  408. package/pg-core/columns/numeric.d.cts +6 -3
  409. package/pg-core/columns/numeric.d.ts +6 -3
  410. package/pg-core/columns/numeric.js +3 -1
  411. package/pg-core/columns/numeric.js.map +1 -1
  412. package/pg-core/columns/point.cjs +3 -1
  413. package/pg-core/columns/point.cjs.map +1 -1
  414. package/pg-core/columns/point.d.cts +5 -3
  415. package/pg-core/columns/point.d.ts +5 -3
  416. package/pg-core/columns/point.js +3 -1
  417. package/pg-core/columns/point.js.map +1 -1
  418. package/pg-core/columns/postgis_extension/geometry.cjs +6 -4
  419. package/pg-core/columns/postgis_extension/geometry.cjs.map +1 -1
  420. package/pg-core/columns/postgis_extension/geometry.d.cts +4 -3
  421. package/pg-core/columns/postgis_extension/geometry.d.ts +4 -3
  422. package/pg-core/columns/postgis_extension/geometry.js +3 -1
  423. package/pg-core/columns/postgis_extension/geometry.js.map +1 -1
  424. package/pg-core/columns/real.cjs +1 -1
  425. package/pg-core/columns/real.cjs.map +1 -1
  426. package/pg-core/columns/real.d.cts +2 -1
  427. package/pg-core/columns/real.d.ts +2 -1
  428. package/pg-core/columns/real.js +1 -1
  429. package/pg-core/columns/real.js.map +1 -1
  430. package/pg-core/columns/serial.cjs +1 -1
  431. package/pg-core/columns/serial.cjs.map +1 -1
  432. package/pg-core/columns/serial.d.cts +2 -1
  433. package/pg-core/columns/serial.d.ts +2 -1
  434. package/pg-core/columns/serial.js +1 -1
  435. package/pg-core/columns/serial.js.map +1 -1
  436. package/pg-core/columns/smallint.cjs +1 -1
  437. package/pg-core/columns/smallint.cjs.map +1 -1
  438. package/pg-core/columns/smallint.d.cts +1 -0
  439. package/pg-core/columns/smallint.d.ts +1 -0
  440. package/pg-core/columns/smallint.js +1 -1
  441. package/pg-core/columns/smallint.js.map +1 -1
  442. package/pg-core/columns/smallserial.cjs +1 -1
  443. package/pg-core/columns/smallserial.cjs.map +1 -1
  444. package/pg-core/columns/smallserial.d.cts +2 -1
  445. package/pg-core/columns/smallserial.d.ts +2 -1
  446. package/pg-core/columns/smallserial.js +1 -1
  447. package/pg-core/columns/smallserial.js.map +1 -1
  448. package/pg-core/columns/text.cjs +3 -1
  449. package/pg-core/columns/text.cjs.map +1 -1
  450. package/pg-core/columns/text.d.cts +4 -2
  451. package/pg-core/columns/text.d.ts +4 -2
  452. package/pg-core/columns/text.js +3 -1
  453. package/pg-core/columns/text.js.map +1 -1
  454. package/pg-core/columns/time.cjs +3 -1
  455. package/pg-core/columns/time.cjs.map +1 -1
  456. package/pg-core/columns/time.d.cts +2 -0
  457. package/pg-core/columns/time.d.ts +2 -0
  458. package/pg-core/columns/time.js +3 -1
  459. package/pg-core/columns/time.js.map +1 -1
  460. package/pg-core/columns/timestamp.cjs +5 -3
  461. package/pg-core/columns/timestamp.cjs.map +1 -1
  462. package/pg-core/columns/timestamp.d.cts +5 -3
  463. package/pg-core/columns/timestamp.d.ts +5 -3
  464. package/pg-core/columns/timestamp.js +5 -3
  465. package/pg-core/columns/timestamp.js.map +1 -1
  466. package/pg-core/columns/uuid.cjs +1 -1
  467. package/pg-core/columns/uuid.cjs.map +1 -1
  468. package/pg-core/columns/uuid.d.cts +1 -0
  469. package/pg-core/columns/uuid.d.ts +1 -0
  470. package/pg-core/columns/uuid.js +1 -1
  471. package/pg-core/columns/uuid.js.map +1 -1
  472. package/pg-core/columns/varchar.cjs +3 -1
  473. package/pg-core/columns/varchar.cjs.map +1 -1
  474. package/pg-core/columns/varchar.d.cts +5 -3
  475. package/pg-core/columns/varchar.d.ts +5 -3
  476. package/pg-core/columns/varchar.js +3 -1
  477. package/pg-core/columns/varchar.js.map +1 -1
  478. package/pg-core/columns/vector_extension/bit.cjs +3 -1
  479. package/pg-core/columns/vector_extension/bit.cjs.map +1 -1
  480. package/pg-core/columns/vector_extension/bit.d.cts +1 -0
  481. package/pg-core/columns/vector_extension/bit.d.ts +1 -0
  482. package/pg-core/columns/vector_extension/bit.js +3 -1
  483. package/pg-core/columns/vector_extension/bit.js.map +1 -1
  484. package/pg-core/columns/vector_extension/halfvec.cjs +3 -1
  485. package/pg-core/columns/vector_extension/halfvec.cjs.map +1 -1
  486. package/pg-core/columns/vector_extension/halfvec.d.cts +1 -0
  487. package/pg-core/columns/vector_extension/halfvec.d.ts +1 -0
  488. package/pg-core/columns/vector_extension/halfvec.js +3 -1
  489. package/pg-core/columns/vector_extension/halfvec.js.map +1 -1
  490. package/pg-core/columns/vector_extension/sparsevec.cjs +3 -1
  491. package/pg-core/columns/vector_extension/sparsevec.cjs.map +1 -1
  492. package/pg-core/columns/vector_extension/sparsevec.d.cts +1 -0
  493. package/pg-core/columns/vector_extension/sparsevec.d.ts +1 -0
  494. package/pg-core/columns/vector_extension/sparsevec.js +3 -1
  495. package/pg-core/columns/vector_extension/sparsevec.js.map +1 -1
  496. package/pg-core/columns/vector_extension/vector.cjs +3 -1
  497. package/pg-core/columns/vector_extension/vector.cjs.map +1 -1
  498. package/pg-core/columns/vector_extension/vector.d.cts +1 -0
  499. package/pg-core/columns/vector_extension/vector.d.ts +1 -0
  500. package/pg-core/columns/vector_extension/vector.js +3 -1
  501. package/pg-core/columns/vector_extension/vector.js.map +1 -1
  502. package/pg-core/db.cjs +2 -1
  503. package/pg-core/db.cjs.map +1 -1
  504. package/pg-core/db.js +2 -1
  505. package/pg-core/db.js.map +1 -1
  506. package/pg-core/dialect.cjs +13 -4
  507. package/pg-core/dialect.cjs.map +1 -1
  508. package/pg-core/dialect.d.cts +5 -1
  509. package/pg-core/dialect.d.ts +5 -1
  510. package/pg-core/dialect.js +13 -4
  511. package/pg-core/dialect.js.map +1 -1
  512. package/pg-core/foreign-keys.cjs +3 -3
  513. package/pg-core/foreign-keys.cjs.map +1 -1
  514. package/pg-core/foreign-keys.d.cts +1 -1
  515. package/pg-core/foreign-keys.d.ts +1 -1
  516. package/pg-core/foreign-keys.js +3 -3
  517. package/pg-core/foreign-keys.js.map +1 -1
  518. package/pg-core/indexes.cjs +3 -3
  519. package/pg-core/indexes.cjs.map +1 -1
  520. package/pg-core/indexes.js +3 -3
  521. package/pg-core/indexes.js.map +1 -1
  522. package/pg-core/query-builders/count.cjs +4 -4
  523. package/pg-core/query-builders/count.cjs.map +1 -1
  524. package/pg-core/query-builders/count.d.cts +2 -3
  525. package/pg-core/query-builders/count.d.ts +2 -3
  526. package/pg-core/query-builders/count.js +2 -2
  527. package/pg-core/query-builders/count.js.map +1 -1
  528. package/pg-core/query-builders/insert.cjs +2 -2
  529. package/pg-core/query-builders/insert.cjs.map +1 -1
  530. package/pg-core/query-builders/insert.js +2 -2
  531. package/pg-core/query-builders/insert.js.map +1 -1
  532. package/pg-core/query-builders/query-builder.cjs +6 -1
  533. package/pg-core/query-builders/query-builder.cjs.map +1 -1
  534. package/pg-core/query-builders/query-builder.d.cts +4 -0
  535. package/pg-core/query-builders/query-builder.d.ts +4 -0
  536. package/pg-core/query-builders/query-builder.js +7 -2
  537. package/pg-core/query-builders/query-builder.js.map +1 -1
  538. package/pg-core/table.cjs +6 -2
  539. package/pg-core/table.cjs.map +1 -1
  540. package/pg-core/table.d.cts +7 -0
  541. package/pg-core/table.d.ts +7 -0
  542. package/pg-core/table.js +6 -2
  543. package/pg-core/table.js.map +1 -1
  544. package/pg-core/unique-constraint.cjs +2 -2
  545. package/pg-core/unique-constraint.cjs.map +1 -1
  546. package/pg-core/unique-constraint.d.cts +1 -1
  547. package/pg-core/unique-constraint.d.ts +1 -1
  548. package/pg-core/unique-constraint.js +2 -2
  549. package/pg-core/unique-constraint.js.map +1 -1
  550. package/pg-proxy/driver.cjs +1 -1
  551. package/pg-proxy/driver.cjs.map +1 -1
  552. package/pg-proxy/driver.js +1 -1
  553. package/pg-proxy/driver.js.map +1 -1
  554. package/pglite/driver.cjs +1 -1
  555. package/pglite/driver.cjs.map +1 -1
  556. package/pglite/driver.js +1 -1
  557. package/pglite/driver.js.map +1 -1
  558. package/planetscale-serverless/driver.cjs +1 -1
  559. package/planetscale-serverless/driver.cjs.map +1 -1
  560. package/planetscale-serverless/driver.js +1 -1
  561. package/planetscale-serverless/driver.js.map +1 -1
  562. package/postgres-js/driver.cjs +1 -1
  563. package/postgres-js/driver.cjs.map +1 -1
  564. package/postgres-js/driver.js +1 -1
  565. package/postgres-js/driver.js.map +1 -1
  566. package/sql/functions/vector.cjs.map +1 -1
  567. package/sql/functions/vector.d.cts +1 -1
  568. package/sql/functions/vector.d.ts +1 -1
  569. package/sql/functions/vector.js.map +1 -1
  570. package/sql/sql.cjs +4 -2
  571. package/sql/sql.cjs.map +1 -1
  572. package/sql/sql.d.cts +2 -0
  573. package/sql/sql.d.ts +2 -0
  574. package/sql/sql.js +4 -2
  575. package/sql/sql.js.map +1 -1
  576. package/sql-js/driver.cjs +1 -1
  577. package/sql-js/driver.cjs.map +1 -1
  578. package/sql-js/driver.js +1 -1
  579. package/sql-js/driver.js.map +1 -1
  580. package/sqlite-core/columns/all.cjs +44 -0
  581. package/sqlite-core/columns/all.cjs.map +1 -0
  582. package/sqlite-core/columns/all.d.cts +15 -0
  583. package/sqlite-core/columns/all.d.ts +15 -0
  584. package/sqlite-core/columns/all.js +20 -0
  585. package/sqlite-core/columns/all.js.map +1 -0
  586. package/sqlite-core/columns/blob.cjs +3 -1
  587. package/sqlite-core/columns/blob.cjs.map +1 -1
  588. package/sqlite-core/columns/blob.d.cts +3 -1
  589. package/sqlite-core/columns/blob.d.ts +3 -1
  590. package/sqlite-core/columns/blob.js +3 -1
  591. package/sqlite-core/columns/blob.js.map +1 -1
  592. package/sqlite-core/columns/custom.cjs +5 -3
  593. package/sqlite-core/columns/custom.cjs.map +1 -1
  594. package/sqlite-core/columns/custom.d.cts +10 -3
  595. package/sqlite-core/columns/custom.d.ts +10 -3
  596. package/sqlite-core/columns/custom.js +5 -3
  597. package/sqlite-core/columns/custom.js.map +1 -1
  598. package/sqlite-core/columns/integer.cjs +3 -1
  599. package/sqlite-core/columns/integer.cjs.map +1 -1
  600. package/sqlite-core/columns/integer.d.cts +3 -1
  601. package/sqlite-core/columns/integer.d.ts +3 -1
  602. package/sqlite-core/columns/integer.js +3 -1
  603. package/sqlite-core/columns/integer.js.map +1 -1
  604. package/sqlite-core/columns/numeric.cjs +1 -1
  605. package/sqlite-core/columns/numeric.cjs.map +1 -1
  606. package/sqlite-core/columns/numeric.d.cts +1 -0
  607. package/sqlite-core/columns/numeric.d.ts +1 -0
  608. package/sqlite-core/columns/numeric.js +1 -1
  609. package/sqlite-core/columns/numeric.js.map +1 -1
  610. package/sqlite-core/columns/real.cjs +1 -1
  611. package/sqlite-core/columns/real.cjs.map +1 -1
  612. package/sqlite-core/columns/real.d.cts +1 -0
  613. package/sqlite-core/columns/real.d.ts +1 -0
  614. package/sqlite-core/columns/real.js +1 -1
  615. package/sqlite-core/columns/real.js.map +1 -1
  616. package/sqlite-core/columns/text.cjs +7 -2
  617. package/sqlite-core/columns/text.cjs.map +1 -1
  618. package/sqlite-core/columns/text.d.cts +4 -2
  619. package/sqlite-core/columns/text.d.ts +4 -2
  620. package/sqlite-core/columns/text.js +7 -2
  621. package/sqlite-core/columns/text.js.map +1 -1
  622. package/sqlite-core/db.cjs +2 -1
  623. package/sqlite-core/db.cjs.map +1 -1
  624. package/sqlite-core/db.js +2 -1
  625. package/sqlite-core/db.js.map +1 -1
  626. package/sqlite-core/dialect.cjs +14 -8
  627. package/sqlite-core/dialect.cjs.map +1 -1
  628. package/sqlite-core/dialect.d.cts +5 -1
  629. package/sqlite-core/dialect.d.ts +5 -1
  630. package/sqlite-core/dialect.js +14 -8
  631. package/sqlite-core/dialect.js.map +1 -1
  632. package/sqlite-core/foreign-keys.cjs +3 -3
  633. package/sqlite-core/foreign-keys.cjs.map +1 -1
  634. package/sqlite-core/foreign-keys.d.cts +1 -1
  635. package/sqlite-core/foreign-keys.d.ts +1 -1
  636. package/sqlite-core/foreign-keys.js +3 -3
  637. package/sqlite-core/foreign-keys.js.map +1 -1
  638. package/sqlite-core/query-builders/count.cjs +4 -4
  639. package/sqlite-core/query-builders/count.cjs.map +1 -1
  640. package/sqlite-core/query-builders/count.d.cts +2 -3
  641. package/sqlite-core/query-builders/count.d.ts +2 -3
  642. package/sqlite-core/query-builders/count.js +2 -2
  643. package/sqlite-core/query-builders/count.js.map +1 -1
  644. package/sqlite-core/query-builders/query-builder.cjs +6 -1
  645. package/sqlite-core/query-builders/query-builder.cjs.map +1 -1
  646. package/sqlite-core/query-builders/query-builder.d.cts +4 -0
  647. package/sqlite-core/query-builders/query-builder.d.ts +4 -0
  648. package/sqlite-core/query-builders/query-builder.js +8 -3
  649. package/sqlite-core/query-builders/query-builder.js.map +1 -1
  650. package/sqlite-core/query-builders/raw.cjs.map +1 -1
  651. package/sqlite-core/query-builders/raw.d.cts +2 -2
  652. package/sqlite-core/query-builders/raw.d.ts +2 -2
  653. package/sqlite-core/query-builders/raw.js.map +1 -1
  654. package/sqlite-core/table.cjs +4 -1
  655. package/sqlite-core/table.cjs.map +1 -1
  656. package/sqlite-core/table.d.cts +7 -0
  657. package/sqlite-core/table.d.ts +7 -0
  658. package/sqlite-core/table.js +4 -1
  659. package/sqlite-core/table.js.map +1 -1
  660. package/sqlite-core/unique-constraint.cjs +2 -2
  661. package/sqlite-core/unique-constraint.cjs.map +1 -1
  662. package/sqlite-core/unique-constraint.d.cts +1 -1
  663. package/sqlite-core/unique-constraint.d.ts +1 -1
  664. package/sqlite-core/unique-constraint.js +2 -2
  665. package/sqlite-core/unique-constraint.js.map +1 -1
  666. package/sqlite-proxy/driver.cjs +1 -1
  667. package/sqlite-proxy/driver.cjs.map +1 -1
  668. package/sqlite-proxy/driver.js +1 -1
  669. package/sqlite-proxy/driver.js.map +1 -1
  670. package/table.cjs +6 -8
  671. package/table.cjs.map +1 -1
  672. package/table.js +1 -2
  673. package/table.js.map +1 -1
  674. package/table.utils.cjs +29 -0
  675. package/table.utils.cjs.map +1 -0
  676. package/table.utils.d.cts +1 -0
  677. package/table.utils.d.ts +1 -0
  678. package/table.utils.js +5 -0
  679. package/table.utils.js.map +1 -0
  680. package/tidb-serverless/driver.cjs +1 -1
  681. package/tidb-serverless/driver.cjs.map +1 -1
  682. package/tidb-serverless/driver.js +1 -1
  683. package/tidb-serverless/driver.js.map +1 -1
  684. package/utils.cjs +8 -0
  685. package/utils.cjs.map +1 -1
  686. package/utils.d.cts +2 -0
  687. package/utils.d.ts +2 -0
  688. package/utils.js +7 -0
  689. package/utils.js.map +1 -1
  690. package/vercel-postgres/driver.cjs +1 -1
  691. package/vercel-postgres/driver.cjs.map +1 -1
  692. package/vercel-postgres/driver.js +1 -1
  693. package/vercel-postgres/driver.js.map +1 -1
  694. package/version.cjs +1 -1
  695. package/version.d.cts +1 -1
  696. package/version.d.ts +1 -1
  697. package/version.js +1 -1
  698. package/xata-http/driver.cjs +1 -1
  699. package/xata-http/driver.cjs.map +1 -1
  700. package/xata-http/driver.js +1 -1
  701. package/xata-http/driver.js.map +1 -1
@@ -1,6 +1,6 @@
1
1
  import { entityKind } from "../entity.js";
2
2
  import type { AnySQLiteColumn, SQLiteColumn } from "./columns/index.js";
3
- import { SQLiteTable } from "./table.js";
3
+ import type { SQLiteTable } from "./table.js";
4
4
  export type UpdateDeleteAction = 'cascade' | 'restrict' | 'no action' | 'set null' | 'set default';
5
5
  export type Reference = () => {
6
6
  readonly name?: string;
@@ -1,5 +1,5 @@
1
1
  import { entityKind } from "../entity.js";
2
- import { SQLiteTable } from "./table.js";
2
+ import { TableName } from "../table.utils.js";
3
3
  class ForeignKeyBuilder {
4
4
  static [entityKind] = "SQLiteForeignKeyBuilder";
5
5
  /** @internal */
@@ -47,9 +47,9 @@ class ForeignKey {
47
47
  const columnNames = columns.map((column) => column.name);
48
48
  const foreignColumnNames = foreignColumns.map((column) => column.name);
49
49
  const chunks = [
50
- this.table[SQLiteTable.Symbol.Name],
50
+ this.table[TableName],
51
51
  ...columnNames,
52
- foreignColumns[0].table[SQLiteTable.Symbol.Name],
52
+ foreignColumns[0].table[TableName],
53
53
  ...foreignColumnNames
54
54
  ];
55
55
  return name ?? `${chunks.join("_")}_fk`;
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/sqlite-core/foreign-keys.ts"],"sourcesContent":["import { entityKind } from '~/entity.ts';\nimport type { AnySQLiteColumn, SQLiteColumn } from './columns/index.ts';\nimport { SQLiteTable } from './table.ts';\n\nexport type UpdateDeleteAction = 'cascade' | 'restrict' | 'no action' | 'set null' | 'set default';\n\nexport type Reference = () => {\n\treadonly name?: string;\n\treadonly columns: SQLiteColumn[];\n\treadonly foreignTable: SQLiteTable;\n\treadonly foreignColumns: SQLiteColumn[];\n};\n\nexport class ForeignKeyBuilder {\n\tstatic readonly [entityKind]: string = 'SQLiteForeignKeyBuilder';\n\n\tdeclare _: {\n\t\tbrand: 'SQLiteForeignKeyBuilder';\n\t\tforeignTableName: 'TForeignTableName';\n\t};\n\n\t/** @internal */\n\treference: Reference;\n\n\t/** @internal */\n\t_onUpdate: UpdateDeleteAction | undefined;\n\n\t/** @internal */\n\t_onDelete: UpdateDeleteAction | undefined;\n\n\tconstructor(\n\t\tconfig: () => {\n\t\t\tname?: string;\n\t\t\tcolumns: SQLiteColumn[];\n\t\t\tforeignColumns: SQLiteColumn[];\n\t\t},\n\t\tactions?: {\n\t\t\tonUpdate?: UpdateDeleteAction;\n\t\t\tonDelete?: UpdateDeleteAction;\n\t\t} | undefined,\n\t) {\n\t\tthis.reference = () => {\n\t\t\tconst { name, columns, foreignColumns } = config();\n\t\t\treturn { name, columns, foreignTable: foreignColumns[0]!.table as SQLiteTable, foreignColumns };\n\t\t};\n\t\tif (actions) {\n\t\t\tthis._onUpdate = actions.onUpdate;\n\t\t\tthis._onDelete = actions.onDelete;\n\t\t}\n\t}\n\n\tonUpdate(action: UpdateDeleteAction): this {\n\t\tthis._onUpdate = action;\n\t\treturn this;\n\t}\n\n\tonDelete(action: UpdateDeleteAction): this {\n\t\tthis._onDelete = action;\n\t\treturn this;\n\t}\n\n\t/** @internal */\n\tbuild(table: SQLiteTable): ForeignKey {\n\t\treturn new ForeignKey(table, this);\n\t}\n}\n\nexport class ForeignKey {\n\tstatic readonly [entityKind]: string = 'SQLiteForeignKey';\n\n\treadonly reference: Reference;\n\treadonly onUpdate: UpdateDeleteAction | undefined;\n\treadonly onDelete: UpdateDeleteAction | undefined;\n\n\tconstructor(readonly table: SQLiteTable, builder: ForeignKeyBuilder) {\n\t\tthis.reference = builder.reference;\n\t\tthis.onUpdate = builder._onUpdate;\n\t\tthis.onDelete = builder._onDelete;\n\t}\n\n\tgetName(): string {\n\t\tconst { name, columns, foreignColumns } = this.reference();\n\t\tconst columnNames = columns.map((column) => column.name);\n\t\tconst foreignColumnNames = foreignColumns.map((column) => column.name);\n\t\tconst chunks = [\n\t\t\tthis.table[SQLiteTable.Symbol.Name],\n\t\t\t...columnNames,\n\t\t\tforeignColumns[0]!.table[SQLiteTable.Symbol.Name],\n\t\t\t...foreignColumnNames,\n\t\t];\n\t\treturn name ?? `${chunks.join('_')}_fk`;\n\t}\n}\n\ntype ColumnsWithTable<\n\tTTableName extends string,\n\tTColumns extends SQLiteColumn[],\n> = { [Key in keyof TColumns]: AnySQLiteColumn<{ tableName: TTableName }> };\n\n/**\n * @deprecated please use `foreignKey({ columns: [], foreignColumns: [] })` syntax without callback\n * @param config\n * @returns\n */\nexport function foreignKey<\n\tTTableName extends string,\n\tTForeignTableName extends string,\n\tTColumns extends [AnySQLiteColumn<{ tableName: TTableName }>, ...AnySQLiteColumn<{ tableName: TTableName }>[]],\n>(\n\tconfig: () => {\n\t\tname?: string;\n\t\tcolumns: TColumns;\n\t\tforeignColumns: ColumnsWithTable<TForeignTableName, TColumns>;\n\t},\n): ForeignKeyBuilder;\nexport function foreignKey<\n\tTTableName extends string,\n\tTForeignTableName extends string,\n\tTColumns extends [AnySQLiteColumn<{ tableName: TTableName }>, ...AnySQLiteColumn<{ tableName: TTableName }>[]],\n>(\n\tconfig: {\n\t\tname?: string;\n\t\tcolumns: TColumns;\n\t\tforeignColumns: ColumnsWithTable<TForeignTableName, TColumns>;\n\t},\n): ForeignKeyBuilder;\nexport function foreignKey(\n\tconfig: any,\n): ForeignKeyBuilder {\n\tfunction mappedConfig() {\n\t\tif (typeof config === 'function') {\n\t\t\tconst { name, columns, foreignColumns } = config();\n\t\t\treturn {\n\t\t\t\tname,\n\t\t\t\tcolumns,\n\t\t\t\tforeignColumns,\n\t\t\t};\n\t\t}\n\t\treturn config;\n\t}\n\n\treturn new ForeignKeyBuilder(mappedConfig);\n}\n"],"mappings":"AAAA,SAAS,kBAAkB;AAE3B,SAAS,mBAAmB;AAWrB,MAAM,kBAAkB;AAAA,EAC9B,QAAiB,UAAU,IAAY;AAAA;AAAA,EAQvC;AAAA;AAAA,EAGA;AAAA;AAAA,EAGA;AAAA,EAEA,YACC,QAKA,SAIC;AACD,SAAK,YAAY,MAAM;AACtB,YAAM,EAAE,MAAM,SAAS,eAAe,IAAI,OAAO;AACjD,aAAO,EAAE,MAAM,SAAS,cAAc,eAAe,CAAC,EAAG,OAAsB,eAAe;AAAA,IAC/F;AACA,QAAI,SAAS;AACZ,WAAK,YAAY,QAAQ;AACzB,WAAK,YAAY,QAAQ;AAAA,IAC1B;AAAA,EACD;AAAA,EAEA,SAAS,QAAkC;AAC1C,SAAK,YAAY;AACjB,WAAO;AAAA,EACR;AAAA,EAEA,SAAS,QAAkC;AAC1C,SAAK,YAAY;AACjB,WAAO;AAAA,EACR;AAAA;AAAA,EAGA,MAAM,OAAgC;AACrC,WAAO,IAAI,WAAW,OAAO,IAAI;AAAA,EAClC;AACD;AAEO,MAAM,WAAW;AAAA,EAOvB,YAAqB,OAAoB,SAA4B;AAAhD;AACpB,SAAK,YAAY,QAAQ;AACzB,SAAK,WAAW,QAAQ;AACxB,SAAK,WAAW,QAAQ;AAAA,EACzB;AAAA,EAVA,QAAiB,UAAU,IAAY;AAAA,EAE9B;AAAA,EACA;AAAA,EACA;AAAA,EAQT,UAAkB;AACjB,UAAM,EAAE,MAAM,SAAS,eAAe,IAAI,KAAK,UAAU;AACzD,UAAM,cAAc,QAAQ,IAAI,CAAC,WAAW,OAAO,IAAI;AACvD,UAAM,qBAAqB,eAAe,IAAI,CAAC,WAAW,OAAO,IAAI;AACrE,UAAM,SAAS;AAAA,MACd,KAAK,MAAM,YAAY,OAAO,IAAI;AAAA,MAClC,GAAG;AAAA,MACH,eAAe,CAAC,EAAG,MAAM,YAAY,OAAO,IAAI;AAAA,MAChD,GAAG;AAAA,IACJ;AACA,WAAO,QAAQ,GAAG,OAAO,KAAK,GAAG,CAAC;AAAA,EACnC;AACD;AAkCO,SAAS,WACf,QACoB;AACpB,WAAS,eAAe;AACvB,QAAI,OAAO,WAAW,YAAY;AACjC,YAAM,EAAE,MAAM,SAAS,eAAe,IAAI,OAAO;AACjD,aAAO;AAAA,QACN;AAAA,QACA;AAAA,QACA;AAAA,MACD;AAAA,IACD;AACA,WAAO;AAAA,EACR;AAEA,SAAO,IAAI,kBAAkB,YAAY;AAC1C;","names":[]}
1
+ {"version":3,"sources":["../../src/sqlite-core/foreign-keys.ts"],"sourcesContent":["import { entityKind } from '~/entity.ts';\nimport { TableName } from '~/table.utils.ts';\nimport type { AnySQLiteColumn, SQLiteColumn } from './columns/index.ts';\nimport type { SQLiteTable } from './table.ts';\n\nexport type UpdateDeleteAction = 'cascade' | 'restrict' | 'no action' | 'set null' | 'set default';\n\nexport type Reference = () => {\n\treadonly name?: string;\n\treadonly columns: SQLiteColumn[];\n\treadonly foreignTable: SQLiteTable;\n\treadonly foreignColumns: SQLiteColumn[];\n};\n\nexport class ForeignKeyBuilder {\n\tstatic readonly [entityKind]: string = 'SQLiteForeignKeyBuilder';\n\n\tdeclare _: {\n\t\tbrand: 'SQLiteForeignKeyBuilder';\n\t\tforeignTableName: 'TForeignTableName';\n\t};\n\n\t/** @internal */\n\treference: Reference;\n\n\t/** @internal */\n\t_onUpdate: UpdateDeleteAction | undefined;\n\n\t/** @internal */\n\t_onDelete: UpdateDeleteAction | undefined;\n\n\tconstructor(\n\t\tconfig: () => {\n\t\t\tname?: string;\n\t\t\tcolumns: SQLiteColumn[];\n\t\t\tforeignColumns: SQLiteColumn[];\n\t\t},\n\t\tactions?: {\n\t\t\tonUpdate?: UpdateDeleteAction;\n\t\t\tonDelete?: UpdateDeleteAction;\n\t\t} | undefined,\n\t) {\n\t\tthis.reference = () => {\n\t\t\tconst { name, columns, foreignColumns } = config();\n\t\t\treturn { name, columns, foreignTable: foreignColumns[0]!.table as SQLiteTable, foreignColumns };\n\t\t};\n\t\tif (actions) {\n\t\t\tthis._onUpdate = actions.onUpdate;\n\t\t\tthis._onDelete = actions.onDelete;\n\t\t}\n\t}\n\n\tonUpdate(action: UpdateDeleteAction): this {\n\t\tthis._onUpdate = action;\n\t\treturn this;\n\t}\n\n\tonDelete(action: UpdateDeleteAction): this {\n\t\tthis._onDelete = action;\n\t\treturn this;\n\t}\n\n\t/** @internal */\n\tbuild(table: SQLiteTable): ForeignKey {\n\t\treturn new ForeignKey(table, this);\n\t}\n}\n\nexport class ForeignKey {\n\tstatic readonly [entityKind]: string = 'SQLiteForeignKey';\n\n\treadonly reference: Reference;\n\treadonly onUpdate: UpdateDeleteAction | undefined;\n\treadonly onDelete: UpdateDeleteAction | undefined;\n\n\tconstructor(readonly table: SQLiteTable, builder: ForeignKeyBuilder) {\n\t\tthis.reference = builder.reference;\n\t\tthis.onUpdate = builder._onUpdate;\n\t\tthis.onDelete = builder._onDelete;\n\t}\n\n\tgetName(): string {\n\t\tconst { name, columns, foreignColumns } = this.reference();\n\t\tconst columnNames = columns.map((column) => column.name);\n\t\tconst foreignColumnNames = foreignColumns.map((column) => column.name);\n\t\tconst chunks = [\n\t\t\tthis.table[TableName],\n\t\t\t...columnNames,\n\t\t\tforeignColumns[0]!.table[TableName],\n\t\t\t...foreignColumnNames,\n\t\t];\n\t\treturn name ?? `${chunks.join('_')}_fk`;\n\t}\n}\n\ntype ColumnsWithTable<\n\tTTableName extends string,\n\tTColumns extends SQLiteColumn[],\n> = { [Key in keyof TColumns]: AnySQLiteColumn<{ tableName: TTableName }> };\n\n/**\n * @deprecated please use `foreignKey({ columns: [], foreignColumns: [] })` syntax without callback\n * @param config\n * @returns\n */\nexport function foreignKey<\n\tTTableName extends string,\n\tTForeignTableName extends string,\n\tTColumns extends [AnySQLiteColumn<{ tableName: TTableName }>, ...AnySQLiteColumn<{ tableName: TTableName }>[]],\n>(\n\tconfig: () => {\n\t\tname?: string;\n\t\tcolumns: TColumns;\n\t\tforeignColumns: ColumnsWithTable<TForeignTableName, TColumns>;\n\t},\n): ForeignKeyBuilder;\nexport function foreignKey<\n\tTTableName extends string,\n\tTForeignTableName extends string,\n\tTColumns extends [AnySQLiteColumn<{ tableName: TTableName }>, ...AnySQLiteColumn<{ tableName: TTableName }>[]],\n>(\n\tconfig: {\n\t\tname?: string;\n\t\tcolumns: TColumns;\n\t\tforeignColumns: ColumnsWithTable<TForeignTableName, TColumns>;\n\t},\n): ForeignKeyBuilder;\nexport function foreignKey(\n\tconfig: any,\n): ForeignKeyBuilder {\n\tfunction mappedConfig() {\n\t\tif (typeof config === 'function') {\n\t\t\tconst { name, columns, foreignColumns } = config();\n\t\t\treturn {\n\t\t\t\tname,\n\t\t\t\tcolumns,\n\t\t\t\tforeignColumns,\n\t\t\t};\n\t\t}\n\t\treturn config;\n\t}\n\n\treturn new ForeignKeyBuilder(mappedConfig);\n}\n"],"mappings":"AAAA,SAAS,kBAAkB;AAC3B,SAAS,iBAAiB;AAanB,MAAM,kBAAkB;AAAA,EAC9B,QAAiB,UAAU,IAAY;AAAA;AAAA,EAQvC;AAAA;AAAA,EAGA;AAAA;AAAA,EAGA;AAAA,EAEA,YACC,QAKA,SAIC;AACD,SAAK,YAAY,MAAM;AACtB,YAAM,EAAE,MAAM,SAAS,eAAe,IAAI,OAAO;AACjD,aAAO,EAAE,MAAM,SAAS,cAAc,eAAe,CAAC,EAAG,OAAsB,eAAe;AAAA,IAC/F;AACA,QAAI,SAAS;AACZ,WAAK,YAAY,QAAQ;AACzB,WAAK,YAAY,QAAQ;AAAA,IAC1B;AAAA,EACD;AAAA,EAEA,SAAS,QAAkC;AAC1C,SAAK,YAAY;AACjB,WAAO;AAAA,EACR;AAAA,EAEA,SAAS,QAAkC;AAC1C,SAAK,YAAY;AACjB,WAAO;AAAA,EACR;AAAA;AAAA,EAGA,MAAM,OAAgC;AACrC,WAAO,IAAI,WAAW,OAAO,IAAI;AAAA,EAClC;AACD;AAEO,MAAM,WAAW;AAAA,EAOvB,YAAqB,OAAoB,SAA4B;AAAhD;AACpB,SAAK,YAAY,QAAQ;AACzB,SAAK,WAAW,QAAQ;AACxB,SAAK,WAAW,QAAQ;AAAA,EACzB;AAAA,EAVA,QAAiB,UAAU,IAAY;AAAA,EAE9B;AAAA,EACA;AAAA,EACA;AAAA,EAQT,UAAkB;AACjB,UAAM,EAAE,MAAM,SAAS,eAAe,IAAI,KAAK,UAAU;AACzD,UAAM,cAAc,QAAQ,IAAI,CAAC,WAAW,OAAO,IAAI;AACvD,UAAM,qBAAqB,eAAe,IAAI,CAAC,WAAW,OAAO,IAAI;AACrE,UAAM,SAAS;AAAA,MACd,KAAK,MAAM,SAAS;AAAA,MACpB,GAAG;AAAA,MACH,eAAe,CAAC,EAAG,MAAM,SAAS;AAAA,MAClC,GAAG;AAAA,IACJ;AACA,WAAO,QAAQ,GAAG,OAAO,KAAK,GAAG,CAAC;AAAA,EACnC;AACD;AAkCO,SAAS,WACf,QACoB;AACpB,WAAS,eAAe;AACvB,QAAI,OAAO,WAAW,YAAY;AACjC,YAAM,EAAE,MAAM,SAAS,eAAe,IAAI,OAAO;AACjD,aAAO;AAAA,QACN;AAAA,QACA;AAAA,QACA;AAAA,MACD;AAAA,IACD;AACA,WAAO;AAAA,EACR;AAEA,SAAO,IAAI,kBAAkB,YAAY;AAC1C;","names":[]}
@@ -21,7 +21,7 @@ __export(count_exports, {
21
21
  SQLiteCountBuilder: () => SQLiteCountBuilder
22
22
  });
23
23
  module.exports = __toCommonJS(count_exports);
24
- var import__ = require("../../index.cjs");
24
+ var import_entity = require("../../entity.cjs");
25
25
  var import_sql = require("../../sql/sql.cjs");
26
26
  class SQLiteCountBuilder extends import_sql.SQL {
27
27
  constructor(params) {
@@ -34,14 +34,14 @@ class SQLiteCountBuilder extends import_sql.SQL {
34
34
  );
35
35
  }
36
36
  sql;
37
- static [import__.entityKind] = "SQLiteCountBuilderAsync";
37
+ static [import_entity.entityKind] = "SQLiteCountBuilderAsync";
38
38
  [Symbol.toStringTag] = "SQLiteCountBuilderAsync";
39
39
  session;
40
40
  static buildEmbeddedCount(source, filters) {
41
- return import__.sql`(select count(*) from ${source}${import__.sql.raw(" where ").if(filters)}${filters})`;
41
+ return import_sql.sql`(select count(*) from ${source}${import_sql.sql.raw(" where ").if(filters)}${filters})`;
42
42
  }
43
43
  static buildCount(source, filters) {
44
- return import__.sql`select count(*) from ${source}${import__.sql.raw(" where ").if(filters)}${filters}`;
44
+ return import_sql.sql`select count(*) from ${source}${import_sql.sql.raw(" where ").if(filters)}${filters}`;
45
45
  }
46
46
  then(onfulfilled, onrejected) {
47
47
  return Promise.resolve(this.session.count(this.sql)).then(
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/sqlite-core/query-builders/count.ts"],"sourcesContent":["import { entityKind, sql } from '~/index.ts';\nimport type { SQLWrapper } from '~/sql/sql.ts';\nimport { SQL } from '~/sql/sql.ts';\nimport type { SQLiteSession } from '../session.ts';\nimport type { SQLiteTable } from '../table.ts';\nimport type { SQLiteView } from '../view.ts';\n\nexport class SQLiteCountBuilder<\n\tTSession extends SQLiteSession<any, any, any, any>,\n> extends SQL<number> implements Promise<number>, SQLWrapper {\n\tprivate sql: SQL<number>;\n\n\tstatic readonly [entityKind] = 'SQLiteCountBuilderAsync';\n\t[Symbol.toStringTag] = 'SQLiteCountBuilderAsync';\n\n\tprivate session: TSession;\n\n\tprivate static buildEmbeddedCount(\n\t\tsource: SQLiteTable | SQLiteView | SQL | SQLWrapper,\n\t\tfilters?: SQL<unknown>,\n\t): SQL<number> {\n\t\treturn sql<number>`(select count(*) from ${source}${sql.raw(' where ').if(filters)}${filters})`;\n\t}\n\n\tprivate static buildCount(\n\t\tsource: SQLiteTable | SQLiteView | SQL | SQLWrapper,\n\t\tfilters?: SQL<unknown>,\n\t): SQL<number> {\n\t\treturn sql<number>`select count(*) from ${source}${sql.raw(' where ').if(filters)}${filters}`;\n\t}\n\n\tconstructor(\n\t\treadonly params: {\n\t\t\tsource: SQLiteTable | SQLiteView | SQL | SQLWrapper;\n\t\t\tfilters?: SQL<unknown>;\n\t\t\tsession: TSession;\n\t\t},\n\t) {\n\t\tsuper(SQLiteCountBuilder.buildEmbeddedCount(params.source, params.filters).queryChunks);\n\n\t\tthis.session = params.session;\n\n\t\tthis.sql = SQLiteCountBuilder.buildCount(\n\t\t\tparams.source,\n\t\t\tparams.filters,\n\t\t);\n\t}\n\n\tthen<TResult1 = number, TResult2 = never>(\n\t\tonfulfilled?: ((value: number) => TResult1 | PromiseLike<TResult1>) | null | undefined,\n\t\tonrejected?: ((reason: any) => TResult2 | PromiseLike<TResult2>) | null | undefined,\n\t): Promise<TResult1 | TResult2> {\n\t\treturn Promise.resolve(this.session.count(this.sql)).then(\n\t\t\tonfulfilled,\n\t\t\tonrejected,\n\t\t);\n\t}\n\n\tcatch(\n\t\tonRejected?: ((reason: any) => never | PromiseLike<never>) | null | undefined,\n\t): Promise<number> {\n\t\treturn this.then(undefined, onRejected);\n\t}\n\n\tfinally(onFinally?: (() => void) | null | undefined): Promise<number> {\n\t\treturn this.then(\n\t\t\t(value) => {\n\t\t\t\tonFinally?.();\n\t\t\t\treturn value;\n\t\t\t},\n\t\t\t(reason) => {\n\t\t\t\tonFinally?.();\n\t\t\t\tthrow reason;\n\t\t\t},\n\t\t);\n\t}\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,eAAgC;AAEhC,iBAAoB;AAKb,MAAM,2BAEH,eAAmD;AAAA,EAsB5D,YACU,QAKR;AACD,UAAM,mBAAmB,mBAAmB,OAAO,QAAQ,OAAO,OAAO,EAAE,WAAW;AAN7E;AAQT,SAAK,UAAU,OAAO;AAEtB,SAAK,MAAM,mBAAmB;AAAA,MAC7B,OAAO;AAAA,MACP,OAAO;AAAA,IACR;AAAA,EACD;AAAA,EApCQ;AAAA,EAER,QAAiB,mBAAU,IAAI;AAAA,EAC/B,CAAC,OAAO,WAAW,IAAI;AAAA,EAEf;AAAA,EAER,OAAe,mBACd,QACA,SACc;AACd,WAAO,qCAAoC,MAAM,GAAG,aAAI,IAAI,SAAS,EAAE,GAAG,OAAO,CAAC,GAAG,OAAO;AAAA,EAC7F;AAAA,EAEA,OAAe,WACd,QACA,SACc;AACd,WAAO,oCAAmC,MAAM,GAAG,aAAI,IAAI,SAAS,EAAE,GAAG,OAAO,CAAC,GAAG,OAAO;AAAA,EAC5F;AAAA,EAmBA,KACC,aACA,YAC+B;AAC/B,WAAO,QAAQ,QAAQ,KAAK,QAAQ,MAAM,KAAK,GAAG,CAAC,EAAE;AAAA,MACpD;AAAA,MACA;AAAA,IACD;AAAA,EACD;AAAA,EAEA,MACC,YACkB;AAClB,WAAO,KAAK,KAAK,QAAW,UAAU;AAAA,EACvC;AAAA,EAEA,QAAQ,WAA8D;AACrE,WAAO,KAAK;AAAA,MACX,CAAC,UAAU;AACV,oBAAY;AACZ,eAAO;AAAA,MACR;AAAA,MACA,CAAC,WAAW;AACX,oBAAY;AACZ,cAAM;AAAA,MACP;AAAA,IACD;AAAA,EACD;AACD;","names":[]}
1
+ {"version":3,"sources":["../../../src/sqlite-core/query-builders/count.ts"],"sourcesContent":["import { entityKind } from '~/entity.ts';\nimport { SQL, sql, type SQLWrapper } from '~/sql/sql.ts';\nimport type { SQLiteSession } from '../session.ts';\nimport type { SQLiteTable } from '../table.ts';\nimport type { SQLiteView } from '../view.ts';\n\nexport class SQLiteCountBuilder<\n\tTSession extends SQLiteSession<any, any, any, any>,\n> extends SQL<number> implements Promise<number>, SQLWrapper {\n\tprivate sql: SQL<number>;\n\n\tstatic readonly [entityKind] = 'SQLiteCountBuilderAsync';\n\t[Symbol.toStringTag] = 'SQLiteCountBuilderAsync';\n\n\tprivate session: TSession;\n\n\tprivate static buildEmbeddedCount(\n\t\tsource: SQLiteTable | SQLiteView | SQL | SQLWrapper,\n\t\tfilters?: SQL<unknown>,\n\t): SQL<number> {\n\t\treturn sql<number>`(select count(*) from ${source}${sql.raw(' where ').if(filters)}${filters})`;\n\t}\n\n\tprivate static buildCount(\n\t\tsource: SQLiteTable | SQLiteView | SQL | SQLWrapper,\n\t\tfilters?: SQL<unknown>,\n\t): SQL<number> {\n\t\treturn sql<number>`select count(*) from ${source}${sql.raw(' where ').if(filters)}${filters}`;\n\t}\n\n\tconstructor(\n\t\treadonly params: {\n\t\t\tsource: SQLiteTable | SQLiteView | SQL | SQLWrapper;\n\t\t\tfilters?: SQL<unknown>;\n\t\t\tsession: TSession;\n\t\t},\n\t) {\n\t\tsuper(SQLiteCountBuilder.buildEmbeddedCount(params.source, params.filters).queryChunks);\n\n\t\tthis.session = params.session;\n\n\t\tthis.sql = SQLiteCountBuilder.buildCount(\n\t\t\tparams.source,\n\t\t\tparams.filters,\n\t\t);\n\t}\n\n\tthen<TResult1 = number, TResult2 = never>(\n\t\tonfulfilled?: ((value: number) => TResult1 | PromiseLike<TResult1>) | null | undefined,\n\t\tonrejected?: ((reason: any) => TResult2 | PromiseLike<TResult2>) | null | undefined,\n\t): Promise<TResult1 | TResult2> {\n\t\treturn Promise.resolve(this.session.count(this.sql)).then(\n\t\t\tonfulfilled,\n\t\t\tonrejected,\n\t\t);\n\t}\n\n\tcatch(\n\t\tonRejected?: ((reason: any) => never | PromiseLike<never>) | null | undefined,\n\t): Promise<number> {\n\t\treturn this.then(undefined, onRejected);\n\t}\n\n\tfinally(onFinally?: (() => void) | null | undefined): Promise<number> {\n\t\treturn this.then(\n\t\t\t(value) => {\n\t\t\t\tonFinally?.();\n\t\t\t\treturn value;\n\t\t\t},\n\t\t\t(reason) => {\n\t\t\t\tonFinally?.();\n\t\t\t\tthrow reason;\n\t\t\t},\n\t\t);\n\t}\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,oBAA2B;AAC3B,iBAA0C;AAKnC,MAAM,2BAEH,eAAmD;AAAA,EAsB5D,YACU,QAKR;AACD,UAAM,mBAAmB,mBAAmB,OAAO,QAAQ,OAAO,OAAO,EAAE,WAAW;AAN7E;AAQT,SAAK,UAAU,OAAO;AAEtB,SAAK,MAAM,mBAAmB;AAAA,MAC7B,OAAO;AAAA,MACP,OAAO;AAAA,IACR;AAAA,EACD;AAAA,EApCQ;AAAA,EAER,QAAiB,wBAAU,IAAI;AAAA,EAC/B,CAAC,OAAO,WAAW,IAAI;AAAA,EAEf;AAAA,EAER,OAAe,mBACd,QACA,SACc;AACd,WAAO,uCAAoC,MAAM,GAAG,eAAI,IAAI,SAAS,EAAE,GAAG,OAAO,CAAC,GAAG,OAAO;AAAA,EAC7F;AAAA,EAEA,OAAe,WACd,QACA,SACc;AACd,WAAO,sCAAmC,MAAM,GAAG,eAAI,IAAI,SAAS,EAAE,GAAG,OAAO,CAAC,GAAG,OAAO;AAAA,EAC5F;AAAA,EAmBA,KACC,aACA,YAC+B;AAC/B,WAAO,QAAQ,QAAQ,KAAK,QAAQ,MAAM,KAAK,GAAG,CAAC,EAAE;AAAA,MACpD;AAAA,MACA;AAAA,IACD;AAAA,EACD;AAAA,EAEA,MACC,YACkB;AAClB,WAAO,KAAK,KAAK,QAAW,UAAU;AAAA,EACvC;AAAA,EAEA,QAAQ,WAA8D;AACrE,WAAO,KAAK;AAAA,MACX,CAAC,UAAU;AACV,oBAAY;AACZ,eAAO;AAAA,MACR;AAAA,MACA,CAAC,WAAW;AACX,oBAAY;AACZ,cAAM;AAAA,MACP;AAAA,IACD;AAAA,EACD;AACD;","names":[]}
@@ -1,6 +1,5 @@
1
- import { entityKind } from "../../index.cjs";
2
- import type { SQLWrapper } from "../../sql/sql.cjs";
3
- import { SQL } from "../../sql/sql.cjs";
1
+ import { entityKind } from "../../entity.cjs";
2
+ import { SQL, type SQLWrapper } from "../../sql/sql.cjs";
4
3
  import type { SQLiteSession } from "../session.cjs";
5
4
  import type { SQLiteTable } from "../table.cjs";
6
5
  import type { SQLiteView } from "../view.cjs";
@@ -1,6 +1,5 @@
1
- import { entityKind } from "../../index.js";
2
- import type { SQLWrapper } from "../../sql/sql.js";
3
- import { SQL } from "../../sql/sql.js";
1
+ import { entityKind } from "../../entity.js";
2
+ import { SQL, type SQLWrapper } from "../../sql/sql.js";
4
3
  import type { SQLiteSession } from "../session.js";
5
4
  import type { SQLiteTable } from "../table.js";
6
5
  import type { SQLiteView } from "../view.js";
@@ -1,5 +1,5 @@
1
- import { entityKind, sql } from "../../index.js";
2
- import { SQL } from "../../sql/sql.js";
1
+ import { entityKind } from "../../entity.js";
2
+ import { SQL, sql } from "../../sql/sql.js";
3
3
  class SQLiteCountBuilder extends SQL {
4
4
  constructor(params) {
5
5
  super(SQLiteCountBuilder.buildEmbeddedCount(params.source, params.filters).queryChunks);
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/sqlite-core/query-builders/count.ts"],"sourcesContent":["import { entityKind, sql } from '~/index.ts';\nimport type { SQLWrapper } from '~/sql/sql.ts';\nimport { SQL } from '~/sql/sql.ts';\nimport type { SQLiteSession } from '../session.ts';\nimport type { SQLiteTable } from '../table.ts';\nimport type { SQLiteView } from '../view.ts';\n\nexport class SQLiteCountBuilder<\n\tTSession extends SQLiteSession<any, any, any, any>,\n> extends SQL<number> implements Promise<number>, SQLWrapper {\n\tprivate sql: SQL<number>;\n\n\tstatic readonly [entityKind] = 'SQLiteCountBuilderAsync';\n\t[Symbol.toStringTag] = 'SQLiteCountBuilderAsync';\n\n\tprivate session: TSession;\n\n\tprivate static buildEmbeddedCount(\n\t\tsource: SQLiteTable | SQLiteView | SQL | SQLWrapper,\n\t\tfilters?: SQL<unknown>,\n\t): SQL<number> {\n\t\treturn sql<number>`(select count(*) from ${source}${sql.raw(' where ').if(filters)}${filters})`;\n\t}\n\n\tprivate static buildCount(\n\t\tsource: SQLiteTable | SQLiteView | SQL | SQLWrapper,\n\t\tfilters?: SQL<unknown>,\n\t): SQL<number> {\n\t\treturn sql<number>`select count(*) from ${source}${sql.raw(' where ').if(filters)}${filters}`;\n\t}\n\n\tconstructor(\n\t\treadonly params: {\n\t\t\tsource: SQLiteTable | SQLiteView | SQL | SQLWrapper;\n\t\t\tfilters?: SQL<unknown>;\n\t\t\tsession: TSession;\n\t\t},\n\t) {\n\t\tsuper(SQLiteCountBuilder.buildEmbeddedCount(params.source, params.filters).queryChunks);\n\n\t\tthis.session = params.session;\n\n\t\tthis.sql = SQLiteCountBuilder.buildCount(\n\t\t\tparams.source,\n\t\t\tparams.filters,\n\t\t);\n\t}\n\n\tthen<TResult1 = number, TResult2 = never>(\n\t\tonfulfilled?: ((value: number) => TResult1 | PromiseLike<TResult1>) | null | undefined,\n\t\tonrejected?: ((reason: any) => TResult2 | PromiseLike<TResult2>) | null | undefined,\n\t): Promise<TResult1 | TResult2> {\n\t\treturn Promise.resolve(this.session.count(this.sql)).then(\n\t\t\tonfulfilled,\n\t\t\tonrejected,\n\t\t);\n\t}\n\n\tcatch(\n\t\tonRejected?: ((reason: any) => never | PromiseLike<never>) | null | undefined,\n\t): Promise<number> {\n\t\treturn this.then(undefined, onRejected);\n\t}\n\n\tfinally(onFinally?: (() => void) | null | undefined): Promise<number> {\n\t\treturn this.then(\n\t\t\t(value) => {\n\t\t\t\tonFinally?.();\n\t\t\t\treturn value;\n\t\t\t},\n\t\t\t(reason) => {\n\t\t\t\tonFinally?.();\n\t\t\t\tthrow reason;\n\t\t\t},\n\t\t);\n\t}\n}\n"],"mappings":"AAAA,SAAS,YAAY,WAAW;AAEhC,SAAS,WAAW;AAKb,MAAM,2BAEH,IAAmD;AAAA,EAsB5D,YACU,QAKR;AACD,UAAM,mBAAmB,mBAAmB,OAAO,QAAQ,OAAO,OAAO,EAAE,WAAW;AAN7E;AAQT,SAAK,UAAU,OAAO;AAEtB,SAAK,MAAM,mBAAmB;AAAA,MAC7B,OAAO;AAAA,MACP,OAAO;AAAA,IACR;AAAA,EACD;AAAA,EApCQ;AAAA,EAER,QAAiB,UAAU,IAAI;AAAA,EAC/B,CAAC,OAAO,WAAW,IAAI;AAAA,EAEf;AAAA,EAER,OAAe,mBACd,QACA,SACc;AACd,WAAO,4BAAoC,MAAM,GAAG,IAAI,IAAI,SAAS,EAAE,GAAG,OAAO,CAAC,GAAG,OAAO;AAAA,EAC7F;AAAA,EAEA,OAAe,WACd,QACA,SACc;AACd,WAAO,2BAAmC,MAAM,GAAG,IAAI,IAAI,SAAS,EAAE,GAAG,OAAO,CAAC,GAAG,OAAO;AAAA,EAC5F;AAAA,EAmBA,KACC,aACA,YAC+B;AAC/B,WAAO,QAAQ,QAAQ,KAAK,QAAQ,MAAM,KAAK,GAAG,CAAC,EAAE;AAAA,MACpD;AAAA,MACA;AAAA,IACD;AAAA,EACD;AAAA,EAEA,MACC,YACkB;AAClB,WAAO,KAAK,KAAK,QAAW,UAAU;AAAA,EACvC;AAAA,EAEA,QAAQ,WAA8D;AACrE,WAAO,KAAK;AAAA,MACX,CAAC,UAAU;AACV,oBAAY;AACZ,eAAO;AAAA,MACR;AAAA,MACA,CAAC,WAAW;AACX,oBAAY;AACZ,cAAM;AAAA,MACP;AAAA,IACD;AAAA,EACD;AACD;","names":[]}
1
+ {"version":3,"sources":["../../../src/sqlite-core/query-builders/count.ts"],"sourcesContent":["import { entityKind } from '~/entity.ts';\nimport { SQL, sql, type SQLWrapper } from '~/sql/sql.ts';\nimport type { SQLiteSession } from '../session.ts';\nimport type { SQLiteTable } from '../table.ts';\nimport type { SQLiteView } from '../view.ts';\n\nexport class SQLiteCountBuilder<\n\tTSession extends SQLiteSession<any, any, any, any>,\n> extends SQL<number> implements Promise<number>, SQLWrapper {\n\tprivate sql: SQL<number>;\n\n\tstatic readonly [entityKind] = 'SQLiteCountBuilderAsync';\n\t[Symbol.toStringTag] = 'SQLiteCountBuilderAsync';\n\n\tprivate session: TSession;\n\n\tprivate static buildEmbeddedCount(\n\t\tsource: SQLiteTable | SQLiteView | SQL | SQLWrapper,\n\t\tfilters?: SQL<unknown>,\n\t): SQL<number> {\n\t\treturn sql<number>`(select count(*) from ${source}${sql.raw(' where ').if(filters)}${filters})`;\n\t}\n\n\tprivate static buildCount(\n\t\tsource: SQLiteTable | SQLiteView | SQL | SQLWrapper,\n\t\tfilters?: SQL<unknown>,\n\t): SQL<number> {\n\t\treturn sql<number>`select count(*) from ${source}${sql.raw(' where ').if(filters)}${filters}`;\n\t}\n\n\tconstructor(\n\t\treadonly params: {\n\t\t\tsource: SQLiteTable | SQLiteView | SQL | SQLWrapper;\n\t\t\tfilters?: SQL<unknown>;\n\t\t\tsession: TSession;\n\t\t},\n\t) {\n\t\tsuper(SQLiteCountBuilder.buildEmbeddedCount(params.source, params.filters).queryChunks);\n\n\t\tthis.session = params.session;\n\n\t\tthis.sql = SQLiteCountBuilder.buildCount(\n\t\t\tparams.source,\n\t\t\tparams.filters,\n\t\t);\n\t}\n\n\tthen<TResult1 = number, TResult2 = never>(\n\t\tonfulfilled?: ((value: number) => TResult1 | PromiseLike<TResult1>) | null | undefined,\n\t\tonrejected?: ((reason: any) => TResult2 | PromiseLike<TResult2>) | null | undefined,\n\t): Promise<TResult1 | TResult2> {\n\t\treturn Promise.resolve(this.session.count(this.sql)).then(\n\t\t\tonfulfilled,\n\t\t\tonrejected,\n\t\t);\n\t}\n\n\tcatch(\n\t\tonRejected?: ((reason: any) => never | PromiseLike<never>) | null | undefined,\n\t): Promise<number> {\n\t\treturn this.then(undefined, onRejected);\n\t}\n\n\tfinally(onFinally?: (() => void) | null | undefined): Promise<number> {\n\t\treturn this.then(\n\t\t\t(value) => {\n\t\t\t\tonFinally?.();\n\t\t\t\treturn value;\n\t\t\t},\n\t\t\t(reason) => {\n\t\t\t\tonFinally?.();\n\t\t\t\tthrow reason;\n\t\t\t},\n\t\t);\n\t}\n}\n"],"mappings":"AAAA,SAAS,kBAAkB;AAC3B,SAAS,KAAK,WAA4B;AAKnC,MAAM,2BAEH,IAAmD;AAAA,EAsB5D,YACU,QAKR;AACD,UAAM,mBAAmB,mBAAmB,OAAO,QAAQ,OAAO,OAAO,EAAE,WAAW;AAN7E;AAQT,SAAK,UAAU,OAAO;AAEtB,SAAK,MAAM,mBAAmB;AAAA,MAC7B,OAAO;AAAA,MACP,OAAO;AAAA,IACR;AAAA,EACD;AAAA,EApCQ;AAAA,EAER,QAAiB,UAAU,IAAI;AAAA,EAC/B,CAAC,OAAO,WAAW,IAAI;AAAA,EAEf;AAAA,EAER,OAAe,mBACd,QACA,SACc;AACd,WAAO,4BAAoC,MAAM,GAAG,IAAI,IAAI,SAAS,EAAE,GAAG,OAAO,CAAC,GAAG,OAAO;AAAA,EAC7F;AAAA,EAEA,OAAe,WACd,QACA,SACc;AACd,WAAO,2BAAmC,MAAM,GAAG,IAAI,IAAI,SAAS,EAAE,GAAG,OAAO,CAAC,GAAG,OAAO;AAAA,EAC5F;AAAA,EAmBA,KACC,aACA,YAC+B;AAC/B,WAAO,QAAQ,QAAQ,KAAK,QAAQ,MAAM,KAAK,GAAG,CAAC,EAAE;AAAA,MACpD;AAAA,MACA;AAAA,IACD;AAAA,EACD;AAAA,EAEA,MACC,YACkB;AAClB,WAAO,KAAK,KAAK,QAAW,UAAU;AAAA,EACvC;AAAA,EAEA,QAAQ,WAA8D;AACrE,WAAO,KAAK;AAAA,MACX,CAAC,UAAU;AACV,oBAAY;AACZ,eAAO;AAAA,MACR;AAAA,MACA,CAAC,WAAW;AACX,oBAAY;AACZ,cAAM;AAAA,MACP;AAAA,IACD;AAAA,EACD;AACD;","names":[]}
@@ -29,6 +29,11 @@ var import_select = require("./select.cjs");
29
29
  class QueryBuilder {
30
30
  static [import_entity.entityKind] = "SQLiteQueryBuilder";
31
31
  dialect;
32
+ dialectConfig;
33
+ constructor(dialect) {
34
+ this.dialect = (0, import_entity.is)(dialect, import_dialect.SQLiteDialect) ? dialect : void 0;
35
+ this.dialectConfig = (0, import_entity.is)(dialect, import_dialect.SQLiteDialect) ? void 0 : dialect;
36
+ }
32
37
  $with(alias) {
33
38
  const queryBuilder = this;
34
39
  return {
@@ -78,7 +83,7 @@ class QueryBuilder {
78
83
  // Lazy load dialect to avoid circular dependency
79
84
  getDialect() {
80
85
  if (!this.dialect) {
81
- this.dialect = new import_dialect.SQLiteSyncDialect();
86
+ this.dialect = new import_dialect.SQLiteSyncDialect(this.dialectConfig);
82
87
  }
83
88
  return this.dialect;
84
89
  }
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/sqlite-core/query-builders/query-builder.ts"],"sourcesContent":["import { entityKind } from '~/entity.ts';\nimport type { TypedQueryBuilder } from '~/query-builders/query-builder.ts';\nimport { SelectionProxyHandler } from '~/selection-proxy.ts';\nimport type { ColumnsSelection } from '~/sql/sql.ts';\nimport { SQLiteSyncDialect } from '~/sqlite-core/dialect.ts';\nimport type { WithSubqueryWithSelection } from '~/sqlite-core/subquery.ts';\nimport { WithSubquery } from '~/subquery.ts';\nimport { SQLiteSelectBuilder } from './select.ts';\nimport type { SelectedFields } from './select.types.ts';\n\nexport class QueryBuilder {\n\tstatic readonly [entityKind]: string = 'SQLiteQueryBuilder';\n\n\tprivate dialect: SQLiteSyncDialect | undefined;\n\n\t$with<TAlias extends string>(alias: TAlias) {\n\t\tconst queryBuilder = this;\n\n\t\treturn {\n\t\t\tas<TSelection extends ColumnsSelection>(\n\t\t\t\tqb: TypedQueryBuilder<TSelection> | ((qb: QueryBuilder) => TypedQueryBuilder<TSelection>),\n\t\t\t): WithSubqueryWithSelection<TSelection, TAlias> {\n\t\t\t\tif (typeof qb === 'function') {\n\t\t\t\t\tqb = qb(queryBuilder);\n\t\t\t\t}\n\n\t\t\t\treturn new Proxy(\n\t\t\t\t\tnew WithSubquery(qb.getSQL(), qb.getSelectedFields() as SelectedFields, alias, true),\n\t\t\t\t\tnew SelectionProxyHandler({ alias, sqlAliasedBehavior: 'alias', sqlBehavior: 'error' }),\n\t\t\t\t) as WithSubqueryWithSelection<TSelection, TAlias>;\n\t\t\t},\n\t\t};\n\t}\n\n\twith(...queries: WithSubquery[]) {\n\t\tconst self = this;\n\n\t\tfunction select(): SQLiteSelectBuilder<undefined, 'sync', void, 'qb'>;\n\t\tfunction select<TSelection extends SelectedFields>(\n\t\t\tfields: TSelection,\n\t\t): SQLiteSelectBuilder<TSelection, 'sync', void, 'qb'>;\n\t\tfunction select<TSelection extends SelectedFields>(\n\t\t\tfields?: TSelection,\n\t\t): SQLiteSelectBuilder<TSelection | undefined, 'sync', void, 'qb'> {\n\t\t\treturn new SQLiteSelectBuilder({\n\t\t\t\tfields: fields ?? undefined,\n\t\t\t\tsession: undefined,\n\t\t\t\tdialect: self.getDialect(),\n\t\t\t\twithList: queries,\n\t\t\t});\n\t\t}\n\n\t\tfunction selectDistinct(): SQLiteSelectBuilder<undefined, 'sync', void, 'qb'>;\n\t\tfunction selectDistinct<TSelection extends SelectedFields>(\n\t\t\tfields: TSelection,\n\t\t): SQLiteSelectBuilder<TSelection, 'sync', void, 'qb'>;\n\t\tfunction selectDistinct<TSelection extends SelectedFields>(\n\t\t\tfields?: TSelection,\n\t\t): SQLiteSelectBuilder<TSelection | undefined, 'sync', void, 'qb'> {\n\t\t\treturn new SQLiteSelectBuilder({\n\t\t\t\tfields: fields ?? undefined,\n\t\t\t\tsession: undefined,\n\t\t\t\tdialect: self.getDialect(),\n\t\t\t\twithList: queries,\n\t\t\t\tdistinct: true,\n\t\t\t});\n\t\t}\n\n\t\treturn { select, selectDistinct };\n\t}\n\n\tselect(): SQLiteSelectBuilder<undefined, 'sync', void, 'qb'>;\n\tselect<TSelection extends SelectedFields>(\n\t\tfields: TSelection,\n\t): SQLiteSelectBuilder<TSelection, 'sync', void, 'qb'>;\n\tselect<TSelection extends SelectedFields>(\n\t\tfields?: TSelection,\n\t): SQLiteSelectBuilder<TSelection | undefined, 'sync', void, 'qb'> {\n\t\treturn new SQLiteSelectBuilder({ fields: fields ?? undefined, session: undefined, dialect: this.getDialect() });\n\t}\n\n\tselectDistinct(): SQLiteSelectBuilder<undefined, 'sync', void, 'qb'>;\n\tselectDistinct<TSelection extends SelectedFields>(\n\t\tfields: TSelection,\n\t): SQLiteSelectBuilder<TSelection, 'sync', void, 'qb'>;\n\tselectDistinct<TSelection extends SelectedFields>(\n\t\tfields?: TSelection,\n\t): SQLiteSelectBuilder<TSelection | undefined, 'sync', void, 'qb'> {\n\t\treturn new SQLiteSelectBuilder({\n\t\t\tfields: fields ?? undefined,\n\t\t\tsession: undefined,\n\t\t\tdialect: this.getDialect(),\n\t\t\tdistinct: true,\n\t\t});\n\t}\n\n\t// Lazy load dialect to avoid circular dependency\n\tprivate getDialect() {\n\t\tif (!this.dialect) {\n\t\t\tthis.dialect = new SQLiteSyncDialect();\n\t\t}\n\n\t\treturn this.dialect;\n\t}\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,oBAA2B;AAE3B,6BAAsC;AAEtC,qBAAkC;AAElC,sBAA6B;AAC7B,oBAAoC;AAG7B,MAAM,aAAa;AAAA,EACzB,QAAiB,wBAAU,IAAY;AAAA,EAE/B;AAAA,EAER,MAA6B,OAAe;AAC3C,UAAM,eAAe;AAErB,WAAO;AAAA,MACN,GACC,IACgD;AAChD,YAAI,OAAO,OAAO,YAAY;AAC7B,eAAK,GAAG,YAAY;AAAA,QACrB;AAEA,eAAO,IAAI;AAAA,UACV,IAAI,6BAAa,GAAG,OAAO,GAAG,GAAG,kBAAkB,GAAqB,OAAO,IAAI;AAAA,UACnF,IAAI,6CAAsB,EAAE,OAAO,oBAAoB,SAAS,aAAa,QAAQ,CAAC;AAAA,QACvF;AAAA,MACD;AAAA,IACD;AAAA,EACD;AAAA,EAEA,QAAQ,SAAyB;AAChC,UAAM,OAAO;AAMb,aAAS,OACR,QACkE;AAClE,aAAO,IAAI,kCAAoB;AAAA,QAC9B,QAAQ,UAAU;AAAA,QAClB,SAAS;AAAA,QACT,SAAS,KAAK,WAAW;AAAA,QACzB,UAAU;AAAA,MACX,CAAC;AAAA,IACF;AAMA,aAAS,eACR,QACkE;AAClE,aAAO,IAAI,kCAAoB;AAAA,QAC9B,QAAQ,UAAU;AAAA,QAClB,SAAS;AAAA,QACT,SAAS,KAAK,WAAW;AAAA,QACzB,UAAU;AAAA,QACV,UAAU;AAAA,MACX,CAAC;AAAA,IACF;AAEA,WAAO,EAAE,QAAQ,eAAe;AAAA,EACjC;AAAA,EAMA,OACC,QACkE;AAClE,WAAO,IAAI,kCAAoB,EAAE,QAAQ,UAAU,QAAW,SAAS,QAAW,SAAS,KAAK,WAAW,EAAE,CAAC;AAAA,EAC/G;AAAA,EAMA,eACC,QACkE;AAClE,WAAO,IAAI,kCAAoB;AAAA,MAC9B,QAAQ,UAAU;AAAA,MAClB,SAAS;AAAA,MACT,SAAS,KAAK,WAAW;AAAA,MACzB,UAAU;AAAA,IACX,CAAC;AAAA,EACF;AAAA;AAAA,EAGQ,aAAa;AACpB,QAAI,CAAC,KAAK,SAAS;AAClB,WAAK,UAAU,IAAI,iCAAkB;AAAA,IACtC;AAEA,WAAO,KAAK;AAAA,EACb;AACD;","names":[]}
1
+ {"version":3,"sources":["../../../src/sqlite-core/query-builders/query-builder.ts"],"sourcesContent":["import { entityKind, is } from '~/entity.ts';\nimport type { TypedQueryBuilder } from '~/query-builders/query-builder.ts';\nimport { SelectionProxyHandler } from '~/selection-proxy.ts';\nimport type { ColumnsSelection } from '~/sql/sql.ts';\nimport type { SQLiteDialectConfig } from '~/sqlite-core/dialect.ts';\nimport { SQLiteDialect, SQLiteSyncDialect } from '~/sqlite-core/dialect.ts';\nimport type { WithSubqueryWithSelection } from '~/sqlite-core/subquery.ts';\nimport { WithSubquery } from '~/subquery.ts';\nimport { SQLiteSelectBuilder } from './select.ts';\nimport type { SelectedFields } from './select.types.ts';\n\nexport class QueryBuilder {\n\tstatic readonly [entityKind]: string = 'SQLiteQueryBuilder';\n\n\tprivate dialect: SQLiteDialect | undefined;\n\tprivate dialectConfig: SQLiteDialectConfig | undefined;\n\n\tconstructor(dialect?: SQLiteDialect | SQLiteDialectConfig) {\n\t\tthis.dialect = is(dialect, SQLiteDialect) ? dialect : undefined;\n\t\tthis.dialectConfig = is(dialect, SQLiteDialect) ? undefined : dialect;\n\t}\n\n\t$with<TAlias extends string>(alias: TAlias) {\n\t\tconst queryBuilder = this;\n\n\t\treturn {\n\t\t\tas<TSelection extends ColumnsSelection>(\n\t\t\t\tqb: TypedQueryBuilder<TSelection> | ((qb: QueryBuilder) => TypedQueryBuilder<TSelection>),\n\t\t\t): WithSubqueryWithSelection<TSelection, TAlias> {\n\t\t\t\tif (typeof qb === 'function') {\n\t\t\t\t\tqb = qb(queryBuilder);\n\t\t\t\t}\n\n\t\t\t\treturn new Proxy(\n\t\t\t\t\tnew WithSubquery(qb.getSQL(), qb.getSelectedFields() as SelectedFields, alias, true),\n\t\t\t\t\tnew SelectionProxyHandler({ alias, sqlAliasedBehavior: 'alias', sqlBehavior: 'error' }),\n\t\t\t\t) as WithSubqueryWithSelection<TSelection, TAlias>;\n\t\t\t},\n\t\t};\n\t}\n\n\twith(...queries: WithSubquery[]) {\n\t\tconst self = this;\n\n\t\tfunction select(): SQLiteSelectBuilder<undefined, 'sync', void, 'qb'>;\n\t\tfunction select<TSelection extends SelectedFields>(\n\t\t\tfields: TSelection,\n\t\t): SQLiteSelectBuilder<TSelection, 'sync', void, 'qb'>;\n\t\tfunction select<TSelection extends SelectedFields>(\n\t\t\tfields?: TSelection,\n\t\t): SQLiteSelectBuilder<TSelection | undefined, 'sync', void, 'qb'> {\n\t\t\treturn new SQLiteSelectBuilder({\n\t\t\t\tfields: fields ?? undefined,\n\t\t\t\tsession: undefined,\n\t\t\t\tdialect: self.getDialect(),\n\t\t\t\twithList: queries,\n\t\t\t});\n\t\t}\n\n\t\tfunction selectDistinct(): SQLiteSelectBuilder<undefined, 'sync', void, 'qb'>;\n\t\tfunction selectDistinct<TSelection extends SelectedFields>(\n\t\t\tfields: TSelection,\n\t\t): SQLiteSelectBuilder<TSelection, 'sync', void, 'qb'>;\n\t\tfunction selectDistinct<TSelection extends SelectedFields>(\n\t\t\tfields?: TSelection,\n\t\t): SQLiteSelectBuilder<TSelection | undefined, 'sync', void, 'qb'> {\n\t\t\treturn new SQLiteSelectBuilder({\n\t\t\t\tfields: fields ?? undefined,\n\t\t\t\tsession: undefined,\n\t\t\t\tdialect: self.getDialect(),\n\t\t\t\twithList: queries,\n\t\t\t\tdistinct: true,\n\t\t\t});\n\t\t}\n\n\t\treturn { select, selectDistinct };\n\t}\n\n\tselect(): SQLiteSelectBuilder<undefined, 'sync', void, 'qb'>;\n\tselect<TSelection extends SelectedFields>(\n\t\tfields: TSelection,\n\t): SQLiteSelectBuilder<TSelection, 'sync', void, 'qb'>;\n\tselect<TSelection extends SelectedFields>(\n\t\tfields?: TSelection,\n\t): SQLiteSelectBuilder<TSelection | undefined, 'sync', void, 'qb'> {\n\t\treturn new SQLiteSelectBuilder({ fields: fields ?? undefined, session: undefined, dialect: this.getDialect() });\n\t}\n\n\tselectDistinct(): SQLiteSelectBuilder<undefined, 'sync', void, 'qb'>;\n\tselectDistinct<TSelection extends SelectedFields>(\n\t\tfields: TSelection,\n\t): SQLiteSelectBuilder<TSelection, 'sync', void, 'qb'>;\n\tselectDistinct<TSelection extends SelectedFields>(\n\t\tfields?: TSelection,\n\t): SQLiteSelectBuilder<TSelection | undefined, 'sync', void, 'qb'> {\n\t\treturn new SQLiteSelectBuilder({\n\t\t\tfields: fields ?? undefined,\n\t\t\tsession: undefined,\n\t\t\tdialect: this.getDialect(),\n\t\t\tdistinct: true,\n\t\t});\n\t}\n\n\t// Lazy load dialect to avoid circular dependency\n\tprivate getDialect() {\n\t\tif (!this.dialect) {\n\t\t\tthis.dialect = new SQLiteSyncDialect(this.dialectConfig);\n\t\t}\n\n\t\treturn this.dialect;\n\t}\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,oBAA+B;AAE/B,6BAAsC;AAGtC,qBAAiD;AAEjD,sBAA6B;AAC7B,oBAAoC;AAG7B,MAAM,aAAa;AAAA,EACzB,QAAiB,wBAAU,IAAY;AAAA,EAE/B;AAAA,EACA;AAAA,EAER,YAAY,SAA+C;AAC1D,SAAK,cAAU,kBAAG,SAAS,4BAAa,IAAI,UAAU;AACtD,SAAK,oBAAgB,kBAAG,SAAS,4BAAa,IAAI,SAAY;AAAA,EAC/D;AAAA,EAEA,MAA6B,OAAe;AAC3C,UAAM,eAAe;AAErB,WAAO;AAAA,MACN,GACC,IACgD;AAChD,YAAI,OAAO,OAAO,YAAY;AAC7B,eAAK,GAAG,YAAY;AAAA,QACrB;AAEA,eAAO,IAAI;AAAA,UACV,IAAI,6BAAa,GAAG,OAAO,GAAG,GAAG,kBAAkB,GAAqB,OAAO,IAAI;AAAA,UACnF,IAAI,6CAAsB,EAAE,OAAO,oBAAoB,SAAS,aAAa,QAAQ,CAAC;AAAA,QACvF;AAAA,MACD;AAAA,IACD;AAAA,EACD;AAAA,EAEA,QAAQ,SAAyB;AAChC,UAAM,OAAO;AAMb,aAAS,OACR,QACkE;AAClE,aAAO,IAAI,kCAAoB;AAAA,QAC9B,QAAQ,UAAU;AAAA,QAClB,SAAS;AAAA,QACT,SAAS,KAAK,WAAW;AAAA,QACzB,UAAU;AAAA,MACX,CAAC;AAAA,IACF;AAMA,aAAS,eACR,QACkE;AAClE,aAAO,IAAI,kCAAoB;AAAA,QAC9B,QAAQ,UAAU;AAAA,QAClB,SAAS;AAAA,QACT,SAAS,KAAK,WAAW;AAAA,QACzB,UAAU;AAAA,QACV,UAAU;AAAA,MACX,CAAC;AAAA,IACF;AAEA,WAAO,EAAE,QAAQ,eAAe;AAAA,EACjC;AAAA,EAMA,OACC,QACkE;AAClE,WAAO,IAAI,kCAAoB,EAAE,QAAQ,UAAU,QAAW,SAAS,QAAW,SAAS,KAAK,WAAW,EAAE,CAAC;AAAA,EAC/G;AAAA,EAMA,eACC,QACkE;AAClE,WAAO,IAAI,kCAAoB;AAAA,MAC9B,QAAQ,UAAU;AAAA,MAClB,SAAS;AAAA,MACT,SAAS,KAAK,WAAW;AAAA,MACzB,UAAU;AAAA,IACX,CAAC;AAAA,EACF;AAAA;AAAA,EAGQ,aAAa;AACpB,QAAI,CAAC,KAAK,SAAS;AAClB,WAAK,UAAU,IAAI,iCAAkB,KAAK,aAAa;AAAA,IACxD;AAEA,WAAO,KAAK;AAAA,EACb;AACD;","names":[]}
@@ -1,6 +1,8 @@
1
1
  import { entityKind } from "../../entity.cjs";
2
2
  import type { TypedQueryBuilder } from "../../query-builders/query-builder.cjs";
3
3
  import type { ColumnsSelection } from "../../sql/sql.cjs";
4
+ import type { SQLiteDialectConfig } from "../dialect.cjs";
5
+ import { SQLiteDialect } from "../dialect.cjs";
4
6
  import type { WithSubqueryWithSelection } from "../subquery.cjs";
5
7
  import { WithSubquery } from "../../subquery.cjs";
6
8
  import { SQLiteSelectBuilder } from "./select.cjs";
@@ -8,6 +10,8 @@ import type { SelectedFields } from "./select.types.cjs";
8
10
  export declare class QueryBuilder {
9
11
  static readonly [entityKind]: string;
10
12
  private dialect;
13
+ private dialectConfig;
14
+ constructor(dialect?: SQLiteDialect | SQLiteDialectConfig);
11
15
  $with<TAlias extends string>(alias: TAlias): {
12
16
  as<TSelection extends ColumnsSelection>(qb: TypedQueryBuilder<TSelection> | ((qb: QueryBuilder) => TypedQueryBuilder<TSelection>)): WithSubqueryWithSelection<TSelection, TAlias>;
13
17
  };
@@ -1,6 +1,8 @@
1
1
  import { entityKind } from "../../entity.js";
2
2
  import type { TypedQueryBuilder } from "../../query-builders/query-builder.js";
3
3
  import type { ColumnsSelection } from "../../sql/sql.js";
4
+ import type { SQLiteDialectConfig } from "../dialect.js";
5
+ import { SQLiteDialect } from "../dialect.js";
4
6
  import type { WithSubqueryWithSelection } from "../subquery.js";
5
7
  import { WithSubquery } from "../../subquery.js";
6
8
  import { SQLiteSelectBuilder } from "./select.js";
@@ -8,6 +10,8 @@ import type { SelectedFields } from "./select.types.js";
8
10
  export declare class QueryBuilder {
9
11
  static readonly [entityKind]: string;
10
12
  private dialect;
13
+ private dialectConfig;
14
+ constructor(dialect?: SQLiteDialect | SQLiteDialectConfig);
11
15
  $with<TAlias extends string>(alias: TAlias): {
12
16
  as<TSelection extends ColumnsSelection>(qb: TypedQueryBuilder<TSelection> | ((qb: QueryBuilder) => TypedQueryBuilder<TSelection>)): WithSubqueryWithSelection<TSelection, TAlias>;
13
17
  };
@@ -1,11 +1,16 @@
1
- import { entityKind } from "../../entity.js";
1
+ import { entityKind, is } from "../../entity.js";
2
2
  import { SelectionProxyHandler } from "../../selection-proxy.js";
3
- import { SQLiteSyncDialect } from "../dialect.js";
3
+ import { SQLiteDialect, SQLiteSyncDialect } from "../dialect.js";
4
4
  import { WithSubquery } from "../../subquery.js";
5
5
  import { SQLiteSelectBuilder } from "./select.js";
6
6
  class QueryBuilder {
7
7
  static [entityKind] = "SQLiteQueryBuilder";
8
8
  dialect;
9
+ dialectConfig;
10
+ constructor(dialect) {
11
+ this.dialect = is(dialect, SQLiteDialect) ? dialect : void 0;
12
+ this.dialectConfig = is(dialect, SQLiteDialect) ? void 0 : dialect;
13
+ }
9
14
  $with(alias) {
10
15
  const queryBuilder = this;
11
16
  return {
@@ -55,7 +60,7 @@ class QueryBuilder {
55
60
  // Lazy load dialect to avoid circular dependency
56
61
  getDialect() {
57
62
  if (!this.dialect) {
58
- this.dialect = new SQLiteSyncDialect();
63
+ this.dialect = new SQLiteSyncDialect(this.dialectConfig);
59
64
  }
60
65
  return this.dialect;
61
66
  }
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/sqlite-core/query-builders/query-builder.ts"],"sourcesContent":["import { entityKind } from '~/entity.ts';\nimport type { TypedQueryBuilder } from '~/query-builders/query-builder.ts';\nimport { SelectionProxyHandler } from '~/selection-proxy.ts';\nimport type { ColumnsSelection } from '~/sql/sql.ts';\nimport { SQLiteSyncDialect } from '~/sqlite-core/dialect.ts';\nimport type { WithSubqueryWithSelection } from '~/sqlite-core/subquery.ts';\nimport { WithSubquery } from '~/subquery.ts';\nimport { SQLiteSelectBuilder } from './select.ts';\nimport type { SelectedFields } from './select.types.ts';\n\nexport class QueryBuilder {\n\tstatic readonly [entityKind]: string = 'SQLiteQueryBuilder';\n\n\tprivate dialect: SQLiteSyncDialect | undefined;\n\n\t$with<TAlias extends string>(alias: TAlias) {\n\t\tconst queryBuilder = this;\n\n\t\treturn {\n\t\t\tas<TSelection extends ColumnsSelection>(\n\t\t\t\tqb: TypedQueryBuilder<TSelection> | ((qb: QueryBuilder) => TypedQueryBuilder<TSelection>),\n\t\t\t): WithSubqueryWithSelection<TSelection, TAlias> {\n\t\t\t\tif (typeof qb === 'function') {\n\t\t\t\t\tqb = qb(queryBuilder);\n\t\t\t\t}\n\n\t\t\t\treturn new Proxy(\n\t\t\t\t\tnew WithSubquery(qb.getSQL(), qb.getSelectedFields() as SelectedFields, alias, true),\n\t\t\t\t\tnew SelectionProxyHandler({ alias, sqlAliasedBehavior: 'alias', sqlBehavior: 'error' }),\n\t\t\t\t) as WithSubqueryWithSelection<TSelection, TAlias>;\n\t\t\t},\n\t\t};\n\t}\n\n\twith(...queries: WithSubquery[]) {\n\t\tconst self = this;\n\n\t\tfunction select(): SQLiteSelectBuilder<undefined, 'sync', void, 'qb'>;\n\t\tfunction select<TSelection extends SelectedFields>(\n\t\t\tfields: TSelection,\n\t\t): SQLiteSelectBuilder<TSelection, 'sync', void, 'qb'>;\n\t\tfunction select<TSelection extends SelectedFields>(\n\t\t\tfields?: TSelection,\n\t\t): SQLiteSelectBuilder<TSelection | undefined, 'sync', void, 'qb'> {\n\t\t\treturn new SQLiteSelectBuilder({\n\t\t\t\tfields: fields ?? undefined,\n\t\t\t\tsession: undefined,\n\t\t\t\tdialect: self.getDialect(),\n\t\t\t\twithList: queries,\n\t\t\t});\n\t\t}\n\n\t\tfunction selectDistinct(): SQLiteSelectBuilder<undefined, 'sync', void, 'qb'>;\n\t\tfunction selectDistinct<TSelection extends SelectedFields>(\n\t\t\tfields: TSelection,\n\t\t): SQLiteSelectBuilder<TSelection, 'sync', void, 'qb'>;\n\t\tfunction selectDistinct<TSelection extends SelectedFields>(\n\t\t\tfields?: TSelection,\n\t\t): SQLiteSelectBuilder<TSelection | undefined, 'sync', void, 'qb'> {\n\t\t\treturn new SQLiteSelectBuilder({\n\t\t\t\tfields: fields ?? undefined,\n\t\t\t\tsession: undefined,\n\t\t\t\tdialect: self.getDialect(),\n\t\t\t\twithList: queries,\n\t\t\t\tdistinct: true,\n\t\t\t});\n\t\t}\n\n\t\treturn { select, selectDistinct };\n\t}\n\n\tselect(): SQLiteSelectBuilder<undefined, 'sync', void, 'qb'>;\n\tselect<TSelection extends SelectedFields>(\n\t\tfields: TSelection,\n\t): SQLiteSelectBuilder<TSelection, 'sync', void, 'qb'>;\n\tselect<TSelection extends SelectedFields>(\n\t\tfields?: TSelection,\n\t): SQLiteSelectBuilder<TSelection | undefined, 'sync', void, 'qb'> {\n\t\treturn new SQLiteSelectBuilder({ fields: fields ?? undefined, session: undefined, dialect: this.getDialect() });\n\t}\n\n\tselectDistinct(): SQLiteSelectBuilder<undefined, 'sync', void, 'qb'>;\n\tselectDistinct<TSelection extends SelectedFields>(\n\t\tfields: TSelection,\n\t): SQLiteSelectBuilder<TSelection, 'sync', void, 'qb'>;\n\tselectDistinct<TSelection extends SelectedFields>(\n\t\tfields?: TSelection,\n\t): SQLiteSelectBuilder<TSelection | undefined, 'sync', void, 'qb'> {\n\t\treturn new SQLiteSelectBuilder({\n\t\t\tfields: fields ?? undefined,\n\t\t\tsession: undefined,\n\t\t\tdialect: this.getDialect(),\n\t\t\tdistinct: true,\n\t\t});\n\t}\n\n\t// Lazy load dialect to avoid circular dependency\n\tprivate getDialect() {\n\t\tif (!this.dialect) {\n\t\t\tthis.dialect = new SQLiteSyncDialect();\n\t\t}\n\n\t\treturn this.dialect;\n\t}\n}\n"],"mappings":"AAAA,SAAS,kBAAkB;AAE3B,SAAS,6BAA6B;AAEtC,SAAS,yBAAyB;AAElC,SAAS,oBAAoB;AAC7B,SAAS,2BAA2B;AAG7B,MAAM,aAAa;AAAA,EACzB,QAAiB,UAAU,IAAY;AAAA,EAE/B;AAAA,EAER,MAA6B,OAAe;AAC3C,UAAM,eAAe;AAErB,WAAO;AAAA,MACN,GACC,IACgD;AAChD,YAAI,OAAO,OAAO,YAAY;AAC7B,eAAK,GAAG,YAAY;AAAA,QACrB;AAEA,eAAO,IAAI;AAAA,UACV,IAAI,aAAa,GAAG,OAAO,GAAG,GAAG,kBAAkB,GAAqB,OAAO,IAAI;AAAA,UACnF,IAAI,sBAAsB,EAAE,OAAO,oBAAoB,SAAS,aAAa,QAAQ,CAAC;AAAA,QACvF;AAAA,MACD;AAAA,IACD;AAAA,EACD;AAAA,EAEA,QAAQ,SAAyB;AAChC,UAAM,OAAO;AAMb,aAAS,OACR,QACkE;AAClE,aAAO,IAAI,oBAAoB;AAAA,QAC9B,QAAQ,UAAU;AAAA,QAClB,SAAS;AAAA,QACT,SAAS,KAAK,WAAW;AAAA,QACzB,UAAU;AAAA,MACX,CAAC;AAAA,IACF;AAMA,aAAS,eACR,QACkE;AAClE,aAAO,IAAI,oBAAoB;AAAA,QAC9B,QAAQ,UAAU;AAAA,QAClB,SAAS;AAAA,QACT,SAAS,KAAK,WAAW;AAAA,QACzB,UAAU;AAAA,QACV,UAAU;AAAA,MACX,CAAC;AAAA,IACF;AAEA,WAAO,EAAE,QAAQ,eAAe;AAAA,EACjC;AAAA,EAMA,OACC,QACkE;AAClE,WAAO,IAAI,oBAAoB,EAAE,QAAQ,UAAU,QAAW,SAAS,QAAW,SAAS,KAAK,WAAW,EAAE,CAAC;AAAA,EAC/G;AAAA,EAMA,eACC,QACkE;AAClE,WAAO,IAAI,oBAAoB;AAAA,MAC9B,QAAQ,UAAU;AAAA,MAClB,SAAS;AAAA,MACT,SAAS,KAAK,WAAW;AAAA,MACzB,UAAU;AAAA,IACX,CAAC;AAAA,EACF;AAAA;AAAA,EAGQ,aAAa;AACpB,QAAI,CAAC,KAAK,SAAS;AAClB,WAAK,UAAU,IAAI,kBAAkB;AAAA,IACtC;AAEA,WAAO,KAAK;AAAA,EACb;AACD;","names":[]}
1
+ {"version":3,"sources":["../../../src/sqlite-core/query-builders/query-builder.ts"],"sourcesContent":["import { entityKind, is } from '~/entity.ts';\nimport type { TypedQueryBuilder } from '~/query-builders/query-builder.ts';\nimport { SelectionProxyHandler } from '~/selection-proxy.ts';\nimport type { ColumnsSelection } from '~/sql/sql.ts';\nimport type { SQLiteDialectConfig } from '~/sqlite-core/dialect.ts';\nimport { SQLiteDialect, SQLiteSyncDialect } from '~/sqlite-core/dialect.ts';\nimport type { WithSubqueryWithSelection } from '~/sqlite-core/subquery.ts';\nimport { WithSubquery } from '~/subquery.ts';\nimport { SQLiteSelectBuilder } from './select.ts';\nimport type { SelectedFields } from './select.types.ts';\n\nexport class QueryBuilder {\n\tstatic readonly [entityKind]: string = 'SQLiteQueryBuilder';\n\n\tprivate dialect: SQLiteDialect | undefined;\n\tprivate dialectConfig: SQLiteDialectConfig | undefined;\n\n\tconstructor(dialect?: SQLiteDialect | SQLiteDialectConfig) {\n\t\tthis.dialect = is(dialect, SQLiteDialect) ? dialect : undefined;\n\t\tthis.dialectConfig = is(dialect, SQLiteDialect) ? undefined : dialect;\n\t}\n\n\t$with<TAlias extends string>(alias: TAlias) {\n\t\tconst queryBuilder = this;\n\n\t\treturn {\n\t\t\tas<TSelection extends ColumnsSelection>(\n\t\t\t\tqb: TypedQueryBuilder<TSelection> | ((qb: QueryBuilder) => TypedQueryBuilder<TSelection>),\n\t\t\t): WithSubqueryWithSelection<TSelection, TAlias> {\n\t\t\t\tif (typeof qb === 'function') {\n\t\t\t\t\tqb = qb(queryBuilder);\n\t\t\t\t}\n\n\t\t\t\treturn new Proxy(\n\t\t\t\t\tnew WithSubquery(qb.getSQL(), qb.getSelectedFields() as SelectedFields, alias, true),\n\t\t\t\t\tnew SelectionProxyHandler({ alias, sqlAliasedBehavior: 'alias', sqlBehavior: 'error' }),\n\t\t\t\t) as WithSubqueryWithSelection<TSelection, TAlias>;\n\t\t\t},\n\t\t};\n\t}\n\n\twith(...queries: WithSubquery[]) {\n\t\tconst self = this;\n\n\t\tfunction select(): SQLiteSelectBuilder<undefined, 'sync', void, 'qb'>;\n\t\tfunction select<TSelection extends SelectedFields>(\n\t\t\tfields: TSelection,\n\t\t): SQLiteSelectBuilder<TSelection, 'sync', void, 'qb'>;\n\t\tfunction select<TSelection extends SelectedFields>(\n\t\t\tfields?: TSelection,\n\t\t): SQLiteSelectBuilder<TSelection | undefined, 'sync', void, 'qb'> {\n\t\t\treturn new SQLiteSelectBuilder({\n\t\t\t\tfields: fields ?? undefined,\n\t\t\t\tsession: undefined,\n\t\t\t\tdialect: self.getDialect(),\n\t\t\t\twithList: queries,\n\t\t\t});\n\t\t}\n\n\t\tfunction selectDistinct(): SQLiteSelectBuilder<undefined, 'sync', void, 'qb'>;\n\t\tfunction selectDistinct<TSelection extends SelectedFields>(\n\t\t\tfields: TSelection,\n\t\t): SQLiteSelectBuilder<TSelection, 'sync', void, 'qb'>;\n\t\tfunction selectDistinct<TSelection extends SelectedFields>(\n\t\t\tfields?: TSelection,\n\t\t): SQLiteSelectBuilder<TSelection | undefined, 'sync', void, 'qb'> {\n\t\t\treturn new SQLiteSelectBuilder({\n\t\t\t\tfields: fields ?? undefined,\n\t\t\t\tsession: undefined,\n\t\t\t\tdialect: self.getDialect(),\n\t\t\t\twithList: queries,\n\t\t\t\tdistinct: true,\n\t\t\t});\n\t\t}\n\n\t\treturn { select, selectDistinct };\n\t}\n\n\tselect(): SQLiteSelectBuilder<undefined, 'sync', void, 'qb'>;\n\tselect<TSelection extends SelectedFields>(\n\t\tfields: TSelection,\n\t): SQLiteSelectBuilder<TSelection, 'sync', void, 'qb'>;\n\tselect<TSelection extends SelectedFields>(\n\t\tfields?: TSelection,\n\t): SQLiteSelectBuilder<TSelection | undefined, 'sync', void, 'qb'> {\n\t\treturn new SQLiteSelectBuilder({ fields: fields ?? undefined, session: undefined, dialect: this.getDialect() });\n\t}\n\n\tselectDistinct(): SQLiteSelectBuilder<undefined, 'sync', void, 'qb'>;\n\tselectDistinct<TSelection extends SelectedFields>(\n\t\tfields: TSelection,\n\t): SQLiteSelectBuilder<TSelection, 'sync', void, 'qb'>;\n\tselectDistinct<TSelection extends SelectedFields>(\n\t\tfields?: TSelection,\n\t): SQLiteSelectBuilder<TSelection | undefined, 'sync', void, 'qb'> {\n\t\treturn new SQLiteSelectBuilder({\n\t\t\tfields: fields ?? undefined,\n\t\t\tsession: undefined,\n\t\t\tdialect: this.getDialect(),\n\t\t\tdistinct: true,\n\t\t});\n\t}\n\n\t// Lazy load dialect to avoid circular dependency\n\tprivate getDialect() {\n\t\tif (!this.dialect) {\n\t\t\tthis.dialect = new SQLiteSyncDialect(this.dialectConfig);\n\t\t}\n\n\t\treturn this.dialect;\n\t}\n}\n"],"mappings":"AAAA,SAAS,YAAY,UAAU;AAE/B,SAAS,6BAA6B;AAGtC,SAAS,eAAe,yBAAyB;AAEjD,SAAS,oBAAoB;AAC7B,SAAS,2BAA2B;AAG7B,MAAM,aAAa;AAAA,EACzB,QAAiB,UAAU,IAAY;AAAA,EAE/B;AAAA,EACA;AAAA,EAER,YAAY,SAA+C;AAC1D,SAAK,UAAU,GAAG,SAAS,aAAa,IAAI,UAAU;AACtD,SAAK,gBAAgB,GAAG,SAAS,aAAa,IAAI,SAAY;AAAA,EAC/D;AAAA,EAEA,MAA6B,OAAe;AAC3C,UAAM,eAAe;AAErB,WAAO;AAAA,MACN,GACC,IACgD;AAChD,YAAI,OAAO,OAAO,YAAY;AAC7B,eAAK,GAAG,YAAY;AAAA,QACrB;AAEA,eAAO,IAAI;AAAA,UACV,IAAI,aAAa,GAAG,OAAO,GAAG,GAAG,kBAAkB,GAAqB,OAAO,IAAI;AAAA,UACnF,IAAI,sBAAsB,EAAE,OAAO,oBAAoB,SAAS,aAAa,QAAQ,CAAC;AAAA,QACvF;AAAA,MACD;AAAA,IACD;AAAA,EACD;AAAA,EAEA,QAAQ,SAAyB;AAChC,UAAM,OAAO;AAMb,aAAS,OACR,QACkE;AAClE,aAAO,IAAI,oBAAoB;AAAA,QAC9B,QAAQ,UAAU;AAAA,QAClB,SAAS;AAAA,QACT,SAAS,KAAK,WAAW;AAAA,QACzB,UAAU;AAAA,MACX,CAAC;AAAA,IACF;AAMA,aAAS,eACR,QACkE;AAClE,aAAO,IAAI,oBAAoB;AAAA,QAC9B,QAAQ,UAAU;AAAA,QAClB,SAAS;AAAA,QACT,SAAS,KAAK,WAAW;AAAA,QACzB,UAAU;AAAA,QACV,UAAU;AAAA,MACX,CAAC;AAAA,IACF;AAEA,WAAO,EAAE,QAAQ,eAAe;AAAA,EACjC;AAAA,EAMA,OACC,QACkE;AAClE,WAAO,IAAI,oBAAoB,EAAE,QAAQ,UAAU,QAAW,SAAS,QAAW,SAAS,KAAK,WAAW,EAAE,CAAC;AAAA,EAC/G;AAAA,EAMA,eACC,QACkE;AAClE,WAAO,IAAI,oBAAoB;AAAA,MAC9B,QAAQ,UAAU;AAAA,MAClB,SAAS;AAAA,MACT,SAAS,KAAK,WAAW;AAAA,MACzB,UAAU;AAAA,IACX,CAAC;AAAA,EACF;AAAA;AAAA,EAGQ,aAAa;AACpB,QAAI,CAAC,KAAK,SAAS;AAClB,WAAK,UAAU,IAAI,kBAAkB,KAAK,aAAa;AAAA,IACxD;AAEA,WAAO,KAAK;AAAA,EACb;AACD;","names":[]}
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/sqlite-core/query-builders/raw.ts"],"sourcesContent":["import { entityKind } from '~/entity.ts';\nimport type { SQL, SQLWrapper } from '~/index.ts';\nimport { QueryPromise } from '~/query-promise.ts';\nimport type { RunnableQuery } from '~/runnable-query.ts';\nimport type { PreparedQuery } from '~/session.ts';\nimport type { SQLiteAsyncDialect } from '../dialect.ts';\n\ntype SQLiteRawAction = 'all' | 'get' | 'values' | 'run';\nexport interface SQLiteRawConfig {\n\taction: SQLiteRawAction;\n}\n\nexport interface SQLiteRaw<TResult> extends QueryPromise<TResult>, RunnableQuery<TResult, 'sqlite'>, SQLWrapper {}\n\nexport class SQLiteRaw<TResult> extends QueryPromise<TResult>\n\timplements RunnableQuery<TResult, 'sqlite'>, SQLWrapper, PreparedQuery\n{\n\tstatic readonly [entityKind]: string = 'SQLiteRaw';\n\n\tdeclare readonly _: {\n\t\treadonly dialect: 'sqlite';\n\t\treadonly result: TResult;\n\t};\n\n\t/** @internal */\n\tconfig: SQLiteRawConfig;\n\n\tconstructor(\n\t\tpublic execute: () => Promise<TResult>,\n\t\t/** @internal */\n\t\tpublic getSQL: () => SQL,\n\t\taction: SQLiteRawAction,\n\t\tprivate dialect: SQLiteAsyncDialect,\n\t\tprivate mapBatchResult: (result: unknown) => unknown,\n\t) {\n\t\tsuper();\n\t\tthis.config = { action };\n\t}\n\n\tgetQuery() {\n\t\treturn { ...this.dialect.sqlToQuery(this.getSQL()), method: this.config.action };\n\t}\n\n\tmapResult(result: unknown, isFromBatch?: boolean) {\n\t\treturn isFromBatch ? this.mapBatchResult(result) : result;\n\t}\n\n\t_prepare(): PreparedQuery {\n\t\treturn this;\n\t}\n\n\t/** @internal */\n\tisResponseInArrayMode(): boolean {\n\t\treturn false;\n\t}\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,oBAA2B;AAE3B,2BAA6B;AAYtB,MAAM,kBAA2B,kCAExC;AAAA,EAWC,YACQ,SAEA,QACP,QACQ,SACA,gBACP;AACD,UAAM;AAPC;AAEA;AAEC;AACA;AAGR,SAAK,SAAS,EAAE,OAAO;AAAA,EACxB;AAAA,EApBA,QAAiB,wBAAU,IAAY;AAAA;AAAA,EAQvC;AAAA,EAcA,WAAW;AACV,WAAO,EAAE,GAAG,KAAK,QAAQ,WAAW,KAAK,OAAO,CAAC,GAAG,QAAQ,KAAK,OAAO,OAAO;AAAA,EAChF;AAAA,EAEA,UAAU,QAAiB,aAAuB;AACjD,WAAO,cAAc,KAAK,eAAe,MAAM,IAAI;AAAA,EACpD;AAAA,EAEA,WAA0B;AACzB,WAAO;AAAA,EACR;AAAA;AAAA,EAGA,wBAAiC;AAChC,WAAO;AAAA,EACR;AACD;","names":[]}
1
+ {"version":3,"sources":["../../../src/sqlite-core/query-builders/raw.ts"],"sourcesContent":["import { entityKind } from '~/entity.ts';\nimport { QueryPromise } from '~/query-promise.ts';\nimport type { RunnableQuery } from '~/runnable-query.ts';\nimport type { PreparedQuery } from '~/session.ts';\nimport type { SQL, SQLWrapper } from '~/sql/sql.ts';\nimport type { SQLiteAsyncDialect } from '../dialect.ts';\n\ntype SQLiteRawAction = 'all' | 'get' | 'values' | 'run';\nexport interface SQLiteRawConfig {\n\taction: SQLiteRawAction;\n}\n\nexport interface SQLiteRaw<TResult> extends QueryPromise<TResult>, RunnableQuery<TResult, 'sqlite'>, SQLWrapper {}\n\nexport class SQLiteRaw<TResult> extends QueryPromise<TResult>\n\timplements RunnableQuery<TResult, 'sqlite'>, SQLWrapper, PreparedQuery\n{\n\tstatic readonly [entityKind]: string = 'SQLiteRaw';\n\n\tdeclare readonly _: {\n\t\treadonly dialect: 'sqlite';\n\t\treadonly result: TResult;\n\t};\n\n\t/** @internal */\n\tconfig: SQLiteRawConfig;\n\n\tconstructor(\n\t\tpublic execute: () => Promise<TResult>,\n\t\t/** @internal */\n\t\tpublic getSQL: () => SQL,\n\t\taction: SQLiteRawAction,\n\t\tprivate dialect: SQLiteAsyncDialect,\n\t\tprivate mapBatchResult: (result: unknown) => unknown,\n\t) {\n\t\tsuper();\n\t\tthis.config = { action };\n\t}\n\n\tgetQuery() {\n\t\treturn { ...this.dialect.sqlToQuery(this.getSQL()), method: this.config.action };\n\t}\n\n\tmapResult(result: unknown, isFromBatch?: boolean) {\n\t\treturn isFromBatch ? this.mapBatchResult(result) : result;\n\t}\n\n\t_prepare(): PreparedQuery {\n\t\treturn this;\n\t}\n\n\t/** @internal */\n\tisResponseInArrayMode(): boolean {\n\t\treturn false;\n\t}\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,oBAA2B;AAC3B,2BAA6B;AAatB,MAAM,kBAA2B,kCAExC;AAAA,EAWC,YACQ,SAEA,QACP,QACQ,SACA,gBACP;AACD,UAAM;AAPC;AAEA;AAEC;AACA;AAGR,SAAK,SAAS,EAAE,OAAO;AAAA,EACxB;AAAA,EApBA,QAAiB,wBAAU,IAAY;AAAA;AAAA,EAQvC;AAAA,EAcA,WAAW;AACV,WAAO,EAAE,GAAG,KAAK,QAAQ,WAAW,KAAK,OAAO,CAAC,GAAG,QAAQ,KAAK,OAAO,OAAO;AAAA,EAChF;AAAA,EAEA,UAAU,QAAiB,aAAuB;AACjD,WAAO,cAAc,KAAK,eAAe,MAAM,IAAI;AAAA,EACpD;AAAA,EAEA,WAA0B;AACzB,WAAO;AAAA,EACR;AAAA;AAAA,EAGA,wBAAiC;AAChC,WAAO;AAAA,EACR;AACD;","names":[]}
@@ -1,8 +1,8 @@
1
1
  import { entityKind } from "../../entity.cjs";
2
- import type { SQL, SQLWrapper } from "../../index.cjs";
3
2
  import { QueryPromise } from "../../query-promise.cjs";
4
3
  import type { RunnableQuery } from "../../runnable-query.cjs";
5
4
  import type { PreparedQuery } from "../../session.cjs";
5
+ import type { SQL, SQLWrapper } from "../../sql/sql.cjs";
6
6
  import type { SQLiteAsyncDialect } from "../dialect.cjs";
7
7
  type SQLiteRawAction = 'all' | 'get' | 'values' | 'run';
8
8
  export interface SQLiteRawConfig {
@@ -24,7 +24,7 @@ export declare class SQLiteRaw<TResult> extends QueryPromise<TResult> implements
24
24
  getSQL: () => SQL, action: SQLiteRawAction, dialect: SQLiteAsyncDialect, mapBatchResult: (result: unknown) => unknown);
25
25
  getQuery(): {
26
26
  method: SQLiteRawAction;
27
- typings?: import("../../index.ts").QueryTypingsValue[] | undefined;
27
+ typings?: import("../../sql/sql.ts").QueryTypingsValue[] | undefined;
28
28
  sql: string;
29
29
  params: unknown[];
30
30
  };
@@ -1,8 +1,8 @@
1
1
  import { entityKind } from "../../entity.js";
2
- import type { SQL, SQLWrapper } from "../../index.js";
3
2
  import { QueryPromise } from "../../query-promise.js";
4
3
  import type { RunnableQuery } from "../../runnable-query.js";
5
4
  import type { PreparedQuery } from "../../session.js";
5
+ import type { SQL, SQLWrapper } from "../../sql/sql.js";
6
6
  import type { SQLiteAsyncDialect } from "../dialect.js";
7
7
  type SQLiteRawAction = 'all' | 'get' | 'values' | 'run';
8
8
  export interface SQLiteRawConfig {
@@ -24,7 +24,7 @@ export declare class SQLiteRaw<TResult> extends QueryPromise<TResult> implements
24
24
  getSQL: () => SQL, action: SQLiteRawAction, dialect: SQLiteAsyncDialect, mapBatchResult: (result: unknown) => unknown);
25
25
  getQuery(): {
26
26
  method: SQLiteRawAction;
27
- typings?: import("../../index.js").QueryTypingsValue[] | undefined;
27
+ typings?: import("../../sql/sql.js").QueryTypingsValue[] | undefined;
28
28
  sql: string;
29
29
  params: unknown[];
30
30
  };
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/sqlite-core/query-builders/raw.ts"],"sourcesContent":["import { entityKind } from '~/entity.ts';\nimport type { SQL, SQLWrapper } from '~/index.ts';\nimport { QueryPromise } from '~/query-promise.ts';\nimport type { RunnableQuery } from '~/runnable-query.ts';\nimport type { PreparedQuery } from '~/session.ts';\nimport type { SQLiteAsyncDialect } from '../dialect.ts';\n\ntype SQLiteRawAction = 'all' | 'get' | 'values' | 'run';\nexport interface SQLiteRawConfig {\n\taction: SQLiteRawAction;\n}\n\nexport interface SQLiteRaw<TResult> extends QueryPromise<TResult>, RunnableQuery<TResult, 'sqlite'>, SQLWrapper {}\n\nexport class SQLiteRaw<TResult> extends QueryPromise<TResult>\n\timplements RunnableQuery<TResult, 'sqlite'>, SQLWrapper, PreparedQuery\n{\n\tstatic readonly [entityKind]: string = 'SQLiteRaw';\n\n\tdeclare readonly _: {\n\t\treadonly dialect: 'sqlite';\n\t\treadonly result: TResult;\n\t};\n\n\t/** @internal */\n\tconfig: SQLiteRawConfig;\n\n\tconstructor(\n\t\tpublic execute: () => Promise<TResult>,\n\t\t/** @internal */\n\t\tpublic getSQL: () => SQL,\n\t\taction: SQLiteRawAction,\n\t\tprivate dialect: SQLiteAsyncDialect,\n\t\tprivate mapBatchResult: (result: unknown) => unknown,\n\t) {\n\t\tsuper();\n\t\tthis.config = { action };\n\t}\n\n\tgetQuery() {\n\t\treturn { ...this.dialect.sqlToQuery(this.getSQL()), method: this.config.action };\n\t}\n\n\tmapResult(result: unknown, isFromBatch?: boolean) {\n\t\treturn isFromBatch ? this.mapBatchResult(result) : result;\n\t}\n\n\t_prepare(): PreparedQuery {\n\t\treturn this;\n\t}\n\n\t/** @internal */\n\tisResponseInArrayMode(): boolean {\n\t\treturn false;\n\t}\n}\n"],"mappings":"AAAA,SAAS,kBAAkB;AAE3B,SAAS,oBAAoB;AAYtB,MAAM,kBAA2B,aAExC;AAAA,EAWC,YACQ,SAEA,QACP,QACQ,SACA,gBACP;AACD,UAAM;AAPC;AAEA;AAEC;AACA;AAGR,SAAK,SAAS,EAAE,OAAO;AAAA,EACxB;AAAA,EApBA,QAAiB,UAAU,IAAY;AAAA;AAAA,EAQvC;AAAA,EAcA,WAAW;AACV,WAAO,EAAE,GAAG,KAAK,QAAQ,WAAW,KAAK,OAAO,CAAC,GAAG,QAAQ,KAAK,OAAO,OAAO;AAAA,EAChF;AAAA,EAEA,UAAU,QAAiB,aAAuB;AACjD,WAAO,cAAc,KAAK,eAAe,MAAM,IAAI;AAAA,EACpD;AAAA,EAEA,WAA0B;AACzB,WAAO;AAAA,EACR;AAAA;AAAA,EAGA,wBAAiC;AAChC,WAAO;AAAA,EACR;AACD;","names":[]}
1
+ {"version":3,"sources":["../../../src/sqlite-core/query-builders/raw.ts"],"sourcesContent":["import { entityKind } from '~/entity.ts';\nimport { QueryPromise } from '~/query-promise.ts';\nimport type { RunnableQuery } from '~/runnable-query.ts';\nimport type { PreparedQuery } from '~/session.ts';\nimport type { SQL, SQLWrapper } from '~/sql/sql.ts';\nimport type { SQLiteAsyncDialect } from '../dialect.ts';\n\ntype SQLiteRawAction = 'all' | 'get' | 'values' | 'run';\nexport interface SQLiteRawConfig {\n\taction: SQLiteRawAction;\n}\n\nexport interface SQLiteRaw<TResult> extends QueryPromise<TResult>, RunnableQuery<TResult, 'sqlite'>, SQLWrapper {}\n\nexport class SQLiteRaw<TResult> extends QueryPromise<TResult>\n\timplements RunnableQuery<TResult, 'sqlite'>, SQLWrapper, PreparedQuery\n{\n\tstatic readonly [entityKind]: string = 'SQLiteRaw';\n\n\tdeclare readonly _: {\n\t\treadonly dialect: 'sqlite';\n\t\treadonly result: TResult;\n\t};\n\n\t/** @internal */\n\tconfig: SQLiteRawConfig;\n\n\tconstructor(\n\t\tpublic execute: () => Promise<TResult>,\n\t\t/** @internal */\n\t\tpublic getSQL: () => SQL,\n\t\taction: SQLiteRawAction,\n\t\tprivate dialect: SQLiteAsyncDialect,\n\t\tprivate mapBatchResult: (result: unknown) => unknown,\n\t) {\n\t\tsuper();\n\t\tthis.config = { action };\n\t}\n\n\tgetQuery() {\n\t\treturn { ...this.dialect.sqlToQuery(this.getSQL()), method: this.config.action };\n\t}\n\n\tmapResult(result: unknown, isFromBatch?: boolean) {\n\t\treturn isFromBatch ? this.mapBatchResult(result) : result;\n\t}\n\n\t_prepare(): PreparedQuery {\n\t\treturn this;\n\t}\n\n\t/** @internal */\n\tisResponseInArrayMode(): boolean {\n\t\treturn false;\n\t}\n}\n"],"mappings":"AAAA,SAAS,kBAAkB;AAC3B,SAAS,oBAAoB;AAatB,MAAM,kBAA2B,aAExC;AAAA,EAWC,YACQ,SAEA,QACP,QACQ,SACA,gBACP;AACD,UAAM;AAPC;AAEA;AAEC;AACA;AAGR,SAAK,SAAS,EAAE,OAAO;AAAA,EACxB;AAAA,EApBA,QAAiB,UAAU,IAAY;AAAA;AAAA,EAQvC;AAAA,EAcA,WAAW;AACV,WAAO,EAAE,GAAG,KAAK,QAAQ,WAAW,KAAK,OAAO,CAAC,GAAG,QAAQ,KAAK,OAAO,OAAO;AAAA,EAChF;AAAA,EAEA,UAAU,QAAiB,aAAuB;AACjD,WAAO,cAAc,KAAK,eAAe,MAAM,IAAI;AAAA,EACpD;AAAA,EAEA,WAA0B;AACzB,WAAO;AAAA,EACR;AAAA;AAAA,EAGA,wBAAiC;AAChC,WAAO;AAAA,EACR;AACD;","names":[]}
@@ -26,6 +26,7 @@ __export(table_exports, {
26
26
  module.exports = __toCommonJS(table_exports);
27
27
  var import_entity = require("../entity.cjs");
28
28
  var import_table = require("../table.cjs");
29
+ var import_all = require("./columns/all.cjs");
29
30
  const InlineForeignKeys = Symbol.for("drizzle:SQLiteInlineForeignKeys");
30
31
  class SQLiteTable extends import_table.Table {
31
32
  static [import_entity.entityKind] = "SQLiteTable";
@@ -42,9 +43,11 @@ class SQLiteTable extends import_table.Table {
42
43
  }
43
44
  function sqliteTableBase(name, columns, extraConfig, schema, baseName = name) {
44
45
  const rawTable = new SQLiteTable(name, schema, baseName);
46
+ const parsedColumns = typeof columns === "function" ? columns((0, import_all.getSQLiteColumnBuilders)()) : columns;
45
47
  const builtColumns = Object.fromEntries(
46
- Object.entries(columns).map(([name2, colBuilderBase]) => {
48
+ Object.entries(parsedColumns).map(([name2, colBuilderBase]) => {
47
49
  const colBuilder = colBuilderBase;
50
+ colBuilder.setName(name2);
48
51
  const column = colBuilder.build(rawTable);
49
52
  rawTable[InlineForeignKeys].push(...colBuilder.buildForeignKeys(column, rawTable));
50
53
  return [name2, column];
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/sqlite-core/table.ts"],"sourcesContent":["import type { BuildColumns, BuildExtraConfigColumns } from '~/column-builder.ts';\nimport { entityKind } from '~/entity.ts';\nimport { Table, type TableConfig as TableConfigBase, type UpdateTableConfig } from '~/table.ts';\nimport type { CheckBuilder } from './checks.ts';\nimport type { SQLiteColumn, SQLiteColumnBuilder, SQLiteColumnBuilderBase } from './columns/common.ts';\nimport type { ForeignKey, ForeignKeyBuilder } from './foreign-keys.ts';\nimport type { IndexBuilder } from './indexes.ts';\nimport type { PrimaryKeyBuilder } from './primary-keys.ts';\nimport type { UniqueConstraintBuilder } from './unique-constraint.ts';\n\nexport type SQLiteTableExtraConfig = Record<\n\tstring,\n\t| IndexBuilder\n\t| CheckBuilder\n\t| ForeignKeyBuilder\n\t| PrimaryKeyBuilder\n\t| UniqueConstraintBuilder\n>;\n\nexport type TableConfig = TableConfigBase<SQLiteColumn<any>>;\n\n/** @internal */\nexport const InlineForeignKeys = Symbol.for('drizzle:SQLiteInlineForeignKeys');\n\nexport class SQLiteTable<T extends TableConfig = TableConfig> extends Table<T> {\n\tstatic readonly [entityKind]: string = 'SQLiteTable';\n\n\t/** @internal */\n\tstatic override readonly Symbol = Object.assign({}, Table.Symbol, {\n\t\tInlineForeignKeys: InlineForeignKeys as typeof InlineForeignKeys,\n\t});\n\n\t/** @internal */\n\toverride [Table.Symbol.Columns]!: NonNullable<T['columns']>;\n\n\t/** @internal */\n\t[InlineForeignKeys]: ForeignKey[] = [];\n\n\t/** @internal */\n\toverride [Table.Symbol.ExtraConfigBuilder]:\n\t\t| ((self: Record<string, SQLiteColumn>) => SQLiteTableExtraConfig)\n\t\t| undefined = undefined;\n}\n\nexport type AnySQLiteTable<TPartial extends Partial<TableConfig> = {}> = SQLiteTable<\n\tUpdateTableConfig<TableConfig, TPartial>\n>;\n\nexport type SQLiteTableWithColumns<T extends TableConfig> =\n\t& SQLiteTable<T>\n\t& {\n\t\t[Key in keyof T['columns']]: T['columns'][Key];\n\t};\n\nexport interface SQLiteTableFn<TSchema extends string | undefined = undefined> {\n\t<\n\t\tTTableName extends string,\n\t\tTColumnsMap extends Record<string, SQLiteColumnBuilderBase>,\n\t>(\n\t\tname: TTableName,\n\t\tcolumns: TColumnsMap,\n\t\textraConfig?: (self: BuildColumns<TTableName, TColumnsMap, 'sqlite'>) => SQLiteTableExtraConfig,\n\t): SQLiteTableWithColumns<{\n\t\tname: TTableName;\n\t\tschema: TSchema;\n\t\tcolumns: BuildColumns<TTableName, TColumnsMap, 'sqlite'>;\n\t\tdialect: 'sqlite';\n\t}>;\n}\n\nfunction sqliteTableBase<\n\tTTableName extends string,\n\tTColumnsMap extends Record<string, SQLiteColumnBuilderBase>,\n\tTSchema extends string | undefined,\n>(\n\tname: TTableName,\n\tcolumns: TColumnsMap,\n\textraConfig?: (self: BuildColumns<TTableName, TColumnsMap, 'sqlite'>) => SQLiteTableExtraConfig,\n\tschema?: TSchema,\n\tbaseName = name,\n): SQLiteTableWithColumns<{\n\tname: TTableName;\n\tschema: TSchema;\n\tcolumns: BuildColumns<TTableName, TColumnsMap, 'sqlite'>;\n\tdialect: 'sqlite';\n}> {\n\tconst rawTable = new SQLiteTable<{\n\t\tname: TTableName;\n\t\tschema: TSchema;\n\t\tcolumns: BuildColumns<TTableName, TColumnsMap, 'sqlite'>;\n\t\tdialect: 'sqlite';\n\t}>(name, schema, baseName);\n\n\tconst builtColumns = Object.fromEntries(\n\t\tObject.entries(columns).map(([name, colBuilderBase]) => {\n\t\t\tconst colBuilder = colBuilderBase as SQLiteColumnBuilder;\n\t\t\tconst column = colBuilder.build(rawTable);\n\t\t\trawTable[InlineForeignKeys].push(...colBuilder.buildForeignKeys(column, rawTable));\n\t\t\treturn [name, column];\n\t\t}),\n\t) as unknown as BuildColumns<TTableName, TColumnsMap, 'sqlite'>;\n\n\tconst table = Object.assign(rawTable, builtColumns);\n\n\ttable[Table.Symbol.Columns] = builtColumns;\n\ttable[Table.Symbol.ExtraConfigColumns] = builtColumns as unknown as BuildExtraConfigColumns<\n\t\tTTableName,\n\t\tTColumnsMap,\n\t\t'sqlite'\n\t>;\n\n\tif (extraConfig) {\n\t\ttable[SQLiteTable.Symbol.ExtraConfigBuilder] = extraConfig as (\n\t\t\tself: Record<string, SQLiteColumn>,\n\t\t) => SQLiteTableExtraConfig;\n\t}\n\n\treturn table;\n}\n\nexport const sqliteTable: SQLiteTableFn = (name, columns, extraConfig) => {\n\treturn sqliteTableBase(name, columns, extraConfig);\n};\n\nexport function sqliteTableCreator(customizeTableName: (name: string) => string): SQLiteTableFn {\n\treturn (name, columns, extraConfig) => {\n\t\treturn sqliteTableBase(customizeTableName(name) as typeof name, columns, extraConfig, undefined, name);\n\t};\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA,oBAA2B;AAC3B,mBAAmF;AAoB5E,MAAM,oBAAoB,OAAO,IAAI,iCAAiC;AAEtE,MAAM,oBAAyD,mBAAS;AAAA,EAC9E,QAAiB,wBAAU,IAAY;AAAA;AAAA,EAGvC,OAAyB,SAAS,OAAO,OAAO,CAAC,GAAG,mBAAM,QAAQ;AAAA,IACjE;AAAA,EACD,CAAC;AAAA;AAAA,EAGD,CAAU,mBAAM,OAAO,OAAO;AAAA;AAAA,EAG9B,CAAC,iBAAiB,IAAkB,CAAC;AAAA;AAAA,EAGrC,CAAU,mBAAM,OAAO,kBAAkB,IAE1B;AAChB;AA4BA,SAAS,gBAKR,MACA,SACA,aACA,QACA,WAAW,MAMT;AACF,QAAM,WAAW,IAAI,YAKlB,MAAM,QAAQ,QAAQ;AAEzB,QAAM,eAAe,OAAO;AAAA,IAC3B,OAAO,QAAQ,OAAO,EAAE,IAAI,CAAC,CAACA,OAAM,cAAc,MAAM;AACvD,YAAM,aAAa;AACnB,YAAM,SAAS,WAAW,MAAM,QAAQ;AACxC,eAAS,iBAAiB,EAAE,KAAK,GAAG,WAAW,iBAAiB,QAAQ,QAAQ,CAAC;AACjF,aAAO,CAACA,OAAM,MAAM;AAAA,IACrB,CAAC;AAAA,EACF;AAEA,QAAM,QAAQ,OAAO,OAAO,UAAU,YAAY;AAElD,QAAM,mBAAM,OAAO,OAAO,IAAI;AAC9B,QAAM,mBAAM,OAAO,kBAAkB,IAAI;AAMzC,MAAI,aAAa;AAChB,UAAM,YAAY,OAAO,kBAAkB,IAAI;AAAA,EAGhD;AAEA,SAAO;AACR;AAEO,MAAM,cAA6B,CAAC,MAAM,SAAS,gBAAgB;AACzE,SAAO,gBAAgB,MAAM,SAAS,WAAW;AAClD;AAEO,SAAS,mBAAmB,oBAA6D;AAC/F,SAAO,CAAC,MAAM,SAAS,gBAAgB;AACtC,WAAO,gBAAgB,mBAAmB,IAAI,GAAkB,SAAS,aAAa,QAAW,IAAI;AAAA,EACtG;AACD;","names":["name"]}
1
+ {"version":3,"sources":["../../src/sqlite-core/table.ts"],"sourcesContent":["import type { BuildColumns, BuildExtraConfigColumns } from '~/column-builder.ts';\nimport { entityKind } from '~/entity.ts';\nimport { Table, type TableConfig as TableConfigBase, type UpdateTableConfig } from '~/table.ts';\nimport type { CheckBuilder } from './checks.ts';\nimport { getSQLiteColumnBuilders, type SQLiteColumnBuilders } from './columns/all.ts';\nimport type { SQLiteColumn, SQLiteColumnBuilder, SQLiteColumnBuilderBase } from './columns/common.ts';\nimport type { ForeignKey, ForeignKeyBuilder } from './foreign-keys.ts';\nimport type { IndexBuilder } from './indexes.ts';\nimport type { PrimaryKeyBuilder } from './primary-keys.ts';\nimport type { UniqueConstraintBuilder } from './unique-constraint.ts';\n\nexport type SQLiteTableExtraConfig = Record<\n\tstring,\n\t| IndexBuilder\n\t| CheckBuilder\n\t| ForeignKeyBuilder\n\t| PrimaryKeyBuilder\n\t| UniqueConstraintBuilder\n>;\n\nexport type TableConfig = TableConfigBase<SQLiteColumn<any>>;\n\n/** @internal */\nexport const InlineForeignKeys = Symbol.for('drizzle:SQLiteInlineForeignKeys');\n\nexport class SQLiteTable<T extends TableConfig = TableConfig> extends Table<T> {\n\tstatic readonly [entityKind]: string = 'SQLiteTable';\n\n\t/** @internal */\n\tstatic override readonly Symbol = Object.assign({}, Table.Symbol, {\n\t\tInlineForeignKeys: InlineForeignKeys as typeof InlineForeignKeys,\n\t});\n\n\t/** @internal */\n\toverride [Table.Symbol.Columns]!: NonNullable<T['columns']>;\n\n\t/** @internal */\n\t[InlineForeignKeys]: ForeignKey[] = [];\n\n\t/** @internal */\n\toverride [Table.Symbol.ExtraConfigBuilder]:\n\t\t| ((self: Record<string, SQLiteColumn>) => SQLiteTableExtraConfig)\n\t\t| undefined = undefined;\n}\n\nexport type AnySQLiteTable<TPartial extends Partial<TableConfig> = {}> = SQLiteTable<\n\tUpdateTableConfig<TableConfig, TPartial>\n>;\n\nexport type SQLiteTableWithColumns<T extends TableConfig> =\n\t& SQLiteTable<T>\n\t& {\n\t\t[Key in keyof T['columns']]: T['columns'][Key];\n\t};\n\nexport interface SQLiteTableFn<TSchema extends string | undefined = undefined> {\n\t<\n\t\tTTableName extends string,\n\t\tTColumnsMap extends Record<string, SQLiteColumnBuilderBase>,\n\t>(\n\t\tname: TTableName,\n\t\tcolumns: TColumnsMap,\n\t\textraConfig?: (self: BuildColumns<TTableName, TColumnsMap, 'sqlite'>) => SQLiteTableExtraConfig,\n\t): SQLiteTableWithColumns<{\n\t\tname: TTableName;\n\t\tschema: TSchema;\n\t\tcolumns: BuildColumns<TTableName, TColumnsMap, 'sqlite'>;\n\t\tdialect: 'sqlite';\n\t}>;\n\n\t<\n\t\tTTableName extends string,\n\t\tTColumnsMap extends Record<string, SQLiteColumnBuilderBase>,\n\t>(\n\t\tname: TTableName,\n\t\tcolumns: (columnTypes: SQLiteColumnBuilders) => TColumnsMap,\n\t\textraConfig?: (self: BuildColumns<TTableName, TColumnsMap, 'sqlite'>) => SQLiteTableExtraConfig,\n\t): SQLiteTableWithColumns<{\n\t\tname: TTableName;\n\t\tschema: TSchema;\n\t\tcolumns: BuildColumns<TTableName, TColumnsMap, 'sqlite'>;\n\t\tdialect: 'sqlite';\n\t}>;\n}\n\nfunction sqliteTableBase<\n\tTTableName extends string,\n\tTColumnsMap extends Record<string, SQLiteColumnBuilderBase>,\n\tTSchema extends string | undefined,\n>(\n\tname: TTableName,\n\tcolumns: TColumnsMap | ((columnTypes: SQLiteColumnBuilders) => TColumnsMap),\n\textraConfig?: (self: BuildColumns<TTableName, TColumnsMap, 'sqlite'>) => SQLiteTableExtraConfig,\n\tschema?: TSchema,\n\tbaseName = name,\n): SQLiteTableWithColumns<{\n\tname: TTableName;\n\tschema: TSchema;\n\tcolumns: BuildColumns<TTableName, TColumnsMap, 'sqlite'>;\n\tdialect: 'sqlite';\n}> {\n\tconst rawTable = new SQLiteTable<{\n\t\tname: TTableName;\n\t\tschema: TSchema;\n\t\tcolumns: BuildColumns<TTableName, TColumnsMap, 'sqlite'>;\n\t\tdialect: 'sqlite';\n\t}>(name, schema, baseName);\n\n\tconst parsedColumns: TColumnsMap = typeof columns === 'function' ? columns(getSQLiteColumnBuilders()) : columns;\n\n\tconst builtColumns = Object.fromEntries(\n\t\tObject.entries(parsedColumns).map(([name, colBuilderBase]) => {\n\t\t\tconst colBuilder = colBuilderBase as SQLiteColumnBuilder;\n\t\t\tcolBuilder.setName(name);\n\t\t\tconst column = colBuilder.build(rawTable);\n\t\t\trawTable[InlineForeignKeys].push(...colBuilder.buildForeignKeys(column, rawTable));\n\t\t\treturn [name, column];\n\t\t}),\n\t) as unknown as BuildColumns<TTableName, TColumnsMap, 'sqlite'>;\n\n\tconst table = Object.assign(rawTable, builtColumns);\n\n\ttable[Table.Symbol.Columns] = builtColumns;\n\ttable[Table.Symbol.ExtraConfigColumns] = builtColumns as unknown as BuildExtraConfigColumns<\n\t\tTTableName,\n\t\tTColumnsMap,\n\t\t'sqlite'\n\t>;\n\n\tif (extraConfig) {\n\t\ttable[SQLiteTable.Symbol.ExtraConfigBuilder] = extraConfig as (\n\t\t\tself: Record<string, SQLiteColumn>,\n\t\t) => SQLiteTableExtraConfig;\n\t}\n\n\treturn table;\n}\n\nexport const sqliteTable: SQLiteTableFn = (name, columns, extraConfig) => {\n\treturn sqliteTableBase(name, columns, extraConfig);\n};\n\nexport function sqliteTableCreator(customizeTableName: (name: string) => string): SQLiteTableFn {\n\treturn (name, columns, extraConfig) => {\n\t\treturn sqliteTableBase(customizeTableName(name) as typeof name, columns, extraConfig, undefined, name);\n\t};\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA,oBAA2B;AAC3B,mBAAmF;AAEnF,iBAAmE;AAmB5D,MAAM,oBAAoB,OAAO,IAAI,iCAAiC;AAEtE,MAAM,oBAAyD,mBAAS;AAAA,EAC9E,QAAiB,wBAAU,IAAY;AAAA;AAAA,EAGvC,OAAyB,SAAS,OAAO,OAAO,CAAC,GAAG,mBAAM,QAAQ;AAAA,IACjE;AAAA,EACD,CAAC;AAAA;AAAA,EAGD,CAAU,mBAAM,OAAO,OAAO;AAAA;AAAA,EAG9B,CAAC,iBAAiB,IAAkB,CAAC;AAAA;AAAA,EAGrC,CAAU,mBAAM,OAAO,kBAAkB,IAE1B;AAChB;AA0CA,SAAS,gBAKR,MACA,SACA,aACA,QACA,WAAW,MAMT;AACF,QAAM,WAAW,IAAI,YAKlB,MAAM,QAAQ,QAAQ;AAEzB,QAAM,gBAA6B,OAAO,YAAY,aAAa,YAAQ,oCAAwB,CAAC,IAAI;AAExG,QAAM,eAAe,OAAO;AAAA,IAC3B,OAAO,QAAQ,aAAa,EAAE,IAAI,CAAC,CAACA,OAAM,cAAc,MAAM;AAC7D,YAAM,aAAa;AACnB,iBAAW,QAAQA,KAAI;AACvB,YAAM,SAAS,WAAW,MAAM,QAAQ;AACxC,eAAS,iBAAiB,EAAE,KAAK,GAAG,WAAW,iBAAiB,QAAQ,QAAQ,CAAC;AACjF,aAAO,CAACA,OAAM,MAAM;AAAA,IACrB,CAAC;AAAA,EACF;AAEA,QAAM,QAAQ,OAAO,OAAO,UAAU,YAAY;AAElD,QAAM,mBAAM,OAAO,OAAO,IAAI;AAC9B,QAAM,mBAAM,OAAO,kBAAkB,IAAI;AAMzC,MAAI,aAAa;AAChB,UAAM,YAAY,OAAO,kBAAkB,IAAI;AAAA,EAGhD;AAEA,SAAO;AACR;AAEO,MAAM,cAA6B,CAAC,MAAM,SAAS,gBAAgB;AACzE,SAAO,gBAAgB,MAAM,SAAS,WAAW;AAClD;AAEO,SAAS,mBAAmB,oBAA6D;AAC/F,SAAO,CAAC,MAAM,SAAS,gBAAgB;AACtC,WAAO,gBAAgB,mBAAmB,IAAI,GAAkB,SAAS,aAAa,QAAW,IAAI;AAAA,EACtG;AACD;","names":["name"]}
@@ -2,6 +2,7 @@ import type { BuildColumns } from "../column-builder.cjs";
2
2
  import { entityKind } from "../entity.cjs";
3
3
  import { Table, type TableConfig as TableConfigBase, type UpdateTableConfig } from "../table.cjs";
4
4
  import type { CheckBuilder } from "./checks.cjs";
5
+ import { type SQLiteColumnBuilders } from "./columns/all.cjs";
5
6
  import type { SQLiteColumn, SQLiteColumnBuilderBase } from "./columns/common.cjs";
6
7
  import type { ForeignKeyBuilder } from "./foreign-keys.cjs";
7
8
  import type { IndexBuilder } from "./indexes.cjs";
@@ -23,6 +24,12 @@ export interface SQLiteTableFn<TSchema extends string | undefined = undefined> {
23
24
  columns: BuildColumns<TTableName, TColumnsMap, 'sqlite'>;
24
25
  dialect: 'sqlite';
25
26
  }>;
27
+ <TTableName extends string, TColumnsMap extends Record<string, SQLiteColumnBuilderBase>>(name: TTableName, columns: (columnTypes: SQLiteColumnBuilders) => TColumnsMap, extraConfig?: (self: BuildColumns<TTableName, TColumnsMap, 'sqlite'>) => SQLiteTableExtraConfig): SQLiteTableWithColumns<{
28
+ name: TTableName;
29
+ schema: TSchema;
30
+ columns: BuildColumns<TTableName, TColumnsMap, 'sqlite'>;
31
+ dialect: 'sqlite';
32
+ }>;
26
33
  }
27
34
  export declare const sqliteTable: SQLiteTableFn;
28
35
  export declare function sqliteTableCreator(customizeTableName: (name: string) => string): SQLiteTableFn;
@@ -2,6 +2,7 @@ import type { BuildColumns } from "../column-builder.js";
2
2
  import { entityKind } from "../entity.js";
3
3
  import { Table, type TableConfig as TableConfigBase, type UpdateTableConfig } from "../table.js";
4
4
  import type { CheckBuilder } from "./checks.js";
5
+ import { type SQLiteColumnBuilders } from "./columns/all.js";
5
6
  import type { SQLiteColumn, SQLiteColumnBuilderBase } from "./columns/common.js";
6
7
  import type { ForeignKeyBuilder } from "./foreign-keys.js";
7
8
  import type { IndexBuilder } from "./indexes.js";
@@ -23,6 +24,12 @@ export interface SQLiteTableFn<TSchema extends string | undefined = undefined> {
23
24
  columns: BuildColumns<TTableName, TColumnsMap, 'sqlite'>;
24
25
  dialect: 'sqlite';
25
26
  }>;
27
+ <TTableName extends string, TColumnsMap extends Record<string, SQLiteColumnBuilderBase>>(name: TTableName, columns: (columnTypes: SQLiteColumnBuilders) => TColumnsMap, extraConfig?: (self: BuildColumns<TTableName, TColumnsMap, 'sqlite'>) => SQLiteTableExtraConfig): SQLiteTableWithColumns<{
28
+ name: TTableName;
29
+ schema: TSchema;
30
+ columns: BuildColumns<TTableName, TColumnsMap, 'sqlite'>;
31
+ dialect: 'sqlite';
32
+ }>;
26
33
  }
27
34
  export declare const sqliteTable: SQLiteTableFn;
28
35
  export declare function sqliteTableCreator(customizeTableName: (name: string) => string): SQLiteTableFn;
@@ -1,5 +1,6 @@
1
1
  import { entityKind } from "../entity.js";
2
2
  import { Table } from "../table.js";
3
+ import { getSQLiteColumnBuilders } from "./columns/all.js";
3
4
  const InlineForeignKeys = Symbol.for("drizzle:SQLiteInlineForeignKeys");
4
5
  class SQLiteTable extends Table {
5
6
  static [entityKind] = "SQLiteTable";
@@ -16,9 +17,11 @@ class SQLiteTable extends Table {
16
17
  }
17
18
  function sqliteTableBase(name, columns, extraConfig, schema, baseName = name) {
18
19
  const rawTable = new SQLiteTable(name, schema, baseName);
20
+ const parsedColumns = typeof columns === "function" ? columns(getSQLiteColumnBuilders()) : columns;
19
21
  const builtColumns = Object.fromEntries(
20
- Object.entries(columns).map(([name2, colBuilderBase]) => {
22
+ Object.entries(parsedColumns).map(([name2, colBuilderBase]) => {
21
23
  const colBuilder = colBuilderBase;
24
+ colBuilder.setName(name2);
22
25
  const column = colBuilder.build(rawTable);
23
26
  rawTable[InlineForeignKeys].push(...colBuilder.buildForeignKeys(column, rawTable));
24
27
  return [name2, column];
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/sqlite-core/table.ts"],"sourcesContent":["import type { BuildColumns, BuildExtraConfigColumns } from '~/column-builder.ts';\nimport { entityKind } from '~/entity.ts';\nimport { Table, type TableConfig as TableConfigBase, type UpdateTableConfig } from '~/table.ts';\nimport type { CheckBuilder } from './checks.ts';\nimport type { SQLiteColumn, SQLiteColumnBuilder, SQLiteColumnBuilderBase } from './columns/common.ts';\nimport type { ForeignKey, ForeignKeyBuilder } from './foreign-keys.ts';\nimport type { IndexBuilder } from './indexes.ts';\nimport type { PrimaryKeyBuilder } from './primary-keys.ts';\nimport type { UniqueConstraintBuilder } from './unique-constraint.ts';\n\nexport type SQLiteTableExtraConfig = Record<\n\tstring,\n\t| IndexBuilder\n\t| CheckBuilder\n\t| ForeignKeyBuilder\n\t| PrimaryKeyBuilder\n\t| UniqueConstraintBuilder\n>;\n\nexport type TableConfig = TableConfigBase<SQLiteColumn<any>>;\n\n/** @internal */\nexport const InlineForeignKeys = Symbol.for('drizzle:SQLiteInlineForeignKeys');\n\nexport class SQLiteTable<T extends TableConfig = TableConfig> extends Table<T> {\n\tstatic readonly [entityKind]: string = 'SQLiteTable';\n\n\t/** @internal */\n\tstatic override readonly Symbol = Object.assign({}, Table.Symbol, {\n\t\tInlineForeignKeys: InlineForeignKeys as typeof InlineForeignKeys,\n\t});\n\n\t/** @internal */\n\toverride [Table.Symbol.Columns]!: NonNullable<T['columns']>;\n\n\t/** @internal */\n\t[InlineForeignKeys]: ForeignKey[] = [];\n\n\t/** @internal */\n\toverride [Table.Symbol.ExtraConfigBuilder]:\n\t\t| ((self: Record<string, SQLiteColumn>) => SQLiteTableExtraConfig)\n\t\t| undefined = undefined;\n}\n\nexport type AnySQLiteTable<TPartial extends Partial<TableConfig> = {}> = SQLiteTable<\n\tUpdateTableConfig<TableConfig, TPartial>\n>;\n\nexport type SQLiteTableWithColumns<T extends TableConfig> =\n\t& SQLiteTable<T>\n\t& {\n\t\t[Key in keyof T['columns']]: T['columns'][Key];\n\t};\n\nexport interface SQLiteTableFn<TSchema extends string | undefined = undefined> {\n\t<\n\t\tTTableName extends string,\n\t\tTColumnsMap extends Record<string, SQLiteColumnBuilderBase>,\n\t>(\n\t\tname: TTableName,\n\t\tcolumns: TColumnsMap,\n\t\textraConfig?: (self: BuildColumns<TTableName, TColumnsMap, 'sqlite'>) => SQLiteTableExtraConfig,\n\t): SQLiteTableWithColumns<{\n\t\tname: TTableName;\n\t\tschema: TSchema;\n\t\tcolumns: BuildColumns<TTableName, TColumnsMap, 'sqlite'>;\n\t\tdialect: 'sqlite';\n\t}>;\n}\n\nfunction sqliteTableBase<\n\tTTableName extends string,\n\tTColumnsMap extends Record<string, SQLiteColumnBuilderBase>,\n\tTSchema extends string | undefined,\n>(\n\tname: TTableName,\n\tcolumns: TColumnsMap,\n\textraConfig?: (self: BuildColumns<TTableName, TColumnsMap, 'sqlite'>) => SQLiteTableExtraConfig,\n\tschema?: TSchema,\n\tbaseName = name,\n): SQLiteTableWithColumns<{\n\tname: TTableName;\n\tschema: TSchema;\n\tcolumns: BuildColumns<TTableName, TColumnsMap, 'sqlite'>;\n\tdialect: 'sqlite';\n}> {\n\tconst rawTable = new SQLiteTable<{\n\t\tname: TTableName;\n\t\tschema: TSchema;\n\t\tcolumns: BuildColumns<TTableName, TColumnsMap, 'sqlite'>;\n\t\tdialect: 'sqlite';\n\t}>(name, schema, baseName);\n\n\tconst builtColumns = Object.fromEntries(\n\t\tObject.entries(columns).map(([name, colBuilderBase]) => {\n\t\t\tconst colBuilder = colBuilderBase as SQLiteColumnBuilder;\n\t\t\tconst column = colBuilder.build(rawTable);\n\t\t\trawTable[InlineForeignKeys].push(...colBuilder.buildForeignKeys(column, rawTable));\n\t\t\treturn [name, column];\n\t\t}),\n\t) as unknown as BuildColumns<TTableName, TColumnsMap, 'sqlite'>;\n\n\tconst table = Object.assign(rawTable, builtColumns);\n\n\ttable[Table.Symbol.Columns] = builtColumns;\n\ttable[Table.Symbol.ExtraConfigColumns] = builtColumns as unknown as BuildExtraConfigColumns<\n\t\tTTableName,\n\t\tTColumnsMap,\n\t\t'sqlite'\n\t>;\n\n\tif (extraConfig) {\n\t\ttable[SQLiteTable.Symbol.ExtraConfigBuilder] = extraConfig as (\n\t\t\tself: Record<string, SQLiteColumn>,\n\t\t) => SQLiteTableExtraConfig;\n\t}\n\n\treturn table;\n}\n\nexport const sqliteTable: SQLiteTableFn = (name, columns, extraConfig) => {\n\treturn sqliteTableBase(name, columns, extraConfig);\n};\n\nexport function sqliteTableCreator(customizeTableName: (name: string) => string): SQLiteTableFn {\n\treturn (name, columns, extraConfig) => {\n\t\treturn sqliteTableBase(customizeTableName(name) as typeof name, columns, extraConfig, undefined, name);\n\t};\n}\n"],"mappings":"AACA,SAAS,kBAAkB;AAC3B,SAAS,aAA0E;AAoB5E,MAAM,oBAAoB,OAAO,IAAI,iCAAiC;AAEtE,MAAM,oBAAyD,MAAS;AAAA,EAC9E,QAAiB,UAAU,IAAY;AAAA;AAAA,EAGvC,OAAyB,SAAS,OAAO,OAAO,CAAC,GAAG,MAAM,QAAQ;AAAA,IACjE;AAAA,EACD,CAAC;AAAA;AAAA,EAGD,CAAU,MAAM,OAAO,OAAO;AAAA;AAAA,EAG9B,CAAC,iBAAiB,IAAkB,CAAC;AAAA;AAAA,EAGrC,CAAU,MAAM,OAAO,kBAAkB,IAE1B;AAChB;AA4BA,SAAS,gBAKR,MACA,SACA,aACA,QACA,WAAW,MAMT;AACF,QAAM,WAAW,IAAI,YAKlB,MAAM,QAAQ,QAAQ;AAEzB,QAAM,eAAe,OAAO;AAAA,IAC3B,OAAO,QAAQ,OAAO,EAAE,IAAI,CAAC,CAACA,OAAM,cAAc,MAAM;AACvD,YAAM,aAAa;AACnB,YAAM,SAAS,WAAW,MAAM,QAAQ;AACxC,eAAS,iBAAiB,EAAE,KAAK,GAAG,WAAW,iBAAiB,QAAQ,QAAQ,CAAC;AACjF,aAAO,CAACA,OAAM,MAAM;AAAA,IACrB,CAAC;AAAA,EACF;AAEA,QAAM,QAAQ,OAAO,OAAO,UAAU,YAAY;AAElD,QAAM,MAAM,OAAO,OAAO,IAAI;AAC9B,QAAM,MAAM,OAAO,kBAAkB,IAAI;AAMzC,MAAI,aAAa;AAChB,UAAM,YAAY,OAAO,kBAAkB,IAAI;AAAA,EAGhD;AAEA,SAAO;AACR;AAEO,MAAM,cAA6B,CAAC,MAAM,SAAS,gBAAgB;AACzE,SAAO,gBAAgB,MAAM,SAAS,WAAW;AAClD;AAEO,SAAS,mBAAmB,oBAA6D;AAC/F,SAAO,CAAC,MAAM,SAAS,gBAAgB;AACtC,WAAO,gBAAgB,mBAAmB,IAAI,GAAkB,SAAS,aAAa,QAAW,IAAI;AAAA,EACtG;AACD;","names":["name"]}
1
+ {"version":3,"sources":["../../src/sqlite-core/table.ts"],"sourcesContent":["import type { BuildColumns, BuildExtraConfigColumns } from '~/column-builder.ts';\nimport { entityKind } from '~/entity.ts';\nimport { Table, type TableConfig as TableConfigBase, type UpdateTableConfig } from '~/table.ts';\nimport type { CheckBuilder } from './checks.ts';\nimport { getSQLiteColumnBuilders, type SQLiteColumnBuilders } from './columns/all.ts';\nimport type { SQLiteColumn, SQLiteColumnBuilder, SQLiteColumnBuilderBase } from './columns/common.ts';\nimport type { ForeignKey, ForeignKeyBuilder } from './foreign-keys.ts';\nimport type { IndexBuilder } from './indexes.ts';\nimport type { PrimaryKeyBuilder } from './primary-keys.ts';\nimport type { UniqueConstraintBuilder } from './unique-constraint.ts';\n\nexport type SQLiteTableExtraConfig = Record<\n\tstring,\n\t| IndexBuilder\n\t| CheckBuilder\n\t| ForeignKeyBuilder\n\t| PrimaryKeyBuilder\n\t| UniqueConstraintBuilder\n>;\n\nexport type TableConfig = TableConfigBase<SQLiteColumn<any>>;\n\n/** @internal */\nexport const InlineForeignKeys = Symbol.for('drizzle:SQLiteInlineForeignKeys');\n\nexport class SQLiteTable<T extends TableConfig = TableConfig> extends Table<T> {\n\tstatic readonly [entityKind]: string = 'SQLiteTable';\n\n\t/** @internal */\n\tstatic override readonly Symbol = Object.assign({}, Table.Symbol, {\n\t\tInlineForeignKeys: InlineForeignKeys as typeof InlineForeignKeys,\n\t});\n\n\t/** @internal */\n\toverride [Table.Symbol.Columns]!: NonNullable<T['columns']>;\n\n\t/** @internal */\n\t[InlineForeignKeys]: ForeignKey[] = [];\n\n\t/** @internal */\n\toverride [Table.Symbol.ExtraConfigBuilder]:\n\t\t| ((self: Record<string, SQLiteColumn>) => SQLiteTableExtraConfig)\n\t\t| undefined = undefined;\n}\n\nexport type AnySQLiteTable<TPartial extends Partial<TableConfig> = {}> = SQLiteTable<\n\tUpdateTableConfig<TableConfig, TPartial>\n>;\n\nexport type SQLiteTableWithColumns<T extends TableConfig> =\n\t& SQLiteTable<T>\n\t& {\n\t\t[Key in keyof T['columns']]: T['columns'][Key];\n\t};\n\nexport interface SQLiteTableFn<TSchema extends string | undefined = undefined> {\n\t<\n\t\tTTableName extends string,\n\t\tTColumnsMap extends Record<string, SQLiteColumnBuilderBase>,\n\t>(\n\t\tname: TTableName,\n\t\tcolumns: TColumnsMap,\n\t\textraConfig?: (self: BuildColumns<TTableName, TColumnsMap, 'sqlite'>) => SQLiteTableExtraConfig,\n\t): SQLiteTableWithColumns<{\n\t\tname: TTableName;\n\t\tschema: TSchema;\n\t\tcolumns: BuildColumns<TTableName, TColumnsMap, 'sqlite'>;\n\t\tdialect: 'sqlite';\n\t}>;\n\n\t<\n\t\tTTableName extends string,\n\t\tTColumnsMap extends Record<string, SQLiteColumnBuilderBase>,\n\t>(\n\t\tname: TTableName,\n\t\tcolumns: (columnTypes: SQLiteColumnBuilders) => TColumnsMap,\n\t\textraConfig?: (self: BuildColumns<TTableName, TColumnsMap, 'sqlite'>) => SQLiteTableExtraConfig,\n\t): SQLiteTableWithColumns<{\n\t\tname: TTableName;\n\t\tschema: TSchema;\n\t\tcolumns: BuildColumns<TTableName, TColumnsMap, 'sqlite'>;\n\t\tdialect: 'sqlite';\n\t}>;\n}\n\nfunction sqliteTableBase<\n\tTTableName extends string,\n\tTColumnsMap extends Record<string, SQLiteColumnBuilderBase>,\n\tTSchema extends string | undefined,\n>(\n\tname: TTableName,\n\tcolumns: TColumnsMap | ((columnTypes: SQLiteColumnBuilders) => TColumnsMap),\n\textraConfig?: (self: BuildColumns<TTableName, TColumnsMap, 'sqlite'>) => SQLiteTableExtraConfig,\n\tschema?: TSchema,\n\tbaseName = name,\n): SQLiteTableWithColumns<{\n\tname: TTableName;\n\tschema: TSchema;\n\tcolumns: BuildColumns<TTableName, TColumnsMap, 'sqlite'>;\n\tdialect: 'sqlite';\n}> {\n\tconst rawTable = new SQLiteTable<{\n\t\tname: TTableName;\n\t\tschema: TSchema;\n\t\tcolumns: BuildColumns<TTableName, TColumnsMap, 'sqlite'>;\n\t\tdialect: 'sqlite';\n\t}>(name, schema, baseName);\n\n\tconst parsedColumns: TColumnsMap = typeof columns === 'function' ? columns(getSQLiteColumnBuilders()) : columns;\n\n\tconst builtColumns = Object.fromEntries(\n\t\tObject.entries(parsedColumns).map(([name, colBuilderBase]) => {\n\t\t\tconst colBuilder = colBuilderBase as SQLiteColumnBuilder;\n\t\t\tcolBuilder.setName(name);\n\t\t\tconst column = colBuilder.build(rawTable);\n\t\t\trawTable[InlineForeignKeys].push(...colBuilder.buildForeignKeys(column, rawTable));\n\t\t\treturn [name, column];\n\t\t}),\n\t) as unknown as BuildColumns<TTableName, TColumnsMap, 'sqlite'>;\n\n\tconst table = Object.assign(rawTable, builtColumns);\n\n\ttable[Table.Symbol.Columns] = builtColumns;\n\ttable[Table.Symbol.ExtraConfigColumns] = builtColumns as unknown as BuildExtraConfigColumns<\n\t\tTTableName,\n\t\tTColumnsMap,\n\t\t'sqlite'\n\t>;\n\n\tif (extraConfig) {\n\t\ttable[SQLiteTable.Symbol.ExtraConfigBuilder] = extraConfig as (\n\t\t\tself: Record<string, SQLiteColumn>,\n\t\t) => SQLiteTableExtraConfig;\n\t}\n\n\treturn table;\n}\n\nexport const sqliteTable: SQLiteTableFn = (name, columns, extraConfig) => {\n\treturn sqliteTableBase(name, columns, extraConfig);\n};\n\nexport function sqliteTableCreator(customizeTableName: (name: string) => string): SQLiteTableFn {\n\treturn (name, columns, extraConfig) => {\n\t\treturn sqliteTableBase(customizeTableName(name) as typeof name, columns, extraConfig, undefined, name);\n\t};\n}\n"],"mappings":"AACA,SAAS,kBAAkB;AAC3B,SAAS,aAA0E;AAEnF,SAAS,+BAA0D;AAmB5D,MAAM,oBAAoB,OAAO,IAAI,iCAAiC;AAEtE,MAAM,oBAAyD,MAAS;AAAA,EAC9E,QAAiB,UAAU,IAAY;AAAA;AAAA,EAGvC,OAAyB,SAAS,OAAO,OAAO,CAAC,GAAG,MAAM,QAAQ;AAAA,IACjE;AAAA,EACD,CAAC;AAAA;AAAA,EAGD,CAAU,MAAM,OAAO,OAAO;AAAA;AAAA,EAG9B,CAAC,iBAAiB,IAAkB,CAAC;AAAA;AAAA,EAGrC,CAAU,MAAM,OAAO,kBAAkB,IAE1B;AAChB;AA0CA,SAAS,gBAKR,MACA,SACA,aACA,QACA,WAAW,MAMT;AACF,QAAM,WAAW,IAAI,YAKlB,MAAM,QAAQ,QAAQ;AAEzB,QAAM,gBAA6B,OAAO,YAAY,aAAa,QAAQ,wBAAwB,CAAC,IAAI;AAExG,QAAM,eAAe,OAAO;AAAA,IAC3B,OAAO,QAAQ,aAAa,EAAE,IAAI,CAAC,CAACA,OAAM,cAAc,MAAM;AAC7D,YAAM,aAAa;AACnB,iBAAW,QAAQA,KAAI;AACvB,YAAM,SAAS,WAAW,MAAM,QAAQ;AACxC,eAAS,iBAAiB,EAAE,KAAK,GAAG,WAAW,iBAAiB,QAAQ,QAAQ,CAAC;AACjF,aAAO,CAACA,OAAM,MAAM;AAAA,IACrB,CAAC;AAAA,EACF;AAEA,QAAM,QAAQ,OAAO,OAAO,UAAU,YAAY;AAElD,QAAM,MAAM,OAAO,OAAO,IAAI;AAC9B,QAAM,MAAM,OAAO,kBAAkB,IAAI;AAMzC,MAAI,aAAa;AAChB,UAAM,YAAY,OAAO,kBAAkB,IAAI;AAAA,EAGhD;AAEA,SAAO;AACR;AAEO,MAAM,cAA6B,CAAC,MAAM,SAAS,gBAAgB;AACzE,SAAO,gBAAgB,MAAM,SAAS,WAAW;AAClD;AAEO,SAAS,mBAAmB,oBAA6D;AAC/F,SAAO,CAAC,MAAM,SAAS,gBAAgB;AACtC,WAAO,gBAAgB,mBAAmB,IAAI,GAAkB,SAAS,aAAa,QAAW,IAAI;AAAA,EACtG;AACD;","names":["name"]}
@@ -26,9 +26,9 @@ __export(unique_constraint_exports, {
26
26
  });
27
27
  module.exports = __toCommonJS(unique_constraint_exports);
28
28
  var import_entity = require("../entity.cjs");
29
- var import_table = require("./table.cjs");
29
+ var import_table_utils = require("../table.utils.cjs");
30
30
  function uniqueKeyName(table, columns) {
31
- return `${table[import_table.SQLiteTable.Symbol.Name]}_${columns.join("_")}_unique`;
31
+ return `${table[import_table_utils.TableName]}_${columns.join("_")}_unique`;
32
32
  }
33
33
  function unique(name) {
34
34
  return new UniqueOnConstraintBuilder(name);
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/sqlite-core/unique-constraint.ts"],"sourcesContent":["import { entityKind } from '~/entity.ts';\nimport type { SQLiteColumn } from './columns/common.ts';\nimport { SQLiteTable } from './table.ts';\n\nexport function uniqueKeyName(table: SQLiteTable, columns: string[]) {\n\treturn `${table[SQLiteTable.Symbol.Name]}_${columns.join('_')}_unique`;\n}\n\nexport function unique(name?: string): UniqueOnConstraintBuilder {\n\treturn new UniqueOnConstraintBuilder(name);\n}\n\nexport class UniqueConstraintBuilder {\n\tstatic readonly [entityKind]: string = 'SQLiteUniqueConstraintBuilder';\n\n\t/** @internal */\n\tcolumns: SQLiteColumn[];\n\n\tconstructor(\n\t\tcolumns: SQLiteColumn[],\n\t\tprivate name?: string,\n\t) {\n\t\tthis.columns = columns;\n\t}\n\n\t/** @internal */\n\tbuild(table: SQLiteTable): UniqueConstraint {\n\t\treturn new UniqueConstraint(table, this.columns, this.name);\n\t}\n}\n\nexport class UniqueOnConstraintBuilder {\n\tstatic readonly [entityKind]: string = 'SQLiteUniqueOnConstraintBuilder';\n\n\t/** @internal */\n\tname?: string;\n\n\tconstructor(\n\t\tname?: string,\n\t) {\n\t\tthis.name = name;\n\t}\n\n\ton(...columns: [SQLiteColumn, ...SQLiteColumn[]]) {\n\t\treturn new UniqueConstraintBuilder(columns, this.name);\n\t}\n}\n\nexport class UniqueConstraint {\n\tstatic readonly [entityKind]: string = 'SQLiteUniqueConstraint';\n\n\treadonly columns: SQLiteColumn[];\n\treadonly name?: string;\n\n\tconstructor(readonly table: SQLiteTable, columns: SQLiteColumn[], name?: string) {\n\t\tthis.columns = columns;\n\t\tthis.name = name ?? uniqueKeyName(this.table, this.columns.map((column) => column.name));\n\t}\n\n\tgetName() {\n\t\treturn this.name;\n\t}\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,oBAA2B;AAE3B,mBAA4B;AAErB,SAAS,cAAc,OAAoB,SAAmB;AACpE,SAAO,GAAG,MAAM,yBAAY,OAAO,IAAI,CAAC,IAAI,QAAQ,KAAK,GAAG,CAAC;AAC9D;AAEO,SAAS,OAAO,MAA0C;AAChE,SAAO,IAAI,0BAA0B,IAAI;AAC1C;AAEO,MAAM,wBAAwB;AAAA,EAMpC,YACC,SACQ,MACP;AADO;AAER,SAAK,UAAU;AAAA,EAChB;AAAA,EAVA,QAAiB,wBAAU,IAAY;AAAA;AAAA,EAGvC;AAAA;AAAA,EAUA,MAAM,OAAsC;AAC3C,WAAO,IAAI,iBAAiB,OAAO,KAAK,SAAS,KAAK,IAAI;AAAA,EAC3D;AACD;AAEO,MAAM,0BAA0B;AAAA,EACtC,QAAiB,wBAAU,IAAY;AAAA;AAAA,EAGvC;AAAA,EAEA,YACC,MACC;AACD,SAAK,OAAO;AAAA,EACb;AAAA,EAEA,MAAM,SAA4C;AACjD,WAAO,IAAI,wBAAwB,SAAS,KAAK,IAAI;AAAA,EACtD;AACD;AAEO,MAAM,iBAAiB;AAAA,EAM7B,YAAqB,OAAoB,SAAyB,MAAe;AAA5D;AACpB,SAAK,UAAU;AACf,SAAK,OAAO,QAAQ,cAAc,KAAK,OAAO,KAAK,QAAQ,IAAI,CAAC,WAAW,OAAO,IAAI,CAAC;AAAA,EACxF;AAAA,EARA,QAAiB,wBAAU,IAAY;AAAA,EAE9B;AAAA,EACA;AAAA,EAOT,UAAU;AACT,WAAO,KAAK;AAAA,EACb;AACD;","names":[]}
1
+ {"version":3,"sources":["../../src/sqlite-core/unique-constraint.ts"],"sourcesContent":["import { entityKind } from '~/entity.ts';\nimport { TableName } from '~/table.utils.ts';\nimport type { SQLiteColumn } from './columns/common.ts';\nimport type { SQLiteTable } from './table.ts';\n\nexport function uniqueKeyName(table: SQLiteTable, columns: string[]) {\n\treturn `${table[TableName]}_${columns.join('_')}_unique`;\n}\n\nexport function unique(name?: string): UniqueOnConstraintBuilder {\n\treturn new UniqueOnConstraintBuilder(name);\n}\n\nexport class UniqueConstraintBuilder {\n\tstatic readonly [entityKind]: string = 'SQLiteUniqueConstraintBuilder';\n\n\t/** @internal */\n\tcolumns: SQLiteColumn[];\n\n\tconstructor(\n\t\tcolumns: SQLiteColumn[],\n\t\tprivate name?: string,\n\t) {\n\t\tthis.columns = columns;\n\t}\n\n\t/** @internal */\n\tbuild(table: SQLiteTable): UniqueConstraint {\n\t\treturn new UniqueConstraint(table, this.columns, this.name);\n\t}\n}\n\nexport class UniqueOnConstraintBuilder {\n\tstatic readonly [entityKind]: string = 'SQLiteUniqueOnConstraintBuilder';\n\n\t/** @internal */\n\tname?: string;\n\n\tconstructor(\n\t\tname?: string,\n\t) {\n\t\tthis.name = name;\n\t}\n\n\ton(...columns: [SQLiteColumn, ...SQLiteColumn[]]) {\n\t\treturn new UniqueConstraintBuilder(columns, this.name);\n\t}\n}\n\nexport class UniqueConstraint {\n\tstatic readonly [entityKind]: string = 'SQLiteUniqueConstraint';\n\n\treadonly columns: SQLiteColumn[];\n\treadonly name?: string;\n\n\tconstructor(readonly table: SQLiteTable, columns: SQLiteColumn[], name?: string) {\n\t\tthis.columns = columns;\n\t\tthis.name = name ?? uniqueKeyName(this.table, this.columns.map((column) => column.name));\n\t}\n\n\tgetName() {\n\t\treturn this.name;\n\t}\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,oBAA2B;AAC3B,yBAA0B;AAInB,SAAS,cAAc,OAAoB,SAAmB;AACpE,SAAO,GAAG,MAAM,4BAAS,CAAC,IAAI,QAAQ,KAAK,GAAG,CAAC;AAChD;AAEO,SAAS,OAAO,MAA0C;AAChE,SAAO,IAAI,0BAA0B,IAAI;AAC1C;AAEO,MAAM,wBAAwB;AAAA,EAMpC,YACC,SACQ,MACP;AADO;AAER,SAAK,UAAU;AAAA,EAChB;AAAA,EAVA,QAAiB,wBAAU,IAAY;AAAA;AAAA,EAGvC;AAAA;AAAA,EAUA,MAAM,OAAsC;AAC3C,WAAO,IAAI,iBAAiB,OAAO,KAAK,SAAS,KAAK,IAAI;AAAA,EAC3D;AACD;AAEO,MAAM,0BAA0B;AAAA,EACtC,QAAiB,wBAAU,IAAY;AAAA;AAAA,EAGvC;AAAA,EAEA,YACC,MACC;AACD,SAAK,OAAO;AAAA,EACb;AAAA,EAEA,MAAM,SAA4C;AACjD,WAAO,IAAI,wBAAwB,SAAS,KAAK,IAAI;AAAA,EACtD;AACD;AAEO,MAAM,iBAAiB;AAAA,EAM7B,YAAqB,OAAoB,SAAyB,MAAe;AAA5D;AACpB,SAAK,UAAU;AACf,SAAK,OAAO,QAAQ,cAAc,KAAK,OAAO,KAAK,QAAQ,IAAI,CAAC,WAAW,OAAO,IAAI,CAAC;AAAA,EACxF;AAAA,EARA,QAAiB,wBAAU,IAAY;AAAA,EAE9B;AAAA,EACA;AAAA,EAOT,UAAU;AACT,WAAO,KAAK;AAAA,EACb;AACD;","names":[]}
@@ -1,6 +1,6 @@
1
1
  import { entityKind } from "../entity.cjs";
2
2
  import type { SQLiteColumn } from "./columns/common.cjs";
3
- import { SQLiteTable } from "./table.cjs";
3
+ import type { SQLiteTable } from "./table.cjs";
4
4
  export declare function uniqueKeyName(table: SQLiteTable, columns: string[]): string;
5
5
  export declare function unique(name?: string): UniqueOnConstraintBuilder;
6
6
  export declare class UniqueConstraintBuilder {
@@ -1,6 +1,6 @@
1
1
  import { entityKind } from "../entity.js";
2
2
  import type { SQLiteColumn } from "./columns/common.js";
3
- import { SQLiteTable } from "./table.js";
3
+ import type { SQLiteTable } from "./table.js";
4
4
  export declare function uniqueKeyName(table: SQLiteTable, columns: string[]): string;
5
5
  export declare function unique(name?: string): UniqueOnConstraintBuilder;
6
6
  export declare class UniqueConstraintBuilder {
@@ -1,7 +1,7 @@
1
1
  import { entityKind } from "../entity.js";
2
- import { SQLiteTable } from "./table.js";
2
+ import { TableName } from "../table.utils.js";
3
3
  function uniqueKeyName(table, columns) {
4
- return `${table[SQLiteTable.Symbol.Name]}_${columns.join("_")}_unique`;
4
+ return `${table[TableName]}_${columns.join("_")}_unique`;
5
5
  }
6
6
  function unique(name) {
7
7
  return new UniqueOnConstraintBuilder(name);