loom-kernel 0.10.0__tar.gz → 0.10.2__tar.gz

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 (848) hide show
  1. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/CHANGELOG.md +34 -0
  2. loom_kernel-0.10.2/CHANGELOG_RELEASE.md +15 -0
  3. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/PKG-INFO +1 -1
  4. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/pyproject.toml +2 -2
  5. loom_kernel-0.10.2/src/loom/etl/backends/polars/_streaming.py +82 -0
  6. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/backends/polars/_writer.py +95 -1
  7. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/declarative/target/_into.py +27 -9
  8. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/declarative/target/_table.py +24 -0
  9. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/testing/_runners.py +8 -0
  10. loom_kernel-0.10.2/tests/unit/etl/backends/test_polars/test_streaming_write.py +257 -0
  11. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/uv.lock +1 -1
  12. loom_kernel-0.10.0/CHANGELOG_RELEASE.md +0 -32
  13. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/.github/workflows/ci-main.yml +0 -0
  14. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/.github/workflows/ci-pr.yml +0 -0
  15. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/.github/workflows/docs.yml +0 -0
  16. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/.github/workflows/release.yml +0 -0
  17. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/.gitignore +0 -0
  18. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/.pre-commit-config.yaml +0 -0
  19. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/.readthedocs.yaml +0 -0
  20. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/LICENSE +0 -0
  21. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/Makefile +0 -0
  22. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/README.md +0 -0
  23. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/codecov.yml +0 -0
  24. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/docker-compose.local.yaml +0 -0
  25. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/docs/_static/.gitkeep +0 -0
  26. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/docs/_static/custom.css +0 -0
  27. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/docs/_static/logo-transparent.png +0 -0
  28. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/docs/_static/logo.svg +0 -0
  29. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/docs/architecture/adr/README.md +0 -0
  30. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/docs/architecture/clean-architecture.md +0 -0
  31. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/docs/architecture/overview.md +0 -0
  32. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/docs/conf.py +0 -0
  33. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/docs/etl/examples.md +0 -0
  34. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/docs/etl/pipelines.md +0 -0
  35. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/docs/etl/testing.md +0 -0
  36. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/docs/examples-repo/index.md +0 -0
  37. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/docs/getting-started/etl.md +0 -0
  38. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/docs/getting-started/rest.md +0 -0
  39. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/docs/getting-started/streaming.md +0 -0
  40. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/docs/guides/autocrud.md +0 -0
  41. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/docs/guides/celery.md +0 -0
  42. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/docs/guides/etl.md +0 -0
  43. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/docs/guides/fake-repo-examples.md +0 -0
  44. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/docs/guides/quickstart.md +0 -0
  45. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/docs/guides/use-case-dsl.md +0 -0
  46. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/docs/index.rst +0 -0
  47. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/docs/overview.md +0 -0
  48. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/docs/reference/api/core.rst +0 -0
  49. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/docs/reference/api/etl.rst +0 -0
  50. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/docs/reference/api/repository.rst +0 -0
  51. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/docs/reference/api/rest.rst +0 -0
  52. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/docs/reference/api/streaming.rst +0 -0
  53. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/docs/reference/api/testing.rst +0 -0
  54. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/docs/reference/index.rst +0 -0
  55. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/docs/requirements.txt +0 -0
  56. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/docs/rest/autocrud.md +0 -0
  57. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/docs/rest/celery.md +0 -0
  58. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/docs/rest/examples.md +0 -0
  59. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/docs/rest/testing.md +0 -0
  60. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/docs/rest/use-case-dsl.md +0 -0
  61. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/docs/streaming/bytewax.md +0 -0
  62. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/sonar-project.properties +0 -0
  63. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/__init__.py +0 -0
  64. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/celery/__init__.py +0 -0
  65. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/celery/auto.py +0 -0
  66. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/celery/bootstrap.py +0 -0
  67. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/celery/config.py +0 -0
  68. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/celery/constants.py +0 -0
  69. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/celery/runner.py +0 -0
  70. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/celery/service.py +0 -0
  71. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/async_bridge.py +0 -0
  72. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/backend/__init__.py +0 -0
  73. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/backend/core_model.py +0 -0
  74. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/backend/protocol.py +0 -0
  75. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/backend/sqlalchemy.py +0 -0
  76. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/bootstrap/__init__.py +0 -0
  77. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/bootstrap/bootstrap.py +0 -0
  78. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/bootstrap/kernel.py +0 -0
  79. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/cache/__init__.py +0 -0
  80. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/cache/abc/__init__.py +0 -0
  81. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/cache/abc/backend.py +0 -0
  82. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/cache/abc/config.py +0 -0
  83. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/cache/abc/dependency.py +0 -0
  84. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/cache/codec.py +0 -0
  85. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/cache/decorators.py +0 -0
  86. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/cache/dependency.py +0 -0
  87. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/cache/gateway.py +0 -0
  88. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/cache/keys.py +0 -0
  89. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/cache/repository.py +0 -0
  90. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/cache/serializer.py +0 -0
  91. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/command/__init__.py +0 -0
  92. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/command/adapter.py +0 -0
  93. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/command/base.py +0 -0
  94. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/command/field.py +0 -0
  95. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/command/introspection.py +0 -0
  96. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/compiler.py +0 -0
  97. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/config/__init__.py +0 -0
  98. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/config/_resolver_utils.py +0 -0
  99. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/config/binder.py +0 -0
  100. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/config/configurable.py +0 -0
  101. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/config/context.py +0 -0
  102. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/config/errors.py +0 -0
  103. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/config/keys.py +0 -0
  104. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/config/loader.py +0 -0
  105. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/config/model.py +0 -0
  106. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/config/observability.py +0 -0
  107. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/config/resolver.py +0 -0
  108. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/config/secrets.py +0 -0
  109. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/config/ssm.py +0 -0
  110. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/contracts/__init__.py +0 -0
  111. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/contracts/manifest.py +0 -0
  112. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/di/__init__.py +0 -0
  113. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/di/container.py +0 -0
  114. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/di/scope.py +0 -0
  115. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/discovery/__init__.py +0 -0
  116. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/discovery/_utils.py +0 -0
  117. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/discovery/base.py +0 -0
  118. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/discovery/interfaces.py +0 -0
  119. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/discovery/manifest.py +0 -0
  120. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/discovery/modules.py +0 -0
  121. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/engine/__init__.py +0 -0
  122. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/engine/compilable.py +0 -0
  123. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/engine/compiler.py +0 -0
  124. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/engine/events.py +0 -0
  125. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/engine/executor.py +0 -0
  126. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/engine/metrics.py +0 -0
  127. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/engine/plan.py +0 -0
  128. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/errors/__init__.py +0 -0
  129. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/errors/codes.py +0 -0
  130. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/errors/errors.py +0 -0
  131. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/expr/__init__.py +0 -0
  132. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/expr/eval.py +0 -0
  133. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/expr/nodes.py +0 -0
  134. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/expr/refs.py +0 -0
  135. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/job/__init__.py +0 -0
  136. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/job/callback.py +0 -0
  137. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/job/context.py +0 -0
  138. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/job/handle.py +0 -0
  139. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/job/job.py +0 -0
  140. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/job/service.py +0 -0
  141. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/logger/__init__.py +0 -0
  142. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/logger/abc.py +0 -0
  143. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/logger/config.py +0 -0
  144. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/logger/registry.py +0 -0
  145. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/logger/structlogger.py +0 -0
  146. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/model/__init__.py +0 -0
  147. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/model/base.py +0 -0
  148. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/model/enums.py +0 -0
  149. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/model/field.py +0 -0
  150. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/model/introspection.py +0 -0
  151. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/model/projection.py +0 -0
  152. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/model/relation.py +0 -0
  153. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/model/struct.py +0 -0
  154. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/model/timestamped.py +0 -0
  155. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/model/types.py +0 -0
  156. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/model/types_postgres.py +0 -0
  157. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/observability/__init__.py +0 -0
  158. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/observability/config.py +0 -0
  159. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/observability/event.py +0 -0
  160. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/observability/observer/__init__.py +0 -0
  161. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/observability/observer/noop.py +0 -0
  162. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/observability/observer/otel.py +0 -0
  163. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/observability/observer/structlog.py +0 -0
  164. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/observability/protocol.py +0 -0
  165. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/observability/runtime.py +0 -0
  166. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/observability/topology.py +0 -0
  167. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/projection/__init__.py +0 -0
  168. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/projection/loaders.py +0 -0
  169. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/projection/runtime.py +0 -0
  170. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/repository/__init__.py +0 -0
  171. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/repository/abc/__init__.py +0 -0
  172. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/repository/abc/query.py +0 -0
  173. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/repository/abc/repo_for.py +0 -0
  174. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/repository/abc/repository.py +0 -0
  175. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/repository/mutation.py +0 -0
  176. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/repository/registration.py +0 -0
  177. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/repository/registry.py +0 -0
  178. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/repository/sqlalchemy/__init__.py +0 -0
  179. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/repository/sqlalchemy/integrity.py +0 -0
  180. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/repository/sqlalchemy/loaders.py +0 -0
  181. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/repository/sqlalchemy/mixins.py +0 -0
  182. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/repository/sqlalchemy/model.py +0 -0
  183. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/repository/sqlalchemy/profile_loader.py +0 -0
  184. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/repository/sqlalchemy/projection.py +0 -0
  185. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/repository/sqlalchemy/query_compiler/__init__.py +0 -0
  186. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/repository/sqlalchemy/query_compiler/compiler.py +0 -0
  187. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/repository/sqlalchemy/query_compiler/cursor.py +0 -0
  188. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/repository/sqlalchemy/query_compiler/errors.py +0 -0
  189. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/repository/sqlalchemy/query_compiler/filters.py +0 -0
  190. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/repository/sqlalchemy/query_compiler/ordering.py +0 -0
  191. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/repository/sqlalchemy/query_compiler/paths.py +0 -0
  192. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/repository/sqlalchemy/query_compiler/subquery.py +0 -0
  193. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/repository/sqlalchemy/registry.py +0 -0
  194. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/repository/sqlalchemy/repository.py +0 -0
  195. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/repository/sqlalchemy/session_manager.py +0 -0
  196. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/repository/sqlalchemy/transactional.py +0 -0
  197. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/repository/sqlalchemy/uow.py +0 -0
  198. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/response/__init__.py +0 -0
  199. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/response/base.py +0 -0
  200. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/routing/__init__.py +0 -0
  201. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/routing/ref.py +0 -0
  202. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/routing/resolver.py +0 -0
  203. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/runner.py +0 -0
  204. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/schema/__init__.py +0 -0
  205. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/schema/schema_mode.py +0 -0
  206. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/tracing/__init__.py +0 -0
  207. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/tracing/context.py +0 -0
  208. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/transport/__init__.py +0 -0
  209. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/transport/adapter.py +0 -0
  210. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/uow/__init__.py +0 -0
  211. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/uow/abc.py +0 -0
  212. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/uow/context.py +0 -0
  213. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/use_case/__init__.py +0 -0
  214. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/use_case/_predicates.py +0 -0
  215. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/use_case/compute.py +0 -0
  216. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/use_case/constants.py +0 -0
  217. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/use_case/factory.py +0 -0
  218. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/use_case/field_ref.py +0 -0
  219. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/use_case/invoker.py +0 -0
  220. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/use_case/keys.py +0 -0
  221. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/use_case/markers.py +0 -0
  222. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/use_case/registry.py +0 -0
  223. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/use_case/rule.py +0 -0
  224. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/core/use_case/use_case.py +0 -0
  225. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/__init__.py +0 -0
  226. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/backends/__init__.py +0 -0
  227. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/backends/_format_registry.py +0 -0
  228. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/backends/_historify/__init__.py +0 -0
  229. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/backends/_historify/_common.py +0 -0
  230. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/backends/_historify/_log.py +0 -0
  231. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/backends/_historify/_ops.py +0 -0
  232. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/backends/_historify/_snapshot.py +0 -0
  233. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/backends/_historify/_transform.py +0 -0
  234. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/backends/_merge.py +0 -0
  235. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/backends/_predicate.py +0 -0
  236. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/backends/_schema_aligner/__init__.py +0 -0
  237. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/backends/_schema_aligner/_aligner.py +0 -0
  238. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/backends/_schema_aligner/_policy.py +0 -0
  239. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/backends/_write_policy.py +0 -0
  240. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/backends/polars/__init__.py +0 -0
  241. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/backends/polars/_dtype.py +0 -0
  242. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/backends/polars/_file_writer.py +0 -0
  243. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/backends/polars/_historify.py +0 -0
  244. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/backends/polars/_predicate.py +0 -0
  245. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/backends/polars/_reader.py +0 -0
  246. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/backends/polars/_schema.py +0 -0
  247. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/backends/polars/_schema_aligner.py +0 -0
  248. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/backends/polars/provider.py +0 -0
  249. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/backends/spark/__init__.py +0 -0
  250. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/backends/spark/_dtype.py +0 -0
  251. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/backends/spark/_historify.py +0 -0
  252. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/backends/spark/_reader.py +0 -0
  253. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/backends/spark/_schema.py +0 -0
  254. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/backends/spark/_schema_aligner.py +0 -0
  255. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/backends/spark/_writer.py +0 -0
  256. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/backends/spark/provider.py +0 -0
  257. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/checkpoint/__init__.py +0 -0
  258. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/checkpoint/_backends/_polars.py +0 -0
  259. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/checkpoint/_backends/_spark.py +0 -0
  260. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/checkpoint/_cleaners.py +0 -0
  261. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/checkpoint/_paths.py +0 -0
  262. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/checkpoint/_scope.py +0 -0
  263. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/checkpoint/_store.py +0 -0
  264. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/compiler/__init__.py +0 -0
  265. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/compiler/_binding.py +0 -0
  266. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/compiler/_compiler.py +0 -0
  267. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/compiler/_errors.py +0 -0
  268. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/compiler/_plan.py +0 -0
  269. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/compiler/_validators.py +0 -0
  270. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/compiler/_validators_plan.py +0 -0
  271. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/compiler/_validators_step.py +0 -0
  272. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/declarative/__init__.py +0 -0
  273. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/declarative/_format.py +0 -0
  274. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/declarative/_read_options.py +0 -0
  275. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/declarative/_utils.py +0 -0
  276. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/declarative/_write_options.py +0 -0
  277. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/declarative/expr/__init__.py +0 -0
  278. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/declarative/expr/_params.py +0 -0
  279. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/declarative/expr/_predicate.py +0 -0
  280. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/declarative/expr/_predicate_dialect.py +0 -0
  281. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/declarative/expr/_refs.py +0 -0
  282. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/declarative/source/__init__.py +0 -0
  283. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/declarative/source/_from.py +0 -0
  284. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/declarative/source/_from_clickhouse.py +0 -0
  285. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/declarative/source/_from_mongo.py +0 -0
  286. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/declarative/source/_specs.py +0 -0
  287. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/declarative/target/__init__.py +0 -0
  288. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/declarative/target/_file.py +0 -0
  289. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/declarative/target/_history/__init__.py +0 -0
  290. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/declarative/target/_history/_builder.py +0 -0
  291. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/declarative/target/_history/_enums.py +0 -0
  292. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/declarative/target/_history/_errors.py +0 -0
  293. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/declarative/target/_history/_report.py +0 -0
  294. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/declarative/target/_history/_spec.py +0 -0
  295. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/declarative/target/_schema_mode.py +0 -0
  296. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/declarative/target/_temp.py +0 -0
  297. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/executor/__init__.py +0 -0
  298. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/executor/_dispatcher.py +0 -0
  299. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/executor/_executor.py +0 -0
  300. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/io/__init__.py +0 -0
  301. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/io/_registry.py +0 -0
  302. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/io/sources/__init__.py +0 -0
  303. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/io/sources/_clickhouse.py +0 -0
  304. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/io/sources/_mongo.py +0 -0
  305. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/io/sources/_mongo_batch.py +0 -0
  306. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/io/sources/_mongo_bson.py +0 -0
  307. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/io/sources/_mongo_predicate.py +0 -0
  308. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/io/targets/__init__.py +0 -0
  309. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/io/targets/_clickhouse.py +0 -0
  310. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/lineage/__init__.py +0 -0
  311. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/lineage/_config.py +0 -0
  312. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/lineage/_observer.py +0 -0
  313. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/lineage/_records.py +0 -0
  314. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/lineage/sinks/__init__.py +0 -0
  315. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/lineage/sinks/_protocol.py +0 -0
  316. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/lineage/sinks/_table.py +0 -0
  317. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/lineage/sinks/_writer.py +0 -0
  318. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/pipeline/__init__.py +0 -0
  319. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/pipeline/_generics.py +0 -0
  320. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/pipeline/_params.py +0 -0
  321. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/pipeline/_pipeline.py +0 -0
  322. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/pipeline/_process.py +0 -0
  323. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/pipeline/_sql.py +0 -0
  324. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/pipeline/_step.py +0 -0
  325. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/pipeline/_step_sql.py +0 -0
  326. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/runner/__init__.py +0 -0
  327. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/runner/_providers.py +0 -0
  328. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/runner/_wiring.py +0 -0
  329. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/runner/config_loader.py +0 -0
  330. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/runner/core.py +0 -0
  331. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/runner/errors.py +0 -0
  332. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/runner/filtering.py +0 -0
  333. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/runtime/__init__.py +0 -0
  334. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/runtime/contracts.py +0 -0
  335. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/schema/__init__.py +0 -0
  336. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/schema/_contract.py +0 -0
  337. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/schema/_schema.py +0 -0
  338. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/storage/__init__.py +0 -0
  339. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/storage/_config.py +0 -0
  340. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/storage/_file_locator.py +0 -0
  341. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/storage/_locator.py +0 -0
  342. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/storage/routing.py +0 -0
  343. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/testing/__init__.py +0 -0
  344. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/testing/_result.py +0 -0
  345. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/testing/_scenario.py +0 -0
  346. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/testing/_stubs.py +0 -0
  347. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/etl/testing/spark.py +0 -0
  348. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/prefect/__init__.py +0 -0
  349. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/prefect/_async.py +0 -0
  350. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/prefect/_config.py +0 -0
  351. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/prefect/_ctx.py +0 -0
  352. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/prefect/_meta.py +0 -0
  353. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/prefect/_placeholders.py +0 -0
  354. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/prefect/deploy/__init__.py +0 -0
  355. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/prefect/deploy/_discovery.py +0 -0
  356. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/prefect/deploy/_schedule.py +0 -0
  357. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/prefect/deploy/_yaml.py +0 -0
  358. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/prefect/flow/__init__.py +0 -0
  359. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/prefect/flow/_body.py +0 -0
  360. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/prefect/flow/_factory.py +0 -0
  361. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/prefect/flow/_hooks.py +0 -0
  362. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/prefect/flow/_run_name.py +0 -0
  363. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/prefect/flow/_signature.py +0 -0
  364. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/prefect/manifest/__init__.py +0 -0
  365. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/prefect/manifest/_model.py +0 -0
  366. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/prefect/manifest/_s3.py +0 -0
  367. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/prefect/manifest/_store.py +0 -0
  368. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/prefect/notify/__init__.py +0 -0
  369. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/prefect/notify/_event.py +0 -0
  370. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/prefect/notify/_factory.py +0 -0
  371. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/prefect/notify/_port.py +0 -0
  372. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/prefect/notify/_slack.py +0 -0
  373. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/prefect/observer/__init__.py +0 -0
  374. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/prefect/observer/_flow.py +0 -0
  375. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/prefect/observer/_logging_bridge.py +0 -0
  376. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/prefect/observer/_manifest.py +0 -0
  377. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/prefect/observer/_task_run.py +0 -0
  378. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/prometheus/__init__.py +0 -0
  379. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/prometheus/adapter.py +0 -0
  380. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/prometheus/kafka.py +0 -0
  381. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/prometheus/lifecycle.py +0 -0
  382. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/prometheus/middleware.py +0 -0
  383. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/py.typed +0 -0
  384. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/rest/__init__.py +0 -0
  385. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/rest/adapter.py +0 -0
  386. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/rest/autocrud.py +0 -0
  387. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/rest/compiler.py +0 -0
  388. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/rest/constants.py +0 -0
  389. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/rest/errors.py +0 -0
  390. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/rest/fastapi/__init__.py +0 -0
  391. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/rest/fastapi/app.py +0 -0
  392. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/rest/fastapi/auto.py +0 -0
  393. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/rest/fastapi/openapi.py +0 -0
  394. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/rest/fastapi/response.py +0 -0
  395. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/rest/fastapi/router_runtime.py +0 -0
  396. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/rest/middleware.py +0 -0
  397. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/rest/model.py +0 -0
  398. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/rest/rest_adapter.py +0 -0
  399. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/streaming/__init__.py +0 -0
  400. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/streaming/bytewax/__init__.py +0 -0
  401. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/streaming/bytewax/_adapter.py +0 -0
  402. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/streaming/bytewax/_commit_tracker.py +0 -0
  403. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/streaming/bytewax/_dlq.py +0 -0
  404. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/streaming/bytewax/_error_boundary.py +0 -0
  405. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/streaming/bytewax/_operators.py +0 -0
  406. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/streaming/bytewax/_resource_manager.py +0 -0
  407. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/streaming/bytewax/_runtime_io.py +0 -0
  408. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/streaming/bytewax/_sink_registry.py +0 -0
  409. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/streaming/bytewax/handlers/__init__.py +0 -0
  410. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/streaming/bytewax/handlers/_shared.py +0 -0
  411. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/streaming/bytewax/handlers/boundary.py +0 -0
  412. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/streaming/bytewax/handlers/dispatcher.py +0 -0
  413. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/streaming/bytewax/handlers/routing.py +0 -0
  414. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/streaming/bytewax/handlers/scopes.py +0 -0
  415. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/streaming/bytewax/handlers/shapes.py +0 -0
  416. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/streaming/bytewax/handlers/steps.py +0 -0
  417. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/streaming/bytewax/handlers/storage.py +0 -0
  418. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/streaming/bytewax/runner.py +0 -0
  419. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/streaming/compiler/__init__.py +0 -0
  420. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/streaming/compiler/_bindings.py +0 -0
  421. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/streaming/compiler/_compiler.py +0 -0
  422. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/streaming/compiler/_plan.py +0 -0
  423. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/streaming/compiler/phases/build_plan.py +0 -0
  424. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/streaming/compiler/phases/validate.py +0 -0
  425. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/streaming/core/__init__.py +0 -0
  426. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/streaming/core/_errors.py +0 -0
  427. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/streaming/core/_exceptions.py +0 -0
  428. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/streaming/core/_message.py +0 -0
  429. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/streaming/core/_typing.py +0 -0
  430. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/streaming/graph/__init__.py +0 -0
  431. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/streaming/graph/_flow.py +0 -0
  432. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/streaming/kafka/__init__.py +0 -0
  433. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/streaming/kafka/_codec.py +0 -0
  434. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/streaming/kafka/_config.py +0 -0
  435. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/streaming/kafka/_errors.py +0 -0
  436. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/streaming/kafka/_key_resolver.py +0 -0
  437. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/streaming/kafka/_message.py +0 -0
  438. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/streaming/kafka/_record.py +0 -0
  439. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/streaming/kafka/_wire.py +0 -0
  440. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/streaming/kafka/client/__init__.py +0 -0
  441. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/streaming/kafka/client/_consumer.py +0 -0
  442. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/streaming/kafka/client/_producer.py +0 -0
  443. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/streaming/kafka/client/_protocol.py +0 -0
  444. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/streaming/kafka/message/__init__.py +0 -0
  445. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/streaming/kafka/message/_consumer.py +0 -0
  446. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/streaming/kafka/message/_producer.py +0 -0
  447. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/streaming/kafka/message/_protocol.py +0 -0
  448. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/streaming/mongo/__init__.py +0 -0
  449. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/streaming/mongo/_bytewax_source.py +0 -0
  450. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/streaming/mongo/_config.py +0 -0
  451. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/streaming/mongo/_event.py +0 -0
  452. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/streaming/mongo/_normalize.py +0 -0
  453. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/streaming/nodes/__init__.py +0 -0
  454. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/streaming/nodes/_boundary.py +0 -0
  455. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/streaming/nodes/_broadcast.py +0 -0
  456. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/streaming/nodes/_capabilities.py +0 -0
  457. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/streaming/nodes/_decompose.py +0 -0
  458. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/streaming/nodes/_expand_routes.py +0 -0
  459. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/streaming/nodes/_expr_eval.py +0 -0
  460. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/streaming/nodes/_fork.py +0 -0
  461. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/streaming/nodes/_helpers.py +0 -0
  462. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/streaming/nodes/_mongo.py +0 -0
  463. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/streaming/nodes/_protocols.py +0 -0
  464. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/streaming/nodes/_router.py +0 -0
  465. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/streaming/nodes/_shape.py +0 -0
  466. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/streaming/nodes/_sink.py +0 -0
  467. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/streaming/nodes/_step.py +0 -0
  468. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/streaming/nodes/_table/__init__.py +0 -0
  469. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/streaming/nodes/_table/common.py +0 -0
  470. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/streaming/nodes/_table/config.py +0 -0
  471. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/streaming/nodes/_with.py +0 -0
  472. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/streaming/nodes/refs.py +0 -0
  473. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/streaming/testing.py +0 -0
  474. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/testing/__init__.py +0 -0
  475. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/testing/golden.py +0 -0
  476. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/testing/http_harness.py +0 -0
  477. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/testing/in_memory.py +0 -0
  478. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/testing/repository_harness.py +0 -0
  479. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/src/loom/testing/runner.py +0 -0
  480. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/__init__.py +0 -0
  481. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/conftest.py +0 -0
  482. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/golden/__init__.py +0 -0
  483. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/golden/baselines/.gitkeep +0 -0
  484. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/golden/outputs/.gitkeep +0 -0
  485. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/golden/plans/.gitkeep +0 -0
  486. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/helpers/__init__.py +0 -0
  487. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/integration/__init__.py +0 -0
  488. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/integration/celery_bootstrap/__init__.py +0 -0
  489. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/integration/celery_bootstrap/config/conf.celery.integration.yaml +0 -0
  490. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/integration/celery_bootstrap/test_auto_create_app_integration.py +0 -0
  491. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/integration/celery_bootstrap/test_bootstrap_worker.py +0 -0
  492. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/integration/conftest.py +0 -0
  493. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/integration/core/__init__.py +0 -0
  494. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/integration/core/bootstrap/__init__.py +0 -0
  495. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/integration/core/bootstrap/test_bootstrap_integration.py +0 -0
  496. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/integration/core/repository/__init__.py +0 -0
  497. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/integration/core/repository/sqlalchemy/__init__.py +0 -0
  498. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/integration/core/repository/sqlalchemy/conftest.py +0 -0
  499. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/integration/core/repository/sqlalchemy/test_cache_integration.py +0 -0
  500. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/integration/core/repository/sqlalchemy/test_repository_integration.py +0 -0
  501. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/integration/core/rest/__init__.py +0 -0
  502. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/integration/core/rest/test_auto_interface_integration.py +0 -0
  503. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/integration/core/rest/test_fastapi_app_integration.py +0 -0
  504. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/integration/core/rest/test_rest_error_mapping.py +0 -0
  505. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/integration/core/rest/test_rest_observability.py +0 -0
  506. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/integration/core/use_case/__init__.py +0 -0
  507. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/integration/core/use_case/test_custom_repository_integration.py +0 -0
  508. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/integration/core/use_case/test_use_case_crud_integration.py +0 -0
  509. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/integration/etl/__init__.py +0 -0
  510. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/integration/etl/test_runner_integration.py +0 -0
  511. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/integration/fake_repo/__init__.py +0 -0
  512. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/integration/fake_repo/config/__init__.py +0 -0
  513. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/integration/fake_repo/config/conf.interfaces.yaml +0 -0
  514. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/integration/fake_repo/config/conf.manifest.yaml +0 -0
  515. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/integration/fake_repo/config/conf.modules.yaml +0 -0
  516. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/integration/fake_repo/config/conf.yaml +0 -0
  517. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/integration/fake_repo/main.py +0 -0
  518. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/integration/fake_repo/manifest.py +0 -0
  519. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/integration/fake_repo/product/__init__.py +0 -0
  520. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/integration/fake_repo/product/category/__init__.py +0 -0
  521. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/integration/fake_repo/product/category/model.py +0 -0
  522. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/integration/fake_repo/product/category/schemas.py +0 -0
  523. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/integration/fake_repo/product/interface.py +0 -0
  524. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/integration/fake_repo/product/jobs.py +0 -0
  525. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/integration/fake_repo/product/model.py +0 -0
  526. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/integration/fake_repo/product/relations.py +0 -0
  527. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/integration/fake_repo/product/repository.py +0 -0
  528. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/integration/fake_repo/product/repository_contract.py +0 -0
  529. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/integration/fake_repo/product/review/__init__.py +0 -0
  530. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/integration/fake_repo/product/review/model.py +0 -0
  531. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/integration/fake_repo/product/review/schemas.py +0 -0
  532. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/integration/fake_repo/product/schemas.py +0 -0
  533. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/integration/fake_repo/product/use_cases.py +0 -0
  534. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/integration/streaming/__init__.py +0 -0
  535. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/integration/streaming/test_into_table_integration.py +0 -0
  536. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/integration/support/__init__.py +0 -0
  537. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/integration/support/logical_repo_fixtures.py +0 -0
  538. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/__init__.py +0 -0
  539. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/celery_bootstrap/__init__.py +0 -0
  540. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/celery_bootstrap/test_async_runtime.py +0 -0
  541. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/celery_bootstrap/test_bootstrap.py +0 -0
  542. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/celery_jobs/__init__.py +0 -0
  543. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/celery_jobs/test_auto.py +0 -0
  544. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/celery_jobs/test_celery_service.py +0 -0
  545. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/celery_jobs/test_config.py +0 -0
  546. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/celery_jobs/test_runner.py +0 -0
  547. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/core/__init__.py +0 -0
  548. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/core/backend/__init__.py +0 -0
  549. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/core/backend/test_backend_compiler.py +0 -0
  550. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/core/bootstrap/__init__.py +0 -0
  551. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/core/bootstrap/test_bootstrap.py +0 -0
  552. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/core/bootstrap/test_bootstrap_metrics.py +0 -0
  553. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/core/bootstrap/test_kernel.py +0 -0
  554. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/core/cache/__init__.py +0 -0
  555. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/core/cache/test_cached_repository.py +0 -0
  556. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/core/command/__init__.py +0 -0
  557. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/core/command/test_command_base.py +0 -0
  558. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/core/command/test_command_field.py +0 -0
  559. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/core/command/test_command_patch.py +0 -0
  560. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/core/command/test_introspection.py +0 -0
  561. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/core/config/__init__.py +0 -0
  562. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/core/config/test_binder.py +0 -0
  563. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/core/config/test_config.py +0 -0
  564. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/core/config/test_configurable.py +0 -0
  565. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/core/config/test_context.py +0 -0
  566. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/core/config/test_resolver_utils.py +0 -0
  567. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/core/config/test_secrets.py +0 -0
  568. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/core/config/test_ssm.py +0 -0
  569. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/core/di/__init__.py +0 -0
  570. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/core/di/test_container.py +0 -0
  571. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/core/discovery/__init__.py +0 -0
  572. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/core/discovery/test_manifest.py +0 -0
  573. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/core/engine/__init__.py +0 -0
  574. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/core/engine/test_compiler.py +0 -0
  575. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/core/engine/test_executor.py +0 -0
  576. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/core/engine/test_executor_trace.py +0 -0
  577. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/core/engine/test_executor_uow.py +0 -0
  578. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/core/engine/test_metrics.py +0 -0
  579. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/core/engine/test_plan.py +0 -0
  580. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/core/errors/__init__.py +0 -0
  581. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/core/errors/test_errors.py +0 -0
  582. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/core/expr/__init__.py +0 -0
  583. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/core/expr/test_expr.py +0 -0
  584. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/core/job/__init__.py +0 -0
  585. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/core/job/conftest.py +0 -0
  586. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/core/job/test_callback.py +0 -0
  587. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/core/job/test_context.py +0 -0
  588. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/core/job/test_handle.py +0 -0
  589. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/core/job/test_inline_service.py +0 -0
  590. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/core/job/test_job.py +0 -0
  591. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/core/logger/__init__.py +0 -0
  592. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/core/logger/test_config.py +0 -0
  593. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/core/logger/test_registry.py +0 -0
  594. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/core/model/__init__.py +0 -0
  595. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/core/model/test_model.py +0 -0
  596. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/core/model/test_struct.py +0 -0
  597. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/core/model/test_timestamped.py +0 -0
  598. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/core/observability/__init__.py +0 -0
  599. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/core/observability/test_observers.py +0 -0
  600. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/core/observability/test_runtime.py +0 -0
  601. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/core/projection/__init__.py +0 -0
  602. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/core/projection/test_runtime.py +0 -0
  603. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/core/repository/__init__.py +0 -0
  604. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/core/repository/abc/__init__.py +0 -0
  605. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/core/repository/abc/conftest.py +0 -0
  606. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/core/repository/abc/test_query.py +0 -0
  607. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/core/repository/abc/test_repository_contract.py +0 -0
  608. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/core/repository/sqlalchemy/__init__.py +0 -0
  609. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/core/repository/sqlalchemy/conftest.py +0 -0
  610. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/core/repository/sqlalchemy/test_loaders.py +0 -0
  611. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/core/repository/sqlalchemy/test_repository.py +0 -0
  612. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/core/repository/sqlalchemy/test_transactional.py +0 -0
  613. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/core/routing/__init__.py +0 -0
  614. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/core/routing/test_routing.py +0 -0
  615. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/core/test_async_bridge.py +0 -0
  616. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/core/test_compiler_contracts.py +0 -0
  617. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/core/test_runner_contracts.py +0 -0
  618. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/core/tracing/__init__.py +0 -0
  619. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/core/tracing/test_context.py +0 -0
  620. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/core/uow/__init__.py +0 -0
  621. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/core/uow/test_executor_uow.py +0 -0
  622. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/core/uow/test_sqlalchemy_uow.py +0 -0
  623. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/core/uow/test_uow_protocols.py +0 -0
  624. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/core/use_case/__init__.py +0 -0
  625. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/core/use_case/test_compute.py +0 -0
  626. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/core/use_case/test_factory.py +0 -0
  627. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/core/use_case/test_field_ref.py +0 -0
  628. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/core/use_case/test_invoker.py +0 -0
  629. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/core/use_case/test_markers.py +0 -0
  630. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/core/use_case/test_rule.py +0 -0
  631. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/core/use_case/test_use_case.py +0 -0
  632. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/__init__.py +0 -0
  633. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/backends/__init__.py +0 -0
  634. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/backends/_historify_contract.py +0 -0
  635. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/backends/test_historify_common.py +0 -0
  636. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/backends/test_polars/__init__.py +0 -0
  637. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/backends/test_polars/conftest.py +0 -0
  638. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/backends/test_polars/test_apply_schema.py +0 -0
  639. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/backends/test_polars/test_backend.py +0 -0
  640. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/backends/test_polars/test_dtype.py +0 -0
  641. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/backends/test_polars/test_file_writer.py +0 -0
  642. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/backends/test_polars/test_historify_polars.py +0 -0
  643. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/backends/test_polars/test_predicate_pushdown.py +0 -0
  644. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/backends/test_polars/test_reader_columns.py +0 -0
  645. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/backends/test_polars/test_reader_json_columns.py +0 -0
  646. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/backends/test_polars/test_step_execution.py +0 -0
  647. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/backends/test_polars/test_upsert_writer.py +0 -0
  648. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/backends/test_polars/test_writer_null_schema.py +0 -0
  649. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/backends/test_polars/test_writer_to_frame.py +0 -0
  650. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/backends/test_spark/__init__.py +0 -0
  651. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/backends/test_spark/conftest.py +0 -0
  652. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/backends/test_spark/test_dtype.py +0 -0
  653. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/backends/test_spark/test_historify_spark.py +0 -0
  654. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/backends/test_spark/test_spark_apply_schema.py +0 -0
  655. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/backends/test_spark/test_step_execution.py +0 -0
  656. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/backends/test_spark/test_writer_to_frame.py +0 -0
  657. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/backends/test_write_policy_historify.py +0 -0
  658. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/checkpoint/__init__.py +0 -0
  659. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/checkpoint/backends/__init__.py +0 -0
  660. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/checkpoint/backends/test_checkpoint_polars.py +0 -0
  661. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/checkpoint/test_checkpoint_paths.py +0 -0
  662. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/checkpoint/test_cleaners.py +0 -0
  663. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/checkpoint/test_store.py +0 -0
  664. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/compiler/__init__.py +0 -0
  665. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/compiler/test_catalog_validator.py +0 -0
  666. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/compiler/test_compiler.py +0 -0
  667. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/compiler/test_compiler_catalog.py +0 -0
  668. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/compiler/test_compiler_upsert.py +0 -0
  669. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/compiler/test_errors.py +0 -0
  670. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/compiler/test_errors_additional_factories.py +0 -0
  671. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/compiler/test_errors_runtime_factories.py +0 -0
  672. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/compiler/test_historify_validator.py +0 -0
  673. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/compiler/test_param_exprs_validator.py +0 -0
  674. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/compiler/test_plan_traversal.py +0 -0
  675. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/compiler/test_step_validator.py +0 -0
  676. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/compiler/test_structural.py +0 -0
  677. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/compiler/test_temp_validator.py +0 -0
  678. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/compiler/test_upsert_validator.py +0 -0
  679. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/conftest.py +0 -0
  680. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/io/__init__.py +0 -0
  681. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/io/sources/__init__.py +0 -0
  682. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/io/sources/test_clickhouse_reader.py +0 -0
  683. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/io/sources/test_from_clickhouse.py +0 -0
  684. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/io/sources/test_from_mongo.py +0 -0
  685. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/io/sources/test_mongo_predicate.py +0 -0
  686. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/io/sources/test_mongo_reader.py +0 -0
  687. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/io/sources/test_mongo_reader_memory.py +0 -0
  688. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/io/targets/__init__.py +0 -0
  689. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/io/targets/test_clickhouse_writer.py +0 -0
  690. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/io/targets/test_into_clickhouse.py +0 -0
  691. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/io/test_history_target.py +0 -0
  692. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/io/test_registry.py +0 -0
  693. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/io/test_source.py +0 -0
  694. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/io/test_source_json.py +0 -0
  695. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/io/test_source_options.py +0 -0
  696. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/io/test_target.py +0 -0
  697. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/io/test_utils.py +0 -0
  698. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/io/test_variants.py +0 -0
  699. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/lineage/test_observer.py +0 -0
  700. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/lineage/test_records.py +0 -0
  701. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/lineage/test_store.py +0 -0
  702. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/pipeline/__init__.py +0 -0
  703. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/pipeline/test_pipeline_process.py +0 -0
  704. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/pipeline/test_proxy.py +0 -0
  705. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/pipeline/test_step.py +0 -0
  706. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/schema/__init__.py +0 -0
  707. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/schema/test_contract.py +0 -0
  708. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/schema/test_schema.py +0 -0
  709. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/schema/test_table.py +0 -0
  710. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/sql/__init__.py +0 -0
  711. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/sql/test_merge.py +0 -0
  712. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/sql/test_predicate.py +0 -0
  713. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/sql/test_predicate_dialect.py +0 -0
  714. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/sql/test_sql_runtime.py +0 -0
  715. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/storage/__init__.py +0 -0
  716. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/storage/test_backend_factory.py +0 -0
  717. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/storage/test_io_protocols.py +0 -0
  718. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/storage/test_locator.py +0 -0
  719. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/storage/test_observability_and_protocols.py +0 -0
  720. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/storage/test_route_build.py +0 -0
  721. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/storage/test_schema_readers.py +0 -0
  722. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/storage/test_storage_config.py +0 -0
  723. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/test_config_loader.py +0 -0
  724. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/test_executor.py +0 -0
  725. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/test_format_registry.py +0 -0
  726. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/test_module_contracts.py +0 -0
  727. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/test_public_api_discovery.py +0 -0
  728. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/test_record_schema_coverage.py +0 -0
  729. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/test_runner.py +0 -0
  730. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/test_runner_errors.py +0 -0
  731. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/test_spark_testing.py +0 -0
  732. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/testing/__init__.py +0 -0
  733. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/testing/test_runners.py +0 -0
  734. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/testing/test_scenario_and_stubs.py +0 -0
  735. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/etl/testing/test_spark_helpers.py +0 -0
  736. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/prefect/__init__.py +0 -0
  737. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/prefect/test_config.py +0 -0
  738. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/prefect/test_ctx.py +0 -0
  739. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/prefect/test_etl_flow.py +0 -0
  740. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/prefect/test_logging_bridge.py +0 -0
  741. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/prefect/test_manifest.py +0 -0
  742. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/prefect/test_manifest_s3.py +0 -0
  743. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/prefect/test_notify.py +0 -0
  744. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/prefect/test_observer.py +0 -0
  745. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/prefect/test_placeholders.py +0 -0
  746. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/prefect/test_task_run_observer.py +0 -0
  747. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/prefect/test_yaml_loader.py +0 -0
  748. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/prometheus/__init__.py +0 -0
  749. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/prometheus/test_adapter.py +0 -0
  750. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/prometheus/test_middleware.py +0 -0
  751. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/rest/__init__.py +0 -0
  752. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/rest/test_autocrud.py +0 -0
  753. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/rest/test_fastapi_auto_logger.py +0 -0
  754. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/rest/test_middleware.py +0 -0
  755. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/rest/test_pydantic_adapter.py +0 -0
  756. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/rest/test_response.py +0 -0
  757. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/rest/test_rest_adapter.py +0 -0
  758. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/rest/test_rest_compiler.py +0 -0
  759. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/rest/test_rest_model.py +0 -0
  760. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/rest/test_router_runtime.py +0 -0
  761. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/streaming/__init__.py +0 -0
  762. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/streaming/bytewax/__init__.py +0 -0
  763. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/streaming/bytewax/cases.py +0 -0
  764. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/streaming/bytewax/conftest.py +0 -0
  765. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/streaming/bytewax/test_adapter.py +0 -0
  766. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/streaming/bytewax/test_batch_key.py +0 -0
  767. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/streaming/bytewax/test_bytewax_dispatcher.py +0 -0
  768. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/streaming/bytewax/test_collect_batch.py +0 -0
  769. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/streaming/bytewax/test_dlq.py +0 -0
  770. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/streaming/bytewax/test_error_boundary.py +0 -0
  771. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/streaming/bytewax/test_operators.py +0 -0
  772. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/streaming/bytewax/test_resource_manager.py +0 -0
  773. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/streaming/bytewax/test_runner.py +0 -0
  774. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/streaming/bytewax/test_runtime_io.py +0 -0
  775. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/streaming/bytewax/test_runtime_sink.py +0 -0
  776. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/streaming/bytewax/test_runtime_source.py +0 -0
  777. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/streaming/bytewax/test_sink_registry.py +0 -0
  778. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/streaming/bytewax/test_steps.py +0 -0
  779. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/streaming/bytewax/test_storage.py +0 -0
  780. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/streaming/compiler/__init__.py +0 -0
  781. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/streaming/compiler/cases.py +0 -0
  782. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/streaming/compiler/test_async_walk.py +0 -0
  783. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/streaming/compiler/test_basics.py +0 -0
  784. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/streaming/compiler/test_config_bindings.py +0 -0
  785. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/streaming/compiler/test_mongo_source.py +0 -0
  786. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/streaming/compiler/test_multi_source.py +0 -0
  787. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/streaming/compiler/test_router.py +0 -0
  788. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/streaming/compiler/test_window.py +0 -0
  789. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/streaming/compiler/test_with.py +0 -0
  790. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/streaming/conftest.py +0 -0
  791. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/streaming/contracts/__init__.py +0 -0
  792. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/streaming/contracts/cases.py +0 -0
  793. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/streaming/contracts/test_boundary.py +0 -0
  794. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/streaming/contracts/test_message.py +0 -0
  795. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/streaming/contracts/test_mongo_contracts.py +0 -0
  796. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/streaming/contracts/test_multi_boundary.py +0 -0
  797. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/streaming/contracts/test_steps.py +0 -0
  798. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/streaming/flows/__init__.py +0 -0
  799. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/streaming/flows/cases/__init__.py +0 -0
  800. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/streaming/flows/cases/batch.py +0 -0
  801. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/streaming/flows/cases/explode.py +0 -0
  802. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/streaming/flows/cases/fork.py +0 -0
  803. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/streaming/flows/cases/router.py +0 -0
  804. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/streaming/flows/cases/shared.py +0 -0
  805. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/streaming/flows/cases/simple.py +0 -0
  806. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/streaming/flows/conftest.py +0 -0
  807. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/streaming/flows/test_compiler_examples.py +0 -0
  808. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/streaming/flows/test_flow_examples.py +0 -0
  809. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/streaming/kafka/__init__.py +0 -0
  810. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/streaming/kafka/cases.py +0 -0
  811. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/streaming/kafka/conftest.py +0 -0
  812. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/streaming/kafka/fakes.py +0 -0
  813. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/streaming/kafka/test_client.py +0 -0
  814. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/streaming/kafka/test_config.py +0 -0
  815. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/streaming/kafka/test_key_resolver.py +0 -0
  816. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/streaming/kafka/test_message.py +0 -0
  817. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/streaming/kafka/test_message_client.py +0 -0
  818. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/streaming/kafka/test_multi_wire.py +0 -0
  819. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/streaming/kafka/test_observability.py +0 -0
  820. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/streaming/kafka/test_settings.py +0 -0
  821. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/streaming/kafka/test_wire.py +0 -0
  822. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/streaming/mongo/test_bytewax_source.py +0 -0
  823. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/streaming/nodes/__init__.py +0 -0
  824. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/streaming/nodes/conftest.py +0 -0
  825. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/streaming/nodes/test_broadcast.py +0 -0
  826. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/streaming/nodes/test_delta_config.py +0 -0
  827. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/streaming/nodes/test_logging.py +0 -0
  828. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/streaming/nodes/test_table_package.py +0 -0
  829. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/streaming/observability/__init__.py +0 -0
  830. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/streaming/observability/cases.py +0 -0
  831. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/streaming/observability/conftest.py +0 -0
  832. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/streaming/observability/test_observability_runner.py +0 -0
  833. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/streaming/observability/test_protocols.py +0 -0
  834. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/streaming/observability/test_registry.py +0 -0
  835. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/streaming/observability/test_structlog.py +0 -0
  836. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/streaming/support/__init__.py +0 -0
  837. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/streaming/support/flow_cases.py +0 -0
  838. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/streaming/test_expand_routes.py +0 -0
  839. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/streaming/test_fork.py +0 -0
  840. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/streaming/test_otel_observability.py +0 -0
  841. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/streaming/test_routing.py +0 -0
  842. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/streaming/test_testing_mongo.py +0 -0
  843. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/streaming/test_with.py +0 -0
  844. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/testing/__init__.py +0 -0
  845. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/testing/test_golden.py +0 -0
  846. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/testing/test_http_harness.py +0 -0
  847. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/testing/test_in_memory.py +0 -0
  848. {loom_kernel-0.10.0 → loom_kernel-0.10.2}/tests/unit/testing/test_runner.py +0 -0
