relationalai 0.12.13__py3-none-any.whl → 0.13.0.dev0__py3-none-any.whl

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (825) hide show
  1. relationalai/__init__.py +1 -209
  2. relationalai/config/__init__.py +56 -0
  3. relationalai/config/config.py +289 -0
  4. relationalai/config/config_fields.py +86 -0
  5. relationalai/config/connections/__init__.py +46 -0
  6. relationalai/config/connections/base.py +23 -0
  7. relationalai/config/connections/duckdb.py +29 -0
  8. relationalai/config/connections/snowflake.py +243 -0
  9. relationalai/config/external/__init__.py +17 -0
  10. relationalai/config/external/dbt_converter.py +101 -0
  11. relationalai/config/external/dbt_models.py +93 -0
  12. relationalai/config/external/snowflake_converter.py +41 -0
  13. relationalai/config/external/snowflake_models.py +85 -0
  14. relationalai/config/external/utils.py +19 -0
  15. relationalai/semantics/__init__.py +146 -22
  16. relationalai/semantics/backends/lqp/annotations.py +11 -0
  17. relationalai/semantics/backends/sql/sql_compiler.py +327 -0
  18. relationalai/semantics/frontend/base.py +1707 -0
  19. relationalai/semantics/frontend/core.py +179 -0
  20. relationalai/semantics/frontend/front_compiler.py +1313 -0
  21. relationalai/semantics/frontend/pprint.py +408 -0
  22. relationalai/semantics/metamodel/__init__.py +6 -40
  23. relationalai/semantics/metamodel/builtins.py +205 -769
  24. relationalai/semantics/metamodel/metamodel.py +437 -0
  25. relationalai/semantics/metamodel/metamodel_analyzer.py +519 -0
  26. relationalai/semantics/metamodel/pprint.py +412 -0
  27. relationalai/semantics/metamodel/rewriter.py +266 -0
  28. relationalai/semantics/metamodel/typer.py +1378 -0
  29. relationalai/semantics/std/__init__.py +60 -40
  30. relationalai/semantics/std/aggregates.py +149 -0
  31. relationalai/semantics/std/common.py +44 -0
  32. relationalai/semantics/std/constraints.py +37 -43
  33. relationalai/semantics/std/datetime.py +246 -135
  34. relationalai/semantics/std/decimals.py +45 -52
  35. relationalai/semantics/std/floats.py +13 -5
  36. relationalai/semantics/std/integers.py +26 -11
  37. relationalai/semantics/std/math.py +183 -112
  38. relationalai/semantics/std/numbers.py +86 -0
  39. relationalai/semantics/std/re.py +80 -62
  40. relationalai/semantics/std/strings.py +117 -60
  41. relationalai/shims/executor.py +147 -0
  42. relationalai/shims/helpers.py +126 -0
  43. relationalai/shims/hoister.py +221 -0
  44. relationalai/shims/mm2v0.py +1290 -0
  45. relationalai/tools/cli/__init__.py +6 -0
  46. relationalai/tools/cli/cli.py +90 -0
  47. relationalai/tools/cli/components/__init__.py +5 -0
  48. relationalai/tools/cli/components/progress_reader.py +1524 -0
  49. relationalai/tools/cli/components/utils.py +58 -0
  50. relationalai/tools/cli/config_template.py +45 -0
  51. relationalai/tools/cli/dev.py +19 -0
  52. relationalai/tools/debugger.py +289 -183
  53. relationalai/tools/typer_debugger.py +93 -0
  54. relationalai/util/dataclasses.py +43 -0
  55. relationalai/util/docutils.py +40 -0
  56. relationalai/util/error.py +199 -0
  57. relationalai/util/format.py +48 -106
  58. relationalai/util/naming.py +145 -0
  59. relationalai/util/python.py +35 -0
  60. relationalai/util/runtime.py +156 -0
  61. relationalai/util/schema.py +197 -0
  62. relationalai/util/source.py +185 -0
  63. relationalai/util/structures.py +163 -0
  64. relationalai/util/tracing.py +261 -0
  65. relationalai-0.13.0.dev0.dist-info/METADATA +46 -0
  66. relationalai-0.13.0.dev0.dist-info/RECORD +488 -0
  67. relationalai-0.13.0.dev0.dist-info/WHEEL +5 -0
  68. relationalai-0.13.0.dev0.dist-info/entry_points.txt +3 -0
  69. relationalai-0.13.0.dev0.dist-info/top_level.txt +2 -0
  70. v0/relationalai/__init__.py +216 -0
  71. v0/relationalai/clients/azure.py +477 -0
  72. v0/relationalai/clients/client.py +912 -0
  73. v0/relationalai/clients/config.py +673 -0
  74. v0/relationalai/clients/direct_access_client.py +118 -0
  75. v0/relationalai/clients/hash_util.py +31 -0
  76. v0/relationalai/clients/local.py +571 -0
  77. v0/relationalai/clients/profile_polling.py +73 -0
  78. v0/relationalai/clients/result_helpers.py +420 -0
  79. v0/relationalai/clients/snowflake.py +3869 -0
  80. v0/relationalai/clients/types.py +113 -0
  81. v0/relationalai/clients/use_index_poller.py +980 -0
  82. v0/relationalai/clients/util.py +356 -0
  83. v0/relationalai/debugging.py +389 -0
  84. v0/relationalai/dsl.py +1749 -0
  85. v0/relationalai/early_access/builder/__init__.py +30 -0
  86. v0/relationalai/early_access/builder/builder/__init__.py +35 -0
  87. v0/relationalai/early_access/builder/snowflake/__init__.py +12 -0
  88. v0/relationalai/early_access/builder/std/__init__.py +25 -0
  89. v0/relationalai/early_access/builder/std/decimals/__init__.py +12 -0
  90. v0/relationalai/early_access/builder/std/integers/__init__.py +12 -0
  91. v0/relationalai/early_access/builder/std/math/__init__.py +12 -0
  92. v0/relationalai/early_access/builder/std/strings/__init__.py +14 -0
  93. v0/relationalai/early_access/devtools/__init__.py +12 -0
  94. v0/relationalai/early_access/devtools/benchmark_lqp/__init__.py +12 -0
  95. v0/relationalai/early_access/devtools/extract_lqp/__init__.py +12 -0
  96. v0/relationalai/early_access/dsl/adapters/orm/adapter_qb.py +427 -0
  97. v0/relationalai/early_access/dsl/adapters/orm/parser.py +636 -0
  98. v0/relationalai/early_access/dsl/adapters/owl/adapter.py +176 -0
  99. v0/relationalai/early_access/dsl/adapters/owl/parser.py +160 -0
  100. v0/relationalai/early_access/dsl/bindings/common.py +402 -0
  101. v0/relationalai/early_access/dsl/bindings/csv.py +170 -0
  102. v0/relationalai/early_access/dsl/bindings/legacy/binding_models.py +143 -0
  103. v0/relationalai/early_access/dsl/bindings/snowflake.py +64 -0
  104. v0/relationalai/early_access/dsl/codegen/binder.py +411 -0
  105. v0/relationalai/early_access/dsl/codegen/common.py +79 -0
  106. v0/relationalai/early_access/dsl/codegen/helpers.py +23 -0
  107. v0/relationalai/early_access/dsl/codegen/relations.py +700 -0
  108. v0/relationalai/early_access/dsl/codegen/weaver.py +417 -0
  109. v0/relationalai/early_access/dsl/core/builders/__init__.py +47 -0
  110. v0/relationalai/early_access/dsl/core/builders/logic.py +19 -0
  111. v0/relationalai/early_access/dsl/core/builders/scalar_constraint.py +11 -0
  112. v0/relationalai/early_access/dsl/core/constraints/predicate/atomic.py +455 -0
  113. v0/relationalai/early_access/dsl/core/constraints/predicate/universal.py +73 -0
  114. v0/relationalai/early_access/dsl/core/constraints/scalar.py +310 -0
  115. v0/relationalai/early_access/dsl/core/context.py +13 -0
  116. v0/relationalai/early_access/dsl/core/cset.py +132 -0
  117. v0/relationalai/early_access/dsl/core/exprs/__init__.py +116 -0
  118. v0/relationalai/early_access/dsl/core/exprs/relational.py +18 -0
  119. v0/relationalai/early_access/dsl/core/exprs/scalar.py +412 -0
  120. v0/relationalai/early_access/dsl/core/instances.py +44 -0
  121. v0/relationalai/early_access/dsl/core/logic/__init__.py +193 -0
  122. v0/relationalai/early_access/dsl/core/logic/aggregation.py +98 -0
  123. v0/relationalai/early_access/dsl/core/logic/exists.py +223 -0
  124. v0/relationalai/early_access/dsl/core/logic/helper.py +163 -0
  125. v0/relationalai/early_access/dsl/core/namespaces.py +32 -0
  126. v0/relationalai/early_access/dsl/core/relations.py +276 -0
  127. v0/relationalai/early_access/dsl/core/rules.py +112 -0
  128. v0/relationalai/early_access/dsl/core/std/__init__.py +45 -0
  129. v0/relationalai/early_access/dsl/core/temporal/recall.py +6 -0
  130. v0/relationalai/early_access/dsl/core/types/__init__.py +270 -0
  131. v0/relationalai/early_access/dsl/core/types/concepts.py +128 -0
  132. v0/relationalai/early_access/dsl/core/types/constrained/__init__.py +267 -0
  133. v0/relationalai/early_access/dsl/core/types/constrained/nominal.py +143 -0
  134. v0/relationalai/early_access/dsl/core/types/constrained/subtype.py +124 -0
  135. v0/relationalai/early_access/dsl/core/types/standard.py +92 -0
  136. v0/relationalai/early_access/dsl/core/types/unconstrained.py +50 -0
  137. v0/relationalai/early_access/dsl/core/types/variables.py +203 -0
  138. v0/relationalai/early_access/dsl/ir/compiler.py +318 -0
  139. v0/relationalai/early_access/dsl/ir/executor.py +260 -0
  140. v0/relationalai/early_access/dsl/ontologies/constraints.py +88 -0
  141. v0/relationalai/early_access/dsl/ontologies/export.py +30 -0
  142. v0/relationalai/early_access/dsl/ontologies/models.py +453 -0
  143. v0/relationalai/early_access/dsl/ontologies/python_printer.py +303 -0
  144. v0/relationalai/early_access/dsl/ontologies/readings.py +60 -0
  145. v0/relationalai/early_access/dsl/ontologies/relationships.py +322 -0
  146. v0/relationalai/early_access/dsl/ontologies/roles.py +87 -0
  147. v0/relationalai/early_access/dsl/ontologies/subtyping.py +55 -0
  148. v0/relationalai/early_access/dsl/orm/constraints.py +438 -0
  149. v0/relationalai/early_access/dsl/orm/measures/dimensions.py +200 -0
  150. v0/relationalai/early_access/dsl/orm/measures/initializer.py +16 -0
  151. v0/relationalai/early_access/dsl/orm/measures/measure_rules.py +275 -0
  152. v0/relationalai/early_access/dsl/orm/measures/measures.py +299 -0
  153. v0/relationalai/early_access/dsl/orm/measures/role_exprs.py +268 -0
  154. v0/relationalai/early_access/dsl/orm/models.py +256 -0
  155. v0/relationalai/early_access/dsl/orm/object_oriented_printer.py +344 -0
  156. v0/relationalai/early_access/dsl/orm/printer.py +469 -0
  157. v0/relationalai/early_access/dsl/orm/reasoners.py +480 -0
  158. v0/relationalai/early_access/dsl/orm/relations.py +19 -0
  159. v0/relationalai/early_access/dsl/orm/relationships.py +251 -0
  160. v0/relationalai/early_access/dsl/orm/types.py +42 -0
  161. v0/relationalai/early_access/dsl/orm/utils.py +79 -0
  162. v0/relationalai/early_access/dsl/orm/verb.py +204 -0
  163. v0/relationalai/early_access/dsl/physical_metadata/tables.py +133 -0
  164. v0/relationalai/early_access/dsl/relations.py +170 -0
  165. v0/relationalai/early_access/dsl/rulesets.py +69 -0
  166. v0/relationalai/early_access/dsl/schemas/__init__.py +450 -0
  167. v0/relationalai/early_access/dsl/schemas/builder.py +48 -0
  168. v0/relationalai/early_access/dsl/schemas/comp_names.py +51 -0
  169. v0/relationalai/early_access/dsl/schemas/components.py +203 -0
  170. v0/relationalai/early_access/dsl/schemas/contexts.py +156 -0
  171. v0/relationalai/early_access/dsl/schemas/exprs.py +89 -0
  172. v0/relationalai/early_access/dsl/schemas/fragments.py +464 -0
  173. v0/relationalai/early_access/dsl/serialization.py +79 -0
  174. v0/relationalai/early_access/dsl/serialize/exporter.py +163 -0
  175. v0/relationalai/early_access/dsl/snow/api.py +104 -0
  176. v0/relationalai/early_access/dsl/snow/common.py +76 -0
  177. v0/relationalai/early_access/dsl/state_mgmt/__init__.py +129 -0
  178. v0/relationalai/early_access/dsl/state_mgmt/state_charts.py +125 -0
  179. v0/relationalai/early_access/dsl/state_mgmt/transitions.py +130 -0
  180. v0/relationalai/early_access/dsl/types/__init__.py +40 -0
  181. v0/relationalai/early_access/dsl/types/concepts.py +12 -0
  182. v0/relationalai/early_access/dsl/types/entities.py +135 -0
  183. v0/relationalai/early_access/dsl/types/values.py +17 -0
  184. v0/relationalai/early_access/dsl/utils.py +102 -0
  185. v0/relationalai/early_access/graphs/__init__.py +13 -0
  186. v0/relationalai/early_access/lqp/__init__.py +12 -0
  187. v0/relationalai/early_access/lqp/compiler/__init__.py +12 -0
  188. v0/relationalai/early_access/lqp/constructors/__init__.py +18 -0
  189. v0/relationalai/early_access/lqp/executor/__init__.py +12 -0
  190. v0/relationalai/early_access/lqp/ir/__init__.py +12 -0
  191. v0/relationalai/early_access/lqp/passes/__init__.py +12 -0
  192. v0/relationalai/early_access/lqp/pragmas/__init__.py +12 -0
  193. v0/relationalai/early_access/lqp/primitives/__init__.py +12 -0
  194. v0/relationalai/early_access/lqp/types/__init__.py +12 -0
  195. v0/relationalai/early_access/lqp/utils/__init__.py +12 -0
  196. v0/relationalai/early_access/lqp/validators/__init__.py +12 -0
  197. v0/relationalai/early_access/metamodel/__init__.py +58 -0
  198. v0/relationalai/early_access/metamodel/builtins/__init__.py +12 -0
  199. v0/relationalai/early_access/metamodel/compiler/__init__.py +12 -0
  200. v0/relationalai/early_access/metamodel/dependency/__init__.py +12 -0
  201. v0/relationalai/early_access/metamodel/factory/__init__.py +17 -0
  202. v0/relationalai/early_access/metamodel/helpers/__init__.py +12 -0
  203. v0/relationalai/early_access/metamodel/ir/__init__.py +14 -0
  204. v0/relationalai/early_access/metamodel/rewrite/__init__.py +7 -0
  205. v0/relationalai/early_access/metamodel/typer/__init__.py +3 -0
  206. v0/relationalai/early_access/metamodel/typer/typer/__init__.py +12 -0
  207. v0/relationalai/early_access/metamodel/types/__init__.py +15 -0
  208. v0/relationalai/early_access/metamodel/util/__init__.py +15 -0
  209. v0/relationalai/early_access/metamodel/visitor/__init__.py +12 -0
  210. v0/relationalai/early_access/rel/__init__.py +12 -0
  211. v0/relationalai/early_access/rel/executor/__init__.py +12 -0
  212. v0/relationalai/early_access/rel/rel_utils/__init__.py +12 -0
  213. v0/relationalai/early_access/rel/rewrite/__init__.py +7 -0
  214. v0/relationalai/early_access/solvers/__init__.py +19 -0
  215. v0/relationalai/early_access/sql/__init__.py +11 -0
  216. v0/relationalai/early_access/sql/executor/__init__.py +3 -0
  217. v0/relationalai/early_access/sql/rewrite/__init__.py +3 -0
  218. v0/relationalai/early_access/tests/logging/__init__.py +12 -0
  219. v0/relationalai/early_access/tests/test_snapshot_base/__init__.py +12 -0
  220. v0/relationalai/early_access/tests/utils/__init__.py +12 -0
  221. v0/relationalai/environments/__init__.py +35 -0
  222. v0/relationalai/environments/base.py +381 -0
  223. v0/relationalai/environments/colab.py +14 -0
  224. v0/relationalai/environments/generic.py +71 -0
  225. v0/relationalai/environments/ipython.py +68 -0
  226. v0/relationalai/environments/jupyter.py +9 -0
  227. v0/relationalai/environments/snowbook.py +169 -0
  228. v0/relationalai/errors.py +2455 -0
  229. v0/relationalai/experimental/SF.py +38 -0
  230. v0/relationalai/experimental/inspect.py +47 -0
  231. v0/relationalai/experimental/pathfinder/__init__.py +158 -0
  232. v0/relationalai/experimental/pathfinder/api.py +160 -0
  233. v0/relationalai/experimental/pathfinder/automaton.py +584 -0
  234. v0/relationalai/experimental/pathfinder/bridge.py +226 -0
  235. v0/relationalai/experimental/pathfinder/compiler.py +416 -0
  236. v0/relationalai/experimental/pathfinder/datalog.py +214 -0
  237. v0/relationalai/experimental/pathfinder/diagnostics.py +56 -0
  238. v0/relationalai/experimental/pathfinder/filter.py +236 -0
  239. v0/relationalai/experimental/pathfinder/glushkov.py +439 -0
  240. v0/relationalai/experimental/pathfinder/options.py +265 -0
  241. v0/relationalai/experimental/pathfinder/rpq.py +344 -0
  242. v0/relationalai/experimental/pathfinder/transition.py +200 -0
  243. v0/relationalai/experimental/pathfinder/utils.py +26 -0
  244. v0/relationalai/experimental/paths/api.py +143 -0
  245. v0/relationalai/experimental/paths/benchmarks/grid_graph.py +37 -0
  246. v0/relationalai/experimental/paths/examples/basic_example.py +40 -0
  247. v0/relationalai/experimental/paths/examples/minimal_engine_warmup.py +3 -0
  248. v0/relationalai/experimental/paths/examples/movie_example.py +77 -0
  249. v0/relationalai/experimental/paths/examples/paths_benchmark.py +115 -0
  250. v0/relationalai/experimental/paths/examples/paths_example.py +116 -0
  251. v0/relationalai/experimental/paths/examples/pattern_to_automaton.py +28 -0
  252. v0/relationalai/experimental/paths/find_paths_via_automaton.py +85 -0
  253. v0/relationalai/experimental/paths/graph.py +185 -0
  254. v0/relationalai/experimental/paths/path_algorithms/find_paths.py +280 -0
  255. v0/relationalai/experimental/paths/path_algorithms/one_sided_ball_repetition.py +26 -0
  256. v0/relationalai/experimental/paths/path_algorithms/one_sided_ball_upto.py +111 -0
  257. v0/relationalai/experimental/paths/path_algorithms/single.py +59 -0
  258. v0/relationalai/experimental/paths/path_algorithms/two_sided_balls_repetition.py +39 -0
  259. v0/relationalai/experimental/paths/path_algorithms/two_sided_balls_upto.py +103 -0
  260. v0/relationalai/experimental/paths/path_algorithms/usp-old.py +130 -0
  261. v0/relationalai/experimental/paths/path_algorithms/usp-tuple.py +183 -0
  262. v0/relationalai/experimental/paths/path_algorithms/usp.py +150 -0
  263. v0/relationalai/experimental/paths/product_graph.py +93 -0
  264. v0/relationalai/experimental/paths/rpq/automaton.py +584 -0
  265. v0/relationalai/experimental/paths/rpq/diagnostics.py +56 -0
  266. v0/relationalai/experimental/paths/rpq/rpq.py +378 -0
  267. v0/relationalai/experimental/paths/tests/tests_limit_sp_max_length.py +90 -0
  268. v0/relationalai/experimental/paths/tests/tests_limit_sp_multiple.py +119 -0
  269. v0/relationalai/experimental/paths/tests/tests_limit_sp_single.py +104 -0
  270. v0/relationalai/experimental/paths/tests/tests_limit_walks_multiple.py +113 -0
  271. v0/relationalai/experimental/paths/tests/tests_limit_walks_single.py +149 -0
  272. v0/relationalai/experimental/paths/tests/tests_one_sided_ball_repetition_multiple.py +70 -0
  273. v0/relationalai/experimental/paths/tests/tests_one_sided_ball_repetition_single.py +64 -0
  274. v0/relationalai/experimental/paths/tests/tests_one_sided_ball_upto_multiple.py +115 -0
  275. v0/relationalai/experimental/paths/tests/tests_one_sided_ball_upto_single.py +75 -0
  276. v0/relationalai/experimental/paths/tests/tests_single_paths.py +152 -0
  277. v0/relationalai/experimental/paths/tests/tests_single_walks.py +208 -0
  278. v0/relationalai/experimental/paths/tests/tests_single_walks_undirected.py +297 -0
  279. v0/relationalai/experimental/paths/tests/tests_two_sided_balls_repetition_multiple.py +107 -0
  280. v0/relationalai/experimental/paths/tests/tests_two_sided_balls_repetition_single.py +76 -0
  281. v0/relationalai/experimental/paths/tests/tests_two_sided_balls_upto_multiple.py +76 -0
  282. v0/relationalai/experimental/paths/tests/tests_two_sided_balls_upto_single.py +110 -0
  283. v0/relationalai/experimental/paths/tests/tests_usp_nsp_multiple.py +229 -0
  284. v0/relationalai/experimental/paths/tests/tests_usp_nsp_single.py +108 -0
  285. v0/relationalai/experimental/paths/tree_agg.py +168 -0
  286. v0/relationalai/experimental/paths/utilities/iterators.py +27 -0
  287. v0/relationalai/experimental/paths/utilities/prefix_sum.py +91 -0
  288. v0/relationalai/experimental/solvers.py +1087 -0
  289. v0/relationalai/loaders/__init__.py +0 -0
  290. v0/relationalai/loaders/csv.py +195 -0
  291. v0/relationalai/loaders/loader.py +177 -0
  292. v0/relationalai/loaders/types.py +23 -0
  293. v0/relationalai/rel_emitter.py +373 -0
  294. v0/relationalai/rel_utils.py +185 -0
  295. v0/relationalai/semantics/__init__.py +29 -0
  296. v0/relationalai/semantics/devtools/benchmark_lqp.py +536 -0
  297. v0/relationalai/semantics/devtools/compilation_manager.py +294 -0
  298. v0/relationalai/semantics/devtools/extract_lqp.py +110 -0
  299. v0/relationalai/semantics/internal/internal.py +3785 -0
  300. v0/relationalai/semantics/internal/snowflake.py +324 -0
  301. v0/relationalai/semantics/lqp/builtins.py +16 -0
  302. v0/relationalai/semantics/lqp/compiler.py +22 -0
  303. v0/relationalai/semantics/lqp/constructors.py +68 -0
  304. v0/relationalai/semantics/lqp/executor.py +469 -0
  305. v0/relationalai/semantics/lqp/intrinsics.py +24 -0
  306. v0/relationalai/semantics/lqp/model2lqp.py +839 -0
  307. v0/relationalai/semantics/lqp/passes.py +680 -0
  308. v0/relationalai/semantics/lqp/primitives.py +252 -0
  309. v0/relationalai/semantics/lqp/result_helpers.py +202 -0
  310. v0/relationalai/semantics/lqp/rewrite/annotate_constraints.py +57 -0
  311. v0/relationalai/semantics/lqp/rewrite/cdc.py +216 -0
  312. v0/relationalai/semantics/lqp/rewrite/extract_common.py +338 -0
  313. v0/relationalai/semantics/lqp/rewrite/extract_keys.py +449 -0
  314. v0/relationalai/semantics/lqp/rewrite/function_annotations.py +114 -0
  315. v0/relationalai/semantics/lqp/rewrite/functional_dependencies.py +314 -0
  316. v0/relationalai/semantics/lqp/rewrite/quantify_vars.py +296 -0
  317. v0/relationalai/semantics/lqp/rewrite/splinter.py +76 -0
  318. v0/relationalai/semantics/lqp/types.py +101 -0
  319. v0/relationalai/semantics/lqp/utils.py +160 -0
  320. v0/relationalai/semantics/lqp/validators.py +57 -0
  321. v0/relationalai/semantics/metamodel/__init__.py +40 -0
  322. v0/relationalai/semantics/metamodel/builtins.py +774 -0
  323. v0/relationalai/semantics/metamodel/compiler.py +133 -0
  324. v0/relationalai/semantics/metamodel/dependency.py +862 -0
  325. v0/relationalai/semantics/metamodel/executor.py +61 -0
  326. v0/relationalai/semantics/metamodel/factory.py +287 -0
  327. v0/relationalai/semantics/metamodel/helpers.py +361 -0
  328. v0/relationalai/semantics/metamodel/rewrite/discharge_constraints.py +39 -0
  329. v0/relationalai/semantics/metamodel/rewrite/dnf_union_splitter.py +210 -0
  330. v0/relationalai/semantics/metamodel/rewrite/extract_nested_logicals.py +78 -0
  331. v0/relationalai/semantics/metamodel/rewrite/flatten.py +549 -0
  332. v0/relationalai/semantics/metamodel/rewrite/format_outputs.py +165 -0
  333. v0/relationalai/semantics/metamodel/typer/checker.py +353 -0
  334. v0/relationalai/semantics/metamodel/typer/typer.py +1395 -0
  335. v0/relationalai/semantics/reasoners/__init__.py +10 -0
  336. v0/relationalai/semantics/reasoners/graph/__init__.py +37 -0
  337. v0/relationalai/semantics/reasoners/graph/core.py +9020 -0
  338. v0/relationalai/semantics/reasoners/optimization/__init__.py +68 -0
  339. v0/relationalai/semantics/reasoners/optimization/common.py +88 -0
  340. v0/relationalai/semantics/reasoners/optimization/solvers_dev.py +568 -0
  341. v0/relationalai/semantics/reasoners/optimization/solvers_pb.py +1163 -0
  342. v0/relationalai/semantics/rel/builtins.py +40 -0
  343. v0/relationalai/semantics/rel/compiler.py +989 -0
  344. v0/relationalai/semantics/rel/executor.py +359 -0
  345. v0/relationalai/semantics/rel/rel.py +482 -0
  346. v0/relationalai/semantics/rel/rel_utils.py +276 -0
  347. v0/relationalai/semantics/snowflake/__init__.py +3 -0
  348. v0/relationalai/semantics/sql/compiler.py +2503 -0
  349. v0/relationalai/semantics/sql/executor/duck_db.py +52 -0
  350. v0/relationalai/semantics/sql/executor/result_helpers.py +64 -0
  351. v0/relationalai/semantics/sql/executor/snowflake.py +145 -0
  352. v0/relationalai/semantics/sql/rewrite/denormalize.py +222 -0
  353. v0/relationalai/semantics/sql/rewrite/double_negation.py +49 -0
  354. v0/relationalai/semantics/sql/rewrite/recursive_union.py +127 -0
  355. v0/relationalai/semantics/sql/rewrite/sort_output_query.py +246 -0
  356. v0/relationalai/semantics/sql/sql.py +504 -0
  357. v0/relationalai/semantics/std/__init__.py +54 -0
  358. v0/relationalai/semantics/std/constraints.py +43 -0
  359. v0/relationalai/semantics/std/datetime.py +363 -0
  360. v0/relationalai/semantics/std/decimals.py +62 -0
  361. v0/relationalai/semantics/std/floats.py +7 -0
  362. v0/relationalai/semantics/std/integers.py +22 -0
  363. v0/relationalai/semantics/std/math.py +141 -0
  364. v0/relationalai/semantics/std/pragmas.py +11 -0
  365. v0/relationalai/semantics/std/re.py +83 -0
  366. v0/relationalai/semantics/std/std.py +14 -0
  367. v0/relationalai/semantics/std/strings.py +63 -0
  368. v0/relationalai/semantics/tests/__init__.py +0 -0
  369. v0/relationalai/semantics/tests/test_snapshot_abstract.py +143 -0
  370. v0/relationalai/semantics/tests/test_snapshot_base.py +9 -0
  371. v0/relationalai/semantics/tests/utils.py +46 -0
  372. v0/relationalai/std/__init__.py +70 -0
  373. v0/relationalai/tools/__init__.py +0 -0
  374. v0/relationalai/tools/cli.py +1940 -0
  375. v0/relationalai/tools/cli_controls.py +1826 -0
  376. v0/relationalai/tools/cli_helpers.py +390 -0
  377. v0/relationalai/tools/debugger.py +183 -0
  378. v0/relationalai/tools/debugger_client.py +109 -0
  379. v0/relationalai/tools/debugger_server.py +302 -0
  380. v0/relationalai/tools/dev.py +685 -0
  381. v0/relationalai/tools/qb_debugger.py +425 -0
  382. v0/relationalai/util/clean_up_databases.py +95 -0
  383. v0/relationalai/util/format.py +123 -0
  384. v0/relationalai/util/list_databases.py +9 -0
  385. v0/relationalai/util/otel_configuration.py +25 -0
  386. v0/relationalai/util/otel_handler.py +484 -0
  387. v0/relationalai/util/snowflake_handler.py +88 -0
  388. v0/relationalai/util/span_format_test.py +43 -0
  389. v0/relationalai/util/span_tracker.py +207 -0
  390. v0/relationalai/util/spans_file_handler.py +72 -0
  391. v0/relationalai/util/tracing_handler.py +34 -0
  392. frontend/debugger/dist/.gitignore +0 -2
  393. frontend/debugger/dist/assets/favicon-Dy0ZgA6N.png +0 -0
  394. frontend/debugger/dist/assets/index-Cssla-O7.js +0 -208
  395. frontend/debugger/dist/assets/index-DlHsYx1V.css +0 -9
  396. frontend/debugger/dist/index.html +0 -17
  397. relationalai/clients/azure.py +0 -477
  398. relationalai/clients/client.py +0 -912
  399. relationalai/clients/config.py +0 -673
  400. relationalai/clients/direct_access_client.py +0 -118
  401. relationalai/clients/export_procedure.py.jinja +0 -249
  402. relationalai/clients/hash_util.py +0 -31
  403. relationalai/clients/local.py +0 -571
  404. relationalai/clients/profile_polling.py +0 -73
  405. relationalai/clients/result_helpers.py +0 -420
  406. relationalai/clients/snowflake.py +0 -3869
  407. relationalai/clients/types.py +0 -113
  408. relationalai/clients/use_index_poller.py +0 -980
  409. relationalai/clients/util.py +0 -356
  410. relationalai/debugging.py +0 -389
  411. relationalai/dsl.py +0 -1749
  412. relationalai/early_access/builder/__init__.py +0 -30
  413. relationalai/early_access/builder/builder/__init__.py +0 -35
  414. relationalai/early_access/builder/snowflake/__init__.py +0 -12
  415. relationalai/early_access/builder/std/__init__.py +0 -25
  416. relationalai/early_access/builder/std/decimals/__init__.py +0 -12
  417. relationalai/early_access/builder/std/integers/__init__.py +0 -12
  418. relationalai/early_access/builder/std/math/__init__.py +0 -12
  419. relationalai/early_access/builder/std/strings/__init__.py +0 -14
  420. relationalai/early_access/devtools/__init__.py +0 -12
  421. relationalai/early_access/devtools/benchmark_lqp/__init__.py +0 -12
  422. relationalai/early_access/devtools/extract_lqp/__init__.py +0 -12
  423. relationalai/early_access/dsl/adapters/orm/adapter_qb.py +0 -427
  424. relationalai/early_access/dsl/adapters/orm/parser.py +0 -636
  425. relationalai/early_access/dsl/adapters/owl/adapter.py +0 -176
  426. relationalai/early_access/dsl/adapters/owl/parser.py +0 -160
  427. relationalai/early_access/dsl/bindings/common.py +0 -402
  428. relationalai/early_access/dsl/bindings/csv.py +0 -170
  429. relationalai/early_access/dsl/bindings/legacy/binding_models.py +0 -143
  430. relationalai/early_access/dsl/bindings/snowflake.py +0 -64
  431. relationalai/early_access/dsl/codegen/binder.py +0 -411
  432. relationalai/early_access/dsl/codegen/common.py +0 -79
  433. relationalai/early_access/dsl/codegen/helpers.py +0 -23
  434. relationalai/early_access/dsl/codegen/relations.py +0 -700
  435. relationalai/early_access/dsl/codegen/weaver.py +0 -417
  436. relationalai/early_access/dsl/core/builders/__init__.py +0 -47
  437. relationalai/early_access/dsl/core/builders/logic.py +0 -19
  438. relationalai/early_access/dsl/core/builders/scalar_constraint.py +0 -11
  439. relationalai/early_access/dsl/core/constraints/predicate/atomic.py +0 -455
  440. relationalai/early_access/dsl/core/constraints/predicate/universal.py +0 -73
  441. relationalai/early_access/dsl/core/constraints/scalar.py +0 -310
  442. relationalai/early_access/dsl/core/context.py +0 -13
  443. relationalai/early_access/dsl/core/cset.py +0 -132
  444. relationalai/early_access/dsl/core/exprs/__init__.py +0 -116
  445. relationalai/early_access/dsl/core/exprs/relational.py +0 -18
  446. relationalai/early_access/dsl/core/exprs/scalar.py +0 -412
  447. relationalai/early_access/dsl/core/instances.py +0 -44
  448. relationalai/early_access/dsl/core/logic/__init__.py +0 -193
  449. relationalai/early_access/dsl/core/logic/aggregation.py +0 -98
  450. relationalai/early_access/dsl/core/logic/exists.py +0 -223
  451. relationalai/early_access/dsl/core/logic/helper.py +0 -163
  452. relationalai/early_access/dsl/core/namespaces.py +0 -32
  453. relationalai/early_access/dsl/core/relations.py +0 -276
  454. relationalai/early_access/dsl/core/rules.py +0 -112
  455. relationalai/early_access/dsl/core/std/__init__.py +0 -45
  456. relationalai/early_access/dsl/core/temporal/recall.py +0 -6
  457. relationalai/early_access/dsl/core/types/__init__.py +0 -270
  458. relationalai/early_access/dsl/core/types/concepts.py +0 -128
  459. relationalai/early_access/dsl/core/types/constrained/__init__.py +0 -267
  460. relationalai/early_access/dsl/core/types/constrained/nominal.py +0 -143
  461. relationalai/early_access/dsl/core/types/constrained/subtype.py +0 -124
  462. relationalai/early_access/dsl/core/types/standard.py +0 -92
  463. relationalai/early_access/dsl/core/types/unconstrained.py +0 -50
  464. relationalai/early_access/dsl/core/types/variables.py +0 -203
  465. relationalai/early_access/dsl/ir/compiler.py +0 -318
  466. relationalai/early_access/dsl/ir/executor.py +0 -260
  467. relationalai/early_access/dsl/ontologies/constraints.py +0 -88
  468. relationalai/early_access/dsl/ontologies/export.py +0 -30
  469. relationalai/early_access/dsl/ontologies/models.py +0 -453
  470. relationalai/early_access/dsl/ontologies/python_printer.py +0 -303
  471. relationalai/early_access/dsl/ontologies/readings.py +0 -60
  472. relationalai/early_access/dsl/ontologies/relationships.py +0 -322
  473. relationalai/early_access/dsl/ontologies/roles.py +0 -87
  474. relationalai/early_access/dsl/ontologies/subtyping.py +0 -55
  475. relationalai/early_access/dsl/orm/constraints.py +0 -438
  476. relationalai/early_access/dsl/orm/measures/dimensions.py +0 -200
  477. relationalai/early_access/dsl/orm/measures/initializer.py +0 -16
  478. relationalai/early_access/dsl/orm/measures/measure_rules.py +0 -275
  479. relationalai/early_access/dsl/orm/measures/measures.py +0 -299
  480. relationalai/early_access/dsl/orm/measures/role_exprs.py +0 -268
  481. relationalai/early_access/dsl/orm/models.py +0 -256
  482. relationalai/early_access/dsl/orm/object_oriented_printer.py +0 -344
  483. relationalai/early_access/dsl/orm/printer.py +0 -469
  484. relationalai/early_access/dsl/orm/reasoners.py +0 -480
  485. relationalai/early_access/dsl/orm/relations.py +0 -19
  486. relationalai/early_access/dsl/orm/relationships.py +0 -251
  487. relationalai/early_access/dsl/orm/types.py +0 -42
  488. relationalai/early_access/dsl/orm/utils.py +0 -79
  489. relationalai/early_access/dsl/orm/verb.py +0 -204
  490. relationalai/early_access/dsl/physical_metadata/tables.py +0 -133
  491. relationalai/early_access/dsl/relations.py +0 -170
  492. relationalai/early_access/dsl/rulesets.py +0 -69
  493. relationalai/early_access/dsl/schemas/__init__.py +0 -450
  494. relationalai/early_access/dsl/schemas/builder.py +0 -48
  495. relationalai/early_access/dsl/schemas/comp_names.py +0 -51
  496. relationalai/early_access/dsl/schemas/components.py +0 -203
  497. relationalai/early_access/dsl/schemas/contexts.py +0 -156
  498. relationalai/early_access/dsl/schemas/exprs.py +0 -89
  499. relationalai/early_access/dsl/schemas/fragments.py +0 -464
  500. relationalai/early_access/dsl/serialization.py +0 -79
  501. relationalai/early_access/dsl/serialize/exporter.py +0 -163
  502. relationalai/early_access/dsl/snow/api.py +0 -104
  503. relationalai/early_access/dsl/snow/common.py +0 -76
  504. relationalai/early_access/dsl/state_mgmt/__init__.py +0 -129
  505. relationalai/early_access/dsl/state_mgmt/state_charts.py +0 -125
  506. relationalai/early_access/dsl/state_mgmt/transitions.py +0 -130
  507. relationalai/early_access/dsl/types/__init__.py +0 -40
  508. relationalai/early_access/dsl/types/concepts.py +0 -12
  509. relationalai/early_access/dsl/types/entities.py +0 -135
  510. relationalai/early_access/dsl/types/values.py +0 -17
  511. relationalai/early_access/dsl/utils.py +0 -102
  512. relationalai/early_access/graphs/__init__.py +0 -13
  513. relationalai/early_access/lqp/__init__.py +0 -12
  514. relationalai/early_access/lqp/compiler/__init__.py +0 -12
  515. relationalai/early_access/lqp/constructors/__init__.py +0 -18
  516. relationalai/early_access/lqp/executor/__init__.py +0 -12
  517. relationalai/early_access/lqp/ir/__init__.py +0 -12
  518. relationalai/early_access/lqp/passes/__init__.py +0 -12
  519. relationalai/early_access/lqp/pragmas/__init__.py +0 -12
  520. relationalai/early_access/lqp/primitives/__init__.py +0 -12
  521. relationalai/early_access/lqp/types/__init__.py +0 -12
  522. relationalai/early_access/lqp/utils/__init__.py +0 -12
  523. relationalai/early_access/lqp/validators/__init__.py +0 -12
  524. relationalai/early_access/metamodel/__init__.py +0 -58
  525. relationalai/early_access/metamodel/builtins/__init__.py +0 -12
  526. relationalai/early_access/metamodel/compiler/__init__.py +0 -12
  527. relationalai/early_access/metamodel/dependency/__init__.py +0 -12
  528. relationalai/early_access/metamodel/factory/__init__.py +0 -17
  529. relationalai/early_access/metamodel/helpers/__init__.py +0 -12
  530. relationalai/early_access/metamodel/ir/__init__.py +0 -14
  531. relationalai/early_access/metamodel/rewrite/__init__.py +0 -7
  532. relationalai/early_access/metamodel/typer/__init__.py +0 -3
  533. relationalai/early_access/metamodel/typer/typer/__init__.py +0 -12
  534. relationalai/early_access/metamodel/types/__init__.py +0 -15
  535. relationalai/early_access/metamodel/util/__init__.py +0 -15
  536. relationalai/early_access/metamodel/visitor/__init__.py +0 -12
  537. relationalai/early_access/rel/__init__.py +0 -12
  538. relationalai/early_access/rel/executor/__init__.py +0 -12
  539. relationalai/early_access/rel/rel_utils/__init__.py +0 -12
  540. relationalai/early_access/rel/rewrite/__init__.py +0 -7
  541. relationalai/early_access/solvers/__init__.py +0 -19
  542. relationalai/early_access/sql/__init__.py +0 -11
  543. relationalai/early_access/sql/executor/__init__.py +0 -3
  544. relationalai/early_access/sql/rewrite/__init__.py +0 -3
  545. relationalai/early_access/tests/logging/__init__.py +0 -12
  546. relationalai/early_access/tests/test_snapshot_base/__init__.py +0 -12
  547. relationalai/early_access/tests/utils/__init__.py +0 -12
  548. relationalai/environments/__init__.py +0 -35
  549. relationalai/environments/base.py +0 -381
  550. relationalai/environments/colab.py +0 -14
  551. relationalai/environments/generic.py +0 -71
  552. relationalai/environments/ipython.py +0 -68
  553. relationalai/environments/jupyter.py +0 -9
  554. relationalai/environments/snowbook.py +0 -169
  555. relationalai/errors.py +0 -2455
  556. relationalai/experimental/SF.py +0 -38
  557. relationalai/experimental/inspect.py +0 -47
  558. relationalai/experimental/pathfinder/__init__.py +0 -158
  559. relationalai/experimental/pathfinder/api.py +0 -160
  560. relationalai/experimental/pathfinder/automaton.py +0 -584
  561. relationalai/experimental/pathfinder/bridge.py +0 -226
  562. relationalai/experimental/pathfinder/compiler.py +0 -416
  563. relationalai/experimental/pathfinder/datalog.py +0 -214
  564. relationalai/experimental/pathfinder/diagnostics.py +0 -56
  565. relationalai/experimental/pathfinder/filter.py +0 -236
  566. relationalai/experimental/pathfinder/glushkov.py +0 -439
  567. relationalai/experimental/pathfinder/options.py +0 -265
  568. relationalai/experimental/pathfinder/pathfinder-v0.7.0.rel +0 -1951
  569. relationalai/experimental/pathfinder/rpq.py +0 -344
  570. relationalai/experimental/pathfinder/transition.py +0 -200
  571. relationalai/experimental/pathfinder/utils.py +0 -26
  572. relationalai/experimental/paths/README.md +0 -107
  573. relationalai/experimental/paths/api.py +0 -143
  574. relationalai/experimental/paths/benchmarks/grid_graph.py +0 -37
  575. relationalai/experimental/paths/code_organization.md +0 -2
  576. relationalai/experimental/paths/examples/Movies.ipynb +0 -16328
  577. relationalai/experimental/paths/examples/basic_example.py +0 -40
  578. relationalai/experimental/paths/examples/minimal_engine_warmup.py +0 -3
  579. relationalai/experimental/paths/examples/movie_example.py +0 -77
  580. relationalai/experimental/paths/examples/movies_data/actedin.csv +0 -193
  581. relationalai/experimental/paths/examples/movies_data/directed.csv +0 -45
  582. relationalai/experimental/paths/examples/movies_data/follows.csv +0 -7
  583. relationalai/experimental/paths/examples/movies_data/movies.csv +0 -39
  584. relationalai/experimental/paths/examples/movies_data/person.csv +0 -134
  585. relationalai/experimental/paths/examples/movies_data/produced.csv +0 -16
  586. relationalai/experimental/paths/examples/movies_data/ratings.csv +0 -10
  587. relationalai/experimental/paths/examples/movies_data/wrote.csv +0 -11
  588. relationalai/experimental/paths/examples/paths_benchmark.py +0 -115
  589. relationalai/experimental/paths/examples/paths_example.py +0 -116
  590. relationalai/experimental/paths/examples/pattern_to_automaton.py +0 -28
  591. relationalai/experimental/paths/find_paths_via_automaton.py +0 -85
  592. relationalai/experimental/paths/graph.py +0 -185
  593. relationalai/experimental/paths/path_algorithms/find_paths.py +0 -280
  594. relationalai/experimental/paths/path_algorithms/one_sided_ball_repetition.py +0 -26
  595. relationalai/experimental/paths/path_algorithms/one_sided_ball_upto.py +0 -111
  596. relationalai/experimental/paths/path_algorithms/single.py +0 -59
  597. relationalai/experimental/paths/path_algorithms/two_sided_balls_repetition.py +0 -39
  598. relationalai/experimental/paths/path_algorithms/two_sided_balls_upto.py +0 -103
  599. relationalai/experimental/paths/path_algorithms/usp-old.py +0 -130
  600. relationalai/experimental/paths/path_algorithms/usp-tuple.py +0 -183
  601. relationalai/experimental/paths/path_algorithms/usp.py +0 -150
  602. relationalai/experimental/paths/product_graph.py +0 -93
  603. relationalai/experimental/paths/rpq/automaton.py +0 -584
  604. relationalai/experimental/paths/rpq/diagnostics.py +0 -56
  605. relationalai/experimental/paths/rpq/rpq.py +0 -378
  606. relationalai/experimental/paths/tests/tests_limit_sp_max_length.py +0 -90
  607. relationalai/experimental/paths/tests/tests_limit_sp_multiple.py +0 -119
  608. relationalai/experimental/paths/tests/tests_limit_sp_single.py +0 -104
  609. relationalai/experimental/paths/tests/tests_limit_walks_multiple.py +0 -113
  610. relationalai/experimental/paths/tests/tests_limit_walks_single.py +0 -149
  611. relationalai/experimental/paths/tests/tests_one_sided_ball_repetition_multiple.py +0 -70
  612. relationalai/experimental/paths/tests/tests_one_sided_ball_repetition_single.py +0 -64
  613. relationalai/experimental/paths/tests/tests_one_sided_ball_upto_multiple.py +0 -115
  614. relationalai/experimental/paths/tests/tests_one_sided_ball_upto_single.py +0 -75
  615. relationalai/experimental/paths/tests/tests_single_paths.py +0 -152
  616. relationalai/experimental/paths/tests/tests_single_walks.py +0 -208
  617. relationalai/experimental/paths/tests/tests_single_walks_undirected.py +0 -297
  618. relationalai/experimental/paths/tests/tests_two_sided_balls_repetition_multiple.py +0 -107
  619. relationalai/experimental/paths/tests/tests_two_sided_balls_repetition_single.py +0 -76
  620. relationalai/experimental/paths/tests/tests_two_sided_balls_upto_multiple.py +0 -76
  621. relationalai/experimental/paths/tests/tests_two_sided_balls_upto_single.py +0 -110
  622. relationalai/experimental/paths/tests/tests_usp_nsp_multiple.py +0 -229
  623. relationalai/experimental/paths/tests/tests_usp_nsp_single.py +0 -108
  624. relationalai/experimental/paths/tree_agg.py +0 -168
  625. relationalai/experimental/paths/utilities/iterators.py +0 -27
  626. relationalai/experimental/paths/utilities/prefix_sum.py +0 -91
  627. relationalai/experimental/solvers.py +0 -1087
  628. relationalai/loaders/csv.py +0 -195
  629. relationalai/loaders/loader.py +0 -177
  630. relationalai/loaders/types.py +0 -23
  631. relationalai/rel_emitter.py +0 -373
  632. relationalai/rel_utils.py +0 -185
  633. relationalai/semantics/designs/query_builder/identify_by.md +0 -106
  634. relationalai/semantics/devtools/benchmark_lqp.py +0 -536
  635. relationalai/semantics/devtools/compilation_manager.py +0 -294
  636. relationalai/semantics/devtools/extract_lqp.py +0 -110
  637. relationalai/semantics/internal/internal.py +0 -3785
  638. relationalai/semantics/internal/snowflake.py +0 -324
  639. relationalai/semantics/lqp/README.md +0 -34
  640. relationalai/semantics/lqp/builtins.py +0 -16
  641. relationalai/semantics/lqp/compiler.py +0 -22
  642. relationalai/semantics/lqp/constructors.py +0 -68
  643. relationalai/semantics/lqp/executor.py +0 -469
  644. relationalai/semantics/lqp/intrinsics.py +0 -24
  645. relationalai/semantics/lqp/model2lqp.py +0 -839
  646. relationalai/semantics/lqp/passes.py +0 -680
  647. relationalai/semantics/lqp/primitives.py +0 -252
  648. relationalai/semantics/lqp/result_helpers.py +0 -202
  649. relationalai/semantics/lqp/rewrite/annotate_constraints.py +0 -57
  650. relationalai/semantics/lqp/rewrite/cdc.py +0 -216
  651. relationalai/semantics/lqp/rewrite/extract_common.py +0 -338
  652. relationalai/semantics/lqp/rewrite/extract_keys.py +0 -449
  653. relationalai/semantics/lqp/rewrite/function_annotations.py +0 -114
  654. relationalai/semantics/lqp/rewrite/functional_dependencies.py +0 -314
  655. relationalai/semantics/lqp/rewrite/quantify_vars.py +0 -296
  656. relationalai/semantics/lqp/rewrite/splinter.py +0 -76
  657. relationalai/semantics/lqp/types.py +0 -101
  658. relationalai/semantics/lqp/utils.py +0 -160
  659. relationalai/semantics/lqp/validators.py +0 -57
  660. relationalai/semantics/metamodel/compiler.py +0 -133
  661. relationalai/semantics/metamodel/dependency.py +0 -862
  662. relationalai/semantics/metamodel/executor.py +0 -61
  663. relationalai/semantics/metamodel/factory.py +0 -287
  664. relationalai/semantics/metamodel/helpers.py +0 -361
  665. relationalai/semantics/metamodel/rewrite/discharge_constraints.py +0 -39
  666. relationalai/semantics/metamodel/rewrite/dnf_union_splitter.py +0 -210
  667. relationalai/semantics/metamodel/rewrite/extract_nested_logicals.py +0 -78
  668. relationalai/semantics/metamodel/rewrite/flatten.py +0 -549
  669. relationalai/semantics/metamodel/rewrite/format_outputs.py +0 -165
  670. relationalai/semantics/metamodel/typer/checker.py +0 -353
  671. relationalai/semantics/metamodel/typer/typer.py +0 -1395
  672. relationalai/semantics/reasoners/__init__.py +0 -10
  673. relationalai/semantics/reasoners/graph/README.md +0 -620
  674. relationalai/semantics/reasoners/graph/__init__.py +0 -37
  675. relationalai/semantics/reasoners/graph/core.py +0 -9020
  676. relationalai/semantics/reasoners/graph/design/beyond_demand_transform.md +0 -797
  677. relationalai/semantics/reasoners/graph/tests/README.md +0 -21
  678. relationalai/semantics/reasoners/optimization/__init__.py +0 -68
  679. relationalai/semantics/reasoners/optimization/common.py +0 -88
  680. relationalai/semantics/reasoners/optimization/solvers_dev.py +0 -568
  681. relationalai/semantics/reasoners/optimization/solvers_pb.py +0 -1163
  682. relationalai/semantics/rel/builtins.py +0 -40
  683. relationalai/semantics/rel/compiler.py +0 -989
  684. relationalai/semantics/rel/executor.py +0 -359
  685. relationalai/semantics/rel/rel.py +0 -482
  686. relationalai/semantics/rel/rel_utils.py +0 -276
  687. relationalai/semantics/snowflake/__init__.py +0 -3
  688. relationalai/semantics/sql/compiler.py +0 -2503
  689. relationalai/semantics/sql/executor/duck_db.py +0 -52
  690. relationalai/semantics/sql/executor/result_helpers.py +0 -64
  691. relationalai/semantics/sql/executor/snowflake.py +0 -145
  692. relationalai/semantics/sql/rewrite/denormalize.py +0 -222
  693. relationalai/semantics/sql/rewrite/double_negation.py +0 -49
  694. relationalai/semantics/sql/rewrite/recursive_union.py +0 -127
  695. relationalai/semantics/sql/rewrite/sort_output_query.py +0 -246
  696. relationalai/semantics/sql/sql.py +0 -504
  697. relationalai/semantics/std/pragmas.py +0 -11
  698. relationalai/semantics/std/std.py +0 -14
  699. relationalai/semantics/tests/test_snapshot_abstract.py +0 -143
  700. relationalai/semantics/tests/test_snapshot_base.py +0 -9
  701. relationalai/semantics/tests/utils.py +0 -46
  702. relationalai/std/__init__.py +0 -70
  703. relationalai/tools/cli.py +0 -1940
  704. relationalai/tools/cli_controls.py +0 -1826
  705. relationalai/tools/cli_helpers.py +0 -390
  706. relationalai/tools/debugger_client.py +0 -109
  707. relationalai/tools/debugger_server.py +0 -302
  708. relationalai/tools/dev.py +0 -685
  709. relationalai/tools/notes +0 -7
  710. relationalai/tools/qb_debugger.py +0 -425
  711. relationalai/util/clean_up_databases.py +0 -95
  712. relationalai/util/list_databases.py +0 -9
  713. relationalai/util/otel_configuration.py +0 -25
  714. relationalai/util/otel_handler.py +0 -484
  715. relationalai/util/snowflake_handler.py +0 -88
  716. relationalai/util/span_format_test.py +0 -43
  717. relationalai/util/span_tracker.py +0 -207
  718. relationalai/util/spans_file_handler.py +0 -72
  719. relationalai/util/tracing_handler.py +0 -34
  720. relationalai-0.12.13.dist-info/METADATA +0 -74
  721. relationalai-0.12.13.dist-info/RECORD +0 -449
  722. relationalai-0.12.13.dist-info/WHEEL +0 -4
  723. relationalai-0.12.13.dist-info/entry_points.txt +0 -3
  724. relationalai-0.12.13.dist-info/licenses/LICENSE +0 -202
  725. relationalai_test_util/__init__.py +0 -4
  726. relationalai_test_util/fixtures.py +0 -228
  727. relationalai_test_util/snapshot.py +0 -252
  728. relationalai_test_util/traceback.py +0 -118
  729. /relationalai/{analysis → semantics/frontend}/__init__.py +0 -0
  730. /relationalai/{auth/__init__.py → semantics/metamodel/metamodel_compiler.py} +0 -0
  731. /relationalai/{early_access → shims}/__init__.py +0 -0
  732. {relationalai/early_access/dsl/adapters → v0/relationalai/analysis}/__init__.py +0 -0
  733. {relationalai → v0/relationalai}/analysis/mechanistic.py +0 -0
  734. {relationalai → v0/relationalai}/analysis/whynot.py +0 -0
  735. {relationalai/early_access/dsl/adapters/orm → v0/relationalai/auth}/__init__.py +0 -0
  736. {relationalai → v0/relationalai}/auth/jwt_generator.py +0 -0
  737. {relationalai → v0/relationalai}/auth/oauth_callback_server.py +0 -0
  738. {relationalai → v0/relationalai}/auth/token_handler.py +0 -0
  739. {relationalai → v0/relationalai}/auth/util.py +0 -0
  740. {relationalai → v0/relationalai}/clients/__init__.py +0 -0
  741. {relationalai → v0/relationalai}/clients/cache_store.py +0 -0
  742. {relationalai → v0/relationalai}/compiler.py +0 -0
  743. {relationalai → v0/relationalai}/dependencies.py +0 -0
  744. {relationalai → v0/relationalai}/docutils.py +0 -0
  745. {relationalai/early_access/dsl/adapters/owl → v0/relationalai/early_access}/__init__.py +0 -0
  746. {relationalai → v0/relationalai}/early_access/dsl/__init__.py +0 -0
  747. {relationalai/early_access/dsl/bindings → v0/relationalai/early_access/dsl/adapters}/__init__.py +0 -0
  748. {relationalai/early_access/dsl/bindings/legacy → v0/relationalai/early_access/dsl/adapters/orm}/__init__.py +0 -0
  749. {relationalai → v0/relationalai}/early_access/dsl/adapters/orm/model.py +0 -0
  750. {relationalai/early_access/dsl/codegen → v0/relationalai/early_access/dsl/adapters/owl}/__init__.py +0 -0
  751. {relationalai → v0/relationalai}/early_access/dsl/adapters/owl/model.py +0 -0
  752. {relationalai/early_access/dsl/core/temporal → v0/relationalai/early_access/dsl/bindings}/__init__.py +0 -0
  753. {relationalai/early_access/dsl/ir → v0/relationalai/early_access/dsl/bindings/legacy}/__init__.py +0 -0
  754. {relationalai/early_access/dsl/ontologies → v0/relationalai/early_access/dsl/codegen}/__init__.py +0 -0
  755. {relationalai → v0/relationalai}/early_access/dsl/constants.py +0 -0
  756. {relationalai → v0/relationalai}/early_access/dsl/core/__init__.py +0 -0
  757. {relationalai → v0/relationalai}/early_access/dsl/core/constraints/__init__.py +0 -0
  758. {relationalai → v0/relationalai}/early_access/dsl/core/constraints/predicate/__init__.py +0 -0
  759. {relationalai → v0/relationalai}/early_access/dsl/core/stack.py +0 -0
  760. {relationalai/early_access/dsl/orm → v0/relationalai/early_access/dsl/core/temporal}/__init__.py +0 -0
  761. {relationalai → v0/relationalai}/early_access/dsl/core/utils.py +0 -0
  762. {relationalai/early_access/dsl/orm/measures → v0/relationalai/early_access/dsl/ir}/__init__.py +0 -0
  763. {relationalai/early_access/dsl/physical_metadata → v0/relationalai/early_access/dsl/ontologies}/__init__.py +0 -0
  764. {relationalai → v0/relationalai}/early_access/dsl/ontologies/raw_source.py +0 -0
  765. {relationalai/early_access/dsl/serialize → v0/relationalai/early_access/dsl/orm}/__init__.py +0 -0
  766. {relationalai/early_access/dsl/snow → v0/relationalai/early_access/dsl/orm/measures}/__init__.py +0 -0
  767. {relationalai → v0/relationalai}/early_access/dsl/orm/reasoner_errors.py +0 -0
  768. {relationalai/loaders → v0/relationalai/early_access/dsl/physical_metadata}/__init__.py +0 -0
  769. {relationalai/semantics/tests → v0/relationalai/early_access/dsl/serialize}/__init__.py +0 -0
  770. {relationalai → v0/relationalai}/early_access/dsl/serialize/binding_model.py +0 -0
  771. {relationalai → v0/relationalai}/early_access/dsl/serialize/model.py +0 -0
  772. {relationalai/tools → v0/relationalai/early_access/dsl/snow}/__init__.py +0 -0
  773. {relationalai → v0/relationalai}/early_access/tests/__init__.py +0 -0
  774. {relationalai → v0/relationalai}/environments/ci.py +0 -0
  775. {relationalai → v0/relationalai}/environments/hex.py +0 -0
  776. {relationalai → v0/relationalai}/environments/terminal.py +0 -0
  777. {relationalai → v0/relationalai}/experimental/__init__.py +0 -0
  778. {relationalai → v0/relationalai}/experimental/graphs.py +0 -0
  779. {relationalai → v0/relationalai}/experimental/paths/__init__.py +0 -0
  780. {relationalai → v0/relationalai}/experimental/paths/benchmarks/__init__.py +0 -0
  781. {relationalai → v0/relationalai}/experimental/paths/path_algorithms/__init__.py +0 -0
  782. {relationalai → v0/relationalai}/experimental/paths/rpq/__init__.py +0 -0
  783. {relationalai → v0/relationalai}/experimental/paths/rpq/filter.py +0 -0
  784. {relationalai → v0/relationalai}/experimental/paths/rpq/glushkov.py +0 -0
  785. {relationalai → v0/relationalai}/experimental/paths/rpq/transition.py +0 -0
  786. {relationalai → v0/relationalai}/experimental/paths/utilities/__init__.py +0 -0
  787. {relationalai → v0/relationalai}/experimental/paths/utilities/utilities.py +0 -0
  788. {relationalai → v0/relationalai}/metagen.py +0 -0
  789. {relationalai → v0/relationalai}/metamodel.py +0 -0
  790. {relationalai → v0/relationalai}/rel.py +0 -0
  791. {relationalai → v0/relationalai}/semantics/devtools/__init__.py +0 -0
  792. {relationalai → v0/relationalai}/semantics/internal/__init__.py +0 -0
  793. {relationalai → v0/relationalai}/semantics/internal/annotations.py +0 -0
  794. {relationalai → v0/relationalai}/semantics/lqp/__init__.py +0 -0
  795. {relationalai → v0/relationalai}/semantics/lqp/ir.py +0 -0
  796. {relationalai → v0/relationalai}/semantics/lqp/pragmas.py +0 -0
  797. {relationalai → v0/relationalai}/semantics/lqp/rewrite/__init__.py +0 -0
  798. {relationalai → v0/relationalai}/semantics/metamodel/dataflow.py +0 -0
  799. {relationalai → v0/relationalai}/semantics/metamodel/ir.py +0 -0
  800. {relationalai → v0/relationalai}/semantics/metamodel/rewrite/__init__.py +0 -0
  801. {relationalai → v0/relationalai}/semantics/metamodel/typer/__init__.py +0 -0
  802. {relationalai → v0/relationalai}/semantics/metamodel/types.py +0 -0
  803. {relationalai → v0/relationalai}/semantics/metamodel/util.py +0 -0
  804. {relationalai → v0/relationalai}/semantics/metamodel/visitor.py +0 -0
  805. {relationalai → v0/relationalai}/semantics/reasoners/experimental/__init__.py +0 -0
  806. {relationalai → v0/relationalai}/semantics/rel/__init__.py +0 -0
  807. {relationalai → v0/relationalai}/semantics/sql/__init__.py +0 -0
  808. {relationalai → v0/relationalai}/semantics/sql/executor/__init__.py +0 -0
  809. {relationalai → v0/relationalai}/semantics/sql/rewrite/__init__.py +0 -0
  810. {relationalai → v0/relationalai}/semantics/tests/logging.py +0 -0
  811. {relationalai → v0/relationalai}/std/aggregates.py +0 -0
  812. {relationalai → v0/relationalai}/std/dates.py +0 -0
  813. {relationalai → v0/relationalai}/std/graphs.py +0 -0
  814. {relationalai → v0/relationalai}/std/inspect.py +0 -0
  815. {relationalai → v0/relationalai}/std/math.py +0 -0
  816. {relationalai → v0/relationalai}/std/re.py +0 -0
  817. {relationalai → v0/relationalai}/std/strings.py +0 -0
  818. {relationalai → v0/relationalai}/tools/cleanup_snapshots.py +0 -0
  819. {relationalai → v0/relationalai}/tools/constants.py +0 -0
  820. {relationalai → v0/relationalai}/tools/query_utils.py +0 -0
  821. {relationalai → v0/relationalai}/tools/snapshot_viewer.py +0 -0
  822. {relationalai → v0/relationalai}/util/__init__.py +0 -0
  823. {relationalai → v0/relationalai}/util/constants.py +0 -0
  824. {relationalai → v0/relationalai}/util/graph.py +0 -0
  825. {relationalai → v0/relationalai}/util/timeout.py +0 -0
