pytrilogy 0.0.3.82__tar.gz → 0.0.3.83__tar.gz

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.

Potentially problematic release.


This version of pytrilogy might be problematic. Click here for more details.

Files changed (151) hide show
  1. {pytrilogy-0.0.3.82/pytrilogy.egg-info → pytrilogy-0.0.3.83}/PKG-INFO +1 -1
  2. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83/pytrilogy.egg-info}/PKG-INFO +1 -1
  3. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/__init__.py +1 -1
  4. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/core/enums.py +1 -0
  5. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/core/functions.py +9 -0
  6. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/dialect/base.py +3 -0
  7. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/parsing/parse_engine.py +6 -0
  8. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/parsing/trilogy.lark +3 -1
  9. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/LICENSE.md +0 -0
  10. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/README.md +0 -0
  11. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/pyproject.toml +0 -0
  12. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/pytrilogy.egg-info/SOURCES.txt +0 -0
  13. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/pytrilogy.egg-info/dependency_links.txt +0 -0
  14. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/pytrilogy.egg-info/entry_points.txt +0 -0
  15. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/pytrilogy.egg-info/requires.txt +0 -0
  16. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/pytrilogy.egg-info/top_level.txt +0 -0
  17. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/setup.cfg +0 -0
  18. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/setup.py +0 -0
  19. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/tests/test_datatypes.py +0 -0
  20. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/tests/test_declarations.py +0 -0
  21. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/tests/test_derived_concepts.py +0 -0
  22. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/tests/test_discovery_nodes.py +0 -0
  23. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/tests/test_enums.py +0 -0
  24. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/tests/test_environment.py +0 -0
  25. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/tests/test_execute_models.py +0 -0
  26. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/tests/test_executor.py +0 -0
  27. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/tests/test_failure.py +0 -0
  28. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/tests/test_functions.py +0 -0
  29. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/tests/test_imports.py +0 -0
  30. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/tests/test_metadata.py +0 -0
  31. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/tests/test_models.py +0 -0
  32. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/tests/test_multi_join_assignments.py +0 -0
  33. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/tests/test_parse_engine.py +0 -0
  34. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/tests/test_parsing.py +0 -0
  35. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/tests/test_parsing_failures.py +0 -0
  36. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/tests/test_partial_handling.py +0 -0
  37. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/tests/test_query_processing.py +0 -0
  38. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/tests/test_query_render.py +0 -0
  39. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/tests/test_select.py +0 -0
  40. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/tests/test_show.py +0 -0
  41. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/tests/test_statements.py +0 -0
  42. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/tests/test_typing.py +0 -0
  43. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/tests/test_undefined_concept.py +0 -0
  44. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/tests/test_user_functions.py +0 -0
  45. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/tests/test_where_clause.py +0 -0
  46. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/authoring/__init__.py +0 -0
  47. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/compiler.py +0 -0
  48. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/constants.py +0 -0
  49. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/core/__init__.py +0 -0
  50. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/core/constants.py +0 -0
  51. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/core/env_processor.py +0 -0
  52. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/core/environment_helpers.py +0 -0
  53. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/core/ergonomics.py +0 -0
  54. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/core/exceptions.py +0 -0
  55. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/core/graph_models.py +0 -0
  56. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/core/internal.py +0 -0
  57. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/core/models/__init__.py +0 -0
  58. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/core/models/author.py +0 -0
  59. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/core/models/build.py +0 -0
  60. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/core/models/build_environment.py +0 -0
  61. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/core/models/core.py +0 -0
  62. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/core/models/datasource.py +0 -0
  63. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/core/models/environment.py +0 -0
  64. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/core/models/execute.py +0 -0
  65. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/core/optimization.py +0 -0
  66. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/core/optimizations/__init__.py +0 -0
  67. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/core/optimizations/base_optimization.py +0 -0
  68. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/core/optimizations/inline_datasource.py +0 -0
  69. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/core/optimizations/predicate_pushdown.py +0 -0
  70. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/core/processing/__init__.py +0 -0
  71. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/core/processing/concept_strategies_v3.py +0 -0
  72. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/core/processing/discovery_loop.py +0 -0
  73. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/core/processing/discovery_node_factory.py +0 -0
  74. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/core/processing/discovery_utility.py +0 -0
  75. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/core/processing/discovery_validation.py +0 -0
  76. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/core/processing/graph_utils.py +0 -0
  77. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/core/processing/node_generators/__init__.py +0 -0
  78. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/core/processing/node_generators/basic_node.py +0 -0
  79. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/core/processing/node_generators/common.py +0 -0
  80. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/core/processing/node_generators/constant_node.py +0 -0
  81. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/core/processing/node_generators/filter_node.py +0 -0
  82. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/core/processing/node_generators/group_node.py +0 -0
  83. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/core/processing/node_generators/group_to_node.py +0 -0
  84. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/core/processing/node_generators/multiselect_node.py +0 -0
  85. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/core/processing/node_generators/node_merge_node.py +0 -0
  86. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/core/processing/node_generators/recursive_node.py +0 -0
  87. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/core/processing/node_generators/rowset_node.py +0 -0
  88. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/core/processing/node_generators/select_helpers/__init__.py +0 -0
  89. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/core/processing/node_generators/select_helpers/datasource_injection.py +0 -0
  90. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/core/processing/node_generators/select_merge_node.py +0 -0
  91. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/core/processing/node_generators/select_node.py +0 -0
  92. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/core/processing/node_generators/synonym_node.py +0 -0
  93. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/core/processing/node_generators/union_node.py +0 -0
  94. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/core/processing/node_generators/unnest_node.py +0 -0
  95. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/core/processing/node_generators/window_node.py +0 -0
  96. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/core/processing/nodes/__init__.py +0 -0
  97. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/core/processing/nodes/base_node.py +0 -0
  98. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/core/processing/nodes/filter_node.py +0 -0
  99. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/core/processing/nodes/group_node.py +0 -0
  100. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/core/processing/nodes/merge_node.py +0 -0
  101. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/core/processing/nodes/recursive_node.py +0 -0
  102. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/core/processing/nodes/select_node_v2.py +0 -0
  103. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/core/processing/nodes/union_node.py +0 -0
  104. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/core/processing/nodes/unnest_node.py +0 -0
  105. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/core/processing/nodes/window_node.py +0 -0
  106. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/core/processing/utility.py +0 -0
  107. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/core/query_processor.py +0 -0
  108. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/core/statements/__init__.py +0 -0
  109. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/core/statements/author.py +0 -0
  110. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/core/statements/build.py +0 -0
  111. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/core/statements/common.py +0 -0
  112. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/core/statements/execute.py +0 -0
  113. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/core/utility.py +0 -0
  114. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/dialect/__init__.py +0 -0
  115. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/dialect/bigquery.py +0 -0
  116. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/dialect/common.py +0 -0
  117. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/dialect/config.py +0 -0
  118. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/dialect/dataframe.py +0 -0
  119. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/dialect/duckdb.py +0 -0
  120. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/dialect/enums.py +0 -0
  121. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/dialect/postgres.py +0 -0
  122. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/dialect/presto.py +0 -0
  123. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/dialect/snowflake.py +0 -0
  124. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/dialect/sql_server.py +0 -0
  125. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/engine.py +0 -0
  126. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/executor.py +0 -0
  127. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/hooks/__init__.py +0 -0
  128. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/hooks/base_hook.py +0 -0
  129. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/hooks/graph_hook.py +0 -0
  130. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/hooks/query_debugger.py +0 -0
  131. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/metadata/__init__.py +0 -0
  132. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/parser.py +0 -0
  133. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/parsing/__init__.py +0 -0
  134. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/parsing/common.py +0 -0
  135. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/parsing/config.py +0 -0
  136. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/parsing/exceptions.py +0 -0
  137. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/parsing/helpers.py +0 -0
  138. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/parsing/render.py +0 -0
  139. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/py.typed +0 -0
  140. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/render.py +0 -0
  141. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/scripts/__init__.py +0 -0
  142. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/scripts/trilogy.py +0 -0
  143. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/std/__init__.py +0 -0
  144. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/std/date.preql +0 -0
  145. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/std/display.preql +0 -0
  146. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/std/geography.preql +0 -0
  147. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/std/money.preql +0 -0
  148. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/std/net.preql +0 -0
  149. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/std/ranking.preql +0 -0
  150. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/std/report.preql +0 -0
  151. {pytrilogy-0.0.3.82 → pytrilogy-0.0.3.83}/trilogy/utility.py +0 -0
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: pytrilogy
3
- Version: 0.0.3.82
3
+ Version: 0.0.3.83
4
4
  Summary: Declarative, typed query language that compiles to SQL.