@@ -1,3 +1,37 @@
1
+ # 🚀 Release 0.10.2 ([#46](https://github.com/the-reacher-data/loom-py/pull/46)) ([`0fa17f5`](https://github.com/the-reacher-data/loom-py/commit/0fa17f5735be843e68ba446993bb41f2d107c33b))
2
+
3
+
4
+ ## ✨ Features
5
+ ### polars
6
+ - **polars:** streaming Arrow writes for replace_partitions
7
+
8
+
9
+
10
+
11
+
12
+
13
+
14
+
15
+
16
+
17
+
18
+ # 🚀 Release 0.10.1 ([#44](https://github.com/the-reacher-data/loom-py/pull/44)) ([`a55cd27`](https://github.com/the-reacher-data/loom-py/commit/a55cd27020dee60aea6849b510500e7e6f5a83b2))
19
+
20
+
21
+
22
+ ## 🐛 Fixes
23
+ ### testing
24
+ - **testing:** implement read_streaming on _PolarsStubReader (#44)
25
+
26
+
27
+
28
+
29
+
30
+
31
+
32
+
33
+
34
+
1
35
  # 🚀 Release 0.10.0 ([#41](https://github.com/the-reacher-data/loom-py/pull/41)) ([`099de38`](https://github.com/the-reacher-data/loom-py/commit/099de38b47cd7002a9c36fc56c9c85f673431022))
2
36
 
3
37
 
@@ -0,0 +1,15 @@
1
+ # 🚀 Release 0.10.2 ([#46](https://github.com/the-reacher-data/loom-py/pull/46)) ([`0fa17f5`](https://github.com/the-reacher-data/loom-py/commit/0fa17f5735be843e68ba446993bb41f2d107c33b))
2
+
3
+
4
+ ## ✨ Features
5
+ ### polars
6
+ - **polars:** streaming Arrow writes for replace_partitions
7
+
8
+
9
+
10
+
11
+
12
+
13
+
14
+
15
+
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: loom-kernel
3
- Version: 0.10.0
3
+ Version: 0.10.2
4
4
  Summary: Loom Python project
5
5
  License-File: LICENSE
6
6
  Classifier: Typing :: Typed
@@ -1,6 +1,6 @@
1
1
  [project]
2
2
  name = "loom-kernel"
3
- version = "0.10.0"
3
+ version = "0.10.2"
4
4
  description = "Loom Python project"
5
5
  readme = "README.md"
6
6
  requires-python = ">=3.11"
@@ -268,7 +268,7 @@ markers = [
268
268
 
269
269
  [tool.commitizen]
270
270
  name = "cz_conventional_commits"
271
- version = "0.10.0"
271
+ version = "0.10.2"
272
272
  tag_format = "v$version"
273
273
  version_files = [
274
274
  "pyproject.toml:project.version",
@@ -0,0 +1,82 @@
1
+ """Streaming-write helpers for the Polars Delta backend.
2
+
3
+ Bridges a ``pl.LazyFrame`` to an Arrow ``RecordBatchReader`` via an
4
+ intermediate IPC spool on disk. Memory is bounded by Polars' streaming
5
+ engine plus one batch in flight.
6
+ """
7
+
8
+ from __future__ import annotations
9
+
10
+ import os
11
+ import tempfile
12
+ from collections.abc import Iterator
13
+ from contextlib import contextmanager
14
+ from pathlib import Path
15
+ from typing import NamedTuple
16
+
17
+ import polars as pl
18
+ import pyarrow as pa
19
+ import pyarrow.ipc as ipc
20
+
21
+ _SPOOL_DIR_ENV = "LOOM_SPOOL_DIR"
22
+
23
+
24
+ class StreamingSpool(NamedTuple):
25
+ reader: pa.RecordBatchReader
26
+ spool_path: Path
27
+
28
+
29
+ def _resolve_spool_dir(spool_dir: str | os.PathLike[str] | None) -> str | None:
30
+ if spool_dir is not None:
31
+ return str(spool_dir)
32
+ env_dir = os.environ.get(_SPOOL_DIR_ENV)
33
+ return env_dir if env_dir else None
34
+
35
+
36
+ @contextmanager
37
+ def spool_lazy_to_arrow_reader(
38
+ frame: pl.LazyFrame,
39
+ *,
40
+ spool_dir: str | os.PathLike[str] | None = None,
41
+ ) -> Iterator[StreamingSpool]:
42
+ """Sink *frame* to an IPC file and yield an Arrow ``RecordBatchReader``.
43
+
44
+ The spool file lives in a temporary directory removed on context exit
45
+ even when the consumer raises. The yielded reader is single-pass;
46
+ callers needing a separate scan (e.g. for partition pruning) should
47
+ ``pl.scan_ipc(spool_path)`` while the context is active.
48
+
49
+ Args:
50
+ frame: Lazy frame to materialise to a streaming Arrow source.
51
+ spool_dir: Base directory for the temporary spool. When ``None``
52
+ defaults to ``$LOOM_SPOOL_DIR`` if set, else the
53
+ system temp dir. Set this on container workloads
54
+ where ``/tmp`` is a ``tmpfs`` mount (e.g. Fargate)
55
+ to avoid spilling back to RAM.
56
+
57
+ Yields:
58
+ A :class:`StreamingSpool` with the reader and the spool path.
59
+ """
60
+ base_dir = _resolve_spool_dir(spool_dir)
61
+ with tempfile.TemporaryDirectory(prefix="loom-spool-", dir=base_dir) as tmp_dir:
62
+ spool_path = Path(tmp_dir) / "spool.arrow"
63
+ frame.sink_ipc(spool_path, compression="lz4")
64
+ source = ipc.open_file(spool_path)
65
+
66
+ def _iter_batches() -> Iterator[pa.RecordBatch]:
67
+ for index in range(source.num_record_batches):
68
+ yield source.get_batch(index)
69
+
70
+ reader = pa.RecordBatchReader.from_batches(source.schema, _iter_batches())
71
+ yield StreamingSpool(reader=reader, spool_path=spool_path)
72
+
73
+
74
+ def partition_rows_from_spool(
75
+ spool_path: Path,
76
+ partition_cols: tuple[str, ...],
77
+ ) -> list[dict[str, object]]:
78
+ """Return distinct partition combinations from the spool file."""
79
+ frame = (
80
+ pl.scan_ipc(spool_path).select(list(partition_cols)).unique().collect(engine="streaming")
81
+ )
82
+ return list(frame.iter_rows(named=True))
@@ -29,7 +29,11 @@ from loom.etl.backends.polars._schema import (
29
29
  from loom.etl.declarative.target import SchemaMode
30
30
  from loom.etl.declarative.target._file import FileSpec
31
31
  from loom.etl.declarative.target._history import HistorifyRepairReport, HistorifySpec
32
- from loom.etl.declarative.target._table import AppendSpec, UpsertSpec
32
+ from loom.etl.declarative.target._table import (
33
+ AppendSpec,
34
+ ReplacePartitionsSpec,
35
+ UpsertSpec,
36
+ )
33
37
  from loom.etl.lineage._records import LineageRecord, WriteContext, get_lineage_schema
34
38
  from loom.etl.schema._schema import SchemaError
35
39
  from loom.etl.storage import (
@@ -46,6 +50,7 @@ from loom.etl.storage._locator import TableLocator, _as_locator
46
50
 
47
51
  from ._dtype import loom_type_to_polars
48
52
  from ._file_writer import PolarsFileWriter
53
+ from ._streaming import partition_rows_from_spool, spool_lazy_to_arrow_reader
49
54
 
50
55
  _log = get_logger(__name__)
51
56
 
@@ -88,6 +93,27 @@ def _log_write_commit(mode: str, location: TableLocation) -> None:
88
93
  _log.info("delta write commit", mode=mode, uri=location.uri, metrics="unavailable")
89
94
 
90
95
 
96
+ def _check_null_dtype_columns_lazy(frame: pl.LazyFrame) -> None:
97
+ """Lazy variant of :func:`_check_null_dtype_columns`.
98
+
99
+ Raises :exc:`~loom.etl.schema.SchemaError` if any column in the lazy
100
+ schema has dtype ``Null``. Operates on ``collect_schema()`` (metadata
101
+ only), so it is safe to call on a frame about to be streamed.
102
+ """
103
+ schema = frame.collect_schema()
104
+ null_cols = [name for name, dtype in schema.items() if isinstance(dtype, pl.Null)]
105
+ if not null_cols:
106
+ return
107
+ schema_repr = "\n".join(f" {n}: {d}" for n, d in schema.items())
108
+ raise SchemaError(
109
+ f"Delta Lake does not support the Null dtype. "
110
+ f"Column(s) with Null dtype: {null_cols}.\n"
111
+ f"Cast each column to its intended type before writing "
112
+ f"(use an explicit schema declaration or .cast() in the pipeline step).\n"
113
+ f"Full frame schema:\n{schema_repr}"
114
+ )
115
+
116
+
91
117
  def _check_null_dtype_columns(frame: pl.DataFrame) -> None:
92
118
  """Raise :exc:`~loom.etl.schema.SchemaError` if any column has dtype ``Null``.
93
119
 
@@ -189,6 +215,74 @@ class PolarsTargetWriter(_WritePolicy[pl.LazyFrame, pl.DataFrame, PolarsPhysical
189
215
  _check_null_dtype_columns(df)
190
216
  return df
191
217
 
218
+ def _do_replace_partitions(
219
+ self,
220
+ frame: pl.LazyFrame,
221
+ target: ResolvedTarget,
222
+ spec: ReplacePartitionsSpec,
223
+ streaming: bool,
224
+ ) -> None:
225
+ if not spec.streaming:
226
+ super()._do_replace_partitions(frame, target, spec, streaming)
227
+ return
228
+
229
+ existing = self._physical_schema(target)
230
+ if existing is None:
231
+ super()._do_replace_partitions(frame, target, spec, streaming)
232
+ return
233
+
234
+ aligned = self._align(frame, existing, spec.schema_mode)
235
+ _check_null_dtype_columns_lazy(aligned)
236
+ self._streaming_replace_partitions(aligned, target, spec)
237
+
238
+ def _streaming_replace_partitions(
239
+ self,
240
+ frame: pl.LazyFrame,
241
+ target: ResolvedTarget,
242
+ spec: ReplacePartitionsSpec,
243
+ ) -> None:
244
+ path_target = self._as_path_target(target)
245
+ location = path_target.location
246
+ with spool_lazy_to_arrow_reader(frame) as spool:
247
+ partition_rows = partition_rows_from_spool(spool.spool_path, spec.partition_cols)
248
+ if not partition_rows:
249
+ _log.warning("replace_partitions empty frame", table=location.uri)
250
+ return
251
+ null_rows = [r for r in partition_rows if any(v is None for v in r.values())]
252
+ if null_rows:
253
+ sample = null_rows[:5]
254
+ more = (
255
+ f" (+{len(null_rows) - len(sample)} more)"
256
+ if len(null_rows) > len(sample)
257
+ else ""
258
+ )
259
+ raise ValueError(
260
+ f"replace_partitions: null values in partition columns "
261
+ f"{spec.partition_cols} for table {path_target}. Null partition "
262
+ f"values cannot be used as a replace predicate. Ensure all "
263
+ f"partition columns are non-null before writing. "
264
+ f"Offending rows: {sample}{more}"
265
+ )
266
+ predicate = _build_partition_predicate(iter(partition_rows), spec.partition_cols)
267
+ _log.info(
268
+ "delta write start",
269
+ mode="replace_partitions",
270
+ uri=location.uri,
271
+ rows="streaming",
272
+ cols=None,
273
+ partition_cols=list(spec.partition_cols),
274
+ predicate=predicate,
275
+ )
276
+ write_deltalake(
277
+ location.uri,
278
+ spool.reader,
279
+ mode="overwrite",
280
+ predicate=predicate,
281
+ schema_mode=self._delta_schema_mode(spec.schema_mode),
282
+ **self._write_kwargs(location),
283
+ )
284
+ _log_write_commit("replace_partitions", location)
285
+
192
286
  def _predicate_to_sql(self, predicate: Any, params: Any) -> str:
193
287
  """Convert predicate to SQL (Polars uses internal SQL representation)."""
194
288
  return predicate_to_sql(predicate, params)
@@ -82,38 +82,53 @@ class IntoTable:
82
82
  # Default write mode is REPLACE. Call a write-mode method to change it.
83
83
  self._spec: Any = ReplaceSpec(table_ref=table_ref)
84
84
 
85
- def append(self, *, schema: SchemaMode = SchemaMode.STRICT) -> IntoTable:
85
+ def append(
86
+ self,
87
+ *,
88
+ schema: SchemaMode = SchemaMode.STRICT,
89
+ streaming: bool = False,
90
+ ) -> IntoTable:
86
91
  """Write mode: append rows to the target table.
87
92
 
88
93
  Args:
89
- schema: Schema evolution strategy. Defaults to
90
- :attr:`~SchemaMode.STRICT`.
94
+ schema: Schema evolution strategy. Defaults to
95
+ :attr:`~SchemaMode.STRICT`.
96
+ streaming: When ``True`` the Polars backend writes via an Arrow
97
+ ``RecordBatchReader`` instead of materialising.
91
98
 
92
99
  Returns:
93
100
  New ``IntoTable`` with APPEND mode.
94
101
  """
95
- return self._with(AppendSpec(table_ref=self._ref, schema_mode=schema))
102
+ return self._with(AppendSpec(table_ref=self._ref, schema_mode=schema, streaming=streaming))
96
103
 
97
- def replace(self, *, schema: SchemaMode = SchemaMode.STRICT) -> IntoTable:
104
+ def replace(
105
+ self,
106
+ *,
107
+ schema: SchemaMode = SchemaMode.STRICT,
108
+ streaming: bool = False,
109
+ ) -> IntoTable:
98
110
  """Write mode: full replace of the target table.
99
111
 
100
112
  Overwrites all data in the table. Use :meth:`replace_partitions` for
101
113
  partition-scoped overwrite or :meth:`replace_where` for predicate-scoped.
102
114
 
103
115
  Args:
104
- schema: Schema evolution strategy. Use
105
- :attr:`~SchemaMode.OVERWRITE` to replace the table schema
106
- entirely alongside the data.
116
+ schema: Schema evolution strategy. Use
117
+ :attr:`~SchemaMode.OVERWRITE` to replace the table schema
118
+ entirely alongside the data.
119
+ streaming: When ``True`` the Polars backend writes via an Arrow
120
+ ``RecordBatchReader`` instead of materialising.
107
121
 
108
122
  Returns:
109
123
  New ``IntoTable`` with REPLACE mode.
110
124
  """
111
- return self._with(ReplaceSpec(table_ref=self._ref, schema_mode=schema))
125
+ return self._with(ReplaceSpec(table_ref=self._ref, schema_mode=schema, streaming=streaming))
112
126
 
113
127
  def replace_partitions(
114
128
  self,
115
129
  *cols: str,
116
130
  schema: SchemaMode = SchemaMode.STRICT,
131
+ streaming: bool = False,
117
132
  ) -> IntoTable:
118
133
  """Write mode: replace the partitions present in the batch frame.
119
134
 
@@ -144,6 +159,7 @@ class IntoTable:
144
159
  table_ref=self._ref,
145
160
  partition_cols=cols,
146
161
  schema_mode=schema,
162
+ streaming=streaming,
147
163
  )
148
164
  )
149
165
 
@@ -200,6 +216,7 @@ class IntoTable:
200
216
  predicate: PredicateNode,
201
217
  *,
202
218
  schema: SchemaMode = SchemaMode.STRICT,
219
+ streaming: bool = False,
203
220
  ) -> IntoTable:
204
221
  """Write mode: replace rows matching an explicit predicate.
205
222
 
@@ -228,6 +245,7 @@ class IntoTable:
228
245
  table_ref=self._ref,
229
246
  replace_predicate=predicate,
230
247
  schema_mode=schema,
248
+ streaming=streaming,
231
249
  )
232
250
  )
233
251
 
@@ -22,10 +22,16 @@ class AppendSpec:
22
22
  Args:
23
23
  table_ref: Logical table reference.
24
24
  schema_mode: Schema evolution strategy. Defaults to ``STRICT``.
25
+ streaming: When ``True`` requests a streaming Arrow write. In
26
+ this release the Polars backend honours the flag
27
+ only for :class:`ReplacePartitionsSpec`; other modes
28
+ accept the flag for forward-compatibility but still
29
+ materialise the frame.
25
30
  """
26
31
 
27
32
  table_ref: TableRef
28
33
  schema_mode: SchemaMode = SchemaMode.STRICT
34
+ streaming: bool = False
29
35
 
30
36
 
31
37
  @dataclass(frozen=True)
@@ -36,10 +42,16 @@ class ReplaceSpec:
36
42
  table_ref: Logical table reference.
37
43
  schema_mode: Schema evolution strategy. ``OVERWRITE`` replaces the
38
44
  table schema alongside the data.
45
+ streaming: When ``True`` requests a streaming Arrow write. In
46
+ this release the Polars backend honours the flag
47
+ only for :class:`ReplacePartitionsSpec`; other modes
48
+ accept the flag for forward-compatibility but still
49
+ materialise the frame.
39
50
  """
40
51
 
41
52
  table_ref: TableRef
42
53
  schema_mode: SchemaMode = SchemaMode.STRICT
54
+ streaming: bool = False
43
55
 
44
56
 
45
57
  @dataclass(frozen=True)
@@ -53,11 +65,16 @@ class ReplacePartitionsSpec:
53
65
  table_ref: Logical table reference.
54
66
  partition_cols: Partition columns used to build the predicate.
55
67
  schema_mode: Schema evolution strategy.
68
+ streaming: When ``True`` the Polars backend writes via an
69
+ Arrow ``RecordBatchReader`` and computes the
70
+ partition predicate via a cheap projection over
71
+ the spool, bounding peak memory.
56
72
  """
57
73
 
58
74
  table_ref: TableRef
59
75
  partition_cols: tuple[str, ...]
60
76
  schema_mode: SchemaMode = SchemaMode.STRICT
77
+ streaming: bool = False
61
78
 
62
79
 
63
80
  @dataclass(frozen=True)
@@ -71,11 +88,18 @@ class ReplaceWhereSpec:
71
88
  table_ref: Logical table reference.
72
89
  replace_predicate: Predicate node built with the col/params DSL.
73
90
  schema_mode: Schema evolution strategy.
91
+ streaming: When ``True`` requests a streaming Arrow write.
92
+ In this release the Polars backend honours
93
+ the flag only for
94
+ :class:`ReplacePartitionsSpec`; other modes
95
+ accept the flag for forward-compatibility but
96
+ still materialise the frame.
74
97
  """
75
98
 
76
99
  table_ref: TableRef
77
100
  replace_predicate: PredicateNode
78
101
  schema_mode: SchemaMode = SchemaMode.STRICT
102
+ streaming: bool = False
79
103
 
80
104
 
81
105
  @dataclass(frozen=True)
@@ -50,6 +50,14 @@ class _PolarsStubReader:
50
50
  key = table_ref.ref if table_ref is not None else spec.alias
51
51
  return self._frames[key]
52
52
 
53
+ def read_streaming(
54
+ self,
55
+ spec: SourceSpec,
56
+ params_instance: Any,
57
+ /,
58
+ ) -> pl.LazyFrame:
59
+ return self.read(spec, params_instance)
60
+
53
61
  def execute_sql(self, frames: dict[str, Any], query: str, /) -> pl.LazyFrame:
54
62
  ctx = pl.SQLContext()
55
63
  for name, frame in frames.items():