@@ -1,9 +0,0 @@
1
- @import"https://fonts.googleapis.com/css2?family=Fira+Code:wght@300..700&family=Inter:wght@100..900&display=swap";code[class*=language-],pre[class*=language-]{color:#000;background:none;text-shadow:0 1px white;font-family:Consolas,Monaco,Andale Mono,Ubuntu Mono,monospace;font-size:1em;text-align:left;white-space:pre;word-spacing:normal;word-break:normal;word-wrap:normal;line-height:1.5;-moz-tab-size:4;-o-tab-size:4;tab-size:4;-webkit-hyphens:none;-moz-hyphens:none;-ms-hyphens:none;hyphens:none}pre[class*=language-]::-moz-selection,pre[class*=language-] ::-moz-selection,code[class*=language-]::-moz-selection,code[class*=language-] ::-moz-selection{text-shadow:none;background:#b3d4fc}pre[class*=language-]::selection,pre[class*=language-] ::selection,code[class*=language-]::selection,code[class*=language-] ::selection{text-shadow:none;background:#b3d4fc}@media print{code[class*=language-],pre[class*=language-]{text-shadow:none}}pre[class*=language-]{padding:1em;margin:.5em 0;overflow:auto}:not(pre)>code[class*=language-],pre[class*=language-]{background:#f5f2f0}.token.comment,.token.prolog,.token.doctype,.token.cdata{color:#708090}.token.punctuation{color:#999}.token.property,.token.tag,.token.boolean,.token.number,.token.constant,.token.symbol,.token.deleted{color:#905}.token.selector,.token.attr-name,.token.string,.token.char,.token.builtin,.token.inserted{color:#690}.token.operator,.token.entity,.token.url,.language-css .token.string,.style .token.string{color:#9a6e3a;background:#ffffff80}.token.atrule,.token.attr-value,.token.keyword{color:#07a}.token.function,.token.class-name{color:#dd4a68}.token.regex,.token.important,.token.variable{color:#e90}pre[class*=language-].line-numbers{position:relative;padding-left:3.8em;counter-reset:linenumber}pre[class*=language-].line-numbers>code{position:relative;white-space:inherit}.line-numbers .line-numbers-rows{position:absolute;pointer-events:none;top:0;font-size:100%;left:-3.8em;width:3em;letter-spacing:-1px;border-right:1px solid #999;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.line-numbers-rows>span{display:block;counter-increment:linenumber}.line-numbers-rows>span:before{content:counter(linenumber);color:#999;display:block;padding-right:.8em;text-align:right}pre[data-line]{position:relative;padding:1em 0 1em 3em}.line-highlight{position:absolute;left:0;right:0;padding:inherit 0;margin-top:1em;background:#997a6614;background:linear-gradient(to right,#997a661a 70%,#997a6600);pointer-events:none;line-height:inherit;white-space:pre}@media print{.line-highlight{-webkit-print-color-adjust:exact;color-adjust:exact}}.line-highlight:before,.line-highlight[data-end]:after{content:attr(data-start);position:absolute;top:.4em;left:.6em;min-width:1em;padding:0 .5em;background-color:#997a6666;color:#f5f2f0;font:700 65%/1.5 sans-serif;text-align:center;vertical-align:.3em;border-radius:999px;text-shadow:none;box-shadow:0 1px #fff}.line-highlight[data-end]:after{content:attr(data-end);top:auto;bottom:.4em}.line-numbers .line-highlight:before,.line-numbers .line-highlight:after{content:none}pre[id].linkable-line-numbers span.line-numbers-rows{pointer-events:all}pre[id].linkable-line-numbers span.line-numbers-rows>span:before{cursor:pointer}pre[id].linkable-line-numbers span.line-numbers-rows>span:hover:before{background-color:#80808033}div.code-toolbar{position:relative}div.code-toolbar>.toolbar{position:absolute;z-index:10;top:.3em;right:.2em;transition:opacity .3s ease-in-out;opacity:0}div.code-toolbar:hover>.toolbar{opacity:1}div.code-toolbar:focus-within>.toolbar{opacity:1}div.code-toolbar>.toolbar>.toolbar-item{display:inline-block}div.code-toolbar>.toolbar>.toolbar-item>a{cursor:pointer}div.code-toolbar>.toolbar>.toolbar-item>button{background:none;border:0;color:inherit;font:inherit;line-height:normal;overflow:visible;padding:0;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}div.code-toolbar>.toolbar>.toolbar-item>a,div.code-toolbar>.toolbar>.toolbar-item>button,div.code-toolbar>.toolbar>.toolbar-item>span{color:#bbb;font-size:.8em;padding:0 .5em;background:#f5f2f0;background:#e0e0e033;box-shadow:0 2px #0003;border-radius:.5em}div.code-toolbar>.toolbar>.toolbar-item>a:hover,div.code-toolbar>.toolbar>.toolbar-item>a:focus,div.code-toolbar>.toolbar>.toolbar-item>button:hover,div.code-toolbar>.toolbar>.toolbar-item>button:focus,div.code-toolbar>.toolbar>.toolbar-item>span:hover,div.code-toolbar>.toolbar>.toolbar-item>span:focus{color:inherit;text-decoration:none}code[class*=language-],pre[class*=language-]{color:#f8f8f2;background:none;text-shadow:0 1px rgba(0,0,0,.3);font-family:Consolas,Monaco,Andale Mono,Ubuntu Mono,monospace;font-size:1em;text-align:left;white-space:pre;word-spacing:normal;word-break:normal;word-wrap:normal;line-height:1.5;-moz-tab-size:4;-o-tab-size:4;tab-size:4;-webkit-hyphens:none;-moz-hyphens:none;-ms-hyphens:none;hyphens:none}pre[class*=language-]{padding:1em;margin:.5em 0;overflow:auto;border-radius:.3em}:not(pre)>code[class*=language-],pre[class*=language-]{background:#272822}:not(pre)>code[class*=language-]{padding:.1em;border-radius:.3em;white-space:normal}.token.comment,.token.prolog,.token.doctype,.token.cdata{color:#8292a2}.token.punctuation{color:#f8f8f2}.token.namespace{opacity:.7}.token.property,.token.tag,.token.constant,.token.symbol,.token.deleted{color:#f92672}.token.boolean,.token.number{color:#ae81ff}.token.selector,.token.attr-name,.token.string,.token.char,.token.builtin,.token.inserted{color:#a6e22e}.token.operator,.token.entity,.token.url,.language-css .token.string,.style .token.string,.token.variable{color:#f8f8f2}.token.atrule,.token.attr-value,.token.function,.token.class-name{color:#e6db74}.token.keyword{color:#66d9ef}.token.regex,.token.important{color:#fd971f}.token.important,.token.bold{font-weight:700}.token.italic{font-style:italic}.token.entity{cursor:help}:root{--tooltip-bg: var(--card-bg);--tooltip-border: var(--card-border);--tooltip-shadow: var(--card-shadow);--tooltip-anim-open-duration: var(--anim-duration-quick);--tooltip-anim-close-duration: var(--anim-duration-normal)}.ui-tooltip{z-index:50}.ui-tooltip .ui-tooltip-arrow{margin-bottom:-1px}.ui-tooltip .ui-tooltip-arrow svg{fill:var(--tooltip-bg);stroke:var(--tooltip-border);stroke-width:1.8px}.ui-tooltip .ui-tooltip-arrow *{vector-effect:non-scaling-stroke}.ui-tooltip-inner{padding:4px 8px;max-width:380px;font-size:.8em;background:var(--tooltip-bg);border-radius:4px;border:1px solid var(--tooltip-border);box-shadow:1px 4px 11px var(--tooltip-shadow);transform-origin:var(--kb-tooltip-content-transform-origin)}.ui-tooltip[data-expanded]{animation:tooltip_show var(--tooltip-anim-open-duration) ease-out}.ui-tooltip[data-closed]{animation:tooltip_hide var(--tooltip-anim-close-duration) ease-in forwards}.ui-tooltip-trigger.maybe{padding:0;margin:0;line-height:1}@-moz-keyframes tooltip_show{0%{opacity:0;transform:translateY(-6px) scale(.94)}to{opacity:1;transform:translateY(0) scale(1)}}@-webkit-keyframes tooltip_show{0%{opacity:0;transform:translateY(-6px) scale(.94)}to{opacity:1;transform:translateY(0) scale(1)}}@-o-keyframes tooltip_show{0%{opacity:0;transform:translateY(-6px) scale(.94)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes tooltip_show{0%{opacity:0;transform:translateY(-6px) scale(.94)}to{opacity:1;transform:translateY(0) scale(1)}}@-moz-keyframes tooltip_hide{0%{opacity:1;transform:translateY(0) scale(1)}to{opacity:0;transform:translateY(-6px) scale(.94)}}@-webkit-keyframes tooltip_hide{0%{opacity:1;transform:translateY(0) scale(1)}to{opacity:0;transform:translateY(-6px) scale(.94)}}@-o-keyframes tooltip_hide{0%{opacity:1;transform:translateY(0) scale(1)}to{opacity:0;transform:translateY(-6px) scale(.94)}}@keyframes tooltip_hide{0%{opacity:1;transform:translateY(0) scale(1)}to{opacity:0;transform:translateY(-6px) scale(.94)}}.ui-button{display:flex;align-items:center;color:currentcolor;cursor:pointer}.ui-button.icon{appearance:none;padding:0;background:transparent;border:0px solid transparent}:root{--code-block-bg: var(--card-bg);--code-block-border: var(--card-border);--code-block-shadow: var(--card-shadow)}code.ui-code{box-sizing:border-box;font-family:Fira Code,mono;border-radius:4px}code.ui-code .token.operator{background:transparent}pre.ui-code-block{box-sizing:border-box;position:relative;padding:1em 1.5em;background:var(--color-1-xdim);border-radius:8px;box-shadow:0 4px 4px #0004}pre.ui-code-block,pre.ui-code-block code{white-space:pre-wrap;word-wrap:break-word}pre.ui-code-block.dense{padding:4px 6px;font-size:14px;border-radius:4px}pre.ui-code-block.borderless{margin:0;padding:0;background:none;border:none}pre.ui-code-block .code-controls{display:flex;gap:5px;position:absolute;top:6px;right:6px;opacity:0;transition:opacity .1s ease-out .1s}pre.ui-code-block .code-controls .ui-button.ui-button{opacity:.66;transition:opacity .1s ease-out .1s}pre.ui-code-block .code-controls .ui-button.ui-button:hover,pre.ui-code-block:hover .code-controls,pre.ui-code-block.focus .code-controls{opacity:1}:not(pre):not(pre)>code[class*=language-]{background:unset}/*!
2
- * OverlayScrollbars
3
- * Version: 2.10.0
4
- *
5
- * Copyright (c) Rene Haas | KingSora.
6
- * https://github.com/KingSora
7
- *
8
- * Released under the MIT license.
9
- */.os-size-observer,.os-size-observer-listener{scroll-behavior:auto!important;direction:inherit;pointer-events:none;overflow:hidden;visibility:hidden;box-sizing:border-box}.os-size-observer,.os-size-observer-listener,.os-size-observer-listener-item,.os-size-observer-listener-item-final{writing-mode:horizontal-tb;position:absolute;left:0;top:0}.os-size-observer{z-index:-1;contain:strict;display:flex;flex-direction:row;flex-wrap:nowrap;padding:inherit;border:inherit;box-sizing:inherit;margin:-133px;inset:0;transform:scale(.1)}.os-size-observer:before{content:"";flex:none;box-sizing:inherit;padding:10px;width:10px;height:10px}.os-size-observer-appear{animation:os-size-observer-appear-animation 1ms forwards}.os-size-observer-listener{box-sizing:border-box;position:relative;flex:auto;padding:inherit;border:inherit;margin:-133px;transform:scale(10)}.os-size-observer-listener.ltr{margin-right:-266px;margin-left:0}.os-size-observer-listener.rtl{margin-left:-266px;margin-right:0}.os-size-observer-listener:empty:before{content:"";width:100%;height:100%}.os-size-observer-listener:empty:before,.os-size-observer-listener>.os-size-observer-listener-item{display:block;position:relative;padding:inherit;border:inherit;box-sizing:content-box;flex:auto}.os-size-observer-listener-scroll{box-sizing:border-box;display:flex}.os-size-observer-listener-item{right:0;bottom:0;overflow:hidden;direction:ltr;flex:none}.os-size-observer-listener-item-final{transition:none}@keyframes os-size-observer-appear-animation{0%{cursor:auto}to{cursor:none}}.os-trinsic-observer{flex:none;box-sizing:border-box;position:relative;max-width:0px;max-height:1px;padding:0;margin:0;border:none;overflow:hidden;z-index:-1;height:0;top:calc(100% + 1px);contain:strict}.os-trinsic-observer:not(:empty){height:calc(100% + 1px);top:-1px}.os-trinsic-observer:not(:empty)>.os-size-observer{width:1000%;height:1000%;min-height:1px;min-width:1px}[data-overlayscrollbars-initialize],[data-overlayscrollbars-viewport~=scrollbarHidden]{scrollbar-width:none!important}[data-overlayscrollbars-initialize]::-webkit-scrollbar,[data-overlayscrollbars-initialize]::-webkit-scrollbar-corner,[data-overlayscrollbars-viewport~=scrollbarHidden]::-webkit-scrollbar,[data-overlayscrollbars-viewport~=scrollbarHidden]::-webkit-scrollbar-corner{-webkit-appearance:none!important;appearance:none!important;display:none!important;width:0!important;height:0!important}[data-overlayscrollbars-initialize]:not([data-overlayscrollbars]):not(html):not(body){overflow:auto}html[data-overlayscrollbars-body]{overflow:hidden}html[data-overlayscrollbars-body],html[data-overlayscrollbars-body]>body{width:100%;height:100%;margin:0}html[data-overlayscrollbars-body]>body{overflow:visible;margin:0}[data-overlayscrollbars]{position:relative}[data-overlayscrollbars~=host],[data-overlayscrollbars-padding]{display:flex;align-items:stretch!important;flex-direction:row!important;flex-wrap:nowrap!important;scroll-behavior:auto!important}[data-overlayscrollbars-padding],[data-overlayscrollbars-viewport]:not([data-overlayscrollbars]){box-sizing:inherit;position:relative;flex:auto!important;height:auto;width:100%;min-width:0;padding:0;margin:0;border:none;z-index:0}[data-overlayscrollbars-viewport]:not([data-overlayscrollbars]){--os-vaw: 0;--os-vah: 0;outline:none}[data-overlayscrollbars-viewport]:not([data-overlayscrollbars]):focus{outline:none}[data-overlayscrollbars-viewport][data-overlayscrollbars-viewport~=arrange]:before{content:"";position:absolute;pointer-events:none;z-index:-1;min-width:1px;min-height:1px;width:var(--os-vaw);height:var(--os-vah)}[data-overlayscrollbars],[data-overlayscrollbars-padding],[data-overlayscrollbars-viewport]{overflow:hidden!important}[data-overlayscrollbars~=noClipping],[data-overlayscrollbars-padding~=noClipping]{overflow:visible!important}[data-overlayscrollbars-viewport~=measuring]{overflow:hidden!important;scroll-behavior:auto!important;scroll-snap-type:none!important}[data-overlayscrollbars-viewport~=overflowXVisible]:not([data-overlayscrollbars-viewport~=measuring]){overflow-x:visible!important}[data-overlayscrollbars-viewport~=overflowXHidden]{overflow-x:hidden!important}[data-overlayscrollbars-viewport~=overflowXScroll]{overflow-x:scroll!important}[data-overlayscrollbars-viewport~=overflowYVisible]:not([data-overlayscrollbars-viewport~=measuring]){overflow-y:visible!important}[data-overlayscrollbars-viewport~=overflowYHidden]{overflow-y:hidden!important}[data-overlayscrollbars-viewport~=overflowYScroll]{overflow-y:scroll!important}[data-overlayscrollbars-viewport~=noContent]:not(#osFakeId){font-size:0!important;line-height:0!important}[data-overlayscrollbars-viewport~=noContent]:not(#osFakeId):before,[data-overlayscrollbars-viewport~=noContent]:not(#osFakeId):after,[data-overlayscrollbars-viewport~=noContent]:not(#osFakeId)>*{display:none!important;position:absolute!important;width:1px!important;height:1px!important;padding:0!important;margin:-1px!important;overflow:hidden!important;clip:rect(0,0,0,0)!important;white-space:nowrap!important;border-width:0!important}[data-overlayscrollbars-viewport~=scrolling]{scroll-behavior:auto!important;scroll-snap-type:none!important}[data-overlayscrollbars-content]{box-sizing:inherit}[data-overlayscrollbars-contents]:not(#osFakeId):not([data-overlayscrollbars-padding]):not([data-overlayscrollbars-viewport]):not([data-overlayscrollbars-content]){display:contents}[data-overlayscrollbars-grid],[data-overlayscrollbars-grid] [data-overlayscrollbars-padding]{display:grid;grid-template:1fr/1fr}[data-overlayscrollbars-grid]>[data-overlayscrollbars-padding],[data-overlayscrollbars-grid]>[data-overlayscrollbars-viewport],[data-overlayscrollbars-grid]>[data-overlayscrollbars-padding]>[data-overlayscrollbars-viewport]{height:auto!important;width:auto!important}@property --os-scroll-percent{syntax: "<number>"; inherits: true; initial-value: 0;}@property --os-viewport-percent{syntax: "<number>"; inherits: true; initial-value: 0;}.os-scrollbar{--os-viewport-percent: 0;--os-scroll-percent: 0;--os-scroll-direction: 0;--os-scroll-percent-directional: calc( var(--os-scroll-percent) - (var(--os-scroll-percent) + (1 - var(--os-scroll-percent)) * -1) * var(--os-scroll-direction) )}.os-scrollbar{contain:size layout;contain:size layout style;transition:opacity .15s,visibility .15s,top .15s,right .15s,bottom .15s,left .15s;pointer-events:none;position:absolute;opacity:0;visibility:hidden}body>.os-scrollbar{position:fixed;z-index:99999}.os-scrollbar-transitionless{transition:none!important}.os-scrollbar-track{position:relative;padding:0!important;border:none!important}.os-scrollbar-handle{position:absolute}.os-scrollbar-track,.os-scrollbar-handle{pointer-events:none;width:100%;height:100%}.os-scrollbar.os-scrollbar-track-interactive .os-scrollbar-track,.os-scrollbar.os-scrollbar-handle-interactive .os-scrollbar-handle{pointer-events:auto;touch-action:none}.os-scrollbar-horizontal{bottom:0;left:0}.os-scrollbar-vertical{top:0;right:0}.os-scrollbar-rtl.os-scrollbar-horizontal{right:0}.os-scrollbar-rtl.os-scrollbar-vertical{right:auto;left:0}.os-scrollbar-visible{opacity:1;visibility:visible}.os-scrollbar-auto-hide.os-scrollbar-auto-hide-hidden{opacity:0;visibility:hidden}.os-scrollbar-interaction.os-scrollbar-visible{opacity:1;visibility:visible}.os-scrollbar-unusable,.os-scrollbar-unusable *,.os-scrollbar-wheel,.os-scrollbar-wheel *{pointer-events:none!important}.os-scrollbar-unusable .os-scrollbar-handle{opacity:0!important;transition:none!important}.os-scrollbar-horizontal .os-scrollbar-handle{bottom:0;left:calc(var(--os-scroll-percent-directional) * 100%);transform:translate(calc(var(--os-scroll-percent-directional) * -100%));width:calc(var(--os-viewport-percent) * 100%)}.os-scrollbar-vertical .os-scrollbar-handle{right:0;top:calc(var(--os-scroll-percent-directional) * 100%);transform:translateY(calc(var(--os-scroll-percent-directional) * -100%));height:calc(var(--os-viewport-percent) * 100%)}@supports (container-type: size){.os-scrollbar-track{container-type:size}.os-scrollbar-horizontal .os-scrollbar-handle{left:auto;transform:translate(calc(var(--os-scroll-percent-directional) * 100cqw + var(--os-scroll-percent-directional) * -100%))}.os-scrollbar-vertical .os-scrollbar-handle{top:auto;transform:translateY(calc(var(--os-scroll-percent-directional) * 100cqh + var(--os-scroll-percent-directional) * -100%))}.os-scrollbar-rtl.os-scrollbar-horizontal .os-scrollbar-handle{right:auto;left:0}}.os-scrollbar-rtl.os-scrollbar-vertical .os-scrollbar-handle{right:auto;left:0}.os-scrollbar.os-scrollbar-horizontal.os-scrollbar-cornerless,.os-scrollbar.os-scrollbar-horizontal.os-scrollbar-cornerless.os-scrollbar-rtl{left:0;right:0}.os-scrollbar.os-scrollbar-vertical.os-scrollbar-cornerless,.os-scrollbar.os-scrollbar-vertical.os-scrollbar-cornerless.os-scrollbar-rtl{top:0;bottom:0}@media print{.os-scrollbar{display:none}}.os-scrollbar{--os-size: 0;--os-padding-perpendicular: 0;--os-padding-axis: 0;--os-track-border-radius: 0;--os-track-bg: none;--os-track-bg-hover: none;--os-track-bg-active: none;--os-track-border: none;--os-track-border-hover: none;--os-track-border-active: none;--os-handle-border-radius: 0;--os-handle-bg: none;--os-handle-bg-hover: none;--os-handle-bg-active: none;--os-handle-border: none;--os-handle-border-hover: none;--os-handle-border-active: none;--os-handle-min-size: 33px;--os-handle-max-size: none;--os-handle-perpendicular-size: 100%;--os-handle-perpendicular-size-hover: 100%;--os-handle-perpendicular-size-active: 100%;--os-handle-interactive-area-offset: 0}.os-scrollbar-track{border:var(--os-track-border);border-radius:var(--os-track-border-radius);background:var(--os-track-bg);transition:opacity .15s,background-color .15s,border-color .15s}.os-scrollbar-track:hover{border:var(--os-track-border-hover);background:var(--os-track-bg-hover)}.os-scrollbar-track:active{border:var(--os-track-border-active);background:var(--os-track-bg-active)}.os-scrollbar-handle{border:var(--os-handle-border);border-radius:var(--os-handle-border-radius);background:var(--os-handle-bg)}.os-scrollbar-handle:hover{border:var(--os-handle-border-hover);background:var(--os-handle-bg-hover)}.os-scrollbar-handle:active{border:var(--os-handle-border-active);background:var(--os-handle-bg-active)}.os-scrollbar-track:before,.os-scrollbar-handle:before{content:"";position:absolute;inset:0;display:block}.os-scrollbar-horizontal{padding:var(--os-padding-perpendicular) var(--os-padding-axis);right:var(--os-size);height:var(--os-size)}.os-scrollbar-horizontal.os-scrollbar-rtl{left:var(--os-size);right:0}.os-scrollbar-horizontal .os-scrollbar-track:before{top:calc(var(--os-padding-perpendicular) * -1);bottom:calc(var(--os-padding-perpendicular) * -1)}.os-scrollbar-horizontal .os-scrollbar-handle{min-width:var(--os-handle-min-size);max-width:var(--os-handle-max-size);height:var(--os-handle-perpendicular-size);transition:opacity .15s,background-color .15s,border-color .15s,height .15s}.os-scrollbar-horizontal .os-scrollbar-handle:before{top:calc((var(--os-padding-perpendicular) + var(--os-handle-interactive-area-offset)) * -1);bottom:calc(var(--os-padding-perpendicular) * -1)}.os-scrollbar-horizontal:hover .os-scrollbar-handle{height:var(--os-handle-perpendicular-size-hover)}.os-scrollbar-horizontal:active .os-scrollbar-handle{height:var(--os-handle-perpendicular-size-active)}.os-scrollbar-vertical{padding:var(--os-padding-axis) var(--os-padding-perpendicular);bottom:var(--os-size);width:var(--os-size)}.os-scrollbar-vertical .os-scrollbar-track:before{left:calc(var(--os-padding-perpendicular) * -1);right:calc(var(--os-padding-perpendicular) * -1)}.os-scrollbar-vertical .os-scrollbar-handle{min-height:var(--os-handle-min-size);max-height:var(--os-handle-max-size);width:var(--os-handle-perpendicular-size);transition:opacity .15s,background-color .15s,border-color .15s,width .15s}.os-scrollbar-vertical .os-scrollbar-handle:before{left:calc((var(--os-padding-perpendicular) + var(--os-handle-interactive-area-offset)) * -1);right:calc(var(--os-padding-perpendicular) * -1)}.os-scrollbar-vertical.os-scrollbar-rtl .os-scrollbar-handle:before{right:calc((var(--os-padding-perpendicular) + var(--os-handle-interactive-area-offset)) * -1);left:calc(var(--os-padding-perpendicular) * -1)}.os-scrollbar-vertical:hover .os-scrollbar-handle{width:var(--os-handle-perpendicular-size-hover)}.os-scrollbar-vertical:active .os-scrollbar-handle{width:var(--os-handle-perpendicular-size-active)}[data-overlayscrollbars-viewport~=measuring]>.os-scrollbar,.os-theme-none.os-scrollbar{display:none!important}.os-theme-dark,.os-theme-light{box-sizing:border-box;--os-size: 10px;--os-padding-perpendicular: 2px;--os-padding-axis: 2px;--os-track-border-radius: 10px;--os-handle-interactive-area-offset: 4px;--os-handle-border-radius: 10px}.os-theme-dark{--os-handle-bg: rgba(0, 0, 0, .44);--os-handle-bg-hover: rgba(0, 0, 0, .55);--os-handle-bg-active: rgba(0, 0, 0, .66)}.os-theme-light{--os-handle-bg: rgba(255, 255, 255, .44);--os-handle-bg-hover: rgba(255, 255, 255, .55);--os-handle-bg-active: rgba(255, 255, 255, .66)}.os-scrollbar.os-theme-light .os-scrollbar-handle{--os-handle-bg: oklch(from var(--color-1) l c h / .5);--os-handle-bg-hover: oklch(from var(--color-1) l c h / .66);--os-handle-bg-active: oklch(from var(--color-1) l c h / .75)}:root{--event-list-shadow: var(--card-shadow);--event-info-fg: var(--color-1);--event-fg: var(--color-1-em);--event-active-fg: var(--color-2-em);--event-duration: var(--color-1-em);--event-edge-top: var(--color-1-dim);--event-edge-bot: var(--color-danger-dim);--event-edge-m1: color-mix(in oklch, var(--event-edge-top) 75%, var(--event-edge-bot));--event-edge-m2: color-mix(in oklch, var(--event-edge-top) 25%, var(--event-edge-bot));--edge-margin: 60px;--open-duration: .4s;--edge-open-duration: calc((var(--open-duration) / 2));--edge-dedent-duration-base: .2s;--edge-expand-duration: .2s;--edge-expand-ease: ease;--edge-contract-duration: .2s;--edge-contract-ease: ease;--edge-contract-delay: .1s;--edge-indent-duration: .2s;--edge-indent-ease: ease;--edge-indent-delay: .05s;--edge-dedent-duration: var(--edge-dedent-duration-base);--edge-dedent-ease: ease;--edge-skew-duration: .2s;--edge-skew-ease: cubic-bezier(.15, .15, .15, 1.025);--edge-skew-delay: .05s;--edge-deskew-duration: .2s;--edge-deskew-ease: cubic-bezier(.3, .09, .25, .9)}.event-list-item>header .event-detail,.event-list-item.leaf .event-detail{display:flex;gap:.35em}.event-list-item>header .event-time,.event-list-item.leaf .event-time{color:var(--event-info-fg)}.event-list-item>header .event-duration,.event-list-item.leaf .event-duration{color:var(--event-fg);transition:color .2s ease}.running.event-list-item>header .event-duration,.running.event-list-item.leaf .event-duration{color:var(--event-active-fg)}.event-list-item>header .ui-code-block[scroll],.event-list-item.leaf .ui-code-block[scroll]{max-height:300px;max-width:60vw}.event-list-item.program .event-after{color:var(--title-text)}.event-list-item.program>.event-list-item-content>.event-icon>.node{animation-name:event-node-top-float-in}.event-list-item.program .event-detail .subtle{color:var(--event-info-fg)}.event-list-item.rule_batch>header .event-detail{color:var(--event-fg)}.event-list-item.block-node>header>.wire-tree-item-after .compilation,.event-list-item.block-node>header>.wire-tree-item-after .block{--mask-height: 20px;position:relative;width:60vw}.event-list-item.block-node>header>.wire-tree-item-after .compilation pre[scroll],.event-list-item.block-node>header>.wire-tree-item-after .block pre[scroll]{max-height:calc(300px + 2 * var(--mask-height));padding:var(--mask-height) 0;margin:calc(-1 * var(--mask-height)) 0;mask-image:linear-gradient(to bottom,transparent,#000 var(--mask-height),#000 calc(100% - var(--mask-height)),transparent),linear-gradient(#000,#000);mask-size:calc(100% - 8px) 100%,8px 100%;mask-position:0 0,100% 0;mask-repeat:no-repeat}.event-list-item.block-node>header>.wire-tree-item-after .compilation pre[scroll] .code-controls,.event-list-item.block-node>header>.wire-tree-item-after .block pre[scroll] .code-controls{top:8px;right:8px}.event-list-item.compilation .event-after,.event-list-item.block-node .event-after{max-width:800px}.event-list-item.error.error .wire-tree-item-node .node{--node-color: var(--node-color-error)}.event-list-item.error.error .event-detail{display:inline-block;padding:8px 16px;margin-top:-8px;margin-bottom:8px;background:var(--status-danger-bg);border-radius:5px;color:var(--status-danger)}.event-list-item.warn.warn .wire-tree-item-node .node{--node-color: var(--node-color-warn)}.event-list-item.warn.warn .event-detail{display:inline-block;padding:8px 16px;margin-top:-8px;margin-bottom:8px;background:var(--status-warn-bg);border-radius:5px;color:var(--status-warn)}.event-list-item.has-error-descendant>header>.wire-tree-item-node>.node{--node-color: var(--node-color-error)}.event-list-item.has-warn-descendant>header>.wire-tree-item-node>.node{--node-color: var(--node-color-warn)}.event-list-item.transaction .event-detail{gap:20px}.event-list-item.transaction .event-detail label{color:var(--event-fg)}.event-list-item.transaction .event-detail .subtle{color:var(--event-info-fg)}.event-list-item.transaction .event-detail .ui-button{color:var(--event-fg);opacity:0;transition:opacity .2s ease}.event-list-item.transaction:hover .ui-button{opacity:1}.event-list-item.install_batch .event-after{color:var(--event-fg)}.event-list-item.install_batch .event-detail{color:var(--event-info-fg)}.event-list-item.query_results .event-detail{display:block;margin-top:1em;text-align:right;padding-right:30px}.transaction-info{display:flex;flex-direction:column;gap:20px}.transaction-info .transaction-id{display:flex;gap:10px;align-items:center}.transaction-info .transaction-profile-node-progress{display:inline-block;margin-bottom:10px}.transaction-info .profiler-time-spent .category label:after{display:inline;content:" "}.transaction-info .profiler-time-spent .category+.category:before{display:inline;content:" | ";opacity:.5}.tree-branch-children>div>.metric-sorter{display:contents}.tree-branch-children>div>.metric-sorter .metric-sorter-controls .wire-tree-item-node{place-items:center start;width:100%}.tree-branch-children>div>.metric-sorter .metric-sorter-controls .metric-selector{position:relative;z-index:11;margin:-1px 0 -1px 8px}@-moz-keyframes event-node-top-float-in{0%{scale:.25;translate:0 50%;opacity:.75}to{opacity:1}}@-webkit-keyframes event-node-top-float-in{0%{scale:.25;translate:0 50%;opacity:.75}to{opacity:1}}@-o-keyframes event-node-top-float-in{0%{scale:.25;translate:0 50%;opacity:.75}to{opacity:1}}@keyframes event-node-top-float-in{0%{scale:.25;translate:0 50%;opacity:.75}to{opacity:1}}.container{font-family:Fira Code,mono;padding-bottom:3px}.header{display:flex;justify-content:space-between;margin-bottom:1.4em}.details{font-family:inherit;white-space:pre-wrap;word-wrap:break-word;text-indent:0;margin:0}.ui-table.zfxn1{display:block;overflow-x:auto;scrollbar-width:thin;scrollbar-gutter:auto;scrollbar-color:var(--color-1-em) transparent;background:var(--color-1-xdim);border-radius:10px;border-spacing:0;border-collapse:collapse;color:#fff;box-shadow:0 4px 4px #0004;padding-bottom:10px}.ui-table.zfxn1 td{padding:6px 24px}.ui-table.zfxn1 thead tr:first-child{background:#202c60}.ui-table.zfxn1 thead tr:first-child td p{font-size:16px;font-weight:500}.ui-table.zfxn1 tbody tr:first-of-type td{padding-top:16px}.ui-table.zfxn1 tbody tr:hover{background:#ffffff1a}.ui-table.zfxn1 tr td{text-align:left;padding-left:30px}.ui-table.zfxn1 tr td p{font-size:14px;letter-spacing:-1%}.ui-table.zfxn1 tr td:last-child{padding-right:30px}.ui-tabs .ui-tabs-list{position:relative}.ui-tabs button.ui-tabs-trigger{appearance:none;background:none;border:none;color:inherit}.ui-tabs .ui-tabs-indicator{height:1px;background:var(--color-1);border-radius:3px;transition:transform .25s ease}._ui-radio-group_4gg4c_1{align-items:center;padding:2px 0;margin:3px 0;display:flex;gap:.5em;position:relative;background:var(--color-1-xdim);border-radius:30px;box-shadow:inset 0 1px 5px var(--color-water-em)}._ui-radio-group_4gg4c_1[aria-orientation=vertical]{flex-direction:column}._ui-radio-group_4gg4c_1 .ui-radio-group-item-input{position:absolute;clip:rect(0,0,0,0);pointer-events:none}._ui-radio-group_4gg4c_1 .ui-radio-group-item-label{display:flex;aspect-ratio:1;margin:-3px 0;padding:4px 6px;align-items:center;font-size:20px;text-align:center;cursor:pointer;color:var(--color-1-em);transition:background-color .3s,color .3s;border-radius:30px;box-sizing:border-box}._ui-radio-group_4gg4c_1 .ui-radio-group-item-label:hover{color:#fff}._ui-radio-group_4gg4c_1 .ui-radio-group-item-label[data-checked]{background-color:#007bff;box-shadow:inset 0 0 3px var(--color-water-em),0 2px 4px var(--color-water-em);color:#fff}._ui-radio-group_4gg4c_1 .ui-radio-group-item-input:focus~._ui-radio-group_4gg4c_1 .ui-radio-group-item-label{box-shadow:0 0 0 2px #007bff80}._metric-grid_16g93_1{display:grid;grid-template-columns:auto auto;grid-template-rows:auto;gap:5px 20px}._metric-grid_16g93_1 .metric-grid-row{display:grid;grid-column:1/-1;grid-template-columns:subgrid}:root{--event-list-shadow: var(--card-shadow);--event-info-fg: var(--color-1);--event-fg: var(--color-1-em);--event-active-fg: var(--color-2-em);--event-duration: var(--color-1-em);--event-edge-top: var(--color-1-dim);--event-edge-bot: var(--color-danger-dim);--event-edge-mid: color-mix(in oklch, var(--event-edge-top) 50%, var(--event-edge-bot));--edge-margin: 60px;--open-duration: .4s;--edge-open-duration: calc((var(--open-duration) / 2));--edge-indent-duration: .2s;--edge-indent-ease: ease-in-out;--edge-indent-delay: .05s;--edge-expand-duration: .2s;--edge-expand-ease: ease;--edge-dedent-duration: .2s;--edge-dedent-ease: ease;--edge-contract-duration: .2s;--edge-contract-ease: ease;--edge-contract-delay: .1s}._wire-tree-item-node_p6iko_27{--stroke-width: 4px;--node-color-default: linear-gradient(to bottom right, var(--color-1-dim), var(--color-1-xdim));--node-color-error: linear-gradient(to bottom right, var(--color-danger), var(--color-danger-dim));--node-color-warn: linear-gradient(to bottom right, var(--color-warn), var(--color-1-xdim));height:calc(var(--base-radius) * 2);aspect-ratio:1;position:relative;justify-self:center;margin:1px}._wire-tree-item-node_p6iko_27 .node{--radius: var(--base-radius);--node-color: var(--node-color-default);--fill: var(--node-color);--stroke: none;position:absolute;width:calc(var(--radius) * 2);aspect-ratio:1;background:var(--fill, transparent);border-radius:999px;box-shadow:0 0 1px var(--node-color);filter:drop-shadow(0 0 3px var(--event-list-shadow));animation:wire-tree-node-float-in .2s ease;transition:background .2s ease}._wire-tree-item-node_p6iko_27 .multi{align-self:stretch;width:24px;aspect-ratio:1}._wire-tree-item-node_p6iko_27 .multi .node{--cx: 0;--cy: 0;--scale: 1;animation:wire-tree-node-pop-out .25s ease;transform:translate(calc(var(--base-radius) / var(--cx)),calc(var(--base-radius) / var(--cy))) scale(var(--scale))}._wire-tree-item-node_p6iko_27 .multi .node:nth-child(1){--cx: -.75;--cy: 2;--scale: calc(1 / 1.5);filter:brightness(.85)}._wire-tree-item-node_p6iko_27 .multi .node:nth-child(2){--cx: 1;--cy: -1;--scale: calc(1 / 1.75);filter:brightness(.75) blur(1px)}._wire-tree-item-node_p6iko_27 .multi .node:nth-child(3){--cx: 1.25;--cy: 1;--scale: calc(1 / 1.75);filter:brightness(.7) blur(1px)}._wire-tree-item-node_p6iko_27 .active-overlay{--orbit-distance: 4px;--orbit-offset: calc(var(--orbit-distance) + var(--trail-width));--radius: var(--base-radius);--outer-radius: calc(var(--radius) + var(--orbit-offset));--trail-width: 1px;--trail-color: var(--status-active);--particle-overhang: 1px;--reflect-color: #fff}._wire-tree-item-node_p6iko_27 .active-overlay,._wire-tree-item-node_p6iko_27 .active-overlay *{position:absolute;width:calc(var(--outer-radius) * 2);aspect-ratio:1}._wire-tree-item-node_p6iko_27 .active-overlay .spinner{border-radius:999px;animation:wire-tree-node-fade-in .3s ease-in,wire-tree-node-spin 2s linear infinite}._wire-tree-item-node_p6iko_27 .active-overlay .spinner:before{display:block;content:"";position:absolute;width:100%;aspect-ratio:1;border-radius:999px;background:conic-gradient(from 0deg,oklch(from var(--trail-color) l c h / 0) 180deg,oklch(from var(--trail-color) l c h / .166) 240deg,oklch(from var(--trail-color) l c h / .666) 300deg,var(--trail-color, 1) 360deg);mask-image:radial-gradient(circle closest-side,transparent calc(100% - var(--trail-width) - 1px),#000 calc(100% - var(--trail-width)))}._wire-tree-item-node_p6iko_27 .active-overlay .spinner:after{--size: calc(var(--trail-width) / 2 + var(--particle-overhang));background:var(--trail-color)}._wire-tree-item-node_p6iko_27 .active-overlay .spinner:after,._wire-tree-item-node_p6iko_27 .active-overlay .reflection:after{display:block;content:"";position:absolute;top:0;left:50%;width:calc(var(--size) * 2);aspect-ratio:1;transform:translate(-50%,calc(-1 * var(--size) + var(--trail-width) / 2));border-radius:999px}._wire-tree-item-node_p6iko_27 .active-overlay .reflection-wrapper{width:100%;--size: 20px;mix-blend-mode:soft-light}._wire-tree-item-node_p6iko_27 .active-overlay .reflection-wrapper .reflection{animation:wire-tree-node-fade-in .3s ease-in,wire-tree-node-spin 2s linear infinite}._wire-tree-item-node_p6iko_27 .active-overlay .reflection-wrapper .reflection:after{background:radial-gradient(circle at center,oklch(from var(--reflect-color) l c h / .9) 0%,oklch(from var(--reflect-color) l c h / .5) 15%,oklch(from var(--reflect-color) l c h / .1) 45%,transparent 75%)}._wire-tree-item-wire_p6iko_140{height:100%;contain:size;place-self:stretch center;width:2px;display:flex;flex-direction:column;z-index:-1}:where(._wire-tree-item-wire_p6iko_140){--abs-depth-change: max(var(--depth-change, 0), -1 * var(--depth-change, 0))}._wire-tree-item-wire_p6iko_140:before,._wire-tree-item-wire_p6iko_140:after{display:block;content:"";flex:1 1 calc(min(var(--abs-depth-change, 0),1)*10px);min-height:0;width:100%;border-radius:1px;transition:flex-grow var(--edge-dedent-duration, 0s) var(--edge-dedent-ease, ease) var(--edge-dedent-delay, 0s),flex-basis var(--edge-dedent-duration, 0s) var(--edge-dedent-ease, ease) var(--edge-dedent-delay, 0s),margin-left var(--edge-dedent-duration, 0s) var(--edge-dedent-ease, ease) var(--edge-dedent-delay, 0s)}._wire-tree-item-wire_p6iko_140:before{background:linear-gradient(var(--event-edge-top),var(--event-edge-mid))}._wire-tree-item-wire_p6iko_140:after{margin-left:calc(var(--depth-change, 0) * 40px);background:linear-gradient(var(--event-edge-mid),var(--event-edge-bot))}._wire-tree-item-wire_p6iko_140 .wire-tree-item-wire-inner{flex:0 1 calc(min(var(--abs-depth-change, 0),1)*40px);min-height:0;width:400px;translate:-50% 0;margin:-1px 1px;stroke:var(--event-edge-mid);stroke-width:2px;stroke-linecap:round;overflow:visible;border-radius:1px;transition:flex-basis var(--edge-dedent-duration, 0s) var(--edge-dedent-ease, ease) var(--edge-dedent-delay, 0s)}._wire-tree-item-wire_p6iko_140 .wire-tree-item-wire-inner path{transition:d var(--edge-dedent-duration, 0s) var(--edge-dedent-ease, ease) var(--edge-dedent-delay, 0s)}._wire-tree-item_p6iko_27{--depth-change: 0;--dedent-depth-change: 0;--indent-depth-change: 1}._wire-tree-item_p6iko_27:last-child{--dedent-depth-change: calc(var(--next-sibling-depth) - var(--tree-item-depth))}._wire-tree-item_p6iko_27[data-depth="0"]{--indent-depth-change: 0}.tree-branch-children ._wire-tree-item_p6iko_27:has(+._wire-tree-item_p6iko_27)>.tree-branch-children>div{--next-sibling-depth: var(--parent-item-depth)}._wire-tree-item_p6iko_27:last-of-type:not([data-expanded]:not(:has(>.tree-branch-children>div:empty))),._wire-tree-item_p6iko_27[data-depth="0"]:not([data-expanded]:not(:has(>.tree-branch-children>div:empty))){--depth-change: var(--dedent-depth-change)}._wire-tree-item_p6iko_27:last-of-type:not([data-expanded]:not(:has(>.tree-branch-children>div:empty))).branch>.tree-branch-header>.wire-tree-item-wire,._wire-tree-item_p6iko_27[data-depth="0"]:not([data-expanded]:not(:has(>.tree-branch-children>div:empty))).branch>.tree-branch-header>.wire-tree-item-wire,._wire-tree-item_p6iko_27:last-of-type:not([data-expanded]:not(:has(>.tree-branch-children>div:empty))).leaf>.wire-tree-item-wire,._wire-tree-item_p6iko_27[data-depth="0"]:not([data-expanded]:not(:has(>.tree-branch-children>div:empty))).leaf>.wire-tree-item-wire{--not-last: min(var(--next-sibling-depth), 1)}._wire-tree-item_p6iko_27:last-of-type:not([data-expanded]:not(:has(>.tree-branch-children>div:empty))).branch>.tree-branch-header>.wire-tree-item-wire:before,._wire-tree-item_p6iko_27[data-depth="0"]:not([data-expanded]:not(:has(>.tree-branch-children>div:empty))).branch>.tree-branch-header>.wire-tree-item-wire:before,._wire-tree-item_p6iko_27:last-of-type:not([data-expanded]:not(:has(>.tree-branch-children>div:empty))).leaf>.wire-tree-item-wire:before,._wire-tree-item_p6iko_27[data-depth="0"]:not([data-expanded]:not(:has(>.tree-branch-children>div:empty))).leaf>.wire-tree-item-wire:before,._wire-tree-item_p6iko_27:last-of-type:not([data-expanded]:not(:has(>.tree-branch-children>div:empty))).branch>.tree-branch-header>.wire-tree-item-wire:after,._wire-tree-item_p6iko_27[data-depth="0"]:not([data-expanded]:not(:has(>.tree-branch-children>div:empty))).branch>.tree-branch-header>.wire-tree-item-wire:after,._wire-tree-item_p6iko_27:last-of-type:not([data-expanded]:not(:has(>.tree-branch-children>div:empty))).leaf>.wire-tree-item-wire:after,._wire-tree-item_p6iko_27[data-depth="0"]:not([data-expanded]:not(:has(>.tree-branch-children>div:empty))).leaf>.wire-tree-item-wire:after{flex-grow:var(--not-last, 0)}._wire-tree-item_p6iko_27:last-of-type.leaf,._wire-tree-item_p6iko_27[data-depth="0"].leaf,._wire-tree-item_p6iko_27:last-of-type.branch>.tree-branch-header,._wire-tree-item_p6iko_27[data-depth="0"].branch>.tree-branch-header{--edge-indent-delay: 0s;--edge-expand-delay: 0s;--edge-expand-ease: ease-in;--edge-contract-delay: .15s;--edge-contract-ease: ease-out}._wire-tree-item_p6iko_27:last-of-type.branch>.tree-branch-children.tree-branch-children,._wire-tree-item_p6iko_27[data-depth="0"].branch>.tree-branch-children.tree-branch-children{transition-duration:.2s;transition-delay:0s!important;transition-timing-function:ease-in}._wire-tree-item_p6iko_27:last-of-type[data-expanded]:not(:has(>.tree-branch-children>div:empty)).branch>.tree-branch-children.tree-branch-children,._wire-tree-item_p6iko_27[data-depth="0"][data-expanded]:not(:has(>.tree-branch-children>div:empty)).branch>.tree-branch-children.tree-branch-children{transition-delay:.2s;transition-timing-function:ease-out}._wire-tree-item_p6iko_27:has(+._wire-tree-item_p6iko_27:not([data-depth="0"])) ._wire-tree-item_p6iko_27:last-of-type.leaf,._wire-tree-item_p6iko_27:has(+._wire-tree-item_p6iko_27:not([data-depth="0"])) ._wire-tree-item_p6iko_27[data-depth="0"].leaf,._wire-tree-item_p6iko_27:has(+._wire-tree-item_p6iko_27:not([data-depth="0"])) ._wire-tree-item_p6iko_27:last-of-type.branch>.tree-branch-header,._wire-tree-item_p6iko_27:has(+._wire-tree-item_p6iko_27:not([data-depth="0"])) ._wire-tree-item_p6iko_27[data-depth="0"].branch>.tree-branch-header{--edge-indent-delay: inherit;--edge-expand-delay: inherit;--edge-contract-delay: inherit}._wire-tree-item-content_p6iko_250{position:relative;display:grid;grid-template-areas:"before node after" "before wire after";grid-template-columns:6.5em 48px 1fr;grid-template-rows:auto 1fr}:where(._wire-tree-item-content_p6iko_250){--node-height: 24px}._wire-tree-item-content_p6iko_250 .wire-tree-item-before{grid-area:before;align-self:flex-start;margin-right:16px;padding-bottom:var(--edge-margin);text-align:right;word-wrap:break-word;transition:opacity var(--open-duration) ease-in;opacity:var(--content-opacity, 1)}._wire-tree-item-content_p6iko_250 .wire-tree-item-node{grid-area:node;justify-self:center;display:grid;grid-template:1fr/1fr;place-items:center}._wire-tree-item-content_p6iko_250 .wire-tree-item-after{grid-area:after;margin-left:16px;padding-bottom:var(--edge-margin);display:flex;flex-direction:column;align-items:flex-start;line-height:1.5;transition:opacity var(--open-duration) ease-in;opacity:var(--content-opacity, 1)}._wire-tree-item-content_p6iko_250 .wire-tree-item-wire{grid-area:wire;--wire-offset: calc(6.5em + 39px) }._wire-tree-item_p6iko_27.branch>.tree-branch-children{--parent-item-depth: var(--tree-item-depth);justify-content:stretch!important;transition:grid-template-rows var(--edge-contract-duration, 0s) var(--edge-contract-ease, ease) var(--edge-contract-delay, 0s)}._wire-tree-item_p6iko_27.branch[data-expanded]:not(:has(>.tree-branch-children>div:empty))>.tree-branch-children{transition:grid-template-rows var(--edge-expand-duration, 0s) var(--edge-expand-ease, ease) var(--edge-expand-delay, 0s)}._wire-tree-item_p6iko_27.branch>.tree-branch-children>div{margin-left:calc(var(--depth-change, 0) * 40px);transition:margin-left var(--edge-dedent-duration, 0s) var(--edge-dedent-ease, ease) var(--edge-dedent-delay, 0s)}._wire-tree-item_p6iko_27.branch[data-expanded]:not(:has(>.tree-branch-children>div:empty)){--depth-change: var(--indent-depth-change)}._wire-tree-item_p6iko_27.branch[data-expanded]:not(:has(>.tree-branch-children>div:empty))>._wire-tree-item-content_p6iko_250>.wire-tree-item-wire:after{transition:flex-grow var(--edge-indent-duration, 0s) var(--edge-indent-ease, ease) var(--edge-indent-delay, 0s),flex-basis var(--edge-indent-duration, 0s) var(--edge-indent-ease, ease) var(--edge-indent-delay, 0s),margin-left var(--edge-indent-duration, 0s) var(--edge-indent-ease, ease) var(--edge-indent-delay, 0s)}._wire-tree-item_p6iko_27.branch[data-expanded]:not(:has(>.tree-branch-children>div:empty))>._wire-tree-item-content_p6iko_250>.wire-tree-item-wire .wire-tree-item-wire-inner{transition:flex-basis var(--edge-indent-duration, 0s) var(--edge-indent-ease, ease) var(--edge-indent-delay, 0s)}._wire-tree-item_p6iko_27.branch[data-expanded]:not(:has(>.tree-branch-children>div:empty))>._wire-tree-item-content_p6iko_250>.wire-tree-item-wire .wire-tree-item-wire-inner path{transition:d var(--edge-indent-duration, 0s) var(--edge-indent-ease, ease) var(--edge-indent-delay, 0s)}._wire-tree-item_p6iko_27.branch[data-expanded]:not(:has(>.tree-branch-children>div:empty))>._wire-tree-item-content_p6iko_250>._wire-tree-item-node_p6iko_27>.node{mask-image:radial-gradient(circle closest-side,transparent calc(100% - var(--stroke-width) - 1px),#000 calc(100% - var(--stroke-width)))}._wire-tree-item_p6iko_27.branch[data-expanded]:not(:has(>.tree-branch-children>div:empty))>.tree-branch-children>div{transition:margin-left var(--edge-indent-duration, 0s) var(--edge-indent-ease, ease) var(--edge-indent-delay, 0s)}._wire-tree-item_p6iko_27.branch>.tree-branch-children>div.collapse-enter,._wire-tree-item_p6iko_27.branch>.tree-branch-children>div.collapse-exit-active{margin-left:calc(var(--dedent-depth-change, 0) * 40px)}._wire-tree-item_p6iko_27.branch>.tree-branch-children>div.collapse-enter ._wire-tree-item_p6iko_27,._wire-tree-item_p6iko_27.branch>.tree-branch-children>div.collapse-exit-active ._wire-tree-item_p6iko_27{--dedent-depth-change: 0}._wire-tree-item_p6iko_27.branch>.tree-branch-children>div>.tree-branch-children{transition:grid-template-rows var(--edge-expand-duration, 0s) var(--edge-expand-ease, ease) var(--edge-expand-delay, 0s)}@-moz-keyframes wire-tree-node-float-in{0%{transform:rotateY(80deg);opacity:.75}to{transform:rotateY(0);opacity:1}}@-webkit-keyframes wire-tree-node-float-in{0%{transform:rotateY(80deg);opacity:.75}to{transform:rotateY(0);opacity:1}}@-o-keyframes wire-tree-node-float-in{0%{transform:rotateY(80deg);opacity:.75}to{transform:rotateY(0);opacity:1}}@keyframes wire-tree-node-float-in{0%{transform:rotateY(80deg);opacity:.75}to{transform:rotateY(0);opacity:1}}@-moz-keyframes wire-tree-node-pop-out{0%{transform:translate(0) scale(.5);opacity:.5}}@-webkit-keyframes wire-tree-node-pop-out{0%{transform:translate(0) scale(.5);opacity:.5}}@-o-keyframes wire-tree-node-pop-out{0%{transform:translate(0) scale(.5);opacity:.5}}@keyframes wire-tree-node-pop-out{0%{transform:translate(0) scale(.5);opacity:.5}}@-moz-keyframes wire-tree-node-spin{to{transform:rotate(360deg)}}@-webkit-keyframes wire-tree-node-spin{to{transform:rotate(360deg)}}@-o-keyframes wire-tree-node-spin{to{transform:rotate(360deg)}}@keyframes wire-tree-node-spin{to{transform:rotate(360deg)}}@-moz-keyframes wire-tree-node-fade-in{0%{opacity:0;scale:.25}to{opacity:1}}@-webkit-keyframes wire-tree-node-fade-in{0%{opacity:0;scale:.25}to{opacity:1}}@-o-keyframes wire-tree-node-fade-in{0%{opacity:0;scale:.25}to{opacity:1}}@keyframes wire-tree-node-fade-in{0%{opacity:0;scale:.25}to{opacity:1}}:root{--collapsible-open-duration: .3s}.ui-collapsible{box-sizing:border-box;position:relative;display:flex}.ui-collapsible.left{flex-direction:row;--collapsible-icon-angle: 90deg}.ui-collapsible.right{flex-direction:row-reverse;--collapsible-icon-angle: 270deg}.ui-collapsible.top{flex-direction:column;--collapsible-icon-angle: 180deg}.ui-collapsible.bottom{flex-direction:column-reverse;--collapsible-icon-angle: 0deg}.ui-collapsible>.ui-collapsible-content{flex:0 1 auto;display:grid;overflow:hidden}.ui-collapsible.top>.ui-collapsible-content,.ui-collapsible.bottom>.ui-collapsible-content{grid-template-rows:0fr;transition:grid-template-rows var(--collapsible-open-duration) ease}.ui-collapsible.top[data-expanded]>.ui-collapsible-content,.ui-collapsible.bottom[data-expanded]>.ui-collapsible-content{grid-template-rows:1fr}.ui-collapsible.top>.ui-collapsible-content.bottom>.ui-collapsible-content,.ui-collapsible.bottom>.ui-collapsible-content.bottom>.ui-collapsible-content{align-items:end}.ui-collapsible.top>.ui-collapsible-content>.ui-collapsible-inner,.ui-collapsible.bottom>.ui-collapsible-content>.ui-collapsible-inner{min-height:0}.ui-collapsible.left>.ui-collapsible-content,.ui-collapsible.right>.ui-collapsible-content{grid-template-columns:0fr;transition:grid-template-columns var(--collapsible-open-duration) ease}.ui-collapsible.left[data-expanded]>.ui-collapsible-content,.ui-collapsible.right[data-expanded]>.ui-collapsible-content{grid-template-columns:1fr}.ui-collapsible.left>.ui-collapsible-content.right>.ui-collapsible-content,.ui-collapsible.right>.ui-collapsible-content.right>.ui-collapsible-content{justify-items:end}.ui-collapsible.left>.ui-collapsible-content>.ui-collapsible-inner,.ui-collapsible.right>.ui-collapsible-content>.ui-collapsible-inner{min-width:0}.ui-collapsible>.ui-collapsible-trigger .ui-collapsible-trigger-icon{opacity:0;transition:opacity .2s ease-out .1s}.ui-collapsible>.ui-collapsible-trigger .ui-collapsible-trigger-icon path{transition:transform var(--collapsible-open-duration) ease-out;transform-origin:12px 12px;vector-effect:non-scaling-stroke}.ui-collapsible>.ui-collapsible-trigger:focus{outline:none}.ui-collapsible:hover>.ui-collapsible-trigger>.ui-collapsible-trigger-icon{opacity:1}.ui-collapsible.left>.ui-collapsible-trigger[data-expanded] .ui-collapsible-trigger-icon path,.ui-collapsible.right>.ui-collapsible-trigger[data-expanded] .ui-collapsible-trigger-icon path{transform:scaleX(1) rotate(var(--collapsible-icon-angle, 0))}.ui-collapsible.left>.ui-collapsible-trigger[data-closed] .ui-collapsible-trigger-icon path,.ui-collapsible.right>.ui-collapsible-trigger[data-closed] .ui-collapsible-trigger-icon path{transform:scaleX(-1) rotate(var(--collapsible-icon-angle, 0))}.ui-collapsible.left>.ui-collapsible-content{align-items:flex-end}.ui-collapsible.top>.ui-collapsible-trigger .ui-collapsible-trigger-icon path,.ui-collapsible.bottom>.ui-collapsible-trigger .ui-collapsible-trigger-icon path{transform:scaleY(1) rotate(var(--collapsible-icon-angle, 0))}.ui-collapsible.top>.ui-collapsible-trigger[data-closed] .ui-collapsible-trigger-icon path,.ui-collapsible.bottom>.ui-collapsible-trigger[data-closed] .ui-collapsible-trigger-icon path{transform:scaleY(-1) rotate(var(--collapsible-icon-angle, 0))}.ui-collapsible.top>.ui-collapsible-content{justify-content:flex-end}@-moz-keyframes do-nothing{0%{--foo: 0}to{--foo: 1}}@-webkit-keyframes do-nothing{0%{--foo: 0}to{--foo: 1}}@-o-keyframes do-nothing{0%{--foo: 0}to{--foo: 1}}@keyframes do-nothing{0%{--foo: 0}to{--foo: 1}}._block-node_14gss_4.block-inspector{position:relative;box-shadow:0 4px 4px #0004}._block-node_14gss_4.block-inspector .ui-code-block:has(+.featured-metrics){margin-bottom:0;border-bottom-left-radius:0;border-bottom-right-radius:0;box-shadow:unset}._block-node_14gss_4.block-inspector .metric-grid{position:absolute;top:-8px;right:100%;margin-right:80px;padding:10px 20px;max-width:120px;background:var(--page-bot);opacity:0;transition:opacity .2s ease}._block-node_14gss_4.block-inspector .metric-grid .value{width:100px;overflow:hidden;word-wrap:break-word}._block-node_14gss_4.block-inspector .describe-optimization-container{margin-top:20px}._block-node_14gss_4.block-inspector .describe-optimization-container .describe-optimization-code{max-height:300px;overflow-y:scroll}._block-node_14gss_4.block-inspector:hover .metric-grid{opacity:1;z-index:10}._block-node_14gss_4 .featured-metrics{display:flex;padding:.5em 1.5em;max-width:100%;justify-content:space-between;border-bottom-left-radius:8px;border-bottom-right-radius:8px;background:var(--color-1-xdim)}._block-node_14gss_4 .featured-metrics .max-tuples{font-size:1em}.drop-zone{position:relative;border-radius:8px;transition:background-color .3s}.drop-zone.dragging,.drop-zone.draggingOver{background-color:#2a2a2a;outline:2px dashed currentcolor}.overlay{position:absolute;inset:0;z-index:1000;display:flex;justify-content:center;align-items:center}.overlay:before{content:"Drop files here...";padding:16px;font-size:14px;color:#f0f0f0}:root{--color-1-xdim: #141c3e;--color-1-dim: #13497e;--color-1: #3e74a9;--color-1-em: #4e9cd7;--color-1-xem: #99b5e3;--color-1-xxem: #bcd;--color-1-wash: #1a1a44;--color-2-xdim: #173d36;--color-2-dim: #3ea9a3;--color-2: rgba(93,255,216,.6);--color-2-em: #5dffd8;--color-danger-xdim: #3f1e33;--color-danger-dim: #402746;--color-danger: #f9a18e;--color-danger-wash: var(--color-danger-xdim);--color-warn: #f2d487;--color-warn-wash: rgba(255,211,55,.267);--color-water-em: #02022d;--color-water-dim: #000;--color-code: #e6edf3;--color-code-1: #8db3f5;--color-code-2: #5dcdff;--title-text: var(--color-1-em);--body-text: var(--color-1);--info-text: var(--color-1);--status-default: var(--color-1-em);--status-default-bg: var(--color-1-wash);--status-active: var(--color-2-em);--status-active-bg: var(--color-2-xdim);--status-inactive: var(--color-1);--status-inactive-bg: var(--color-1-wash);--status-danger: var(--color-danger);--status-danger-bg: var(--color-danger-wash);--status-warn: var(--color-warn);--status-warn-bg: var(--color-warn-wash);--page-top: var(--color-water-em);--page-bot: var(--color-water-dim);--card-bg: var(--color-1-wash);--card-fg: var(--color-1-xem);--card-border: hsl(from var(--bg, var(--card-bg)) h s calc(l*1.33) );--card-shadow: rgba(9,0,16,.4);--card-danger-fg: var(--color-danger);--card-danger-bg: var(--color-danger-wash);--card-warn-fg: var(--color-warn);--card-warn-bg: var(--color-warn-wash);--input-bg: var(--color-1-wash);--input-border: hsl(from var(--bg, var(--input-bg)) h s calc(l*1.33) );--input-outline: hsl(from var(--bg, var(--input-bg)) h s calc(l*1.66) );--anim-duration-quick: .1s;--anim-duration-normal: .25s;--anim-duration-slow: .4s}svg.icon:where(.sm){--icon-size: 20px}svg.icon:where(.md){--icon-size: 24px}svg.icon:where(.lg){--icon-size: 32px}svg.icon.icon-tabler{width:var(--icon-size, var(--icon-width, 24px));height:var(--icon-size, var(--icon-height, 24px))}svg.icon.icon-tabler:not([class$=-filled]){fill:none;stroke:var(--icon-color, currentColor);stroke-width:2;stroke-linecap:round;stroke-linejoin:round}svg.icon.icon-tabler[class$=-filled]{fill:var(--icon-color, currentColor);stroke:none}header{display:flex;align-items:center}h1,h2,h3,h4,h5,h6{margin:0;padding:0}html,body{margin:0;padding:0;min-height:100vh}body{background:var(--bg);color:var(--fg)}body{padding-bottom:60px;min-height:100vh;box-sizing:border-box;overflow-y:scroll;background:linear-gradient(var(--page-top),var(--page-top) 60vh,var(--page-bot) 150vh),var(--page-bot);background-repeat:no-repeat;background-attachment:local;color:var(--body-text);font-family:Inter,sans-serif}.app{min-height:100vh;padding:0 60px}.app>header{--icon-size: 32px;padding-top:40px;padding-bottom:20px}.app>header .hidden-controls{display:flex;opacity:0;transition:opacity .3s ease}.app>header:hover .hidden-controls{opacity:1}.app>header .toggler{display:flex}.import-issues-list{display:flex;flex-direction:column;gap:16px;margin-top:32px;margin-bottom:40px}.import-issues-list .import-group{display:inline-block;padding:8px 16px;margin-top:-8px;margin-bottom:8px;background:var(--status-danger-bg);border-radius:20px;color:var(--status-danger)}.import-issues-list .bold-text{font-weight:700}.system-health-indicator{border-radius:50%;height:20px;width:20px;cursor:pointer;display:flex;align-items:center;justify-content:center}.system-health-indicator.ok{background:var(--status-active)}.system-health-indicator.warning{background:var(--status-warn)}.system-health-indicator.error{background:var(--status-danger)}.system-health-indicator.disconnected{background:transparent;border:2px dashed #808080}:root{--field-border: var(--input-border);--field-bg: var(--input-bg, transparent);--field-outline: var(--input-outline, #999);--field-control-bg: transparent}.ui-field .ui-field-input{position:relative;display:flex;align-items:stretch;border-radius:4px}.ui-field .ui-field-input:focus-within{outline:1px solid var(--field-outline)}.ui-field .ui-field-input>input{flex:1}.ui-field .ui-field-value{padding:6px 8px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:var(--field-bg);border:1px solid var(--field-border);border-radius:4px;color:currentcolor}.ui-field .ui-field-value:focus{outline:none}.ui-field .ui-field-controls{position:absolute;right:4px;top:0;bottom:0;padding:2px;display:flex;flex-direction:column;justify-content:center;gap:1px}.ui-field .ui-field-controls>*:first-child{border-top-left-radius:4px;border-top-right-radius:4px}.ui-field .ui-field-controls>*:last-child{border-bottom-left-radius:4px;border-bottom-right-radius:4px}.ui-field.number .ui-field-input-increment,.ui-field.number .ui-field-input-decrement{--icon-size: 1em;flex:1 1 0;background:var(--field-control-bg);padding:0 1px;background:transparent}.settings-popout :focus{outline:none}.settings-popout .ui-popout-header{position:absolute;right:24px}.settings-popout .ui-popout-arrow{translate:12px 0}.settings-popout .ui-popout-content.ui-popout-content{margin-right:24px;margin-bottom:24px;padding:24px}.settings-popout .ui-popout-close{opacity:0!important}.settings-pane>section+section{margin-top:3em}.settings-pane>section>h2{margin-bottom:.5em}.settings-pane h1,.settings-pane h2,.settings-pane h3{color:var(--title-text)}.settings-pane .ui-field+.ui-field{margin-top:1em}.settings-pane h2{font-size:1.25rem}.settings-pane label{font-size:1rem;font-weight:300;color:var(--color-1-xxem)}.settings-pane input,.settings-pane .ui-field-input{color:var(--color-1-xem)}.overlay-settings-pane .overlay-settings>.overlay-setting:first-child{padding-top:0}.overlay-settings-pane .overlay-setting{padding-top:.5em;display:grid;grid-template-areas:"name name state" "indent child child";grid-template-columns:20px 1fr auto;align-items:center}.overlay-settings-pane .overlay-setting>header{display:contents}.overlay-settings-pane .overlay-setting>label,.overlay-settings-pane .overlay-setting>header>label{grid-area:name}.overlay-settings-pane .overlay-setting .overlay-state-input{grid-area:state;place-self:center end;margin-left:1em}.overlay-settings-pane .overlay-setting>.ui-collapsible-content,.overlay-settings-pane .overlay-setting>.ui-collapsible-content>.ui-collapsible-inner{display:grid;grid-area:child;grid-template-columns:subgrid}.overlay-settings-pane .overlay-setting>.sub-items,.overlay-settings-pane .overlay-setting>.ui-collapsible-content>.ui-collapsible-inner>.sub-items{grid-area:child}:root{--popout-bg: var(--card-bg);--popout-border: var(--card-border);--popout-shadow: var(--card-shadow);--popout-overlay-bg: var(--card-shadow);--popout-anim-open-duration: var(--anim-duration-normal);--popout-anim-close-duration: var(--anim-duration-slow)}.ui-popout{display:flex;flex-direction:column;align-items:center;justify-content:center}.ui-popout .ui-popout-arrow{margin-bottom:-1px}.ui-popout .ui-popout-arrow svg{fill:var(--tooltip-bg);stroke:var(--tooltip-border);stroke-width:1.8px}.ui-popout .ui-popout-arrow *{vector-effect:non-scaling-stroke}.ui-popout,.ui-popout .ui-popout-overlay{position:absolute;inset:0}.ui-popout .ui-popout-overlay{background:var(--popout-overlay-bg)}.ui-popout .ui-popout-content{position:relative;padding:12px;background:var(--popout-bg);border-radius:4px;border:1px solid var(--popout-border);box-shadow:1px 4px 11px var(--popout-shadow);z-index:40}.ui-popout .ui-popout-header:has(h2:not(:empty)){margin-bottom:20px}.ui-popout .ui-popout-title{flex:1}*{box-sizing:border-box}.toggle-group{display:flex;align-items:center}.toggle-group__wrapper{padding:2px;margin:3px 0;display:inline-block;background:var(--color-1-xdim);border-radius:30px;box-shadow:inset 0 1px 5px var(--color-water-em)}.toggle-group__buttons{display:flex;gap:.5em;position:relative}.toggle-group__button-input{position:absolute;clip:rect(0,0,0,0);pointer-events:none}.toggle-group__button{display:flex;aspect-ratio:1;margin:-3px 0;padding:4px 6px;align-items:center;font-size:20px;text-align:center;cursor:pointer;color:var(--color-1-em);transition:background-color .3s,color .3s;border-radius:30px;box-sizing:border-box}.toggle-group__button:hover{color:#fff}:is(.toggle-group__button-input:checked,.toggle-group__button-input.active.inherited)+.toggle-group__button{background-color:#007bff;box-shadow:inset 0 0 3px var(--color-water-em),0 2px 4px var(--color-water-em);color:#fff}.toggle-group__button-input.active.inherited+.toggle-group__button{background-color:#007bffcc}.toggle-group__button-input:focus+.toggle-group__button{box-shadow:0 0 0 2px #007bff80}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}
@@ -1,17 +0,0 @@
1
- <!DOCTYPE html>
2
- <html lang="en">
3
- <head>
4
- <meta charset="utf-8" />
5
- <meta name="viewport" content="width=device-width, initial-scale=1" />
6
- <meta name="theme-color" content="#000000" />
7
- <link rel="shortcut icon" type="image/png" href="/assets/favicon-Dy0ZgA6N.png" />
8
- <title>RAI Debugger</title>
9
- <script type="module" crossorigin src="/assets/index-Cssla-O7.js"></script>
10
- <link rel="stylesheet" crossorigin href="/assets/index-DlHsYx1V.css">
11
- </head>
12
- <body>
13
- <noscript>You need to enable JavaScript to run this app.</noscript>
14
- <div id="root"></div>
15
-
16
- </body>
17
- </html>
@@ -1,477 +0,0 @@
1
- from __future__ import annotations
2
- import atexit
3
- from datetime import datetime, timedelta
4
- import json
5
- import textwrap
6
- import time
7
- from typing import Any, Dict, Tuple, List, cast
8
- from urllib.error import HTTPError
9
-
10
- from pandas import DataFrame
11
-
12
- from relationalai import debugging
13
- from relationalai.clients.util import poll_with_specified_overhead
14
-
15
- from ..errors import EngineNotFoundException, RAIException, AzureUnsupportedQueryTimeoutException
16
- from ..rel_utils import assert_no_problems
17
- from ..loaders.loader import emit_delete_import, import_file, list_available_resources
18
- from .config import Config
19
- from .types import EngineState, ImportSource, ImportSourceFile, TransactionAsyncResponse
20
- from .client import Client, ExportParams, ProviderBase, ResourcesBase
21
- from .. import dsl, rel, metamodel as m
22
- from railib import api
23
- from . import result_helpers
24
-
25
- #--------------------------------------------------
26
- # Constants
27
- #--------------------------------------------------
28
-
29
- TXN_FIELDS = ["id", "account_name", "state", "created_on", "finished_at", "duration", "database_name", "read_only", "engine_name", "query", "query_size", "tags", "user_agent", "response_format_version"]
30
- TXN_REPLACE_MAP = {"database_name": "database", "engine_name": "engine", "account_name": "account", "user_agent": "agent"}
31
- VALID_ENGINE_STATES = ["REQUESTED", "PROVISIONED", "PROVISIONING"]
32
- ENGINE_SIZES = ["XS", "S", "M", "L", "XL"]
33
-
34
- #--------------------------------------------------
35
- # Resources
36
- #--------------------------------------------------
37
-
38
- class Resources(ResourcesBase):
39
- def __init__(self, profile:str|None=None, config:Config|None=None):
40
- super().__init__(profile, config=config)
41
- self._ctx = None
42
- atexit.register(self.cancel_pending_transactions)
43
-
44
- def _api_ctx(self):
45
- if not self._ctx:
46
- self._ctx = api.Context(**self.config.to_rai_config())
47
- return self._ctx
48
-
49
- def reset(self):
50
- self._ctx = None
51
-
52
- #--------------------------------------------------
53
- # Generic
54
- #--------------------------------------------------
55
-
56
- def get_version(self):
57
- raise Exception("Azure version not available")
58
-
59
- #--------------------------------------------------
60
- # Databases
61
- #--------------------------------------------------
62
-
63
- # Note: in contrast to the API definition in `ResourcesBase`, `get_database` in Azure
64
- # can return a `List` object instead of a `Dict` object.
65
- def get_database(self, database:str):
66
- return api.get_database(self._api_ctx(), database)
67
-
68
- # not implemented in Azure
69
- def get_installed_packages(self, database: str) -> Dict | None:
70
- return super().get_installed_packages(database)
71
-
72
- #--------------------------------------------------
73
- # Engines
74
- #--------------------------------------------------
75
- def get_engine_sizes(self, cloud_provider: str|None=None):
76
- return ENGINE_SIZES
77
-
78
- def get_cloud_provider(self) -> str:
79
- return "azure"
80
-
81
- def list_engines(self, state:str|None = None):
82
- return api.list_engines(self._api_ctx(), state)
83
-
84
- def get_engine(self, name:str) -> EngineState:
85
- return cast(EngineState, api.get_engine(self._api_ctx(), name))
86
-
87
- def is_valid_engine_state(self, name:str):
88
- return name in VALID_ENGINE_STATES
89
-
90
- def create_engine(self, name:str, size:str|None=None, auto_suspend_mins: int|None=None):
91
- if size is None:
92
- size = "M"
93
- with debugging.span("create_engine", name=name, size=size):
94
- return api.create_engine_wait(self._api_ctx(), name, size)
95
-
96
- def delete_engine(self, name:str, force:bool=False):
97
- return api.delete_engine(self._api_ctx(), name)
98
-
99
- def suspend_engine(self, name:str):
100
- return api.suspend_engine(self._api_ctx(), name)
101
-
102
- def resume_engine(self, name:str, headers={}):
103
- return api.resume_engine_wait(self._api_ctx(), name)
104
-
105
- def resume_engine_async(self, name:str):
106
- return api.resume_engine(self._api_ctx(), name)
107
-
108
- def auto_create_engine_async(self, name: str | None = None):
109
- raise Exception("Azure doesn't support auto_create_engine_async")
110
-
111
- def alter_engine_pool(self, size: str | None = None, mins: int | None = None, maxs: int | None = None):
112
- raise Exception("Azure doesn't support engine pool alteration")
113
-
114
- #--------------------------------------------------
115
- # Graphs
116
- #--------------------------------------------------
117
-
118
- def list_graphs(self) -> List[Any]:
119
- with debugging.span("list_models"):
120
- return api.list_databases(self._api_ctx())
121
-
122
- def get_graph(self, name:str):
123
- with debugging.span("get_model", name=name):
124
- return api.get_database(self._api_ctx(), name)
125
-
126
- def create_graph(self, name: str):
127
- with debugging.span("create_model", name=name):
128
- return api.create_database(self._api_ctx(), name)
129
-
130
- def delete_graph(self, name:str):
131
- with debugging.span("delete_model", name=name):
132
- return api.delete_database(self._api_ctx(), name)
133
-
134
- def clone_graph(self, target_name:str, source_name:str, nowait_durable:bool=False):
135
- # not a typo: the argument order is indeed target then source
136
- return api.create_database(self._api_ctx(), target_name, source_name)
137
-
138
- #--------------------------------------------------
139
- # Models
140
- #--------------------------------------------------
141
-
142
- def list_models(self, database: str, engine: str):
143
- return api.list_databases(self._api_ctx())
144
-
145
- def create_models(self, database: str, engine: str, models:List[Tuple[str, str]]) -> List[Any]:
146
- rel_code = self.create_models_code(models)
147
- results = self.exec_raw(database, engine, rel_code, readonly=False)
148
- if results.problems:
149
- return results.problems
150
- return []
151
-
152
- def delete_model(self, database:str, engine:str, name:str):
153
- return api.delete_model(self._api_ctx(), database, engine, name)
154
-
155
- def create_models_code(self, models:List[Tuple[str, str]]) -> str:
156
- lines = []
157
- for (name, code) in models:
158
- name = name.replace("\"", "\\\"")
159
- assert "\"\"\"\"\"\"\"" not in code, "Code literals must use fewer than 7 quotes."
160
-
161
- lines.append(textwrap.dedent(f"""
162
- def delete[:rel, :catalog, :model, "{name}"]: rel[:catalog, :model, "{name}"]
163
- def insert[:rel, :catalog, :model, "{name}"]: raw\"\"\"\"\"\"\"
164
- """) + code + "\n\"\"\"\"\"\"\"")
165
- rel_code = "\n\n".join(lines)
166
- return rel_code
167
-
168
- #--------------------------------------------------
169
- # Exports
170
- #--------------------------------------------------
171
-
172
- def list_exports(self, database: str, engine: str):
173
- raise Exception("Azure doesn't support exports")
174
-
175
- def create_export(self, params: ExportParams):
176
- if not params.dry_run:
177
- raise Exception("Azure doesn't support exports")
178
-
179
- def create_export_table(self, database: str, engine: str, table: str, relation: str, columns: Dict[str, str], code: str, refresh: str|None=None):
180
- raise Exception("Azure doesn't support exports")
181
-
182
- def delete_export(self, database: str, engine: str, name: str):
183
- raise Exception("Azure doesn't support exports")
184
-
185
- #--------------------------------------------------
186
- # Imports
187
- #--------------------------------------------------
188
-
189
- def list_imports(self, id:str|None = None, name:str|None = None, model:str|None = None, status:str|None = None, creator:str|None = None):
190
- if not model:
191
- raise RAIException("Imports can only be listed for a particular model in azure")
192
- return [*list_available_resources(self, model, self.get_default_engine_name()).values()]
193
-
194
- def poll_imports(self, sources:List[str], model:str):
195
- raise Exception("Azure doesn't support import polling")
196
-
197
- def create_import_stream(self, source:ImportSource, model:str, rate = 1, options: dict|None = None):
198
- raise Exception("Azure doesn't support import streams")
199
-
200
- def create_import_snapshot(self, source:ImportSource, model:str, options: dict|None = None):
201
- assert isinstance(source, ImportSourceFile), "Azure integration only supports loading from files and URLs right now."
202
- import_file(self, model, source, **(options or {}))
203
-
204
- def delete_import(self, import_name: str, model:str, force = False):
205
- res = self.exec_raw(model, self.get_default_engine_name(), emit_delete_import(import_name), False)
206
- assert_no_problems(res)
207
-
208
- def set_imports_engine_size(self, size: str):
209
- raise Exception("Azure doesn't support setting imports engine size")
210
-
211
- def change_imports_status(self, suspend:bool):
212
- raise Exception("Azure doesn't support import status changes")
213
-
214
- def get_imports_status(self):
215
- return None
216
-
217
- def change_stream_status(self, stream_id: str, model:str, suspend: bool):
218
- raise Exception("Azure doesn't support stream status changes")
219
-
220
- def get_import_stream(self, name: str|None, model:str|None):
221
- raise Exception("Azure doesn't support get import streams")
222
-
223
- #--------------------------------------------------
224
- # Exec
225
- #--------------------------------------------------
226
-
227
- def _exec(self, code:str, params:List[Any]|Any|None = None, raw=False, help=True):
228
- raise Exception("Azure doesn't support _exec")
229
-
230
- def exec_lqp(self, database: str, engine: str | None, raw_code: bytes, readonly=True, *, inputs: Dict | None = None, nowait_durable=False, headers: Dict | None = None, bypass_index=False, query_timeout_mins: int | None = None):
231
- raise Exception("Azure doesn't support exec_lqp")
232
-
233
- def exec_raw(self, database:str, engine:str|None, raw_code:str, readonly=True, *, inputs: Dict | None = None, nowait_durable=False, headers: Dict | None = None, raw_results=True, query_timeout_mins: int | None = None):
234
- if query_timeout_mins is not None or self.config.get("query_timeout_mins", None) is not None:
235
- config_file_path = getattr(self.config, 'file_path', None)
236
- raise AzureUnsupportedQueryTimeoutException(config_file_path=config_file_path)
237
- if engine is None:
238
- engine = self.get_default_engine_name()
239
- try:
240
- with debugging.span("transaction") as txn_span:
241
- ctx = self._api_ctx()
242
- if inputs is None:
243
- inputs = {}
244
- with debugging.span("create"):
245
- txn = api.exec_async(ctx, database, engine, raw_code, readonly=readonly, inputs=inputs)
246
- txn_id = txn.transaction["id"]
247
- txn_span["txn_id"] = txn_id
248
- debugging.event("transaction_created", txn_span, txn_id=txn_id)
249
-
250
- # TODO: dedup with SDK
251
- rsp = api.TransactionAsyncResponse()
252
- txn = api.get_transaction(ctx, txn_id)
253
- start_time = time.time()
254
-
255
- def check_done():
256
- with debugging.span("check_status"):
257
- state = api.get_transaction(ctx, txn_id)["state"]
258
- return api.is_txn_term_state(state)
259
-
260
- with debugging.span("wait", txn_id=txn_id):
261
- poll_with_specified_overhead(
262
- check_done,
263
- overhead_rate=0.1,
264
- start_time=start_time,
265
- )
266
-
267
- # TODO: parallelize
268
- with debugging.span("fetch"):
269
- rsp.transaction = api.get_transaction(ctx, txn_id)
270
- rsp.metadata = api.get_transaction_metadata(ctx, txn_id)
271
- rsp.problems = api.get_transaction_problems(ctx, txn_id)
272
- with debugging.span("fetch_results"):
273
- rsp.results = api.get_transaction_results(ctx, txn_id)
274
-
275
- return cast(TransactionAsyncResponse, rsp)
276
- except HTTPError as err:
277
- res = json.loads(err.read().decode())
278
- # Grab request id; useful for searching logs
279
- request_id = err.headers.get("x-request-id")
280
- # RAI API uses a JSON payload in the body to explain why the request failed
281
- # This annotates the error with that to make the exception actually useful.
282
- if "engine not found" in res.get('message', ''):
283
- print("") # the SDK appears to print some stuff before the error message
284
- exception = EngineNotFoundException(cast(str, self.config.get('engine', "Unknown")), res.get('message'))
285
- raise exception from None
286
- raise RAIException("HTTPError", res.get('message', ''), f"details: {res.get('details', '')}; request_id: {request_id}")
287
-
288
- def format_results(self, results, task:m.Task|None=None) -> Tuple[DataFrame, List[Any]]:
289
- return result_helpers.format_results(results, task)
290
-
291
- #--------------------------------------------------
292
- # Exec format
293
- #--------------------------------------------------
294
-
295
- def exec_format(self, database: str, engine: str, raw_code: str, cols:List[str], format:str, inputs: Dict | None = None, readonly: bool = True, nowait_durable=False, skip_invalid_data=False, headers: Dict | None = None, query_timeout_mins: int | None = None) -> Any: # @FIXME: Better type annotation
296
- raise Exception("Azure doesn't support alternative formats yet")
297
-
298
- def to_model_type(self, model:dsl.Graph, name: str, source:str):
299
- raise Exception("Azure doesn't support import types yet")
300
-
301
- #--------------------------------------------------
302
- # Transactions
303
- #--------------------------------------------------
304
-
305
- def get_transaction(self, transaction_id):
306
- txn = api.get_transaction(self._api_ctx(), transaction_id)
307
- if not txn:
308
- return None
309
- created_on = txn.get("created_on")
310
- finished_at = txn.get("finished_at")
311
- duration = txn.get("duration")
312
- if duration:
313
- txn["duration"] = timedelta(milliseconds=duration)
314
- elif created_on:
315
- txn["duration"] = datetime.now() - datetime.fromtimestamp(created_on / 1000)
316
- if created_on:
317
- txn["created_on"] = datetime.fromtimestamp(created_on / 1000)
318
- if finished_at:
319
- txn["finished_at"] = datetime.fromtimestamp(finished_at / 1000)
320
- # Remap based on the fields we care about
321
- result = {TXN_REPLACE_MAP.get(k, k): v for k, v in txn.items() if k in TXN_FIELDS}
322
- return result
323
-
324
- def remap_fields(self, transactions):
325
- if not transactions:
326
- return []
327
- for transaction in transactions:
328
- for key in list(transaction.keys()):
329
- if key in TXN_REPLACE_MAP:
330
- transaction[TXN_REPLACE_MAP[key]] = transaction.pop(key)
331
- return transactions
332
-
333
- def list_transactions(self, **kwargs):
334
- TERMINAL_STATES = ["COMPLETED", "ABORTED"]
335
- VALID_KEYS = ["id", "state", "engine"]
336
-
337
- state = kwargs.get("state")
338
- only_active = kwargs.get("only_active", False)
339
- options = {}
340
-
341
- # Azure sdk supports more than just VALID_KEYS as filters but for now we pass through those
342
- for k, v in kwargs.items():
343
- if k in VALID_KEYS and v is not None:
344
- # Only pass state if it is a valid terminal state
345
- if k == "state" and v.upper() in TERMINAL_STATES:
346
- options[k] = v.upper()
347
- if k != "state":
348
- if k == "engine":
349
- k = "engine_name"
350
- options[k] = v
351
- # In Azure we store transactions in cosmos and consul
352
- # Cosmos if the state is terminal (COMPLETED or ABORTED) and Consul if the state is not (e.g. "RUNNING")
353
- # So we can not filter on active non terminal states via the options passed
354
- transactions = api.list_transactions(self._api_ctx(), **options)
355
-
356
- if not transactions:
357
- return []
358
- # We filter non terminal transactions here
359
- if only_active:
360
- transactions = [t for t in transactions if t["state"] in ["CREATED", "RUNNING", "PENDING"]]
361
- if (isinstance(state, str) and state.upper() not in TERMINAL_STATES):
362
- transactions = [t for t in transactions if t["state"] in [state.upper()]]
363
- return self.remap_fields(transactions)
364
-
365
- def cancel_transaction(self, transaction_id):
366
- return api.cancel_transaction(self._api_ctx(), transaction_id)
367
-
368
- def cancel_pending_transactions(self):
369
- # all transactions are executed synchronously against azure
370
- pass
371
-
372
- def get_transaction_events(self, transaction_id:str, continuation_token:str):
373
- return api._get_resource(
374
- self._api_ctx(),
375
- f"/transactions/{transaction_id}/events/profiler?continuation_token={continuation_token}",
376
- )
377
-
378
- def is_account_flag_set(self, flag: str):
379
- raise Exception("Azure doesn't support account flags")
380
-
381
- def is_direct_access_enabled(self) -> bool:
382
- raise Exception("Azure doesn't support direct access")
383
- #--------------------------------------------------
384
- # Provider
385
- #--------------------------------------------------
386
-
387
- class Provider(ProviderBase):
388
-
389
- def __init__(
390
- self,
391
- profile: str | None = None,
392
- config: Config | None = None,
393
- resources: Resources | None = None,
394
- ):
395
- if resources:
396
- self.resources = resources
397
- else:
398
- self.resources = Resources(profile, config)
399
-
400
- #--------------------------------------------------
401
- # Graph
402
- #--------------------------------------------------
403
-
404
- def Graph(name, *, profile:str|None=None, config:Config, dry_run:bool=False, isolated=True, keep_model:bool=False, format="default"):
405
- use_monotype_operators = config.get("compiler.use_monotype_operators", False)
406
-
407
- client = Client(
408
- Resources(profile, config),
409
- rel.Compiler(config),
410
- name,
411
- config,
412
- dry_run=dry_run,
413
- isolated=isolated,
414
- keep_model=keep_model,
415
- )
416
- base_rel = """
417
- @inline
418
- def make_identity(x..., z):
419
- rel_primitive_hash_tuple_uint128(x..., z)
420
-
421
- @inline
422
- def pyrel_default({F}, c, k..., v):
423
- F(k..., v) or (not F(k..., _) and v = c)
424
-
425
- @inline
426
- def pyrel_unwrap(x in UInt128, y): y = x
427
-
428
- @inline
429
- def pyrel_dates_period_days(x in Date, y in Date, z in Int):
430
- exists((u) | dates_period_days(x, y , u) and u = ^Day[z])
431
-
432
- @inline
433
- def pyrel_datetimes_period_milliseconds(x in DateTime, y in DateTime, z in Int):
434
- exists((u) | datetimes_period_milliseconds(x, y , u) and u = ^Millisecond[z])
435
-
436
- @inline
437
- def pyrel_bool_filter(a, b, {F}, z): { z = if_then_else[F(a, b), boolean_true, boolean_false] }
438
-
439
- @inline
440
- def pyrel_strftime(v, fmt, tz in String, s in String):
441
- (Date(v) and s = format_date[v, fmt])
442
- or (DateTime(v) and s = format_datetime[v, fmt, tz])
443
-
444
- @inline
445
- def pyrel_regex_match_all(pattern, string in String, pos in Int, offset in Int, match in String):
446
- regex_match_all(pattern, string, offset, match) and offset >= pos
447
-
448
- @inline
449
- def pyrel_regex_match(pattern, string in String, pos in Int, offset in Int, match in String):
450
- pyrel_regex_match_all(pattern, string, pos, offset, match) and offset = pos
451
-
452
- @inline
453
- def pyrel_regex_search(pattern, string in String, pos in Int, offset in Int, match in String):
454
- enumerate(pyrel_regex_match_all[pattern, string, pos], 1, offset, match)
455
-
456
- @inline
457
- def pyrel_regex_sub(pattern, repl in String, string in String, result in String):
458
- string_replace_multiple(string, {(last[regex_match_all[pattern, string]], repl)}, result)
459
-
460
- @inline
461
- def pyrel_capture_group(regex in Pattern, string in String, pos in Int, index, match in String):
462
- (Integer(index) and capture_group_by_index(regex, string, pos, index, match)) or
463
- (String(index) and capture_group_by_name(regex, string, pos, index, match))
464
-
465
- declare __resource
466
- declare __compiled_patterns
467
- """
468
- if use_monotype_operators:
469
- base_rel += """
470
-
471
- // use monotyped operators
472
- from ::std::monotype import +, -, *, /, <, <=, >, >=
473
- """
474
- pyrel_base = dsl.build.raw_task(base_rel)
475
- debugging.set_source(pyrel_base)
476
- client.install("pyrel_base", pyrel_base)
477
- return dsl.Graph(client, name, format=format)