5
5
  Home-page:
6
6
  Author:
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: pytrilogy
3
- Version: 0.0.3.82
3
+ Version: 0.0.3.83
4
4
  Summary: Declarative, typed query language that compiles to SQL.
5
5
  Home-page:
6
6
  Author:
@@ -4,6 +4,6 @@ from trilogy.dialect.enums import Dialects
4
4
  from trilogy.executor import Executor
5
5
  from trilogy.parser import parse
6
6
 
7
- __version__ = "0.0.3.82"
7
+ __version__ = "0.0.3.83"
8
8
 
9
9
  __all__ = ["parse", "Executor", "Dialects", "Environment", "CONFIG"]
@@ -154,6 +154,7 @@ class FunctionType(Enum):
154
154
  ARRAY_SUM = "array_sum"
155
155
  ARRAY_SORT = "array_sort"
156
156
  ARRAY_TRANSFORM = "array_transform"
157
+ ARRAY_TO_STRING = "array_to_string"
157
158
 
158
159
  # TEXT AND MAYBE MORE
159
160
  SPLIT = "split"
@@ -283,6 +283,15 @@ FUNCTION_REGISTRY: dict[FunctionType, FunctionConfig] = {
283
283
  output_type_function=get_transform_output_type,
284
284
  arg_count=3,
285
285
  ),
