sqlspec 0.36.0__cp310-cp310-manylinux2014_aarch64.manylinux_2_17_aarch64.manylinux_2_28_aarch64.whl

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 (531) hide show
  1. ac8f31065839703b4e70__mypyc.cpython-310-aarch64-linux-gnu.so +0 -0
  2. sqlspec/__init__.py +140 -0
  3. sqlspec/__main__.py +12 -0
  4. sqlspec/__metadata__.py +14 -0
  5. sqlspec/_serialization.py +315 -0
  6. sqlspec/_typing.py +700 -0
  7. sqlspec/adapters/__init__.py +0 -0
  8. sqlspec/adapters/adbc/__init__.py +5 -0
  9. sqlspec/adapters/adbc/_typing.py +82 -0
  10. sqlspec/adapters/adbc/adk/__init__.py +5 -0
  11. sqlspec/adapters/adbc/adk/store.py +1273 -0
  12. sqlspec/adapters/adbc/config.py +295 -0
  13. sqlspec/adapters/adbc/core.cpython-310-aarch64-linux-gnu.so +0 -0
  14. sqlspec/adapters/adbc/core.py +735 -0
  15. sqlspec/adapters/adbc/data_dictionary.py +334 -0
  16. sqlspec/adapters/adbc/driver.py +529 -0
  17. sqlspec/adapters/adbc/events/__init__.py +5 -0
  18. sqlspec/adapters/adbc/events/store.py +285 -0
  19. sqlspec/adapters/adbc/litestar/__init__.py +5 -0
  20. sqlspec/adapters/adbc/litestar/store.py +502 -0
  21. sqlspec/adapters/adbc/type_converter.cpython-310-aarch64-linux-gnu.so +0 -0
  22. sqlspec/adapters/adbc/type_converter.py +140 -0
  23. sqlspec/adapters/aiosqlite/__init__.py +25 -0
  24. sqlspec/adapters/aiosqlite/_typing.py +82 -0
  25. sqlspec/adapters/aiosqlite/adk/__init__.py +5 -0
  26. sqlspec/adapters/aiosqlite/adk/store.py +818 -0
  27. sqlspec/adapters/aiosqlite/config.py +334 -0
  28. sqlspec/adapters/aiosqlite/core.cpython-310-aarch64-linux-gnu.so +0 -0
  29. sqlspec/adapters/aiosqlite/core.py +315 -0
  30. sqlspec/adapters/aiosqlite/data_dictionary.py +208 -0
  31. sqlspec/adapters/aiosqlite/driver.py +313 -0
  32. sqlspec/adapters/aiosqlite/events/__init__.py +5 -0
  33. sqlspec/adapters/aiosqlite/events/store.py +20 -0
  34. sqlspec/adapters/aiosqlite/litestar/__init__.py +5 -0
  35. sqlspec/adapters/aiosqlite/litestar/store.py +279 -0
  36. sqlspec/adapters/aiosqlite/pool.py +533 -0
  37. sqlspec/adapters/asyncmy/__init__.py +21 -0
  38. sqlspec/adapters/asyncmy/_typing.py +87 -0
  39. sqlspec/adapters/asyncmy/adk/__init__.py +5 -0
  40. sqlspec/adapters/asyncmy/adk/store.py +703 -0
  41. sqlspec/adapters/asyncmy/config.py +302 -0
  42. sqlspec/adapters/asyncmy/core.cpython-310-aarch64-linux-gnu.so +0 -0
  43. sqlspec/adapters/asyncmy/core.py +360 -0
  44. sqlspec/adapters/asyncmy/data_dictionary.py +124 -0
  45. sqlspec/adapters/asyncmy/driver.py +383 -0
  46. sqlspec/adapters/asyncmy/events/__init__.py +5 -0
  47. sqlspec/adapters/asyncmy/events/store.py +104 -0
  48. sqlspec/adapters/asyncmy/litestar/__init__.py +5 -0
  49. sqlspec/adapters/asyncmy/litestar/store.py +296 -0
  50. sqlspec/adapters/asyncpg/__init__.py +19 -0
  51. sqlspec/adapters/asyncpg/_typing.py +88 -0
  52. sqlspec/adapters/asyncpg/adk/__init__.py +5 -0
  53. sqlspec/adapters/asyncpg/adk/store.py +748 -0
  54. sqlspec/adapters/asyncpg/config.py +569 -0
  55. sqlspec/adapters/asyncpg/core.cpython-310-aarch64-linux-gnu.so +0 -0
  56. sqlspec/adapters/asyncpg/core.py +367 -0
  57. sqlspec/adapters/asyncpg/data_dictionary.py +162 -0
  58. sqlspec/adapters/asyncpg/driver.py +487 -0
  59. sqlspec/adapters/asyncpg/events/__init__.py +6 -0
  60. sqlspec/adapters/asyncpg/events/backend.py +286 -0
  61. sqlspec/adapters/asyncpg/events/store.py +40 -0
  62. sqlspec/adapters/asyncpg/litestar/__init__.py +5 -0
  63. sqlspec/adapters/asyncpg/litestar/store.py +251 -0
  64. sqlspec/adapters/bigquery/__init__.py +14 -0
  65. sqlspec/adapters/bigquery/_typing.py +86 -0
  66. sqlspec/adapters/bigquery/adk/__init__.py +5 -0
  67. sqlspec/adapters/bigquery/adk/store.py +827 -0
  68. sqlspec/adapters/bigquery/config.py +353 -0
  69. sqlspec/adapters/bigquery/core.cpython-310-aarch64-linux-gnu.so +0 -0
  70. sqlspec/adapters/bigquery/core.py +715 -0
  71. sqlspec/adapters/bigquery/data_dictionary.py +128 -0
  72. sqlspec/adapters/bigquery/driver.py +548 -0
  73. sqlspec/adapters/bigquery/events/__init__.py +5 -0
  74. sqlspec/adapters/bigquery/events/store.py +139 -0
  75. sqlspec/adapters/bigquery/litestar/__init__.py +5 -0
  76. sqlspec/adapters/bigquery/litestar/store.py +325 -0
  77. sqlspec/adapters/bigquery/type_converter.cpython-310-aarch64-linux-gnu.so +0 -0
  78. sqlspec/adapters/bigquery/type_converter.py +107 -0
  79. sqlspec/adapters/cockroach_asyncpg/__init__.py +24 -0
  80. sqlspec/adapters/cockroach_asyncpg/_typing.py +72 -0
  81. sqlspec/adapters/cockroach_asyncpg/adk/__init__.py +3 -0
  82. sqlspec/adapters/cockroach_asyncpg/adk/store.py +410 -0
  83. sqlspec/adapters/cockroach_asyncpg/config.py +238 -0
  84. sqlspec/adapters/cockroach_asyncpg/core.cpython-310-aarch64-linux-gnu.so +0 -0
  85. sqlspec/adapters/cockroach_asyncpg/core.py +55 -0
  86. sqlspec/adapters/cockroach_asyncpg/data_dictionary.py +107 -0
  87. sqlspec/adapters/cockroach_asyncpg/driver.py +144 -0
  88. sqlspec/adapters/cockroach_asyncpg/events/__init__.py +3 -0
  89. sqlspec/adapters/cockroach_asyncpg/events/store.py +20 -0
  90. sqlspec/adapters/cockroach_asyncpg/litestar/__init__.py +3 -0
  91. sqlspec/adapters/cockroach_asyncpg/litestar/store.py +142 -0
  92. sqlspec/adapters/cockroach_psycopg/__init__.py +38 -0
  93. sqlspec/adapters/cockroach_psycopg/_typing.py +129 -0
  94. sqlspec/adapters/cockroach_psycopg/adk/__init__.py +13 -0
  95. sqlspec/adapters/cockroach_psycopg/adk/store.py +868 -0
  96. sqlspec/adapters/cockroach_psycopg/config.py +484 -0
  97. sqlspec/adapters/cockroach_psycopg/core.cpython-310-aarch64-linux-gnu.so +0 -0
  98. sqlspec/adapters/cockroach_psycopg/core.py +63 -0
  99. sqlspec/adapters/cockroach_psycopg/data_dictionary.py +215 -0
  100. sqlspec/adapters/cockroach_psycopg/driver.py +284 -0
  101. sqlspec/adapters/cockroach_psycopg/events/__init__.py +6 -0
  102. sqlspec/adapters/cockroach_psycopg/events/store.py +34 -0
  103. sqlspec/adapters/cockroach_psycopg/litestar/__init__.py +3 -0
  104. sqlspec/adapters/cockroach_psycopg/litestar/store.py +325 -0
  105. sqlspec/adapters/duckdb/__init__.py +25 -0
  106. sqlspec/adapters/duckdb/_typing.py +81 -0
  107. sqlspec/adapters/duckdb/adk/__init__.py +14 -0
  108. sqlspec/adapters/duckdb/adk/store.py +850 -0
  109. sqlspec/adapters/duckdb/config.py +463 -0
  110. sqlspec/adapters/duckdb/core.cpython-310-aarch64-linux-gnu.so +0 -0
  111. sqlspec/adapters/duckdb/core.py +257 -0
  112. sqlspec/adapters/duckdb/data_dictionary.py +140 -0
  113. sqlspec/adapters/duckdb/driver.py +430 -0
  114. sqlspec/adapters/duckdb/events/__init__.py +5 -0
  115. sqlspec/adapters/duckdb/events/store.py +57 -0
  116. sqlspec/adapters/duckdb/litestar/__init__.py +5 -0
  117. sqlspec/adapters/duckdb/litestar/store.py +330 -0
  118. sqlspec/adapters/duckdb/pool.py +293 -0
  119. sqlspec/adapters/duckdb/type_converter.cpython-310-aarch64-linux-gnu.so +0 -0
  120. sqlspec/adapters/duckdb/type_converter.py +118 -0
  121. sqlspec/adapters/mock/__init__.py +72 -0
  122. sqlspec/adapters/mock/_typing.py +147 -0
  123. sqlspec/adapters/mock/config.py +483 -0
  124. sqlspec/adapters/mock/core.py +319 -0
  125. sqlspec/adapters/mock/data_dictionary.py +366 -0
  126. sqlspec/adapters/mock/driver.py +721 -0
  127. sqlspec/adapters/mysqlconnector/__init__.py +36 -0
  128. sqlspec/adapters/mysqlconnector/_typing.py +141 -0
  129. sqlspec/adapters/mysqlconnector/adk/__init__.py +15 -0
  130. sqlspec/adapters/mysqlconnector/adk/store.py +1060 -0
  131. sqlspec/adapters/mysqlconnector/config.py +394 -0
  132. sqlspec/adapters/mysqlconnector/core.cpython-310-aarch64-linux-gnu.so +0 -0
  133. sqlspec/adapters/mysqlconnector/core.py +303 -0
  134. sqlspec/adapters/mysqlconnector/data_dictionary.py +235 -0
  135. sqlspec/adapters/mysqlconnector/driver.py +483 -0
  136. sqlspec/adapters/mysqlconnector/events/__init__.py +8 -0
  137. sqlspec/adapters/mysqlconnector/events/store.py +98 -0
  138. sqlspec/adapters/mysqlconnector/litestar/__init__.py +5 -0
  139. sqlspec/adapters/mysqlconnector/litestar/store.py +426 -0
  140. sqlspec/adapters/oracledb/__init__.py +60 -0
  141. sqlspec/adapters/oracledb/_numpy_handlers.py +141 -0
  142. sqlspec/adapters/oracledb/_typing.py +182 -0
  143. sqlspec/adapters/oracledb/_uuid_handlers.py +166 -0
  144. sqlspec/adapters/oracledb/adk/__init__.py +10 -0
  145. sqlspec/adapters/oracledb/adk/store.py +2369 -0
  146. sqlspec/adapters/oracledb/config.py +550 -0
  147. sqlspec/adapters/oracledb/core.cpython-310-aarch64-linux-gnu.so +0 -0
  148. sqlspec/adapters/oracledb/core.py +543 -0
  149. sqlspec/adapters/oracledb/data_dictionary.py +536 -0
  150. sqlspec/adapters/oracledb/driver.py +1229 -0
  151. sqlspec/adapters/oracledb/events/__init__.py +16 -0
  152. sqlspec/adapters/oracledb/events/backend.py +347 -0
  153. sqlspec/adapters/oracledb/events/store.py +420 -0
  154. sqlspec/adapters/oracledb/litestar/__init__.py +5 -0
  155. sqlspec/adapters/oracledb/litestar/store.py +781 -0
  156. sqlspec/adapters/oracledb/migrations.py +535 -0
  157. sqlspec/adapters/oracledb/type_converter.cpython-310-aarch64-linux-gnu.so +0 -0
  158. sqlspec/adapters/oracledb/type_converter.py +211 -0
  159. sqlspec/adapters/psqlpy/__init__.py +17 -0
  160. sqlspec/adapters/psqlpy/_typing.py +79 -0
  161. sqlspec/adapters/psqlpy/adk/__init__.py +5 -0
  162. sqlspec/adapters/psqlpy/adk/store.py +766 -0
  163. sqlspec/adapters/psqlpy/config.py +304 -0
  164. sqlspec/adapters/psqlpy/core.cpython-310-aarch64-linux-gnu.so +0 -0
  165. sqlspec/adapters/psqlpy/core.py +480 -0
  166. sqlspec/adapters/psqlpy/data_dictionary.py +126 -0
  167. sqlspec/adapters/psqlpy/driver.py +438 -0
  168. sqlspec/adapters/psqlpy/events/__init__.py +6 -0
  169. sqlspec/adapters/psqlpy/events/backend.py +310 -0
  170. sqlspec/adapters/psqlpy/events/store.py +20 -0
  171. sqlspec/adapters/psqlpy/litestar/__init__.py +5 -0
  172. sqlspec/adapters/psqlpy/litestar/store.py +270 -0
  173. sqlspec/adapters/psqlpy/type_converter.cpython-310-aarch64-linux-gnu.so +0 -0
  174. sqlspec/adapters/psqlpy/type_converter.py +113 -0
  175. sqlspec/adapters/psycopg/__init__.py +32 -0
  176. sqlspec/adapters/psycopg/_typing.py +164 -0
  177. sqlspec/adapters/psycopg/adk/__init__.py +10 -0
  178. sqlspec/adapters/psycopg/adk/store.py +1387 -0
  179. sqlspec/adapters/psycopg/config.py +576 -0
  180. sqlspec/adapters/psycopg/core.cpython-310-aarch64-linux-gnu.so +0 -0
  181. sqlspec/adapters/psycopg/core.py +450 -0
  182. sqlspec/adapters/psycopg/data_dictionary.py +289 -0
  183. sqlspec/adapters/psycopg/driver.py +975 -0
  184. sqlspec/adapters/psycopg/events/__init__.py +20 -0
  185. sqlspec/adapters/psycopg/events/backend.py +458 -0
  186. sqlspec/adapters/psycopg/events/store.py +42 -0
  187. sqlspec/adapters/psycopg/litestar/__init__.py +5 -0
  188. sqlspec/adapters/psycopg/litestar/store.py +552 -0
  189. sqlspec/adapters/psycopg/type_converter.cpython-310-aarch64-linux-gnu.so +0 -0
  190. sqlspec/adapters/psycopg/type_converter.py +93 -0
  191. sqlspec/adapters/pymysql/__init__.py +21 -0
  192. sqlspec/adapters/pymysql/_typing.py +71 -0
  193. sqlspec/adapters/pymysql/adk/__init__.py +5 -0
  194. sqlspec/adapters/pymysql/adk/store.py +540 -0
  195. sqlspec/adapters/pymysql/config.py +195 -0
  196. sqlspec/adapters/pymysql/core.cpython-310-aarch64-linux-gnu.so +0 -0
  197. sqlspec/adapters/pymysql/core.py +299 -0
  198. sqlspec/adapters/pymysql/data_dictionary.py +122 -0
  199. sqlspec/adapters/pymysql/driver.py +259 -0
  200. sqlspec/adapters/pymysql/events/__init__.py +5 -0
  201. sqlspec/adapters/pymysql/events/store.py +50 -0
  202. sqlspec/adapters/pymysql/litestar/__init__.py +5 -0
  203. sqlspec/adapters/pymysql/litestar/store.py +232 -0
  204. sqlspec/adapters/pymysql/pool.py +137 -0
  205. sqlspec/adapters/spanner/__init__.py +40 -0
  206. sqlspec/adapters/spanner/_typing.py +86 -0
  207. sqlspec/adapters/spanner/adk/__init__.py +5 -0
  208. sqlspec/adapters/spanner/adk/store.py +732 -0
  209. sqlspec/adapters/spanner/config.py +352 -0
  210. sqlspec/adapters/spanner/core.cpython-310-aarch64-linux-gnu.so +0 -0
  211. sqlspec/adapters/spanner/core.py +188 -0
  212. sqlspec/adapters/spanner/data_dictionary.py +120 -0
  213. sqlspec/adapters/spanner/dialect/__init__.py +6 -0
  214. sqlspec/adapters/spanner/dialect/_spangres.py +57 -0
  215. sqlspec/adapters/spanner/dialect/_spanner.py +130 -0
  216. sqlspec/adapters/spanner/driver.py +373 -0
  217. sqlspec/adapters/spanner/events/__init__.py +5 -0
  218. sqlspec/adapters/spanner/events/store.py +187 -0
  219. sqlspec/adapters/spanner/litestar/__init__.py +5 -0
  220. sqlspec/adapters/spanner/litestar/store.py +291 -0
  221. sqlspec/adapters/spanner/type_converter.cpython-310-aarch64-linux-gnu.so +0 -0
  222. sqlspec/adapters/spanner/type_converter.py +331 -0
  223. sqlspec/adapters/sqlite/__init__.py +19 -0
  224. sqlspec/adapters/sqlite/_typing.py +80 -0
  225. sqlspec/adapters/sqlite/adk/__init__.py +5 -0
  226. sqlspec/adapters/sqlite/adk/store.py +958 -0
  227. sqlspec/adapters/sqlite/config.py +280 -0
  228. sqlspec/adapters/sqlite/core.cpython-310-aarch64-linux-gnu.so +0 -0
  229. sqlspec/adapters/sqlite/core.py +312 -0
  230. sqlspec/adapters/sqlite/data_dictionary.py +202 -0
  231. sqlspec/adapters/sqlite/driver.py +359 -0
  232. sqlspec/adapters/sqlite/events/__init__.py +5 -0
  233. sqlspec/adapters/sqlite/events/store.py +20 -0
  234. sqlspec/adapters/sqlite/litestar/__init__.py +5 -0
  235. sqlspec/adapters/sqlite/litestar/store.py +316 -0
  236. sqlspec/adapters/sqlite/pool.py +198 -0
  237. sqlspec/adapters/sqlite/type_converter.cpython-310-aarch64-linux-gnu.so +0 -0
  238. sqlspec/adapters/sqlite/type_converter.py +114 -0
  239. sqlspec/base.py +747 -0
  240. sqlspec/builder/__init__.py +179 -0
  241. sqlspec/builder/_base.cpython-310-aarch64-linux-gnu.so +0 -0
  242. sqlspec/builder/_base.py +1022 -0
  243. sqlspec/builder/_column.cpython-310-aarch64-linux-gnu.so +0 -0
  244. sqlspec/builder/_column.py +521 -0
  245. sqlspec/builder/_ddl.cpython-310-aarch64-linux-gnu.so +0 -0
  246. sqlspec/builder/_ddl.py +1642 -0
  247. sqlspec/builder/_delete.cpython-310-aarch64-linux-gnu.so +0 -0
  248. sqlspec/builder/_delete.py +95 -0
  249. sqlspec/builder/_dml.cpython-310-aarch64-linux-gnu.so +0 -0
  250. sqlspec/builder/_dml.py +365 -0
  251. sqlspec/builder/_explain.cpython-310-aarch64-linux-gnu.so +0 -0
  252. sqlspec/builder/_explain.py +579 -0
  253. sqlspec/builder/_expression_wrappers.cpython-310-aarch64-linux-gnu.so +0 -0
  254. sqlspec/builder/_expression_wrappers.py +46 -0
  255. sqlspec/builder/_factory.cpython-310-aarch64-linux-gnu.so +0 -0
  256. sqlspec/builder/_factory.py +1697 -0
  257. sqlspec/builder/_insert.cpython-310-aarch64-linux-gnu.so +0 -0
  258. sqlspec/builder/_insert.py +328 -0
  259. sqlspec/builder/_join.cpython-310-aarch64-linux-gnu.so +0 -0
  260. sqlspec/builder/_join.py +499 -0
  261. sqlspec/builder/_merge.cpython-310-aarch64-linux-gnu.so +0 -0
  262. sqlspec/builder/_merge.py +821 -0
  263. sqlspec/builder/_parsing_utils.cpython-310-aarch64-linux-gnu.so +0 -0
  264. sqlspec/builder/_parsing_utils.py +297 -0
  265. sqlspec/builder/_select.cpython-310-aarch64-linux-gnu.so +0 -0
  266. sqlspec/builder/_select.py +1660 -0
  267. sqlspec/builder/_temporal.cpython-310-aarch64-linux-gnu.so +0 -0
  268. sqlspec/builder/_temporal.py +139 -0
  269. sqlspec/builder/_update.cpython-310-aarch64-linux-gnu.so +0 -0
  270. sqlspec/builder/_update.py +173 -0
  271. sqlspec/builder/_vector_expressions.py +267 -0
  272. sqlspec/cli.py +911 -0
  273. sqlspec/config.py +1755 -0
  274. sqlspec/core/__init__.py +374 -0
  275. sqlspec/core/_correlation.cpython-310-aarch64-linux-gnu.so +0 -0
  276. sqlspec/core/_correlation.py +176 -0
  277. sqlspec/core/cache.cpython-310-aarch64-linux-gnu.so +0 -0
  278. sqlspec/core/cache.py +1069 -0
  279. sqlspec/core/compiler.cpython-310-aarch64-linux-gnu.so +0 -0
  280. sqlspec/core/compiler.py +954 -0
  281. sqlspec/core/explain.cpython-310-aarch64-linux-gnu.so +0 -0
  282. sqlspec/core/explain.py +275 -0
  283. sqlspec/core/filters.cpython-310-aarch64-linux-gnu.so +0 -0
  284. sqlspec/core/filters.py +952 -0
  285. sqlspec/core/hashing.cpython-310-aarch64-linux-gnu.so +0 -0
  286. sqlspec/core/hashing.py +262 -0
  287. sqlspec/core/metrics.cpython-310-aarch64-linux-gnu.so +0 -0
  288. sqlspec/core/metrics.py +83 -0
  289. sqlspec/core/parameters/__init__.py +71 -0
  290. sqlspec/core/parameters/_alignment.cpython-310-aarch64-linux-gnu.so +0 -0
  291. sqlspec/core/parameters/_alignment.py +270 -0
  292. sqlspec/core/parameters/_converter.cpython-310-aarch64-linux-gnu.so +0 -0
  293. sqlspec/core/parameters/_converter.py +543 -0
  294. sqlspec/core/parameters/_processor.cpython-310-aarch64-linux-gnu.so +0 -0
  295. sqlspec/core/parameters/_processor.py +505 -0
  296. sqlspec/core/parameters/_registry.cpython-310-aarch64-linux-gnu.so +0 -0
  297. sqlspec/core/parameters/_registry.py +206 -0
  298. sqlspec/core/parameters/_transformers.cpython-310-aarch64-linux-gnu.so +0 -0
  299. sqlspec/core/parameters/_transformers.py +292 -0
  300. sqlspec/core/parameters/_types.cpython-310-aarch64-linux-gnu.so +0 -0
  301. sqlspec/core/parameters/_types.py +499 -0
  302. sqlspec/core/parameters/_validator.cpython-310-aarch64-linux-gnu.so +0 -0
  303. sqlspec/core/parameters/_validator.py +180 -0
  304. sqlspec/core/pipeline.cpython-310-aarch64-linux-gnu.so +0 -0
  305. sqlspec/core/pipeline.py +319 -0
  306. sqlspec/core/query_modifiers.cpython-310-aarch64-linux-gnu.so +0 -0
  307. sqlspec/core/query_modifiers.py +437 -0
  308. sqlspec/core/result/__init__.py +23 -0
  309. sqlspec/core/result/_base.cpython-310-aarch64-linux-gnu.so +0 -0
  310. sqlspec/core/result/_base.py +1121 -0
  311. sqlspec/core/result/_io.cpython-310-aarch64-linux-gnu.so +0 -0
  312. sqlspec/core/result/_io.py +28 -0
  313. sqlspec/core/splitter.cpython-310-aarch64-linux-gnu.so +0 -0
  314. sqlspec/core/splitter.py +966 -0
  315. sqlspec/core/stack.cpython-310-aarch64-linux-gnu.so +0 -0
  316. sqlspec/core/stack.py +163 -0
  317. sqlspec/core/statement.cpython-310-aarch64-linux-gnu.so +0 -0
  318. sqlspec/core/statement.py +1503 -0
  319. sqlspec/core/type_converter.cpython-310-aarch64-linux-gnu.so +0 -0
  320. sqlspec/core/type_converter.py +339 -0
  321. sqlspec/data_dictionary/__init__.py +22 -0
  322. sqlspec/data_dictionary/_loader.py +123 -0
  323. sqlspec/data_dictionary/_registry.cpython-310-aarch64-linux-gnu.so +0 -0
  324. sqlspec/data_dictionary/_registry.py +74 -0
  325. sqlspec/data_dictionary/_types.cpython-310-aarch64-linux-gnu.so +0 -0
  326. sqlspec/data_dictionary/_types.py +121 -0
  327. sqlspec/data_dictionary/dialects/__init__.py +21 -0
  328. sqlspec/data_dictionary/dialects/bigquery.cpython-310-aarch64-linux-gnu.so +0 -0
  329. sqlspec/data_dictionary/dialects/bigquery.py +49 -0
  330. sqlspec/data_dictionary/dialects/cockroachdb.cpython-310-aarch64-linux-gnu.so +0 -0
  331. sqlspec/data_dictionary/dialects/cockroachdb.py +43 -0
  332. sqlspec/data_dictionary/dialects/duckdb.cpython-310-aarch64-linux-gnu.so +0 -0
  333. sqlspec/data_dictionary/dialects/duckdb.py +47 -0
  334. sqlspec/data_dictionary/dialects/mysql.cpython-310-aarch64-linux-gnu.so +0 -0
  335. sqlspec/data_dictionary/dialects/mysql.py +42 -0
  336. sqlspec/data_dictionary/dialects/oracle.cpython-310-aarch64-linux-gnu.so +0 -0
  337. sqlspec/data_dictionary/dialects/oracle.py +34 -0
  338. sqlspec/data_dictionary/dialects/postgres.cpython-310-aarch64-linux-gnu.so +0 -0
  339. sqlspec/data_dictionary/dialects/postgres.py +46 -0
  340. sqlspec/data_dictionary/dialects/spanner.cpython-310-aarch64-linux-gnu.so +0 -0
  341. sqlspec/data_dictionary/dialects/spanner.py +37 -0
  342. sqlspec/data_dictionary/dialects/sqlite.cpython-310-aarch64-linux-gnu.so +0 -0
  343. sqlspec/data_dictionary/dialects/sqlite.py +42 -0
  344. sqlspec/data_dictionary/sql/.gitkeep +0 -0
  345. sqlspec/data_dictionary/sql/bigquery/columns.sql +23 -0
  346. sqlspec/data_dictionary/sql/bigquery/foreign_keys.sql +34 -0
  347. sqlspec/data_dictionary/sql/bigquery/indexes.sql +19 -0
  348. sqlspec/data_dictionary/sql/bigquery/tables.sql +33 -0
  349. sqlspec/data_dictionary/sql/bigquery/version.sql +3 -0
  350. sqlspec/data_dictionary/sql/cockroachdb/columns.sql +34 -0
  351. sqlspec/data_dictionary/sql/cockroachdb/foreign_keys.sql +40 -0
  352. sqlspec/data_dictionary/sql/cockroachdb/indexes.sql +32 -0
  353. sqlspec/data_dictionary/sql/cockroachdb/tables.sql +44 -0
  354. sqlspec/data_dictionary/sql/cockroachdb/version.sql +3 -0
  355. sqlspec/data_dictionary/sql/duckdb/columns.sql +23 -0
  356. sqlspec/data_dictionary/sql/duckdb/foreign_keys.sql +36 -0
  357. sqlspec/data_dictionary/sql/duckdb/indexes.sql +19 -0
  358. sqlspec/data_dictionary/sql/duckdb/tables.sql +38 -0
  359. sqlspec/data_dictionary/sql/duckdb/version.sql +3 -0
  360. sqlspec/data_dictionary/sql/mysql/columns.sql +23 -0
  361. sqlspec/data_dictionary/sql/mysql/foreign_keys.sql +28 -0
  362. sqlspec/data_dictionary/sql/mysql/indexes.sql +26 -0
  363. sqlspec/data_dictionary/sql/mysql/tables.sql +33 -0
  364. sqlspec/data_dictionary/sql/mysql/version.sql +3 -0
  365. sqlspec/data_dictionary/sql/oracle/columns.sql +23 -0
  366. sqlspec/data_dictionary/sql/oracle/foreign_keys.sql +48 -0
  367. sqlspec/data_dictionary/sql/oracle/indexes.sql +44 -0
  368. sqlspec/data_dictionary/sql/oracle/tables.sql +25 -0
  369. sqlspec/data_dictionary/sql/oracle/version.sql +20 -0
  370. sqlspec/data_dictionary/sql/postgres/columns.sql +34 -0
  371. sqlspec/data_dictionary/sql/postgres/foreign_keys.sql +40 -0
  372. sqlspec/data_dictionary/sql/postgres/indexes.sql +56 -0
  373. sqlspec/data_dictionary/sql/postgres/tables.sql +44 -0
  374. sqlspec/data_dictionary/sql/postgres/version.sql +3 -0
  375. sqlspec/data_dictionary/sql/spanner/columns.sql +23 -0
  376. sqlspec/data_dictionary/sql/spanner/foreign_keys.sql +70 -0
  377. sqlspec/data_dictionary/sql/spanner/indexes.sql +30 -0
  378. sqlspec/data_dictionary/sql/spanner/tables.sql +9 -0
  379. sqlspec/data_dictionary/sql/spanner/version.sql +3 -0
  380. sqlspec/data_dictionary/sql/sqlite/columns.sql +23 -0
  381. sqlspec/data_dictionary/sql/sqlite/foreign_keys.sql +22 -0
  382. sqlspec/data_dictionary/sql/sqlite/indexes.sql +7 -0
  383. sqlspec/data_dictionary/sql/sqlite/tables.sql +28 -0
  384. sqlspec/data_dictionary/sql/sqlite/version.sql +3 -0
  385. sqlspec/driver/__init__.py +32 -0
  386. sqlspec/driver/_async.cpython-310-aarch64-linux-gnu.so +0 -0
  387. sqlspec/driver/_async.py +1737 -0
  388. sqlspec/driver/_common.cpython-310-aarch64-linux-gnu.so +0 -0
  389. sqlspec/driver/_common.py +1478 -0
  390. sqlspec/driver/_sql_helpers.cpython-310-aarch64-linux-gnu.so +0 -0
  391. sqlspec/driver/_sql_helpers.py +148 -0
  392. sqlspec/driver/_storage_helpers.cpython-310-aarch64-linux-gnu.so +0 -0
  393. sqlspec/driver/_storage_helpers.py +144 -0
  394. sqlspec/driver/_sync.cpython-310-aarch64-linux-gnu.so +0 -0
  395. sqlspec/driver/_sync.py +1710 -0
  396. sqlspec/exceptions.py +338 -0
  397. sqlspec/extensions/__init__.py +0 -0
  398. sqlspec/extensions/adk/__init__.py +70 -0
  399. sqlspec/extensions/adk/_types.py +51 -0
  400. sqlspec/extensions/adk/converters.py +172 -0
  401. sqlspec/extensions/adk/memory/__init__.py +69 -0
  402. sqlspec/extensions/adk/memory/_types.py +30 -0
  403. sqlspec/extensions/adk/memory/converters.py +149 -0
  404. sqlspec/extensions/adk/memory/service.py +217 -0
  405. sqlspec/extensions/adk/memory/store.py +569 -0
  406. sqlspec/extensions/adk/migrations/0001_create_adk_tables.py +246 -0
  407. sqlspec/extensions/adk/migrations/__init__.py +0 -0
  408. sqlspec/extensions/adk/service.py +225 -0
  409. sqlspec/extensions/adk/store.py +567 -0
  410. sqlspec/extensions/events/__init__.py +51 -0
  411. sqlspec/extensions/events/_channel.py +703 -0
  412. sqlspec/extensions/events/_hints.py +45 -0
  413. sqlspec/extensions/events/_models.py +23 -0
  414. sqlspec/extensions/events/_payload.py +69 -0
  415. sqlspec/extensions/events/_protocols.py +134 -0
  416. sqlspec/extensions/events/_queue.py +461 -0
  417. sqlspec/extensions/events/_store.py +209 -0
  418. sqlspec/extensions/events/migrations/0001_create_event_queue.py +59 -0
  419. sqlspec/extensions/events/migrations/__init__.py +3 -0
  420. sqlspec/extensions/fastapi/__init__.py +19 -0
  421. sqlspec/extensions/fastapi/extension.py +351 -0
  422. sqlspec/extensions/fastapi/providers.py +607 -0
  423. sqlspec/extensions/flask/__init__.py +37 -0
  424. sqlspec/extensions/flask/_state.py +76 -0
  425. sqlspec/extensions/flask/_utils.py +71 -0
  426. sqlspec/extensions/flask/extension.py +519 -0
  427. sqlspec/extensions/litestar/__init__.py +28 -0
  428. sqlspec/extensions/litestar/_utils.py +52 -0
  429. sqlspec/extensions/litestar/channels.py +165 -0
  430. sqlspec/extensions/litestar/cli.py +102 -0
  431. sqlspec/extensions/litestar/config.py +90 -0
  432. sqlspec/extensions/litestar/handlers.py +316 -0
  433. sqlspec/extensions/litestar/migrations/0001_create_session_table.py +137 -0
  434. sqlspec/extensions/litestar/migrations/__init__.py +3 -0
  435. sqlspec/extensions/litestar/plugin.py +671 -0
  436. sqlspec/extensions/litestar/providers.py +526 -0
  437. sqlspec/extensions/litestar/store.py +296 -0
  438. sqlspec/extensions/otel/__init__.py +58 -0
  439. sqlspec/extensions/prometheus/__init__.py +113 -0
  440. sqlspec/extensions/starlette/__init__.py +19 -0
  441. sqlspec/extensions/starlette/_state.py +30 -0
  442. sqlspec/extensions/starlette/_utils.py +96 -0
  443. sqlspec/extensions/starlette/extension.py +346 -0
  444. sqlspec/extensions/starlette/middleware.py +235 -0
  445. sqlspec/loader.cpython-310-aarch64-linux-gnu.so +0 -0
  446. sqlspec/loader.py +702 -0
  447. sqlspec/migrations/__init__.py +36 -0
  448. sqlspec/migrations/base.py +731 -0
  449. sqlspec/migrations/commands.py +1232 -0
  450. sqlspec/migrations/context.py +157 -0
  451. sqlspec/migrations/fix.py +204 -0
  452. sqlspec/migrations/loaders.py +443 -0
  453. sqlspec/migrations/runner.py +1172 -0
  454. sqlspec/migrations/templates.py +234 -0
  455. sqlspec/migrations/tracker.py +611 -0
  456. sqlspec/migrations/utils.py +256 -0
  457. sqlspec/migrations/validation.py +207 -0
  458. sqlspec/migrations/version.py +446 -0
  459. sqlspec/observability/__init__.py +55 -0
  460. sqlspec/observability/_common.cpython-310-aarch64-linux-gnu.so +0 -0
  461. sqlspec/observability/_common.py +77 -0
  462. sqlspec/observability/_config.cpython-310-aarch64-linux-gnu.so +0 -0
  463. sqlspec/observability/_config.py +348 -0
  464. sqlspec/observability/_diagnostics.cpython-310-aarch64-linux-gnu.so +0 -0
  465. sqlspec/observability/_diagnostics.py +74 -0
  466. sqlspec/observability/_dispatcher.cpython-310-aarch64-linux-gnu.so +0 -0
  467. sqlspec/observability/_dispatcher.py +152 -0
  468. sqlspec/observability/_formatters/__init__.py +13 -0
  469. sqlspec/observability/_formatters/_aws.cpython-310-aarch64-linux-gnu.so +0 -0
  470. sqlspec/observability/_formatters/_aws.py +102 -0
  471. sqlspec/observability/_formatters/_azure.cpython-310-aarch64-linux-gnu.so +0 -0
  472. sqlspec/observability/_formatters/_azure.py +96 -0
  473. sqlspec/observability/_formatters/_base.cpython-310-aarch64-linux-gnu.so +0 -0
  474. sqlspec/observability/_formatters/_base.py +57 -0
  475. sqlspec/observability/_formatters/_gcp.cpython-310-aarch64-linux-gnu.so +0 -0
  476. sqlspec/observability/_formatters/_gcp.py +131 -0
  477. sqlspec/observability/_formatting.py +58 -0
  478. sqlspec/observability/_observer.cpython-310-aarch64-linux-gnu.so +0 -0
  479. sqlspec/observability/_observer.py +357 -0
  480. sqlspec/observability/_runtime.cpython-310-aarch64-linux-gnu.so +0 -0
  481. sqlspec/observability/_runtime.py +420 -0
  482. sqlspec/observability/_sampling.cpython-310-aarch64-linux-gnu.so +0 -0
  483. sqlspec/observability/_sampling.py +188 -0
  484. sqlspec/observability/_spans.cpython-310-aarch64-linux-gnu.so +0 -0
  485. sqlspec/observability/_spans.py +161 -0
  486. sqlspec/protocols.py +916 -0
  487. sqlspec/py.typed +0 -0
  488. sqlspec/storage/__init__.py +48 -0
  489. sqlspec/storage/_utils.py +104 -0
  490. sqlspec/storage/backends/__init__.py +1 -0
  491. sqlspec/storage/backends/base.py +253 -0
  492. sqlspec/storage/backends/fsspec.py +529 -0
  493. sqlspec/storage/backends/local.py +441 -0
  494. sqlspec/storage/backends/obstore.py +916 -0
  495. sqlspec/storage/errors.py +104 -0
  496. sqlspec/storage/pipeline.py +582 -0
  497. sqlspec/storage/registry.py +301 -0
  498. sqlspec/typing.py +395 -0
  499. sqlspec/utils/__init__.py +7 -0
  500. sqlspec/utils/arrow_helpers.py +318 -0
  501. sqlspec/utils/config_tools.py +332 -0
  502. sqlspec/utils/correlation.cpython-310-aarch64-linux-gnu.so +0 -0
  503. sqlspec/utils/correlation.py +134 -0
  504. sqlspec/utils/deprecation.py +190 -0
  505. sqlspec/utils/fixtures.cpython-310-aarch64-linux-gnu.so +0 -0
  506. sqlspec/utils/fixtures.py +258 -0
  507. sqlspec/utils/logging.py +222 -0
  508. sqlspec/utils/module_loader.py +306 -0
  509. sqlspec/utils/portal.cpython-310-aarch64-linux-gnu.so +0 -0
  510. sqlspec/utils/portal.py +375 -0
  511. sqlspec/utils/schema.cpython-310-aarch64-linux-gnu.so +0 -0
  512. sqlspec/utils/schema.py +485 -0
  513. sqlspec/utils/serializers.cpython-310-aarch64-linux-gnu.so +0 -0
  514. sqlspec/utils/serializers.py +408 -0
  515. sqlspec/utils/singleton.cpython-310-aarch64-linux-gnu.so +0 -0
  516. sqlspec/utils/singleton.py +41 -0
  517. sqlspec/utils/sync_tools.cpython-310-aarch64-linux-gnu.so +0 -0
  518. sqlspec/utils/sync_tools.py +311 -0
  519. sqlspec/utils/text.cpython-310-aarch64-linux-gnu.so +0 -0
  520. sqlspec/utils/text.py +108 -0
  521. sqlspec/utils/type_converters.cpython-310-aarch64-linux-gnu.so +0 -0
  522. sqlspec/utils/type_converters.py +128 -0
  523. sqlspec/utils/type_guards.cpython-310-aarch64-linux-gnu.so +0 -0
  524. sqlspec/utils/type_guards.py +1360 -0
  525. sqlspec/utils/uuids.cpython-310-aarch64-linux-gnu.so +0 -0
  526. sqlspec/utils/uuids.py +225 -0
  527. sqlspec-0.36.0.dist-info/METADATA +205 -0
  528. sqlspec-0.36.0.dist-info/RECORD +531 -0
  529. sqlspec-0.36.0.dist-info/WHEEL +7 -0
  530. sqlspec-0.36.0.dist-info/entry_points.txt +2 -0
  531. sqlspec-0.36.0.dist-info/licenses/LICENSE +21 -0
