Commit 309e0f2
committed
fix: fall back to Spark for str_to_map when legacy regex split truncation is enabled
Spark 4.1.1 added spark.sql.legacy.truncateForEmptyRegexSplit, which makes
StringToMap truncate trailing empty entries from the split result. Comet's
native str_to_map always behaves as if the flag were false, producing
incorrect results in legacy mode.
Downgrade CometStrToMap to Incompatible when the flag is enabled so it falls
back to Spark unless the user explicitly opts in via allowIncompatible. The
config is read by string key so it resolves on Spark versions where it is not
registered.
Closes #44771 parent 9e86dd9 commit 309e0f2
2 files changed
Lines changed: 58 additions & 1 deletion
File tree
- spark/src
- main/scala/org/apache/comet/serde
- test/resources/sql-tests/expressions/map
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
20 | 20 | | |
21 | 21 | | |
22 | 22 | | |
| 23 | + | |
23 | 24 | | |
24 | 25 | | |
25 | 26 | | |
| |||
164 | 165 | | |
165 | 166 | | |
166 | 167 | | |
167 | | - | |
| 168 | + | |
| 169 | + | |
| 170 | + | |
| 171 | + | |
| 172 | + | |
| 173 | + | |
| 174 | + | |
| 175 | + | |
| 176 | + | |
| 177 | + | |
| 178 | + | |
| 179 | + | |
| 180 | + | |
| 181 | + | |
| 182 | + | |
| 183 | + | |
168 | 184 | | |
169 | 185 | | |
Lines changed: 41 additions & 0 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
| 2 | + | |
| 3 | + | |
| 4 | + | |
| 5 | + | |
| 6 | + | |
| 7 | + | |
| 8 | + | |
| 9 | + | |
| 10 | + | |
| 11 | + | |
| 12 | + | |
| 13 | + | |
| 14 | + | |
| 15 | + | |
| 16 | + | |
| 17 | + | |
| 18 | + | |
| 19 | + | |
| 20 | + | |
| 21 | + | |
| 22 | + | |
| 23 | + | |
| 24 | + | |
| 25 | + | |
| 26 | + | |
| 27 | + | |
| 28 | + | |
| 29 | + | |
| 30 | + | |
| 31 | + | |
| 32 | + | |
| 33 | + | |
| 34 | + | |
| 35 | + | |
| 36 | + | |
| 37 | + | |
| 38 | + | |
| 39 | + | |
| 40 | + | |
| 41 | + | |
0 commit comments