286
+ FunctionType.ARRAY_TO_STRING: FunctionConfig(
287
+ valid_inputs={
288
+ DataType.ARRAY,
289
+ DataType.STRING,
290
+ },
291
+ output_purpose=Purpose.PROPERTY,
292
+ output_type=DataType.STRING,
293
+ arg_count=2,
294
+ ),
286
295
  FunctionType.ARRAY_SUM: FunctionConfig(
287
296
  valid_inputs={
288
297
  DataType.ARRAY,
@@ -193,6 +193,9 @@ FUNCTION_MAP = {
193
193
  FunctionType.ARRAY_TRANSFORM: lambda args: (
194
194
  f"array_transform({args[0]}, {args[1]} -> {args[2]})"
195
195
  ),
196
+ FunctionType.ARRAY_TO_STRING: lambda args: (
197
+ f"array_to_string({args[0]}, {args[1]})"
198
+ ),
196
199
  # math
197
200
  FunctionType.ADD: lambda x: " + ".join(x),
198
201
  FunctionType.ABS: lambda x: f"abs({x[0]})",
@@ -2034,6 +2034,12 @@ class ParseToObjects(Transformer):
2034
2034
  args, FunctionType.ARRAY_DISTINCT, meta
2035
2035
  )
2036
2036
 
2037
+ @v_args(meta=True)
2038
+ def farray_to_string(self, meta, args):
2039
+ return self.function_factory.create_function(
2040
+ args, FunctionType.ARRAY_TO_STRING, meta
2041
+ )
2042
+
2037
2043
  @v_args(meta=True)
2038
2044
  def farray_sort(self, meta, args):
2039
2045
  if len(args) == 1:
@@ -300,13 +300,15 @@
300
300
  farray_sum: _ARRAY_SUM expr ")"
301
301
  _ARRAY_DISTINCT.1: "array_distinct("i
302
302
  farray_distinct: _ARRAY_DISTINCT expr ")"
303
+ _ARRAY_TO_STRING.1: "array_to_string("i
304
+ farray_to_string: _ARRAY_TO_STRING expr "," expr ")"
303
305
  _ARRAY_SORT.1: "array_sort("i
304
306
  farray_sort: _ARRAY_SORT expr ("," ordering )? ")"
305
307
  _ARRAY_TRANSFORM.1: "array_transform("i
306
308
  transform_lambda: "@" IDENTIFIER
307
309
  farray_transform: _ARRAY_TRANSFORM expr "," transform_lambda ")"
308
310
 
309
- _array_functions: farray_sum | farray_distinct | farray_sort | farray_transform
311
+ _array_functions: farray_sum | farray_distinct | farray_sort | farray_transform | farray_to_string
310
312
 
311
313
  // special aggregate
312
314
  _GROUP.1: "group("i
File without changes
File without changes
File without changes
File without changes