@@ -0,0 +1,280 @@
1
+ """SQLite database configuration with thread-local connections."""
2
+
3
+ import uuid
4
+ from typing import TYPE_CHECKING, Any, ClassVar, TypedDict, cast
5
+
6
+ from typing_extensions import NotRequired
7
+
8
+ from sqlspec.adapters.sqlite._typing import SqliteConnection
9
+ from sqlspec.adapters.sqlite.core import apply_driver_features, build_connection_config, default_statement_config
10
+ from sqlspec.adapters.sqlite.driver import SqliteCursor, SqliteDriver, SqliteExceptionHandler, SqliteSessionContext
11
+ from sqlspec.adapters.sqlite.pool import SqliteConnectionPool
12
+ from sqlspec.adapters.sqlite.type_converter import register_type_handlers
13
+ from sqlspec.config import ExtensionConfigs, SyncDatabaseConfig
14
+ from sqlspec.utils.logging import get_logger
15
+
16
+ logger = get_logger("sqlspec.adapters.sqlite")
17
+
18
+ if TYPE_CHECKING:
19
+ from collections.abc import Callable
20
+
21
+ from sqlspec.core import StatementConfig
22
+ from sqlspec.observability import ObservabilityConfig
23
+
24
+
25
+ class SqliteConnectionParams(TypedDict):
26
+ """SQLite connection parameters."""
27
+
28
+ database: NotRequired[str]
29
+ timeout: NotRequired[float]
30
+ detect_types: NotRequired[int]
31
+ isolation_level: "NotRequired[str | None]"
32
+ check_same_thread: NotRequired[bool]
33
+ factory: "NotRequired[type[SqliteConnection] | None]"
34
+ cached_statements: NotRequired[int]
35
+ uri: NotRequired[bool]
36
+
37
+
38
+ class SqliteDriverFeatures(TypedDict):
39
+ """SQLite driver feature configuration.
40
+
41
+ Controls optional type handling and serialization features for SQLite connections.
42
+
43
+ enable_custom_adapters: Enable custom type adapters for JSON/UUID/datetime conversion.
44
+ Defaults to True for enhanced Python type support.
45
+ Set to False only if you need pure SQLite behavior without type conversions.
46
+ json_serializer: Custom JSON serializer function.
47
+ Defaults to sqlspec.utils.serializers.to_json.
48
+ json_deserializer: Custom JSON deserializer function.
49
+ Defaults to sqlspec.utils.serializers.from_json.
50
+ enable_events: Enable database event channel support.
51
+ Defaults to True when extension_config["events"] is configured.
52
+ Provides pub/sub capabilities via table-backed queue (SQLite has no native pub/sub).
53
+ Requires extension_config["events"] for migration setup.
54
+ events_backend: Event channel backend selection.
55
+ Only option: "table_queue" (durable table-backed queue with retries and exactly-once delivery).
56
+ SQLite does not have native pub/sub, so table_queue is the only backend.
57
+ Defaults to "table_queue".
58
+ """
59
+
60
+ enable_custom_adapters: NotRequired[bool]
61
+ json_serializer: "NotRequired[Callable[[Any], str]]"
62
+ json_deserializer: "NotRequired[Callable[[str], Any]]"
63
+ enable_events: NotRequired[bool]
64
+ events_backend: NotRequired[str]
65
+
66
+
67
+ __all__ = ("SqliteConfig", "SqliteConnectionParams", "SqliteDriverFeatures")
68
+
69
+
70
+ class SqliteConnectionContext:
71
+ """Context manager for Sqlite connections."""
72
+
73
+ __slots__ = ("_config", "_ctx")
74
+
75
+ def __init__(self, config: "SqliteConfig") -> None:
76
+ self._config = config
77
+ self._ctx: Any = None
78
+
79
+ def __enter__(self) -> SqliteConnection:
80
+ pool = self._config.provide_pool()
81
+ self._ctx = pool.get_connection()
82
+ return cast("SqliteConnection", self._ctx.__enter__())
83
+
84
+ def __exit__(
85
+ self, exc_type: "type[BaseException] | None", exc_val: "BaseException | None", exc_tb: Any
86
+ ) -> bool | None:
87
+ if self._ctx:
88
+ return cast("bool | None", self._ctx.__exit__(exc_type, exc_val, exc_tb))
89
+ return None
90
+
91
+
92
+ class _SqliteSessionConnectionHandler:
93
+ __slots__ = ("_config", "_ctx")
94
+
95
+ def __init__(self, config: "SqliteConfig") -> None:
96
+ self._config = config
97
+ self._ctx: Any = None
98
+
99
+ def acquire_connection(self) -> "SqliteConnection":
100
+ pool = self._config.provide_pool()
101
+ self._ctx = pool.get_connection()
102
+ return cast("SqliteConnection", self._ctx.__enter__())
103
+
104
+ def release_connection(self, _conn: "SqliteConnection") -> None:
105
+ if self._ctx is None:
106
+ return
107
+ self._ctx.__exit__(None, None, None)
108
+ self._ctx = None
109
+
110
+
111
+ class SqliteConfig(SyncDatabaseConfig[SqliteConnection, SqliteConnectionPool, SqliteDriver]):
112
+ """SQLite configuration with thread-local connections."""
113
+
114
+ driver_type: "ClassVar[type[SqliteDriver]]" = SqliteDriver
115
+ connection_type: "ClassVar[type[SqliteConnection]]" = SqliteConnection
116
+ supports_transactional_ddl: "ClassVar[bool]" = True
117
+ supports_native_arrow_export: "ClassVar[bool]" = True
118
+ supports_native_arrow_import: "ClassVar[bool]" = True
119
+ supports_native_parquet_export: "ClassVar[bool]" = True
120
+ supports_native_parquet_import: "ClassVar[bool]" = True
121
+
122
+ def __init__(
123
+ self,
124
+ *,
125
+ connection_config: "SqliteConnectionParams | dict[str, Any] | None" = None,
126
+ connection_instance: "SqliteConnectionPool | None" = None,
127
+ migration_config: "dict[str, Any] | None" = None,
128
+ statement_config: "StatementConfig | None" = None,
129
+ driver_features: "SqliteDriverFeatures | dict[str, Any] | None" = None,
130
+ bind_key: "str | None" = None,
131
+ extension_config: "ExtensionConfigs | None" = None,
132
+ observability_config: "ObservabilityConfig | None" = None,
133
+ **kwargs: Any,
134
+ ) -> None:
135
+ """Initialize SQLite configuration.
136
+
137
+ Args:
138
+ connection_config: Configuration parameters including connection settings
139
+ connection_instance: Pre-created pool instance
140
+ migration_config: Migration configuration
141
+ statement_config: Default SQL statement configuration
142
+ driver_features: Optional driver feature configuration
143
+ bind_key: Optional bind key for the configuration
144
+ extension_config: Extension-specific configuration (e.g., Litestar plugin settings)
145
+ observability_config: Adapter-level observability overrides for lifecycle hooks and observers
146
+ **kwargs: Additional keyword arguments passed to the base configuration.
147
+ """
148
+ config_dict: dict[str, Any] = dict(connection_config) if connection_config else {}
149
+ if "database" not in config_dict or config_dict["database"] == ":memory:":
150
+ config_dict["database"] = f"file:memory_{uuid.uuid4().hex}?mode=memory&cache=private"
151
+ config_dict["uri"] = True
152
+ elif "database" in config_dict:
153
+ database_path = str(config_dict["database"])
154
+ if database_path.startswith("file:") and not config_dict.get("uri"):
155
+ logger.debug(
156
+ "Database URI detected (%s) but uri=True not set. "
157
+ "Auto-enabling URI mode to prevent physical file creation.",
158
+ database_path,
159
+ )
160
+ config_dict["uri"] = True
161
+
162
+ statement_config = statement_config or default_statement_config
163
+ statement_config, driver_features = apply_driver_features(statement_config, driver_features)
164
+
165
+ super().__init__(
166
+ bind_key=bind_key,
167
+ connection_instance=connection_instance,
168
+ connection_config=config_dict,
169
+ migration_config=migration_config,
170
+ statement_config=statement_config,
171
+ driver_features=driver_features,
172
+ extension_config=extension_config,
173
+ observability_config=observability_config,
174
+ **kwargs,
175
+ )
176
+
177
+ def _create_pool(self) -> SqliteConnectionPool:
178
+ """Create connection pool from configuration."""
179
+ config_dict = build_connection_config(self.connection_config)
180
+
181
+ pool_kwargs: dict[str, Any] = {}
182
+ recycle_seconds = self.connection_config.get("pool_recycle_seconds")
183
+ if recycle_seconds is not None:
184
+ pool_kwargs["recycle_seconds"] = recycle_seconds
185
+
186
+ health_check_interval = self.connection_config.get("health_check_interval")
187
+ if health_check_interval is not None:
188
+ pool_kwargs["health_check_interval"] = health_check_interval
189
+
190
+ enable_optimizations = self.connection_config.get("enable_optimizations")
191
+ if enable_optimizations is not None:
192
+ pool_kwargs["enable_optimizations"] = enable_optimizations
193
+
194
+ pool = SqliteConnectionPool(connection_parameters=config_dict, **pool_kwargs)
195
+
196
+ if self.driver_features.get("enable_custom_adapters", False):
197
+ self._register_type_adapters()
198
+
199
+ return pool
200
+
201
+ def _register_type_adapters(self) -> None:
202
+ """Register custom type adapters and converters for SQLite.
203
+
204
+ Called once during pool creation if enable_custom_adapters is True.
205
+ Registers JSON serialization handlers if configured.
206
+ """
207
+ if self.driver_features.get("enable_custom_adapters", False):
208
+ register_type_handlers(
209
+ json_serializer=self.driver_features.get("json_serializer"),
210
+ json_deserializer=self.driver_features.get("json_deserializer"),
211
+ )
212
+
213
+ def _close_pool(self) -> None:
214
+ """Close the connection pool."""
215
+ if self.connection_instance:
216
+ self.connection_instance.close()
217
+
218
+ def create_connection(self) -> SqliteConnection:
219
+ """Get a SQLite connection from the pool.
220
+
221
+ Returns:
222
+ SqliteConnection: A connection from the pool
223
+ """
224
+ pool = self.provide_pool()
225
+ return pool.acquire()
226
+
227
+ def provide_connection(self, *args: "Any", **kwargs: "Any") -> "SqliteConnectionContext":
228
+ """Provide a SQLite connection context manager.
229
+
230
+ Args:
231
+ *args: Additional arguments.
232
+ **kwargs: Additional keyword arguments.
233
+
234
+ Returns:
235
+ A Sqlite connection context manager.
236
+ """
237
+ return SqliteConnectionContext(self)
238
+
239
+ def provide_session(
240
+ self, *_args: "Any", statement_config: "StatementConfig | None" = None, **_kwargs: "Any"
241
+ ) -> "SqliteSessionContext":
242
+ """Provide a SQLite driver session.
243
+
244
+ Args:
245
+ *_args: Additional arguments.
246
+ statement_config: Optional statement configuration override.
247
+ **_kwargs: Additional keyword arguments.
248
+
249
+ Returns:
250
+ A Sqlite driver session context manager.
251
+ """
252
+ handler = _SqliteSessionConnectionHandler(self)
253
+
254
+ return SqliteSessionContext(
255
+ acquire_connection=handler.acquire_connection,
256
+ release_connection=handler.release_connection,
257
+ statement_config=statement_config or self.statement_config or default_statement_config,
258
+ driver_features=self.driver_features,
259
+ prepare_driver=self._prepare_driver,
260
+ )
261
+
262
+ def get_signature_namespace(self) -> "dict[str, Any]":
263
+ """Get the signature namespace for SQLite types.
264
+
265
+ Returns:
266
+ Dictionary mapping type names to types.
267
+ """
268
+ namespace = super().get_signature_namespace()
269
+ namespace.update({
270
+ "SqliteConnectionContext": SqliteConnectionContext,
271
+ "SqliteConnection": SqliteConnection,
272
+ "SqliteConnectionParams": SqliteConnectionParams,
273
+ "SqliteConnectionPool": SqliteConnectionPool,
274
+ "SqliteCursor": SqliteCursor,
275
+ "SqliteDriver": SqliteDriver,
276
+ "SqliteDriverFeatures": SqliteDriverFeatures,
277
+ "SqliteExceptionHandler": SqliteExceptionHandler,
278
+ "SqliteSessionContext": SqliteSessionContext,
279
+ })
280
+ return namespace
@@ -0,0 +1,312 @@
1
+ """SQLite adapter compiled helpers."""
2
+
3
+ from datetime import date, datetime
4
+ from decimal import Decimal
5
+ from typing import TYPE_CHECKING, Any, cast
6
+
7
+ from sqlspec.core import DriverParameterProfile, ParameterStyle, StatementConfig, build_statement_config_from_profile
8
+ from sqlspec.exceptions import (
9
+ CheckViolationError,
10
+ DatabaseConnectionError,
11
+ DataError,
12
+ ForeignKeyViolationError,
13
+ IntegrityError,
14
+ NotNullViolationError,
15
+ OperationalError,
16
+ SQLParsingError,
17
+ SQLSpecError,
18
+ UniqueViolationError,
19
+ )
20
+ from sqlspec.utils.serializers import from_json, to_json
21
+ from sqlspec.utils.type_converters import build_decimal_converter, build_time_iso_converter
22
+ from sqlspec.utils.type_guards import has_rowcount, has_sqlite_error
23
+
24
+ if TYPE_CHECKING:
25
+ from collections.abc import Callable, Mapping, Sequence
26
+
27
+ __all__ = (
28
+ "apply_driver_features",
29
+ "build_connection_config",
30
+ "build_insert_statement",
31
+ "build_profile",
32
+ "build_statement_config",
33
+ "collect_rows",
34
+ "create_mapped_exception",
35
+ "default_statement_config",
36
+ "driver_profile",
37
+ "format_identifier",
38
+ "normalize_execute_many_parameters",
39
+ "normalize_execute_parameters",
40
+ "resolve_rowcount",
41
+ )
42
+
43
+ SQLITE_CONSTRAINT_UNIQUE_CODE = 2067
44
+ SQLITE_CONSTRAINT_FOREIGNKEY_CODE = 787
45
+ SQLITE_CONSTRAINT_NOTNULL_CODE = 1811
46
+ SQLITE_CONSTRAINT_CHECK_CODE = 531
47
+ SQLITE_CONSTRAINT_CODE = 19
48
+ SQLITE_CANTOPEN_CODE = 14
49
+ SQLITE_IOERR_CODE = 10
50
+ SQLITE_MISMATCH_CODE = 20
51
+
52
+
53
+ _TIME_TO_ISO = build_time_iso_converter()
54
+ _DECIMAL_TO_STRING = build_decimal_converter(mode="string")
55
+
56
+
57
+ def _bool_to_int(value: bool) -> int:
58
+ return int(value)
59
+
60
+
61
+ def _quote_sqlite_identifier(identifier: str) -> str:
62
+ normalized = identifier.replace('"', '""')
63
+ return f'"{normalized}"'
64
+
65
+
66
+ def format_identifier(identifier: str) -> str:
67
+ cleaned = identifier.strip()
68
+ if not cleaned:
69
+ msg = "Table name must not be empty"
70
+ raise SQLSpecError(msg)
71
+
72
+ if "." not in cleaned:
73
+ return _quote_sqlite_identifier(cleaned)
74
+
75
+ return ".".join(_quote_sqlite_identifier(part) for part in cleaned.split(".") if part)
76
+
77
+
78
+ def build_insert_statement(table: str, columns: "list[str]") -> str:
79
+ column_clause = ", ".join(_quote_sqlite_identifier(column) for column in columns)
80
+ placeholders = ", ".join("?" for _ in columns)
81
+ return f"INSERT INTO {format_identifier(table)} ({column_clause}) VALUES ({placeholders})"
82
+
83
+
84
+ def collect_rows(
85
+ fetched_data: "list[Any]", description: "Sequence[Any] | None"
86
+ ) -> "tuple[list[dict[str, Any]], list[str], int]":
87
+ """Collect SQLite result rows into dictionaries.
88
+
89
+ Optimized helper to convert raw rows and cursor description into list of dicts.
90
+
91
+ Args:
92
+ fetched_data: Raw rows from cursor.fetchall()
93
+ description: Cursor description (tuple of tuples)
94
+
95
+ Returns:
96
+ Tuple of (data, column_names, row_count)
97
+ """
98
+ if not description:
99
+ return [], [], 0
100
+
101
+ column_names = [col[0] for col in description]
102
+ # compiled list comp and zip is faster in mypyc
103
+ data = [dict(zip(column_names, row, strict=False)) for row in fetched_data]
104
+ return data, column_names, len(data)
105
+
106
+
107
+ def resolve_rowcount(cursor: Any) -> int:
108
+ """Resolve rowcount from a SQLite cursor.
109
+
110
+ Args:
111
+ cursor: SQLite cursor with optional rowcount metadata.
112
+
113
+ Returns:
114
+ Positive rowcount value or 0 when unknown.
115
+ """
116
+ if not has_rowcount(cursor):
117
+ return 0
118
+ rowcount = cursor.rowcount
119
+ if isinstance(rowcount, int) and rowcount > 0:
120
+ return rowcount
121
+ return 0
122
+
123
+
124
+ def normalize_execute_parameters(parameters: Any) -> Any:
125
+ """Normalize parameters for SQLite execute calls.
126
+
127
+ Args:
128
+ parameters: Prepared parameters payload.
129
+
130
+ Returns:
131
+ Normalized parameters payload.
132
+ """
133
+ return parameters or ()
134
+
135
+
136
+ def normalize_execute_many_parameters(parameters: Any) -> Any:
137
+ """Normalize parameters for SQLite executemany calls.
138
+
139
+ Args:
140
+ parameters: Prepared parameters payload.
141
+
142
+ Returns:
143
+ Normalized parameters payload.
144
+
145
+ Raises:
146
+ ValueError: When parameters are missing for executemany.
147
+ """
148
+ if not parameters:
149
+ msg = "execute_many requires parameters"
150
+ raise ValueError(msg)
151
+ return parameters
152
+
153
+
154
+ def build_connection_config(connection_config: "Mapping[str, Any]") -> "dict[str, Any]":
155
+ """Build connection configuration for pool creation.
156
+
157
+ Args:
158
+ connection_config: Raw connection configuration mapping.
159
+
160
+ Returns:
161
+ Dictionary with connection parameters.
162
+ """
163
+ excluded_keys = {
164
+ "enable_optimizations",
165
+ "health_check_interval",
166
+ "pool_min_size",
167
+ "pool_max_size",
168
+ "pool_timeout",
169
+ "pool_recycle_seconds",
170
+ "extra",
171
+ }
172
+ return {key: value for key, value in connection_config.items() if value is not None and key not in excluded_keys}
173
+
174
+
175
+ def _create_sqlite_error(
176
+ error: Any, code: "int | None", error_class: type[SQLSpecError], description: str
177
+ ) -> SQLSpecError:
178
+ """Create a SQLSpec exception from a SQLite error.
179
+
180
+ Args:
181
+ error: The original SQLite exception
182
+ code: SQLite extended error code
183
+ error_class: The SQLSpec exception class to instantiate
184
+ description: Human-readable description of the error type
185
+
186
+ Returns:
187
+ A new SQLSpec exception instance with the original as its cause
188
+ """
189
+ code_str = f"[code {code}]" if code else ""
190
+ msg = f"SQLite {description} {code_str}: {error}" if code_str else f"SQLite {description}: {error}"
191
+ exc = error_class(msg)
192
+ exc.__cause__ = cast("BaseException", error)
193
+ return exc
194
+
195
+
196
+ def create_mapped_exception(error: BaseException) -> SQLSpecError:
197
+ """Map SQLite exceptions to SQLSpec exceptions.
198
+
199
+ This is a factory function that returns an exception instance rather than
200
+ raising. This pattern is more robust for use in __exit__ handlers and
201
+ avoids issues with exception control flow in different Python versions.
202
+
203
+ Args:
204
+ error: The SQLite exception to map
205
+
206
+ Returns:
207
+ A SQLSpec exception that wraps the original error
208
+ """
209
+ if has_sqlite_error(error):
210
+ error_code = error.sqlite_errorcode
211
+ error_name = error.sqlite_errorname
212
+ else:
213
+ error_code = None
214
+ error_name = None
215
+ error_msg = str(error).lower()
216
+
217
+ if "locked" in error_msg:
218
+ return _create_sqlite_error(error, error_code or 0, OperationalError, "operational error")
219
+
220
+ if not error_code:
221
+ if "unique constraint" in error_msg:
222
+ return _create_sqlite_error(error, 0, UniqueViolationError, "unique constraint violation")
223
+ if "foreign key constraint" in error_msg:
224
+ return _create_sqlite_error(error, 0, ForeignKeyViolationError, "foreign key constraint violation")
225
+ if "not null constraint" in error_msg:
226
+ return _create_sqlite_error(error, 0, NotNullViolationError, "not-null constraint violation")
227
+ if "check constraint" in error_msg:
228
+ return _create_sqlite_error(error, 0, CheckViolationError, "check constraint violation")
229
+ if "syntax" in error_msg:
230
+ return _create_sqlite_error(error, None, SQLParsingError, "SQL syntax error")
231
+ return _create_sqlite_error(error, None, SQLSpecError, "database error")
232
+
233
+ if error_code == SQLITE_CONSTRAINT_UNIQUE_CODE or error_name == "SQLITE_CONSTRAINT_UNIQUE":
234
+ return _create_sqlite_error(error, error_code, UniqueViolationError, "unique constraint violation")
235
+ if error_code == SQLITE_CONSTRAINT_FOREIGNKEY_CODE or error_name == "SQLITE_CONSTRAINT_FOREIGNKEY":
236
+ return _create_sqlite_error(error, error_code, ForeignKeyViolationError, "foreign key constraint violation")
237
+ if error_code == SQLITE_CONSTRAINT_NOTNULL_CODE or error_name == "SQLITE_CONSTRAINT_NOTNULL":
238
+ return _create_sqlite_error(error, error_code, NotNullViolationError, "not-null constraint violation")
239
+ if error_code == SQLITE_CONSTRAINT_CHECK_CODE or error_name == "SQLITE_CONSTRAINT_CHECK":
240
+ return _create_sqlite_error(error, error_code, CheckViolationError, "check constraint violation")
241
+ if error_code == SQLITE_CONSTRAINT_CODE or error_name == "SQLITE_CONSTRAINT":
242
+ return _create_sqlite_error(error, error_code, IntegrityError, "integrity constraint violation")
243
+ if error_code == SQLITE_CANTOPEN_CODE or error_name == "SQLITE_CANTOPEN":
244
+ return _create_sqlite_error(error, error_code, DatabaseConnectionError, "connection error")
245
+ if error_code == SQLITE_IOERR_CODE or error_name == "SQLITE_IOERR":
246
+ return _create_sqlite_error(error, error_code, OperationalError, "operational error")
247
+ if error_code == SQLITE_MISMATCH_CODE or error_name == "SQLITE_MISMATCH":
248
+ return _create_sqlite_error(error, error_code, DataError, "data error")
249
+ if error_code == 1 or "syntax" in error_msg:
250
+ return _create_sqlite_error(error, error_code, SQLParsingError, "SQL syntax error")
251
+ return _create_sqlite_error(error, error_code, SQLSpecError, "database error")
252
+
253
+
254
+ def build_profile() -> "DriverParameterProfile":
255
+ """Create the SQLite driver parameter profile."""
256
+
257
+ return DriverParameterProfile(
258
+ name="SQLite",
259
+ default_style=ParameterStyle.QMARK,
260
+ supported_styles={ParameterStyle.QMARK, ParameterStyle.NAMED_COLON},
261
+ default_execution_style=ParameterStyle.QMARK,
262
+ supported_execution_styles={ParameterStyle.QMARK, ParameterStyle.NAMED_COLON},
263
+ has_native_list_expansion=False,
264
+ preserve_parameter_format=True,
265
+ needs_static_script_compilation=False,
266
+ allow_mixed_parameter_styles=False,
267
+ preserve_original_params_for_many=False,
268
+ json_serializer_strategy="helper",
269
+ custom_type_coercions={
270
+ bool: _bool_to_int,
271
+ datetime: _TIME_TO_ISO,
272
+ date: _TIME_TO_ISO,
273
+ Decimal: _DECIMAL_TO_STRING,
274
+ },
275
+ default_dialect="sqlite",
276
+ )
277
+
278
+
279
+ driver_profile = build_profile()
280
+
281
+
282
+ def build_statement_config(
283
+ *, json_serializer: "Callable[[Any], str] | None" = None, json_deserializer: "Callable[[str], Any] | None" = None
284
+ ) -> "StatementConfig":
285
+ """Construct the SQLite statement configuration with optional JSON codecs."""
286
+ serializer = json_serializer or to_json
287
+ deserializer = json_deserializer or from_json
288
+ profile = driver_profile
289
+ return build_statement_config_from_profile(
290
+ profile, statement_overrides={"dialect": "sqlite"}, json_serializer=serializer, json_deserializer=deserializer
291
+ )
292
+
293
+
294
+ default_statement_config = build_statement_config()
295
+
296
+
297
+ def apply_driver_features(
298
+ statement_config: "StatementConfig", driver_features: "Mapping[str, Any] | None"
299
+ ) -> "tuple[StatementConfig, dict[str, Any]]":
300
+ """Apply SQLite driver feature defaults to statement config."""
301
+ features: dict[str, Any] = dict(driver_features) if driver_features else {}
302
+ features.setdefault("enable_custom_adapters", True)
303
+ json_serializer = features.setdefault("json_serializer", to_json)
304
+ json_deserializer = features.setdefault("json_deserializer", from_json)
305
+
306
+ if json_serializer is not None:
307
+ parameter_config = statement_config.parameter_config.with_json_serializers(
308
+ json_serializer, deserializer=json_deserializer
309
+ )
310
+ statement_config = statement_config.replace(parameter_config=parameter_config)
311
+
312
+ return statement_config, features