From d46ee211b8b7fe9184ec7bd9a72577d57619cb15 Mon Sep 17 00:00:00 2001 From: ncordon Date: Mon, 30 Mar 2026 19:01:08 +0200 Subject: [PATCH 1/7] [ESQL] Makes LIMIT BY Tech Preview --- .../esql/src/main/antlr/EsqlBaseParser.g4 | 2 +- .../xpack/esql/action/EsqlCapabilities.java | 4 +- .../xpack/esql/parser/EsqlBaseParser.interp | 2 +- .../xpack/esql/parser/EsqlBaseParser.java | 1885 ++++++++--------- .../xpack/esql/analysis/AnalyzerTests.java | 1 - .../LocalPhysicalPlanOptimizerTests.java | 4 - .../optimizer/LogicalPlanOptimizerTests.java | 5 - .../optimizer/PhysicalPlanOptimizerTests.java | 7 - .../rules/logical/CombineLimitTopNTests.java | 5 - .../rules/logical/PruneColumnsTests.java | 1 - .../logical/PruneLiteralsInLimitByTests.java | 1 - .../PushDownAndCombineLimitByGoldenTests.java | 1 - .../PushDownAndCombineLimitByTests.java | 1 - ...eLimitByExpressionWithEvalGoldenTests.java | 7 - .../physical/local/LimitByGoldenTests.java | 2 - ...rderLimitProjectAndOrderByGoldenTests.java | 2 - .../esql/parser/StatementParserTests.java | 4 - 17 files changed, 941 insertions(+), 993 deletions(-) diff --git a/x-pack/plugin/esql/src/main/antlr/EsqlBaseParser.g4 b/x-pack/plugin/esql/src/main/antlr/EsqlBaseParser.g4 index 86658c9c82a76..9ab4323a6dd54 100644 --- a/x-pack/plugin/esql/src/main/antlr/EsqlBaseParser.g4 +++ b/x-pack/plugin/esql/src/main/antlr/EsqlBaseParser.g4 @@ -225,7 +225,7 @@ limitCommand ; limitByGroupKey: - {this.isDevVersion()}? BY booleanExpression (COMMA booleanExpression)* + BY booleanExpression (COMMA booleanExpression)* ; sortCommand diff --git a/x-pack/plugin/esql/src/main/java/org/elasticsearch/xpack/esql/action/EsqlCapabilities.java b/x-pack/plugin/esql/src/main/java/org/elasticsearch/xpack/esql/action/EsqlCapabilities.java index 042bebdc40748..d68e909975ec8 100644 --- a/x-pack/plugin/esql/src/main/java/org/elasticsearch/xpack/esql/action/EsqlCapabilities.java +++ b/x-pack/plugin/esql/src/main/java/org/elasticsearch/xpack/esql/action/EsqlCapabilities.java @@ -2344,12 +2344,12 @@ public enum Cap { * Enables the feature LIMIT n BY expr1, expr2 for retaining at most n docs per group. * The feature will not work if we had SORT | LIMIT n BY */ - ESQL_LIMIT_BY(Build.current().isSnapshot()), + ESQL_LIMIT_BY, /** * Enables the SORT | LIMIT n BY expr1, expr2 support, see ESQL_LIMIT_BY for more context */ - ESQL_TOPN_BY(Build.current().isSnapshot()), + ESQL_TOPN_BY, /** * Corrects a bug with ENRICH when a shard does not contain an index field and we use LIMIT BY on top diff --git a/x-pack/plugin/esql/src/main/java/org/elasticsearch/xpack/esql/parser/EsqlBaseParser.interp b/x-pack/plugin/esql/src/main/java/org/elasticsearch/xpack/esql/parser/EsqlBaseParser.interp index 5a206ccbb49e0..97e9818d37161 100644 --- a/x-pack/plugin/esql/src/main/java/org/elasticsearch/xpack/esql/parser/EsqlBaseParser.interp +++ b/x-pack/plugin/esql/src/main/java/org/elasticsearch/xpack/esql/parser/EsqlBaseParser.interp @@ -458,4 +458,4 @@ promqlIndexString atn: -[4, 1, 168, 1160, 2, 0, 7, 0, 2, 1, 7, 1, 2, 2, 7, 2, 2, 3, 7, 3, 2, 4, 7, 4, 2, 5, 7, 5, 2, 6, 7, 6, 2, 7, 7, 7, 2, 8, 7, 8, 2, 9, 7, 9, 2, 10, 7, 10, 2, 11, 7, 11, 2, 12, 7, 12, 2, 13, 7, 13, 2, 14, 7, 14, 2, 15, 7, 15, 2, 16, 7, 16, 2, 17, 7, 17, 2, 18, 7, 18, 2, 19, 7, 19, 2, 20, 7, 20, 2, 21, 7, 21, 2, 22, 7, 22, 2, 23, 7, 23, 2, 24, 7, 24, 2, 25, 7, 25, 2, 26, 7, 26, 2, 27, 7, 27, 2, 28, 7, 28, 2, 29, 7, 29, 2, 30, 7, 30, 2, 31, 7, 31, 2, 32, 7, 32, 2, 33, 7, 33, 2, 34, 7, 34, 2, 35, 7, 35, 2, 36, 7, 36, 2, 37, 7, 37, 2, 38, 7, 38, 2, 39, 7, 39, 2, 40, 7, 40, 2, 41, 7, 41, 2, 42, 7, 42, 2, 43, 7, 43, 2, 44, 7, 44, 2, 45, 7, 45, 2, 46, 7, 46, 2, 47, 7, 47, 2, 48, 7, 48, 2, 49, 7, 49, 2, 50, 7, 50, 2, 51, 7, 51, 2, 52, 7, 52, 2, 53, 7, 53, 2, 54, 7, 54, 2, 55, 7, 55, 2, 56, 7, 56, 2, 57, 7, 57, 2, 58, 7, 58, 2, 59, 7, 59, 2, 60, 7, 60, 2, 61, 7, 61, 2, 62, 7, 62, 2, 63, 7, 63, 2, 64, 7, 64, 2, 65, 7, 65, 2, 66, 7, 66, 2, 67, 7, 67, 2, 68, 7, 68, 2, 69, 7, 69, 2, 70, 7, 70, 2, 71, 7, 71, 2, 72, 7, 72, 2, 73, 7, 73, 2, 74, 7, 74, 2, 75, 7, 75, 2, 76, 7, 76, 2, 77, 7, 77, 2, 78, 7, 78, 2, 79, 7, 79, 2, 80, 7, 80, 2, 81, 7, 81, 2, 82, 7, 82, 2, 83, 7, 83, 2, 84, 7, 84, 2, 85, 7, 85, 2, 86, 7, 86, 2, 87, 7, 87, 2, 88, 7, 88, 2, 89, 7, 89, 2, 90, 7, 90, 2, 91, 7, 91, 2, 92, 7, 92, 2, 93, 7, 93, 2, 94, 7, 94, 2, 95, 7, 95, 2, 96, 7, 96, 2, 97, 7, 97, 2, 98, 7, 98, 2, 99, 7, 99, 2, 100, 7, 100, 2, 101, 7, 101, 2, 102, 7, 102, 2, 103, 7, 103, 2, 104, 7, 104, 2, 105, 7, 105, 2, 106, 7, 106, 2, 107, 7, 107, 2, 108, 7, 108, 2, 109, 7, 109, 2, 110, 7, 110, 2, 111, 7, 111, 2, 112, 7, 112, 2, 113, 7, 113, 1, 0, 5, 0, 230, 8, 0, 10, 0, 12, 0, 233, 9, 0, 1, 0, 1, 0, 1, 0, 1, 1, 1, 1, 1, 1, 1, 2, 1, 2, 1, 2, 1, 2, 1, 2, 1, 2, 5, 2, 247, 8, 2, 10, 2, 12, 2, 250, 9, 2, 1, 3, 1, 3, 1, 3, 1, 3, 1, 3, 1, 3, 1, 3, 1, 3, 1, 3, 3, 3, 261, 8, 3, 1, 4, 1, 4, 1, 4, 1, 4, 1, 4, 1, 4, 1, 4, 1, 4, 1, 4, 1, 4, 1, 4, 1, 4, 1, 4, 1, 4, 1, 4, 1, 4, 1, 4, 1, 4, 1, 4, 1, 4, 1, 4, 1, 4, 1, 4, 1, 4, 1, 4, 1, 4, 1, 4, 1, 4, 1, 4, 3, 4, 292, 8, 4, 1, 5, 1, 5, 1, 5, 1, 6, 1, 6, 1, 7, 1, 7, 1, 7, 1, 8, 1, 8, 1, 8, 5, 8, 305, 8, 8, 10, 8, 12, 8, 308, 9, 8, 1, 9, 1, 9, 1, 9, 3, 9, 313, 8, 9, 1, 9, 1, 9, 1, 10, 1, 10, 1, 10, 1, 11, 1, 11, 1, 11, 1, 12, 1, 12, 1, 12, 1, 12, 1, 13, 1, 13, 1, 13, 5, 13, 330, 8, 13, 10, 13, 12, 13, 333, 9, 13, 1, 13, 3, 13, 336, 8, 13, 1, 14, 1, 14, 1, 14, 3, 14, 341, 8, 14, 1, 15, 1, 15, 1, 15, 1, 15, 5, 15, 347, 8, 15, 10, 15, 12, 15, 350, 9, 15, 1, 15, 1, 15, 1, 16, 1, 16, 1, 16, 3, 16, 357, 8, 16, 1, 16, 1, 16, 1, 16, 3, 16, 362, 8, 16, 1, 16, 3, 16, 365, 8, 16, 1, 17, 1, 17, 1, 18, 1, 18, 1, 19, 1, 19, 1, 20, 1, 20, 1, 21, 1, 21, 1, 21, 1, 21, 5, 21, 379, 8, 21, 10, 21, 12, 21, 382, 9, 21, 1, 22, 1, 22, 1, 22, 1, 23, 1, 23, 3, 23, 389, 8, 23, 1, 23, 1, 23, 3, 23, 393, 8, 23, 1, 24, 1, 24, 1, 24, 5, 24, 398, 8, 24, 10, 24, 12, 24, 401, 9, 24, 1, 25, 1, 25, 1, 25, 3, 25, 406, 8, 25, 1, 26, 1, 26, 1, 26, 3, 26, 411, 8, 26, 1, 26, 1, 26, 1, 26, 1, 26, 1, 26, 1, 26, 1, 26, 3, 26, 420, 8, 26, 1, 27, 1, 27, 1, 27, 5, 27, 425, 8, 27, 10, 27, 12, 27, 428, 9, 27, 1, 28, 1, 28, 1, 28, 3, 28, 433, 8, 28, 1, 28, 1, 28, 1, 28, 1, 28, 1, 28, 1, 28, 1, 28, 3, 28, 442, 8, 28, 1, 29, 1, 29, 1, 29, 5, 29, 447, 8, 29, 10, 29, 12, 29, 450, 9, 29, 1, 30, 1, 30, 1, 30, 5, 30, 455, 8, 30, 10, 30, 12, 30, 458, 9, 30, 1, 31, 1, 31, 1, 32, 1, 32, 1, 32, 3, 32, 465, 8, 32, 1, 33, 1, 33, 3, 33, 469, 8, 33, 1, 34, 1, 34, 3, 34, 473, 8, 34, 1, 35, 1, 35, 1, 35, 3, 35, 478, 8, 35, 1, 36, 1, 36, 3, 36, 482, 8, 36, 1, 37, 1, 37, 1, 37, 3, 37, 487, 8, 37, 1, 38, 1, 38, 1, 38, 1, 38, 1, 38, 5, 38, 494, 8, 38, 10, 38, 12, 38, 497, 9, 38, 1, 39, 1, 39, 1, 39, 1, 39, 5, 39, 503, 8, 39, 10, 39, 12, 39, 506, 9, 39, 1, 40, 1, 40, 3, 40, 510, 8, 40, 1, 40, 1, 40, 3, 40, 514, 8, 40, 1, 41, 1, 41, 1, 41, 1, 42, 1, 42, 1, 42, 1, 43, 1, 43, 1, 43, 1, 43, 5, 43, 526, 8, 43, 10, 43, 12, 43, 529, 9, 43, 1, 44, 1, 44, 1, 44, 1, 44, 1, 44, 1, 44, 1, 44, 1, 44, 3, 44, 539, 8, 44, 1, 45, 1, 45, 1, 45, 1, 45, 3, 45, 545, 8, 45, 1, 46, 1, 46, 1, 46, 5, 46, 550, 8, 46, 10, 46, 12, 46, 553, 9, 46, 1, 47, 1, 47, 1, 47, 1, 47, 1, 48, 1, 48, 3, 48, 561, 8, 48, 1, 49, 1, 49, 1, 49, 1, 49, 1, 49, 5, 49, 568, 8, 49, 10, 49, 12, 49, 571, 9, 49, 1, 50, 1, 50, 1, 50, 1, 51, 1, 51, 1, 51, 1, 52, 1, 52, 1, 52, 1, 52, 1, 53, 1, 53, 1, 53, 1, 54, 1, 54, 1, 54, 1, 54, 3, 54, 590, 8, 54, 1, 54, 1, 54, 1, 54, 1, 54, 5, 54, 596, 8, 54, 10, 54, 12, 54, 599, 9, 54, 3, 54, 601, 8, 54, 1, 55, 1, 55, 1, 56, 1, 56, 1, 56, 3, 56, 608, 8, 56, 1, 56, 1, 56, 1, 57, 1, 57, 1, 57, 1, 58, 1, 58, 1, 58, 5, 58, 618, 8, 58, 10, 58, 12, 58, 621, 9, 58, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 3, 59, 630, 8, 59, 1, 60, 1, 60, 1, 60, 1, 61, 4, 61, 636, 8, 61, 11, 61, 12, 61, 637, 1, 62, 1, 62, 1, 62, 1, 62, 1, 63, 1, 63, 1, 63, 1, 63, 1, 63, 1, 63, 5, 63, 650, 8, 63, 10, 63, 12, 63, 653, 9, 63, 1, 64, 1, 64, 1, 65, 1, 65, 1, 65, 1, 65, 3, 65, 661, 8, 65, 1, 65, 1, 65, 1, 65, 1, 65, 1, 65, 1, 66, 1, 66, 1, 66, 1, 66, 3, 66, 672, 8, 66, 1, 66, 1, 66, 1, 66, 1, 67, 1, 67, 1, 67, 1, 67, 1, 67, 3, 67, 682, 8, 67, 1, 67, 1, 67, 1, 67, 1, 67, 3, 67, 688, 8, 67, 3, 67, 690, 8, 67, 1, 68, 1, 68, 3, 68, 694, 8, 68, 1, 68, 5, 68, 697, 8, 68, 10, 68, 12, 68, 700, 9, 68, 1, 69, 1, 69, 1, 69, 1, 69, 1, 69, 1, 69, 1, 69, 1, 69, 1, 69, 1, 69, 1, 69, 3, 69, 713, 8, 69, 1, 70, 1, 70, 1, 70, 5, 70, 718, 8, 70, 10, 70, 12, 70, 721, 9, 70, 1, 71, 1, 71, 1, 72, 1, 72, 1, 73, 1, 73, 1, 73, 1, 73, 1, 73, 1, 74, 1, 74, 1, 74, 1, 75, 1, 75, 1, 75, 1, 75, 1, 75, 1, 76, 1, 76, 1, 76, 1, 76, 1, 76, 1, 77, 1, 77, 1, 77, 1, 77, 1, 78, 1, 78, 1, 78, 1, 78, 3, 78, 753, 8, 78, 1, 79, 1, 79, 3, 79, 757, 8, 79, 1, 79, 1, 79, 1, 79, 1, 79, 1, 79, 1, 79, 1, 80, 1, 80, 3, 80, 767, 8, 80, 1, 81, 1, 81, 1, 81, 1, 81, 1, 81, 1, 81, 1, 81, 3, 81, 776, 8, 81, 1, 81, 1, 81, 1, 81, 1, 81, 1, 81, 5, 81, 783, 8, 81, 10, 81, 12, 81, 786, 9, 81, 1, 81, 1, 81, 1, 81, 1, 81, 1, 81, 3, 81, 793, 8, 81, 1, 81, 1, 81, 1, 81, 3, 81, 798, 8, 81, 1, 81, 1, 81, 1, 81, 1, 81, 1, 81, 1, 81, 5, 81, 806, 8, 81, 10, 81, 12, 81, 809, 9, 81, 1, 82, 1, 82, 3, 82, 813, 8, 82, 1, 82, 1, 82, 1, 82, 1, 82, 1, 82, 3, 82, 820, 8, 82, 1, 82, 1, 82, 1, 82, 1, 82, 1, 82, 3, 82, 827, 8, 82, 1, 82, 1, 82, 1, 82, 1, 82, 1, 82, 5, 82, 834, 8, 82, 10, 82, 12, 82, 837, 9, 82, 1, 82, 1, 82, 1, 82, 1, 82, 3, 82, 843, 8, 82, 1, 82, 1, 82, 1, 82, 1, 82, 1, 82, 5, 82, 850, 8, 82, 10, 82, 12, 82, 853, 9, 82, 1, 82, 1, 82, 3, 82, 857, 8, 82, 1, 83, 1, 83, 1, 83, 3, 83, 862, 8, 83, 1, 83, 1, 83, 1, 83, 1, 84, 1, 84, 1, 84, 1, 84, 1, 84, 3, 84, 872, 8, 84, 1, 85, 1, 85, 1, 85, 1, 85, 3, 85, 878, 8, 85, 1, 85, 1, 85, 1, 85, 1, 85, 1, 85, 1, 85, 5, 85, 886, 8, 85, 10, 85, 12, 85, 889, 9, 85, 1, 86, 1, 86, 1, 86, 1, 86, 1, 86, 1, 86, 1, 86, 1, 86, 3, 86, 899, 8, 86, 1, 86, 1, 86, 1, 86, 5, 86, 904, 8, 86, 10, 86, 12, 86, 907, 9, 86, 1, 87, 1, 87, 1, 87, 1, 87, 1, 87, 1, 87, 5, 87, 915, 8, 87, 10, 87, 12, 87, 918, 9, 87, 1, 87, 1, 87, 3, 87, 922, 8, 87, 3, 87, 924, 8, 87, 1, 87, 1, 87, 1, 88, 1, 88, 1, 88, 3, 88, 931, 8, 88, 1, 89, 1, 89, 1, 89, 1, 89, 5, 89, 937, 8, 89, 10, 89, 12, 89, 940, 9, 89, 3, 89, 942, 8, 89, 1, 89, 1, 89, 1, 90, 1, 90, 1, 90, 1, 90, 1, 91, 1, 91, 3, 91, 952, 8, 91, 1, 92, 1, 92, 1, 92, 1, 92, 1, 92, 1, 92, 1, 92, 1, 92, 1, 92, 1, 92, 1, 92, 1, 92, 1, 92, 5, 92, 967, 8, 92, 10, 92, 12, 92, 970, 9, 92, 1, 92, 1, 92, 1, 92, 1, 92, 1, 92, 1, 92, 5, 92, 978, 8, 92, 10, 92, 12, 92, 981, 9, 92, 1, 92, 1, 92, 1, 92, 1, 92, 1, 92, 1, 92, 5, 92, 989, 8, 92, 10, 92, 12, 92, 992, 9, 92, 1, 92, 1, 92, 3, 92, 996, 8, 92, 1, 93, 1, 93, 1, 94, 1, 94, 3, 94, 1002, 8, 94, 1, 95, 3, 95, 1005, 8, 95, 1, 95, 1, 95, 1, 96, 3, 96, 1010, 8, 96, 1, 96, 1, 96, 1, 97, 1, 97, 1, 98, 1, 98, 1, 99, 1, 99, 1, 99, 1, 99, 1, 99, 1, 100, 1, 100, 1, 100, 3, 100, 1026, 8, 100, 1, 100, 1, 100, 1, 100, 3, 100, 1031, 8, 100, 1, 101, 1, 101, 1, 101, 1, 101, 5, 101, 1037, 8, 101, 10, 101, 12, 101, 1040, 9, 101, 1, 102, 1, 102, 5, 102, 1044, 8, 102, 10, 102, 12, 102, 1047, 9, 102, 1, 102, 1, 102, 1, 102, 3, 102, 1052, 8, 102, 1, 102, 1, 102, 1, 102, 1, 102, 1, 102, 5, 102, 1059, 8, 102, 10, 102, 12, 102, 1062, 9, 102, 1, 102, 1, 102, 1, 102, 3, 102, 1067, 8, 102, 1, 102, 1, 102, 1, 102, 5, 102, 1072, 8, 102, 10, 102, 12, 102, 1075, 9, 102, 1, 102, 1, 102, 1, 102, 3, 102, 1080, 8, 102, 1, 102, 1, 102, 4, 102, 1084, 8, 102, 11, 102, 12, 102, 1085, 1, 102, 1, 102, 1, 102, 1, 102, 5, 102, 1092, 8, 102, 10, 102, 12, 102, 1095, 9, 102, 1, 102, 4, 102, 1098, 8, 102, 11, 102, 12, 102, 1099, 3, 102, 1102, 8, 102, 1, 103, 1, 103, 1, 104, 1, 104, 1, 104, 1, 104, 1, 105, 1, 105, 1, 106, 1, 106, 1, 106, 5, 106, 1115, 8, 106, 10, 106, 12, 106, 1118, 9, 106, 1, 106, 1, 106, 3, 106, 1122, 8, 106, 1, 107, 1, 107, 1, 108, 4, 108, 1127, 8, 108, 11, 108, 12, 108, 1128, 1, 108, 1, 108, 5, 108, 1133, 8, 108, 10, 108, 12, 108, 1136, 9, 108, 1, 108, 3, 108, 1139, 8, 108, 1, 109, 1, 109, 1, 109, 1, 109, 1, 109, 1, 109, 1, 109, 1, 109, 1, 109, 3, 109, 1150, 8, 109, 1, 110, 1, 110, 1, 111, 1, 111, 1, 112, 1, 112, 1, 113, 1, 113, 1, 113, 0, 5, 4, 126, 162, 170, 172, 114, 0, 2, 4, 6, 8, 10, 12, 14, 16, 18, 20, 22, 24, 26, 28, 30, 32, 34, 36, 38, 40, 42, 44, 46, 48, 50, 52, 54, 56, 58, 60, 62, 64, 66, 68, 70, 72, 74, 76, 78, 80, 82, 84, 86, 88, 90, 92, 94, 96, 98, 100, 102, 104, 106, 108, 110, 112, 114, 116, 118, 120, 122, 124, 126, 128, 130, 132, 134, 136, 138, 140, 142, 144, 146, 148, 150, 152, 154, 156, 158, 160, 162, 164, 166, 168, 170, 172, 174, 176, 178, 180, 182, 184, 186, 188, 190, 192, 194, 196, 198, 200, 202, 204, 206, 208, 210, 212, 214, 216, 218, 220, 222, 224, 226, 0, 14, 2, 0, 58, 58, 113, 113, 1, 0, 107, 108, 2, 0, 62, 62, 69, 69, 2, 0, 72, 72, 75, 75, 2, 0, 47, 47, 58, 58, 1, 0, 93, 94, 1, 0, 95, 97, 2, 0, 71, 71, 84, 84, 2, 0, 86, 86, 88, 92, 2, 0, 29, 29, 31, 32, 3, 0, 58, 58, 101, 101, 107, 108, 8, 0, 58, 58, 63, 63, 65, 66, 68, 68, 101, 101, 107, 108, 113, 113, 155, 157, 2, 0, 107, 107, 113, 113, 3, 0, 58, 58, 107, 107, 113, 113, 1215, 0, 231, 1, 0, 0, 0, 2, 237, 1, 0, 0, 0, 4, 240, 1, 0, 0, 0, 6, 260, 1, 0, 0, 0, 8, 291, 1, 0, 0, 0, 10, 293, 1, 0, 0, 0, 12, 296, 1, 0, 0, 0, 14, 298, 1, 0, 0, 0, 16, 301, 1, 0, 0, 0, 18, 312, 1, 0, 0, 0, 20, 316, 1, 0, 0, 0, 22, 319, 1, 0, 0, 0, 24, 322, 1, 0, 0, 0, 26, 326, 1, 0, 0, 0, 28, 340, 1, 0, 0, 0, 30, 342, 1, 0, 0, 0, 32, 364, 1, 0, 0, 0, 34, 366, 1, 0, 0, 0, 36, 368, 1, 0, 0, 0, 38, 370, 1, 0, 0, 0, 40, 372, 1, 0, 0, 0, 42, 374, 1, 0, 0, 0, 44, 383, 1, 0, 0, 0, 46, 386, 1, 0, 0, 0, 48, 394, 1, 0, 0, 0, 50, 402, 1, 0, 0, 0, 52, 419, 1, 0, 0, 0, 54, 421, 1, 0, 0, 0, 56, 441, 1, 0, 0, 0, 58, 443, 1, 0, 0, 0, 60, 451, 1, 0, 0, 0, 62, 459, 1, 0, 0, 0, 64, 464, 1, 0, 0, 0, 66, 468, 1, 0, 0, 0, 68, 472, 1, 0, 0, 0, 70, 477, 1, 0, 0, 0, 72, 481, 1, 0, 0, 0, 74, 483, 1, 0, 0, 0, 76, 488, 1, 0, 0, 0, 78, 498, 1, 0, 0, 0, 80, 507, 1, 0, 0, 0, 82, 515, 1, 0, 0, 0, 84, 518, 1, 0, 0, 0, 86, 521, 1, 0, 0, 0, 88, 538, 1, 0, 0, 0, 90, 540, 1, 0, 0, 0, 92, 546, 1, 0, 0, 0, 94, 554, 1, 0, 0, 0, 96, 560, 1, 0, 0, 0, 98, 562, 1, 0, 0, 0, 100, 572, 1, 0, 0, 0, 102, 575, 1, 0, 0, 0, 104, 578, 1, 0, 0, 0, 106, 582, 1, 0, 0, 0, 108, 585, 1, 0, 0, 0, 110, 602, 1, 0, 0, 0, 112, 607, 1, 0, 0, 0, 114, 611, 1, 0, 0, 0, 116, 614, 1, 0, 0, 0, 118, 629, 1, 0, 0, 0, 120, 631, 1, 0, 0, 0, 122, 635, 1, 0, 0, 0, 124, 639, 1, 0, 0, 0, 126, 643, 1, 0, 0, 0, 128, 654, 1, 0, 0, 0, 130, 656, 1, 0, 0, 0, 132, 667, 1, 0, 0, 0, 134, 689, 1, 0, 0, 0, 136, 691, 1, 0, 0, 0, 138, 712, 1, 0, 0, 0, 140, 714, 1, 0, 0, 0, 142, 722, 1, 0, 0, 0, 144, 724, 1, 0, 0, 0, 146, 726, 1, 0, 0, 0, 148, 731, 1, 0, 0, 0, 150, 734, 1, 0, 0, 0, 152, 739, 1, 0, 0, 0, 154, 744, 1, 0, 0, 0, 156, 748, 1, 0, 0, 0, 158, 754, 1, 0, 0, 0, 160, 766, 1, 0, 0, 0, 162, 797, 1, 0, 0, 0, 164, 856, 1, 0, 0, 0, 166, 858, 1, 0, 0, 0, 168, 871, 1, 0, 0, 0, 170, 877, 1, 0, 0, 0, 172, 898, 1, 0, 0, 0, 174, 908, 1, 0, 0, 0, 176, 930, 1, 0, 0, 0, 178, 932, 1, 0, 0, 0, 180, 945, 1, 0, 0, 0, 182, 951, 1, 0, 0, 0, 184, 995, 1, 0, 0, 0, 186, 997, 1, 0, 0, 0, 188, 1001, 1, 0, 0, 0, 190, 1004, 1, 0, 0, 0, 192, 1009, 1, 0, 0, 0, 194, 1013, 1, 0, 0, 0, 196, 1015, 1, 0, 0, 0, 198, 1017, 1, 0, 0, 0, 200, 1030, 1, 0, 0, 0, 202, 1032, 1, 0, 0, 0, 204, 1101, 1, 0, 0, 0, 206, 1103, 1, 0, 0, 0, 208, 1105, 1, 0, 0, 0, 210, 1109, 1, 0, 0, 0, 212, 1121, 1, 0, 0, 0, 214, 1123, 1, 0, 0, 0, 216, 1138, 1, 0, 0, 0, 218, 1149, 1, 0, 0, 0, 220, 1151, 1, 0, 0, 0, 222, 1153, 1, 0, 0, 0, 224, 1155, 1, 0, 0, 0, 226, 1157, 1, 0, 0, 0, 228, 230, 3, 154, 77, 0, 229, 228, 1, 0, 0, 0, 230, 233, 1, 0, 0, 0, 231, 229, 1, 0, 0, 0, 231, 232, 1, 0, 0, 0, 232, 234, 1, 0, 0, 0, 233, 231, 1, 0, 0, 0, 234, 235, 3, 2, 1, 0, 235, 236, 5, 0, 0, 1, 236, 1, 1, 0, 0, 0, 237, 238, 3, 4, 2, 0, 238, 239, 5, 0, 0, 1, 239, 3, 1, 0, 0, 0, 240, 241, 6, 2, -1, 0, 241, 242, 3, 6, 3, 0, 242, 248, 1, 0, 0, 0, 243, 244, 10, 1, 0, 0, 244, 245, 5, 57, 0, 0, 245, 247, 3, 8, 4, 0, 246, 243, 1, 0, 0, 0, 247, 250, 1, 0, 0, 0, 248, 246, 1, 0, 0, 0, 248, 249, 1, 0, 0, 0, 249, 5, 1, 0, 0, 0, 250, 248, 1, 0, 0, 0, 251, 261, 3, 20, 10, 0, 252, 261, 3, 14, 7, 0, 253, 261, 3, 106, 53, 0, 254, 261, 3, 22, 11, 0, 255, 261, 3, 204, 102, 0, 256, 257, 4, 3, 1, 0, 257, 261, 3, 102, 51, 0, 258, 259, 4, 3, 2, 0, 259, 261, 3, 24, 12, 0, 260, 251, 1, 0, 0, 0, 260, 252, 1, 0, 0, 0, 260, 253, 1, 0, 0, 0, 260, 254, 1, 0, 0, 0, 260, 255, 1, 0, 0, 0, 260, 256, 1, 0, 0, 0, 260, 258, 1, 0, 0, 0, 261, 7, 1, 0, 0, 0, 262, 292, 3, 44, 22, 0, 263, 292, 3, 10, 5, 0, 264, 292, 3, 82, 41, 0, 265, 292, 3, 74, 37, 0, 266, 292, 3, 46, 23, 0, 267, 292, 3, 78, 39, 0, 268, 292, 3, 84, 42, 0, 269, 292, 3, 86, 43, 0, 270, 292, 3, 90, 45, 0, 271, 292, 3, 98, 49, 0, 272, 292, 3, 108, 54, 0, 273, 292, 3, 100, 50, 0, 274, 292, 3, 198, 99, 0, 275, 292, 3, 116, 58, 0, 276, 292, 3, 132, 66, 0, 277, 292, 3, 114, 57, 0, 278, 292, 3, 120, 60, 0, 279, 292, 3, 130, 65, 0, 280, 292, 3, 134, 67, 0, 281, 292, 3, 136, 68, 0, 282, 292, 3, 150, 75, 0, 283, 292, 3, 142, 71, 0, 284, 292, 3, 152, 76, 0, 285, 292, 3, 144, 72, 0, 286, 292, 3, 158, 79, 0, 287, 288, 4, 4, 3, 0, 288, 292, 3, 146, 73, 0, 289, 290, 4, 4, 4, 0, 290, 292, 3, 148, 74, 0, 291, 262, 1, 0, 0, 0, 291, 263, 1, 0, 0, 0, 291, 264, 1, 0, 0, 0, 291, 265, 1, 0, 0, 0, 291, 266, 1, 0, 0, 0, 291, 267, 1, 0, 0, 0, 291, 268, 1, 0, 0, 0, 291, 269, 1, 0, 0, 0, 291, 270, 1, 0, 0, 0, 291, 271, 1, 0, 0, 0, 291, 272, 1, 0, 0, 0, 291, 273, 1, 0, 0, 0, 291, 274, 1, 0, 0, 0, 291, 275, 1, 0, 0, 0, 291, 276, 1, 0, 0, 0, 291, 277, 1, 0, 0, 0, 291, 278, 1, 0, 0, 0, 291, 279, 1, 0, 0, 0, 291, 280, 1, 0, 0, 0, 291, 281, 1, 0, 0, 0, 291, 282, 1, 0, 0, 0, 291, 283, 1, 0, 0, 0, 291, 284, 1, 0, 0, 0, 291, 285, 1, 0, 0, 0, 291, 286, 1, 0, 0, 0, 291, 287, 1, 0, 0, 0, 291, 289, 1, 0, 0, 0, 292, 9, 1, 0, 0, 0, 293, 294, 5, 17, 0, 0, 294, 295, 3, 162, 81, 0, 295, 11, 1, 0, 0, 0, 296, 297, 3, 62, 31, 0, 297, 13, 1, 0, 0, 0, 298, 299, 5, 13, 0, 0, 299, 300, 3, 16, 8, 0, 300, 15, 1, 0, 0, 0, 301, 306, 3, 18, 9, 0, 302, 303, 5, 68, 0, 0, 303, 305, 3, 18, 9, 0, 304, 302, 1, 0, 0, 0, 305, 308, 1, 0, 0, 0, 306, 304, 1, 0, 0, 0, 306, 307, 1, 0, 0, 0, 307, 17, 1, 0, 0, 0, 308, 306, 1, 0, 0, 0, 309, 310, 3, 52, 26, 0, 310, 311, 5, 63, 0, 0, 311, 313, 1, 0, 0, 0, 312, 309, 1, 0, 0, 0, 312, 313, 1, 0, 0, 0, 313, 314, 1, 0, 0, 0, 314, 315, 3, 162, 81, 0, 315, 19, 1, 0, 0, 0, 316, 317, 5, 22, 0, 0, 317, 318, 3, 26, 13, 0, 318, 21, 1, 0, 0, 0, 319, 320, 5, 23, 0, 0, 320, 321, 3, 26, 13, 0, 321, 23, 1, 0, 0, 0, 322, 323, 5, 24, 0, 0, 323, 324, 3, 72, 36, 0, 324, 325, 3, 96, 48, 0, 325, 25, 1, 0, 0, 0, 326, 331, 3, 28, 14, 0, 327, 328, 5, 68, 0, 0, 328, 330, 3, 28, 14, 0, 329, 327, 1, 0, 0, 0, 330, 333, 1, 0, 0, 0, 331, 329, 1, 0, 0, 0, 331, 332, 1, 0, 0, 0, 332, 335, 1, 0, 0, 0, 333, 331, 1, 0, 0, 0, 334, 336, 3, 42, 21, 0, 335, 334, 1, 0, 0, 0, 335, 336, 1, 0, 0, 0, 336, 27, 1, 0, 0, 0, 337, 341, 3, 32, 16, 0, 338, 339, 4, 14, 5, 0, 339, 341, 3, 30, 15, 0, 340, 337, 1, 0, 0, 0, 340, 338, 1, 0, 0, 0, 341, 29, 1, 0, 0, 0, 342, 343, 5, 105, 0, 0, 343, 348, 3, 20, 10, 0, 344, 345, 5, 57, 0, 0, 345, 347, 3, 8, 4, 0, 346, 344, 1, 0, 0, 0, 347, 350, 1, 0, 0, 0, 348, 346, 1, 0, 0, 0, 348, 349, 1, 0, 0, 0, 349, 351, 1, 0, 0, 0, 350, 348, 1, 0, 0, 0, 351, 352, 5, 106, 0, 0, 352, 31, 1, 0, 0, 0, 353, 354, 3, 34, 17, 0, 354, 355, 5, 66, 0, 0, 355, 357, 1, 0, 0, 0, 356, 353, 1, 0, 0, 0, 356, 357, 1, 0, 0, 0, 357, 358, 1, 0, 0, 0, 358, 361, 3, 38, 19, 0, 359, 360, 5, 65, 0, 0, 360, 362, 3, 36, 18, 0, 361, 359, 1, 0, 0, 0, 361, 362, 1, 0, 0, 0, 362, 365, 1, 0, 0, 0, 363, 365, 3, 40, 20, 0, 364, 356, 1, 0, 0, 0, 364, 363, 1, 0, 0, 0, 365, 33, 1, 0, 0, 0, 366, 367, 5, 113, 0, 0, 367, 35, 1, 0, 0, 0, 368, 369, 5, 113, 0, 0, 369, 37, 1, 0, 0, 0, 370, 371, 5, 113, 0, 0, 371, 39, 1, 0, 0, 0, 372, 373, 7, 0, 0, 0, 373, 41, 1, 0, 0, 0, 374, 375, 5, 112, 0, 0, 375, 380, 5, 113, 0, 0, 376, 377, 5, 68, 0, 0, 377, 379, 5, 113, 0, 0, 378, 376, 1, 0, 0, 0, 379, 382, 1, 0, 0, 0, 380, 378, 1, 0, 0, 0, 380, 381, 1, 0, 0, 0, 381, 43, 1, 0, 0, 0, 382, 380, 1, 0, 0, 0, 383, 384, 5, 9, 0, 0, 384, 385, 3, 16, 8, 0, 385, 45, 1, 0, 0, 0, 386, 388, 5, 16, 0, 0, 387, 389, 3, 48, 24, 0, 388, 387, 1, 0, 0, 0, 388, 389, 1, 0, 0, 0, 389, 392, 1, 0, 0, 0, 390, 391, 5, 64, 0, 0, 391, 393, 3, 16, 8, 0, 392, 390, 1, 0, 0, 0, 392, 393, 1, 0, 0, 0, 393, 47, 1, 0, 0, 0, 394, 399, 3, 50, 25, 0, 395, 396, 5, 68, 0, 0, 396, 398, 3, 50, 25, 0, 397, 395, 1, 0, 0, 0, 398, 401, 1, 0, 0, 0, 399, 397, 1, 0, 0, 0, 399, 400, 1, 0, 0, 0, 400, 49, 1, 0, 0, 0, 401, 399, 1, 0, 0, 0, 402, 405, 3, 18, 9, 0, 403, 404, 5, 17, 0, 0, 404, 406, 3, 162, 81, 0, 405, 403, 1, 0, 0, 0, 405, 406, 1, 0, 0, 0, 406, 51, 1, 0, 0, 0, 407, 408, 4, 26, 6, 0, 408, 410, 5, 103, 0, 0, 409, 411, 5, 107, 0, 0, 410, 409, 1, 0, 0, 0, 410, 411, 1, 0, 0, 0, 411, 412, 1, 0, 0, 0, 412, 413, 5, 104, 0, 0, 413, 414, 5, 70, 0, 0, 414, 415, 5, 103, 0, 0, 415, 416, 3, 54, 27, 0, 416, 417, 5, 104, 0, 0, 417, 420, 1, 0, 0, 0, 418, 420, 3, 54, 27, 0, 419, 407, 1, 0, 0, 0, 419, 418, 1, 0, 0, 0, 420, 53, 1, 0, 0, 0, 421, 426, 3, 70, 35, 0, 422, 423, 5, 70, 0, 0, 423, 425, 3, 70, 35, 0, 424, 422, 1, 0, 0, 0, 425, 428, 1, 0, 0, 0, 426, 424, 1, 0, 0, 0, 426, 427, 1, 0, 0, 0, 427, 55, 1, 0, 0, 0, 428, 426, 1, 0, 0, 0, 429, 430, 4, 28, 7, 0, 430, 432, 5, 103, 0, 0, 431, 433, 5, 148, 0, 0, 432, 431, 1, 0, 0, 0, 432, 433, 1, 0, 0, 0, 433, 434, 1, 0, 0, 0, 434, 435, 5, 104, 0, 0, 435, 436, 5, 70, 0, 0, 436, 437, 5, 103, 0, 0, 437, 438, 3, 58, 29, 0, 438, 439, 5, 104, 0, 0, 439, 442, 1, 0, 0, 0, 440, 442, 3, 58, 29, 0, 441, 429, 1, 0, 0, 0, 441, 440, 1, 0, 0, 0, 442, 57, 1, 0, 0, 0, 443, 448, 3, 64, 32, 0, 444, 445, 5, 70, 0, 0, 445, 447, 3, 64, 32, 0, 446, 444, 1, 0, 0, 0, 447, 450, 1, 0, 0, 0, 448, 446, 1, 0, 0, 0, 448, 449, 1, 0, 0, 0, 449, 59, 1, 0, 0, 0, 450, 448, 1, 0, 0, 0, 451, 456, 3, 56, 28, 0, 452, 453, 5, 68, 0, 0, 453, 455, 3, 56, 28, 0, 454, 452, 1, 0, 0, 0, 455, 458, 1, 0, 0, 0, 456, 454, 1, 0, 0, 0, 456, 457, 1, 0, 0, 0, 457, 61, 1, 0, 0, 0, 458, 456, 1, 0, 0, 0, 459, 460, 7, 1, 0, 0, 460, 63, 1, 0, 0, 0, 461, 465, 5, 148, 0, 0, 462, 465, 3, 66, 33, 0, 463, 465, 3, 68, 34, 0, 464, 461, 1, 0, 0, 0, 464, 462, 1, 0, 0, 0, 464, 463, 1, 0, 0, 0, 465, 65, 1, 0, 0, 0, 466, 469, 5, 82, 0, 0, 467, 469, 5, 101, 0, 0, 468, 466, 1, 0, 0, 0, 468, 467, 1, 0, 0, 0, 469, 67, 1, 0, 0, 0, 470, 473, 5, 100, 0, 0, 471, 473, 5, 102, 0, 0, 472, 470, 1, 0, 0, 0, 472, 471, 1, 0, 0, 0, 473, 69, 1, 0, 0, 0, 474, 478, 3, 62, 31, 0, 475, 478, 3, 66, 33, 0, 476, 478, 3, 68, 34, 0, 477, 474, 1, 0, 0, 0, 477, 475, 1, 0, 0, 0, 477, 476, 1, 0, 0, 0, 478, 71, 1, 0, 0, 0, 479, 482, 3, 194, 97, 0, 480, 482, 3, 66, 33, 0, 481, 479, 1, 0, 0, 0, 481, 480, 1, 0, 0, 0, 482, 73, 1, 0, 0, 0, 483, 484, 5, 11, 0, 0, 484, 486, 3, 184, 92, 0, 485, 487, 3, 76, 38, 0, 486, 485, 1, 0, 0, 0, 486, 487, 1, 0, 0, 0, 487, 75, 1, 0, 0, 0, 488, 489, 4, 38, 8, 0, 489, 490, 5, 64, 0, 0, 490, 495, 3, 162, 81, 0, 491, 492, 5, 68, 0, 0, 492, 494, 3, 162, 81, 0, 493, 491, 1, 0, 0, 0, 494, 497, 1, 0, 0, 0, 495, 493, 1, 0, 0, 0, 495, 496, 1, 0, 0, 0, 496, 77, 1, 0, 0, 0, 497, 495, 1, 0, 0, 0, 498, 499, 5, 15, 0, 0, 499, 504, 3, 80, 40, 0, 500, 501, 5, 68, 0, 0, 501, 503, 3, 80, 40, 0, 502, 500, 1, 0, 0, 0, 503, 506, 1, 0, 0, 0, 504, 502, 1, 0, 0, 0, 504, 505, 1, 0, 0, 0, 505, 79, 1, 0, 0, 0, 506, 504, 1, 0, 0, 0, 507, 509, 3, 162, 81, 0, 508, 510, 7, 2, 0, 0, 509, 508, 1, 0, 0, 0, 509, 510, 1, 0, 0, 0, 510, 513, 1, 0, 0, 0, 511, 512, 5, 79, 0, 0, 512, 514, 7, 3, 0, 0, 513, 511, 1, 0, 0, 0, 513, 514, 1, 0, 0, 0, 514, 81, 1, 0, 0, 0, 515, 516, 5, 37, 0, 0, 516, 517, 3, 60, 30, 0, 517, 83, 1, 0, 0, 0, 518, 519, 5, 36, 0, 0, 519, 520, 3, 60, 30, 0, 520, 85, 1, 0, 0, 0, 521, 522, 5, 40, 0, 0, 522, 527, 3, 88, 44, 0, 523, 524, 5, 68, 0, 0, 524, 526, 3, 88, 44, 0, 525, 523, 1, 0, 0, 0, 526, 529, 1, 0, 0, 0, 527, 525, 1, 0, 0, 0, 527, 528, 1, 0, 0, 0, 528, 87, 1, 0, 0, 0, 529, 527, 1, 0, 0, 0, 530, 531, 3, 56, 28, 0, 531, 532, 5, 158, 0, 0, 532, 533, 3, 56, 28, 0, 533, 539, 1, 0, 0, 0, 534, 535, 3, 56, 28, 0, 535, 536, 5, 63, 0, 0, 536, 537, 3, 56, 28, 0, 537, 539, 1, 0, 0, 0, 538, 530, 1, 0, 0, 0, 538, 534, 1, 0, 0, 0, 539, 89, 1, 0, 0, 0, 540, 541, 5, 8, 0, 0, 541, 542, 3, 172, 86, 0, 542, 544, 3, 194, 97, 0, 543, 545, 3, 92, 46, 0, 544, 543, 1, 0, 0, 0, 544, 545, 1, 0, 0, 0, 545, 91, 1, 0, 0, 0, 546, 551, 3, 94, 47, 0, 547, 548, 5, 68, 0, 0, 548, 550, 3, 94, 47, 0, 549, 547, 1, 0, 0, 0, 550, 553, 1, 0, 0, 0, 551, 549, 1, 0, 0, 0, 551, 552, 1, 0, 0, 0, 552, 93, 1, 0, 0, 0, 553, 551, 1, 0, 0, 0, 554, 555, 3, 62, 31, 0, 555, 556, 5, 63, 0, 0, 556, 557, 3, 184, 92, 0, 557, 95, 1, 0, 0, 0, 558, 559, 5, 85, 0, 0, 559, 561, 3, 178, 89, 0, 560, 558, 1, 0, 0, 0, 560, 561, 1, 0, 0, 0, 561, 97, 1, 0, 0, 0, 562, 563, 5, 10, 0, 0, 563, 564, 3, 172, 86, 0, 564, 569, 3, 194, 97, 0, 565, 566, 5, 68, 0, 0, 566, 568, 3, 194, 97, 0, 567, 565, 1, 0, 0, 0, 568, 571, 1, 0, 0, 0, 569, 567, 1, 0, 0, 0, 569, 570, 1, 0, 0, 0, 570, 99, 1, 0, 0, 0, 571, 569, 1, 0, 0, 0, 572, 573, 5, 35, 0, 0, 573, 574, 3, 52, 26, 0, 574, 101, 1, 0, 0, 0, 575, 576, 5, 6, 0, 0, 576, 577, 3, 104, 52, 0, 577, 103, 1, 0, 0, 0, 578, 579, 5, 105, 0, 0, 579, 580, 3, 4, 2, 0, 580, 581, 5, 106, 0, 0, 581, 105, 1, 0, 0, 0, 582, 583, 5, 42, 0, 0, 583, 584, 5, 165, 0, 0, 584, 107, 1, 0, 0, 0, 585, 586, 5, 5, 0, 0, 586, 589, 3, 110, 55, 0, 587, 588, 5, 80, 0, 0, 588, 590, 3, 56, 28, 0, 589, 587, 1, 0, 0, 0, 589, 590, 1, 0, 0, 0, 590, 600, 1, 0, 0, 0, 591, 592, 5, 85, 0, 0, 592, 597, 3, 112, 56, 0, 593, 594, 5, 68, 0, 0, 594, 596, 3, 112, 56, 0, 595, 593, 1, 0, 0, 0, 596, 599, 1, 0, 0, 0, 597, 595, 1, 0, 0, 0, 597, 598, 1, 0, 0, 0, 598, 601, 1, 0, 0, 0, 599, 597, 1, 0, 0, 0, 600, 591, 1, 0, 0, 0, 600, 601, 1, 0, 0, 0, 601, 109, 1, 0, 0, 0, 602, 603, 7, 4, 0, 0, 603, 111, 1, 0, 0, 0, 604, 605, 3, 56, 28, 0, 605, 606, 5, 63, 0, 0, 606, 608, 1, 0, 0, 0, 607, 604, 1, 0, 0, 0, 607, 608, 1, 0, 0, 0, 608, 609, 1, 0, 0, 0, 609, 610, 3, 56, 28, 0, 610, 113, 1, 0, 0, 0, 611, 612, 5, 14, 0, 0, 612, 613, 3, 184, 92, 0, 613, 115, 1, 0, 0, 0, 614, 615, 5, 4, 0, 0, 615, 619, 3, 52, 26, 0, 616, 618, 3, 118, 59, 0, 617, 616, 1, 0, 0, 0, 618, 621, 1, 0, 0, 0, 619, 617, 1, 0, 0, 0, 619, 620, 1, 0, 0, 0, 620, 117, 1, 0, 0, 0, 621, 619, 1, 0, 0, 0, 622, 623, 5, 80, 0, 0, 623, 630, 3, 52, 26, 0, 624, 625, 5, 158, 0, 0, 625, 626, 3, 52, 26, 0, 626, 627, 5, 68, 0, 0, 627, 628, 3, 52, 26, 0, 628, 630, 1, 0, 0, 0, 629, 622, 1, 0, 0, 0, 629, 624, 1, 0, 0, 0, 630, 119, 1, 0, 0, 0, 631, 632, 5, 25, 0, 0, 632, 633, 3, 122, 61, 0, 633, 121, 1, 0, 0, 0, 634, 636, 3, 124, 62, 0, 635, 634, 1, 0, 0, 0, 636, 637, 1, 0, 0, 0, 637, 635, 1, 0, 0, 0, 637, 638, 1, 0, 0, 0, 638, 123, 1, 0, 0, 0, 639, 640, 5, 105, 0, 0, 640, 641, 3, 126, 63, 0, 641, 642, 5, 106, 0, 0, 642, 125, 1, 0, 0, 0, 643, 644, 6, 63, -1, 0, 644, 645, 3, 128, 64, 0, 645, 651, 1, 0, 0, 0, 646, 647, 10, 1, 0, 0, 647, 648, 5, 57, 0, 0, 648, 650, 3, 128, 64, 0, 649, 646, 1, 0, 0, 0, 650, 653, 1, 0, 0, 0, 651, 649, 1, 0, 0, 0, 651, 652, 1, 0, 0, 0, 652, 127, 1, 0, 0, 0, 653, 651, 1, 0, 0, 0, 654, 655, 3, 8, 4, 0, 655, 129, 1, 0, 0, 0, 656, 660, 5, 12, 0, 0, 657, 658, 3, 52, 26, 0, 658, 659, 5, 63, 0, 0, 659, 661, 1, 0, 0, 0, 660, 657, 1, 0, 0, 0, 660, 661, 1, 0, 0, 0, 661, 662, 1, 0, 0, 0, 662, 663, 3, 184, 92, 0, 663, 664, 5, 80, 0, 0, 664, 665, 3, 16, 8, 0, 665, 666, 3, 96, 48, 0, 666, 131, 1, 0, 0, 0, 667, 671, 5, 7, 0, 0, 668, 669, 3, 52, 26, 0, 669, 670, 5, 63, 0, 0, 670, 672, 1, 0, 0, 0, 671, 668, 1, 0, 0, 0, 671, 672, 1, 0, 0, 0, 672, 673, 1, 0, 0, 0, 673, 674, 3, 172, 86, 0, 674, 675, 3, 96, 48, 0, 675, 133, 1, 0, 0, 0, 676, 677, 5, 27, 0, 0, 677, 678, 5, 126, 0, 0, 678, 681, 3, 48, 24, 0, 679, 680, 5, 64, 0, 0, 680, 682, 3, 16, 8, 0, 681, 679, 1, 0, 0, 0, 681, 682, 1, 0, 0, 0, 682, 690, 1, 0, 0, 0, 683, 684, 5, 28, 0, 0, 684, 687, 3, 48, 24, 0, 685, 686, 5, 64, 0, 0, 686, 688, 3, 16, 8, 0, 687, 685, 1, 0, 0, 0, 687, 688, 1, 0, 0, 0, 688, 690, 1, 0, 0, 0, 689, 676, 1, 0, 0, 0, 689, 683, 1, 0, 0, 0, 690, 135, 1, 0, 0, 0, 691, 693, 5, 26, 0, 0, 692, 694, 3, 62, 31, 0, 693, 692, 1, 0, 0, 0, 693, 694, 1, 0, 0, 0, 694, 698, 1, 0, 0, 0, 695, 697, 3, 138, 69, 0, 696, 695, 1, 0, 0, 0, 697, 700, 1, 0, 0, 0, 698, 696, 1, 0, 0, 0, 698, 699, 1, 0, 0, 0, 699, 137, 1, 0, 0, 0, 700, 698, 1, 0, 0, 0, 701, 702, 5, 121, 0, 0, 702, 703, 5, 64, 0, 0, 703, 713, 3, 52, 26, 0, 704, 705, 5, 122, 0, 0, 705, 706, 5, 64, 0, 0, 706, 713, 3, 140, 70, 0, 707, 708, 5, 120, 0, 0, 708, 709, 5, 64, 0, 0, 709, 713, 3, 52, 26, 0, 710, 711, 5, 85, 0, 0, 711, 713, 3, 178, 89, 0, 712, 701, 1, 0, 0, 0, 712, 704, 1, 0, 0, 0, 712, 707, 1, 0, 0, 0, 712, 710, 1, 0, 0, 0, 713, 139, 1, 0, 0, 0, 714, 719, 3, 52, 26, 0, 715, 716, 5, 68, 0, 0, 716, 718, 3, 52, 26, 0, 717, 715, 1, 0, 0, 0, 718, 721, 1, 0, 0, 0, 719, 717, 1, 0, 0, 0, 719, 720, 1, 0, 0, 0, 720, 141, 1, 0, 0, 0, 721, 719, 1, 0, 0, 0, 722, 723, 5, 19, 0, 0, 723, 143, 1, 0, 0, 0, 724, 725, 5, 21, 0, 0, 725, 145, 1, 0, 0, 0, 726, 727, 5, 33, 0, 0, 727, 728, 3, 32, 16, 0, 728, 729, 5, 80, 0, 0, 729, 730, 3, 60, 30, 0, 730, 147, 1, 0, 0, 0, 731, 732, 5, 38, 0, 0, 732, 733, 3, 60, 30, 0, 733, 149, 1, 0, 0, 0, 734, 735, 5, 18, 0, 0, 735, 736, 3, 52, 26, 0, 736, 737, 5, 63, 0, 0, 737, 738, 3, 172, 86, 0, 738, 151, 1, 0, 0, 0, 739, 740, 5, 20, 0, 0, 740, 741, 3, 52, 26, 0, 741, 742, 5, 63, 0, 0, 742, 743, 3, 172, 86, 0, 743, 153, 1, 0, 0, 0, 744, 745, 5, 41, 0, 0, 745, 746, 3, 156, 78, 0, 746, 747, 5, 67, 0, 0, 747, 155, 1, 0, 0, 0, 748, 749, 3, 62, 31, 0, 749, 752, 5, 63, 0, 0, 750, 753, 3, 184, 92, 0, 751, 753, 3, 178, 89, 0, 752, 750, 1, 0, 0, 0, 752, 751, 1, 0, 0, 0, 753, 157, 1, 0, 0, 0, 754, 756, 5, 34, 0, 0, 755, 757, 3, 160, 80, 0, 756, 755, 1, 0, 0, 0, 756, 757, 1, 0, 0, 0, 757, 758, 1, 0, 0, 0, 758, 759, 5, 80, 0, 0, 759, 760, 3, 52, 26, 0, 760, 761, 5, 141, 0, 0, 761, 762, 3, 192, 96, 0, 762, 763, 3, 96, 48, 0, 763, 159, 1, 0, 0, 0, 764, 767, 3, 66, 33, 0, 765, 767, 3, 172, 86, 0, 766, 764, 1, 0, 0, 0, 766, 765, 1, 0, 0, 0, 767, 161, 1, 0, 0, 0, 768, 769, 6, 81, -1, 0, 769, 770, 5, 77, 0, 0, 770, 798, 3, 162, 81, 8, 771, 798, 3, 168, 84, 0, 772, 798, 3, 164, 82, 0, 773, 775, 3, 168, 84, 0, 774, 776, 5, 77, 0, 0, 775, 774, 1, 0, 0, 0, 775, 776, 1, 0, 0, 0, 776, 777, 1, 0, 0, 0, 777, 778, 5, 73, 0, 0, 778, 779, 5, 105, 0, 0, 779, 784, 3, 168, 84, 0, 780, 781, 5, 68, 0, 0, 781, 783, 3, 168, 84, 0, 782, 780, 1, 0, 0, 0, 783, 786, 1, 0, 0, 0, 784, 782, 1, 0, 0, 0, 784, 785, 1, 0, 0, 0, 785, 787, 1, 0, 0, 0, 786, 784, 1, 0, 0, 0, 787, 788, 5, 106, 0, 0, 788, 798, 1, 0, 0, 0, 789, 790, 3, 168, 84, 0, 790, 792, 5, 74, 0, 0, 791, 793, 5, 77, 0, 0, 792, 791, 1, 0, 0, 0, 792, 793, 1, 0, 0, 0, 793, 794, 1, 0, 0, 0, 794, 795, 5, 78, 0, 0, 795, 798, 1, 0, 0, 0, 796, 798, 3, 166, 83, 0, 797, 768, 1, 0, 0, 0, 797, 771, 1, 0, 0, 0, 797, 772, 1, 0, 0, 0, 797, 773, 1, 0, 0, 0, 797, 789, 1, 0, 0, 0, 797, 796, 1, 0, 0, 0, 798, 807, 1, 0, 0, 0, 799, 800, 10, 5, 0, 0, 800, 801, 5, 61, 0, 0, 801, 806, 3, 162, 81, 6, 802, 803, 10, 4, 0, 0, 803, 804, 5, 81, 0, 0, 804, 806, 3, 162, 81, 5, 805, 799, 1, 0, 0, 0, 805, 802, 1, 0, 0, 0, 806, 809, 1, 0, 0, 0, 807, 805, 1, 0, 0, 0, 807, 808, 1, 0, 0, 0, 808, 163, 1, 0, 0, 0, 809, 807, 1, 0, 0, 0, 810, 812, 3, 168, 84, 0, 811, 813, 5, 77, 0, 0, 812, 811, 1, 0, 0, 0, 812, 813, 1, 0, 0, 0, 813, 814, 1, 0, 0, 0, 814, 815, 5, 76, 0, 0, 815, 816, 3, 72, 36, 0, 816, 857, 1, 0, 0, 0, 817, 819, 3, 168, 84, 0, 818, 820, 5, 77, 0, 0, 819, 818, 1, 0, 0, 0, 819, 820, 1, 0, 0, 0, 820, 821, 1, 0, 0, 0, 821, 822, 5, 83, 0, 0, 822, 823, 3, 72, 36, 0, 823, 857, 1, 0, 0, 0, 824, 826, 3, 168, 84, 0, 825, 827, 5, 77, 0, 0, 826, 825, 1, 0, 0, 0, 826, 827, 1, 0, 0, 0, 827, 828, 1, 0, 0, 0, 828, 829, 5, 76, 0, 0, 829, 830, 5, 105, 0, 0, 830, 835, 3, 72, 36, 0, 831, 832, 5, 68, 0, 0, 832, 834, 3, 72, 36, 0, 833, 831, 1, 0, 0, 0, 834, 837, 1, 0, 0, 0, 835, 833, 1, 0, 0, 0, 835, 836, 1, 0, 0, 0, 836, 838, 1, 0, 0, 0, 837, 835, 1, 0, 0, 0, 838, 839, 5, 106, 0, 0, 839, 857, 1, 0, 0, 0, 840, 842, 3, 168, 84, 0, 841, 843, 5, 77, 0, 0, 842, 841, 1, 0, 0, 0, 842, 843, 1, 0, 0, 0, 843, 844, 1, 0, 0, 0, 844, 845, 5, 83, 0, 0, 845, 846, 5, 105, 0, 0, 846, 851, 3, 72, 36, 0, 847, 848, 5, 68, 0, 0, 848, 850, 3, 72, 36, 0, 849, 847, 1, 0, 0, 0, 850, 853, 1, 0, 0, 0, 851, 849, 1, 0, 0, 0, 851, 852, 1, 0, 0, 0, 852, 854, 1, 0, 0, 0, 853, 851, 1, 0, 0, 0, 854, 855, 5, 106, 0, 0, 855, 857, 1, 0, 0, 0, 856, 810, 1, 0, 0, 0, 856, 817, 1, 0, 0, 0, 856, 824, 1, 0, 0, 0, 856, 840, 1, 0, 0, 0, 857, 165, 1, 0, 0, 0, 858, 861, 3, 52, 26, 0, 859, 860, 5, 65, 0, 0, 860, 862, 3, 12, 6, 0, 861, 859, 1, 0, 0, 0, 861, 862, 1, 0, 0, 0, 862, 863, 1, 0, 0, 0, 863, 864, 5, 66, 0, 0, 864, 865, 3, 184, 92, 0, 865, 167, 1, 0, 0, 0, 866, 872, 3, 170, 85, 0, 867, 868, 3, 170, 85, 0, 868, 869, 3, 196, 98, 0, 869, 870, 3, 170, 85, 0, 870, 872, 1, 0, 0, 0, 871, 866, 1, 0, 0, 0, 871, 867, 1, 0, 0, 0, 872, 169, 1, 0, 0, 0, 873, 874, 6, 85, -1, 0, 874, 878, 3, 172, 86, 0, 875, 876, 7, 5, 0, 0, 876, 878, 3, 170, 85, 3, 877, 873, 1, 0, 0, 0, 877, 875, 1, 0, 0, 0, 878, 887, 1, 0, 0, 0, 879, 880, 10, 2, 0, 0, 880, 881, 7, 6, 0, 0, 881, 886, 3, 170, 85, 3, 882, 883, 10, 1, 0, 0, 883, 884, 7, 5, 0, 0, 884, 886, 3, 170, 85, 2, 885, 879, 1, 0, 0, 0, 885, 882, 1, 0, 0, 0, 886, 889, 1, 0, 0, 0, 887, 885, 1, 0, 0, 0, 887, 888, 1, 0, 0, 0, 888, 171, 1, 0, 0, 0, 889, 887, 1, 0, 0, 0, 890, 891, 6, 86, -1, 0, 891, 899, 3, 184, 92, 0, 892, 899, 3, 52, 26, 0, 893, 899, 3, 174, 87, 0, 894, 895, 5, 105, 0, 0, 895, 896, 3, 162, 81, 0, 896, 897, 5, 106, 0, 0, 897, 899, 1, 0, 0, 0, 898, 890, 1, 0, 0, 0, 898, 892, 1, 0, 0, 0, 898, 893, 1, 0, 0, 0, 898, 894, 1, 0, 0, 0, 899, 905, 1, 0, 0, 0, 900, 901, 10, 1, 0, 0, 901, 902, 5, 65, 0, 0, 902, 904, 3, 12, 6, 0, 903, 900, 1, 0, 0, 0, 904, 907, 1, 0, 0, 0, 905, 903, 1, 0, 0, 0, 905, 906, 1, 0, 0, 0, 906, 173, 1, 0, 0, 0, 907, 905, 1, 0, 0, 0, 908, 909, 3, 176, 88, 0, 909, 923, 5, 105, 0, 0, 910, 924, 5, 95, 0, 0, 911, 916, 3, 162, 81, 0, 912, 913, 5, 68, 0, 0, 913, 915, 3, 162, 81, 0, 914, 912, 1, 0, 0, 0, 915, 918, 1, 0, 0, 0, 916, 914, 1, 0, 0, 0, 916, 917, 1, 0, 0, 0, 917, 921, 1, 0, 0, 0, 918, 916, 1, 0, 0, 0, 919, 920, 5, 68, 0, 0, 920, 922, 3, 178, 89, 0, 921, 919, 1, 0, 0, 0, 921, 922, 1, 0, 0, 0, 922, 924, 1, 0, 0, 0, 923, 910, 1, 0, 0, 0, 923, 911, 1, 0, 0, 0, 923, 924, 1, 0, 0, 0, 924, 925, 1, 0, 0, 0, 925, 926, 5, 106, 0, 0, 926, 175, 1, 0, 0, 0, 927, 931, 3, 70, 35, 0, 928, 931, 5, 72, 0, 0, 929, 931, 5, 75, 0, 0, 930, 927, 1, 0, 0, 0, 930, 928, 1, 0, 0, 0, 930, 929, 1, 0, 0, 0, 931, 177, 1, 0, 0, 0, 932, 941, 5, 98, 0, 0, 933, 938, 3, 180, 90, 0, 934, 935, 5, 68, 0, 0, 935, 937, 3, 180, 90, 0, 936, 934, 1, 0, 0, 0, 937, 940, 1, 0, 0, 0, 938, 936, 1, 0, 0, 0, 938, 939, 1, 0, 0, 0, 939, 942, 1, 0, 0, 0, 940, 938, 1, 0, 0, 0, 941, 933, 1, 0, 0, 0, 941, 942, 1, 0, 0, 0, 942, 943, 1, 0, 0, 0, 943, 944, 5, 99, 0, 0, 944, 179, 1, 0, 0, 0, 945, 946, 3, 194, 97, 0, 946, 947, 5, 66, 0, 0, 947, 948, 3, 182, 91, 0, 948, 181, 1, 0, 0, 0, 949, 952, 3, 184, 92, 0, 950, 952, 3, 178, 89, 0, 951, 949, 1, 0, 0, 0, 951, 950, 1, 0, 0, 0, 952, 183, 1, 0, 0, 0, 953, 996, 5, 78, 0, 0, 954, 955, 3, 192, 96, 0, 955, 956, 5, 107, 0, 0, 956, 996, 1, 0, 0, 0, 957, 996, 3, 190, 95, 0, 958, 996, 3, 192, 96, 0, 959, 996, 3, 186, 93, 0, 960, 996, 3, 66, 33, 0, 961, 996, 3, 194, 97, 0, 962, 963, 5, 103, 0, 0, 963, 968, 3, 188, 94, 0, 964, 965, 5, 68, 0, 0, 965, 967, 3, 188, 94, 0, 966, 964, 1, 0, 0, 0, 967, 970, 1, 0, 0, 0, 968, 966, 1, 0, 0, 0, 968, 969, 1, 0, 0, 0, 969, 971, 1, 0, 0, 0, 970, 968, 1, 0, 0, 0, 971, 972, 5, 104, 0, 0, 972, 996, 1, 0, 0, 0, 973, 974, 5, 103, 0, 0, 974, 979, 3, 186, 93, 0, 975, 976, 5, 68, 0, 0, 976, 978, 3, 186, 93, 0, 977, 975, 1, 0, 0, 0, 978, 981, 1, 0, 0, 0, 979, 977, 1, 0, 0, 0, 979, 980, 1, 0, 0, 0, 980, 982, 1, 0, 0, 0, 981, 979, 1, 0, 0, 0, 982, 983, 5, 104, 0, 0, 983, 996, 1, 0, 0, 0, 984, 985, 5, 103, 0, 0, 985, 990, 3, 194, 97, 0, 986, 987, 5, 68, 0, 0, 987, 989, 3, 194, 97, 0, 988, 986, 1, 0, 0, 0, 989, 992, 1, 0, 0, 0, 990, 988, 1, 0, 0, 0, 990, 991, 1, 0, 0, 0, 991, 993, 1, 0, 0, 0, 992, 990, 1, 0, 0, 0, 993, 994, 5, 104, 0, 0, 994, 996, 1, 0, 0, 0, 995, 953, 1, 0, 0, 0, 995, 954, 1, 0, 0, 0, 995, 957, 1, 0, 0, 0, 995, 958, 1, 0, 0, 0, 995, 959, 1, 0, 0, 0, 995, 960, 1, 0, 0, 0, 995, 961, 1, 0, 0, 0, 995, 962, 1, 0, 0, 0, 995, 973, 1, 0, 0, 0, 995, 984, 1, 0, 0, 0, 996, 185, 1, 0, 0, 0, 997, 998, 7, 7, 0, 0, 998, 187, 1, 0, 0, 0, 999, 1002, 3, 190, 95, 0, 1000, 1002, 3, 192, 96, 0, 1001, 999, 1, 0, 0, 0, 1001, 1000, 1, 0, 0, 0, 1002, 189, 1, 0, 0, 0, 1003, 1005, 7, 5, 0, 0, 1004, 1003, 1, 0, 0, 0, 1004, 1005, 1, 0, 0, 0, 1005, 1006, 1, 0, 0, 0, 1006, 1007, 5, 60, 0, 0, 1007, 191, 1, 0, 0, 0, 1008, 1010, 7, 5, 0, 0, 1009, 1008, 1, 0, 0, 0, 1009, 1010, 1, 0, 0, 0, 1010, 1011, 1, 0, 0, 0, 1011, 1012, 5, 59, 0, 0, 1012, 193, 1, 0, 0, 0, 1013, 1014, 5, 58, 0, 0, 1014, 195, 1, 0, 0, 0, 1015, 1016, 7, 8, 0, 0, 1016, 197, 1, 0, 0, 0, 1017, 1018, 7, 9, 0, 0, 1018, 1019, 5, 130, 0, 0, 1019, 1020, 3, 200, 100, 0, 1020, 1021, 3, 202, 101, 0, 1021, 199, 1, 0, 0, 0, 1022, 1023, 4, 100, 15, 0, 1023, 1025, 3, 32, 16, 0, 1024, 1026, 5, 158, 0, 0, 1025, 1024, 1, 0, 0, 0, 1025, 1026, 1, 0, 0, 0, 1026, 1027, 1, 0, 0, 0, 1027, 1028, 5, 113, 0, 0, 1028, 1031, 1, 0, 0, 0, 1029, 1031, 3, 32, 16, 0, 1030, 1022, 1, 0, 0, 0, 1030, 1029, 1, 0, 0, 0, 1031, 201, 1, 0, 0, 0, 1032, 1033, 5, 80, 0, 0, 1033, 1038, 3, 162, 81, 0, 1034, 1035, 5, 68, 0, 0, 1035, 1037, 3, 162, 81, 0, 1036, 1034, 1, 0, 0, 0, 1037, 1040, 1, 0, 0, 0, 1038, 1036, 1, 0, 0, 0, 1038, 1039, 1, 0, 0, 0, 1039, 203, 1, 0, 0, 0, 1040, 1038, 1, 0, 0, 0, 1041, 1045, 5, 39, 0, 0, 1042, 1044, 3, 208, 104, 0, 1043, 1042, 1, 0, 0, 0, 1044, 1047, 1, 0, 0, 0, 1045, 1043, 1, 0, 0, 0, 1045, 1046, 1, 0, 0, 0, 1046, 1051, 1, 0, 0, 0, 1047, 1045, 1, 0, 0, 0, 1048, 1049, 3, 206, 103, 0, 1049, 1050, 5, 63, 0, 0, 1050, 1052, 1, 0, 0, 0, 1051, 1048, 1, 0, 0, 0, 1051, 1052, 1, 0, 0, 0, 1052, 1053, 1, 0, 0, 0, 1053, 1054, 5, 105, 0, 0, 1054, 1055, 5, 101, 0, 0, 1055, 1102, 5, 106, 0, 0, 1056, 1060, 5, 39, 0, 0, 1057, 1059, 3, 208, 104, 0, 1058, 1057, 1, 0, 0, 0, 1059, 1062, 1, 0, 0, 0, 1060, 1058, 1, 0, 0, 0, 1060, 1061, 1, 0, 0, 0, 1061, 1066, 1, 0, 0, 0, 1062, 1060, 1, 0, 0, 0, 1063, 1064, 3, 206, 103, 0, 1064, 1065, 5, 63, 0, 0, 1065, 1067, 1, 0, 0, 0, 1066, 1063, 1, 0, 0, 0, 1066, 1067, 1, 0, 0, 0, 1067, 1068, 1, 0, 0, 0, 1068, 1102, 5, 101, 0, 0, 1069, 1073, 5, 39, 0, 0, 1070, 1072, 3, 208, 104, 0, 1071, 1070, 1, 0, 0, 0, 1072, 1075, 1, 0, 0, 0, 1073, 1071, 1, 0, 0, 0, 1073, 1074, 1, 0, 0, 0, 1074, 1079, 1, 0, 0, 0, 1075, 1073, 1, 0, 0, 0, 1076, 1077, 3, 206, 103, 0, 1077, 1078, 5, 63, 0, 0, 1078, 1080, 1, 0, 0, 0, 1079, 1076, 1, 0, 0, 0, 1079, 1080, 1, 0, 0, 0, 1080, 1081, 1, 0, 0, 0, 1081, 1083, 5, 105, 0, 0, 1082, 1084, 3, 216, 108, 0, 1083, 1082, 1, 0, 0, 0, 1084, 1085, 1, 0, 0, 0, 1085, 1083, 1, 0, 0, 0, 1085, 1086, 1, 0, 0, 0, 1086, 1087, 1, 0, 0, 0, 1087, 1088, 5, 106, 0, 0, 1088, 1102, 1, 0, 0, 0, 1089, 1093, 5, 39, 0, 0, 1090, 1092, 3, 208, 104, 0, 1091, 1090, 1, 0, 0, 0, 1092, 1095, 1, 0, 0, 0, 1093, 1091, 1, 0, 0, 0, 1093, 1094, 1, 0, 0, 0, 1094, 1097, 1, 0, 0, 0, 1095, 1093, 1, 0, 0, 0, 1096, 1098, 3, 216, 108, 0, 1097, 1096, 1, 0, 0, 0, 1098, 1099, 1, 0, 0, 0, 1099, 1097, 1, 0, 0, 0, 1099, 1100, 1, 0, 0, 0, 1100, 1102, 1, 0, 0, 0, 1101, 1041, 1, 0, 0, 0, 1101, 1056, 1, 0, 0, 0, 1101, 1069, 1, 0, 0, 0, 1101, 1089, 1, 0, 0, 0, 1102, 205, 1, 0, 0, 0, 1103, 1104, 7, 1, 0, 0, 1104, 207, 1, 0, 0, 0, 1105, 1106, 3, 210, 105, 0, 1106, 1107, 5, 63, 0, 0, 1107, 1108, 3, 212, 106, 0, 1108, 209, 1, 0, 0, 0, 1109, 1110, 7, 10, 0, 0, 1110, 211, 1, 0, 0, 0, 1111, 1116, 3, 218, 109, 0, 1112, 1113, 5, 68, 0, 0, 1113, 1115, 3, 218, 109, 0, 1114, 1112, 1, 0, 0, 0, 1115, 1118, 1, 0, 0, 0, 1116, 1114, 1, 0, 0, 0, 1116, 1117, 1, 0, 0, 0, 1117, 1122, 1, 0, 0, 0, 1118, 1116, 1, 0, 0, 0, 1119, 1122, 5, 108, 0, 0, 1120, 1122, 5, 101, 0, 0, 1121, 1111, 1, 0, 0, 0, 1121, 1119, 1, 0, 0, 0, 1121, 1120, 1, 0, 0, 0, 1122, 213, 1, 0, 0, 0, 1123, 1124, 7, 11, 0, 0, 1124, 215, 1, 0, 0, 0, 1125, 1127, 3, 214, 107, 0, 1126, 1125, 1, 0, 0, 0, 1127, 1128, 1, 0, 0, 0, 1128, 1126, 1, 0, 0, 0, 1128, 1129, 1, 0, 0, 0, 1129, 1139, 1, 0, 0, 0, 1130, 1134, 5, 105, 0, 0, 1131, 1133, 3, 216, 108, 0, 1132, 1131, 1, 0, 0, 0, 1133, 1136, 1, 0, 0, 0, 1134, 1132, 1, 0, 0, 0, 1134, 1135, 1, 0, 0, 0, 1135, 1137, 1, 0, 0, 0, 1136, 1134, 1, 0, 0, 0, 1137, 1139, 5, 106, 0, 0, 1138, 1126, 1, 0, 0, 0, 1138, 1130, 1, 0, 0, 0, 1139, 217, 1, 0, 0, 0, 1140, 1141, 3, 220, 110, 0, 1141, 1142, 5, 66, 0, 0, 1142, 1143, 3, 224, 112, 0, 1143, 1150, 1, 0, 0, 0, 1144, 1145, 3, 224, 112, 0, 1145, 1146, 5, 65, 0, 0, 1146, 1147, 3, 222, 111, 0, 1147, 1150, 1, 0, 0, 0, 1148, 1150, 3, 226, 113, 0, 1149, 1140, 1, 0, 0, 0, 1149, 1144, 1, 0, 0, 0, 1149, 1148, 1, 0, 0, 0, 1150, 219, 1, 0, 0, 0, 1151, 1152, 7, 12, 0, 0, 1152, 221, 1, 0, 0, 0, 1153, 1154, 7, 12, 0, 0, 1154, 223, 1, 0, 0, 0, 1155, 1156, 7, 12, 0, 0, 1156, 225, 1, 0, 0, 0, 1157, 1158, 7, 13, 0, 0, 1158, 227, 1, 0, 0, 0, 114, 231, 248, 260, 291, 306, 312, 331, 335, 340, 348, 356, 361, 364, 380, 388, 392, 399, 405, 410, 419, 426, 432, 441, 448, 456, 464, 468, 472, 477, 481, 486, 495, 504, 509, 513, 527, 538, 544, 551, 560, 569, 589, 597, 600, 607, 619, 629, 637, 651, 660, 671, 681, 687, 689, 693, 698, 712, 719, 752, 756, 766, 775, 784, 792, 797, 805, 807, 812, 819, 826, 835, 842, 851, 856, 861, 871, 877, 885, 887, 898, 905, 916, 921, 923, 930, 938, 941, 951, 968, 979, 990, 995, 1001, 1004, 1009, 1025, 1030, 1038, 1045, 1051, 1060, 1066, 1073, 1079, 1085, 1093, 1099, 1101, 1116, 1121, 1128, 1134, 1138, 1149] \ No newline at end of file +[4, 1, 168, 1159, 2, 0, 7, 0, 2, 1, 7, 1, 2, 2, 7, 2, 2, 3, 7, 3, 2, 4, 7, 4, 2, 5, 7, 5, 2, 6, 7, 6, 2, 7, 7, 7, 2, 8, 7, 8, 2, 9, 7, 9, 2, 10, 7, 10, 2, 11, 7, 11, 2, 12, 7, 12, 2, 13, 7, 13, 2, 14, 7, 14, 2, 15, 7, 15, 2, 16, 7, 16, 2, 17, 7, 17, 2, 18, 7, 18, 2, 19, 7, 19, 2, 20, 7, 20, 2, 21, 7, 21, 2, 22, 7, 22, 2, 23, 7, 23, 2, 24, 7, 24, 2, 25, 7, 25, 2, 26, 7, 26, 2, 27, 7, 27, 2, 28, 7, 28, 2, 29, 7, 29, 2, 30, 7, 30, 2, 31, 7, 31, 2, 32, 7, 32, 2, 33, 7, 33, 2, 34, 7, 34, 2, 35, 7, 35, 2, 36, 7, 36, 2, 37, 7, 37, 2, 38, 7, 38, 2, 39, 7, 39, 2, 40, 7, 40, 2, 41, 7, 41, 2, 42, 7, 42, 2, 43, 7, 43, 2, 44, 7, 44, 2, 45, 7, 45, 2, 46, 7, 46, 2, 47, 7, 47, 2, 48, 7, 48, 2, 49, 7, 49, 2, 50, 7, 50, 2, 51, 7, 51, 2, 52, 7, 52, 2, 53, 7, 53, 2, 54, 7, 54, 2, 55, 7, 55, 2, 56, 7, 56, 2, 57, 7, 57, 2, 58, 7, 58, 2, 59, 7, 59, 2, 60, 7, 60, 2, 61, 7, 61, 2, 62, 7, 62, 2, 63, 7, 63, 2, 64, 7, 64, 2, 65, 7, 65, 2, 66, 7, 66, 2, 67, 7, 67, 2, 68, 7, 68, 2, 69, 7, 69, 2, 70, 7, 70, 2, 71, 7, 71, 2, 72, 7, 72, 2, 73, 7, 73, 2, 74, 7, 74, 2, 75, 7, 75, 2, 76, 7, 76, 2, 77, 7, 77, 2, 78, 7, 78, 2, 79, 7, 79, 2, 80, 7, 80, 2, 81, 7, 81, 2, 82, 7, 82, 2, 83, 7, 83, 2, 84, 7, 84, 2, 85, 7, 85, 2, 86, 7, 86, 2, 87, 7, 87, 2, 88, 7, 88, 2, 89, 7, 89, 2, 90, 7, 90, 2, 91, 7, 91, 2, 92, 7, 92, 2, 93, 7, 93, 2, 94, 7, 94, 2, 95, 7, 95, 2, 96, 7, 96, 2, 97, 7, 97, 2, 98, 7, 98, 2, 99, 7, 99, 2, 100, 7, 100, 2, 101, 7, 101, 2, 102, 7, 102, 2, 103, 7, 103, 2, 104, 7, 104, 2, 105, 7, 105, 2, 106, 7, 106, 2, 107, 7, 107, 2, 108, 7, 108, 2, 109, 7, 109, 2, 110, 7, 110, 2, 111, 7, 111, 2, 112, 7, 112, 2, 113, 7, 113, 1, 0, 5, 0, 230, 8, 0, 10, 0, 12, 0, 233, 9, 0, 1, 0, 1, 0, 1, 0, 1, 1, 1, 1, 1, 1, 1, 2, 1, 2, 1, 2, 1, 2, 1, 2, 1, 2, 5, 2, 247, 8, 2, 10, 2, 12, 2, 250, 9, 2, 1, 3, 1, 3, 1, 3, 1, 3, 1, 3, 1, 3, 1, 3, 1, 3, 1, 3, 3, 3, 261, 8, 3, 1, 4, 1, 4, 1, 4, 1, 4, 1, 4, 1, 4, 1, 4, 1, 4, 1, 4, 1, 4, 1, 4, 1, 4, 1, 4, 1, 4, 1, 4, 1, 4, 1, 4, 1, 4, 1, 4, 1, 4, 1, 4, 1, 4, 1, 4, 1, 4, 1, 4, 1, 4, 1, 4, 1, 4, 1, 4, 3, 4, 292, 8, 4, 1, 5, 1, 5, 1, 5, 1, 6, 1, 6, 1, 7, 1, 7, 1, 7, 1, 8, 1, 8, 1, 8, 5, 8, 305, 8, 8, 10, 8, 12, 8, 308, 9, 8, 1, 9, 1, 9, 1, 9, 3, 9, 313, 8, 9, 1, 9, 1, 9, 1, 10, 1, 10, 1, 10, 1, 11, 1, 11, 1, 11, 1, 12, 1, 12, 1, 12, 1, 12, 1, 13, 1, 13, 1, 13, 5, 13, 330, 8, 13, 10, 13, 12, 13, 333, 9, 13, 1, 13, 3, 13, 336, 8, 13, 1, 14, 1, 14, 1, 14, 3, 14, 341, 8, 14, 1, 15, 1, 15, 1, 15, 1, 15, 5, 15, 347, 8, 15, 10, 15, 12, 15, 350, 9, 15, 1, 15, 1, 15, 1, 16, 1, 16, 1, 16, 3, 16, 357, 8, 16, 1, 16, 1, 16, 1, 16, 3, 16, 362, 8, 16, 1, 16, 3, 16, 365, 8, 16, 1, 17, 1, 17, 1, 18, 1, 18, 1, 19, 1, 19, 1, 20, 1, 20, 1, 21, 1, 21, 1, 21, 1, 21, 5, 21, 379, 8, 21, 10, 21, 12, 21, 382, 9, 21, 1, 22, 1, 22, 1, 22, 1, 23, 1, 23, 3, 23, 389, 8, 23, 1, 23, 1, 23, 3, 23, 393, 8, 23, 1, 24, 1, 24, 1, 24, 5, 24, 398, 8, 24, 10, 24, 12, 24, 401, 9, 24, 1, 25, 1, 25, 1, 25, 3, 25, 406, 8, 25, 1, 26, 1, 26, 1, 26, 3, 26, 411, 8, 26, 1, 26, 1, 26, 1, 26, 1, 26, 1, 26, 1, 26, 1, 26, 3, 26, 420, 8, 26, 1, 27, 1, 27, 1, 27, 5, 27, 425, 8, 27, 10, 27, 12, 27, 428, 9, 27, 1, 28, 1, 28, 1, 28, 3, 28, 433, 8, 28, 1, 28, 1, 28, 1, 28, 1, 28, 1, 28, 1, 28, 1, 28, 3, 28, 442, 8, 28, 1, 29, 1, 29, 1, 29, 5, 29, 447, 8, 29, 10, 29, 12, 29, 450, 9, 29, 1, 30, 1, 30, 1, 30, 5, 30, 455, 8, 30, 10, 30, 12, 30, 458, 9, 30, 1, 31, 1, 31, 1, 32, 1, 32, 1, 32, 3, 32, 465, 8, 32, 1, 33, 1, 33, 3, 33, 469, 8, 33, 1, 34, 1, 34, 3, 34, 473, 8, 34, 1, 35, 1, 35, 1, 35, 3, 35, 478, 8, 35, 1, 36, 1, 36, 3, 36, 482, 8, 36, 1, 37, 1, 37, 1, 37, 3, 37, 487, 8, 37, 1, 38, 1, 38, 1, 38, 1, 38, 5, 38, 493, 8, 38, 10, 38, 12, 38, 496, 9, 38, 1, 39, 1, 39, 1, 39, 1, 39, 5, 39, 502, 8, 39, 10, 39, 12, 39, 505, 9, 39, 1, 40, 1, 40, 3, 40, 509, 8, 40, 1, 40, 1, 40, 3, 40, 513, 8, 40, 1, 41, 1, 41, 1, 41, 1, 42, 1, 42, 1, 42, 1, 43, 1, 43, 1, 43, 1, 43, 5, 43, 525, 8, 43, 10, 43, 12, 43, 528, 9, 43, 1, 44, 1, 44, 1, 44, 1, 44, 1, 44, 1, 44, 1, 44, 1, 44, 3, 44, 538, 8, 44, 1, 45, 1, 45, 1, 45, 1, 45, 3, 45, 544, 8, 45, 1, 46, 1, 46, 1, 46, 5, 46, 549, 8, 46, 10, 46, 12, 46, 552, 9, 46, 1, 47, 1, 47, 1, 47, 1, 47, 1, 48, 1, 48, 3, 48, 560, 8, 48, 1, 49, 1, 49, 1, 49, 1, 49, 1, 49, 5, 49, 567, 8, 49, 10, 49, 12, 49, 570, 9, 49, 1, 50, 1, 50, 1, 50, 1, 51, 1, 51, 1, 51, 1, 52, 1, 52, 1, 52, 1, 52, 1, 53, 1, 53, 1, 53, 1, 54, 1, 54, 1, 54, 1, 54, 3, 54, 589, 8, 54, 1, 54, 1, 54, 1, 54, 1, 54, 5, 54, 595, 8, 54, 10, 54, 12, 54, 598, 9, 54, 3, 54, 600, 8, 54, 1, 55, 1, 55, 1, 56, 1, 56, 1, 56, 3, 56, 607, 8, 56, 1, 56, 1, 56, 1, 57, 1, 57, 1, 57, 1, 58, 1, 58, 1, 58, 5, 58, 617, 8, 58, 10, 58, 12, 58, 620, 9, 58, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 3, 59, 629, 8, 59, 1, 60, 1, 60, 1, 60, 1, 61, 4, 61, 635, 8, 61, 11, 61, 12, 61, 636, 1, 62, 1, 62, 1, 62, 1, 62, 1, 63, 1, 63, 1, 63, 1, 63, 1, 63, 1, 63, 5, 63, 649, 8, 63, 10, 63, 12, 63, 652, 9, 63, 1, 64, 1, 64, 1, 65, 1, 65, 1, 65, 1, 65, 3, 65, 660, 8, 65, 1, 65, 1, 65, 1, 65, 1, 65, 1, 65, 1, 66, 1, 66, 1, 66, 1, 66, 3, 66, 671, 8, 66, 1, 66, 1, 66, 1, 66, 1, 67, 1, 67, 1, 67, 1, 67, 1, 67, 3, 67, 681, 8, 67, 1, 67, 1, 67, 1, 67, 1, 67, 3, 67, 687, 8, 67, 3, 67, 689, 8, 67, 1, 68, 1, 68, 3, 68, 693, 8, 68, 1, 68, 5, 68, 696, 8, 68, 10, 68, 12, 68, 699, 9, 68, 1, 69, 1, 69, 1, 69, 1, 69, 1, 69, 1, 69, 1, 69, 1, 69, 1, 69, 1, 69, 1, 69, 3, 69, 712, 8, 69, 1, 70, 1, 70, 1, 70, 5, 70, 717, 8, 70, 10, 70, 12, 70, 720, 9, 70, 1, 71, 1, 71, 1, 72, 1, 72, 1, 73, 1, 73, 1, 73, 1, 73, 1, 73, 1, 74, 1, 74, 1, 74, 1, 75, 1, 75, 1, 75, 1, 75, 1, 75, 1, 76, 1, 76, 1, 76, 1, 76, 1, 76, 1, 77, 1, 77, 1, 77, 1, 77, 1, 78, 1, 78, 1, 78, 1, 78, 3, 78, 752, 8, 78, 1, 79, 1, 79, 3, 79, 756, 8, 79, 1, 79, 1, 79, 1, 79, 1, 79, 1, 79, 1, 79, 1, 80, 1, 80, 3, 80, 766, 8, 80, 1, 81, 1, 81, 1, 81, 1, 81, 1, 81, 1, 81, 1, 81, 3, 81, 775, 8, 81, 1, 81, 1, 81, 1, 81, 1, 81, 1, 81, 5, 81, 782, 8, 81, 10, 81, 12, 81, 785, 9, 81, 1, 81, 1, 81, 1, 81, 1, 81, 1, 81, 3, 81, 792, 8, 81, 1, 81, 1, 81, 1, 81, 3, 81, 797, 8, 81, 1, 81, 1, 81, 1, 81, 1, 81, 1, 81, 1, 81, 5, 81, 805, 8, 81, 10, 81, 12, 81, 808, 9, 81, 1, 82, 1, 82, 3, 82, 812, 8, 82, 1, 82, 1, 82, 1, 82, 1, 82, 1, 82, 3, 82, 819, 8, 82, 1, 82, 1, 82, 1, 82, 1, 82, 1, 82, 3, 82, 826, 8, 82, 1, 82, 1, 82, 1, 82, 1, 82, 1, 82, 5, 82, 833, 8, 82, 10, 82, 12, 82, 836, 9, 82, 1, 82, 1, 82, 1, 82, 1, 82, 3, 82, 842, 8, 82, 1, 82, 1, 82, 1, 82, 1, 82, 1, 82, 5, 82, 849, 8, 82, 10, 82, 12, 82, 852, 9, 82, 1, 82, 1, 82, 3, 82, 856, 8, 82, 1, 83, 1, 83, 1, 83, 3, 83, 861, 8, 83, 1, 83, 1, 83, 1, 83, 1, 84, 1, 84, 1, 84, 1, 84, 1, 84, 3, 84, 871, 8, 84, 1, 85, 1, 85, 1, 85, 1, 85, 3, 85, 877, 8, 85, 1, 85, 1, 85, 1, 85, 1, 85, 1, 85, 1, 85, 5, 85, 885, 8, 85, 10, 85, 12, 85, 888, 9, 85, 1, 86, 1, 86, 1, 86, 1, 86, 1, 86, 1, 86, 1, 86, 1, 86, 3, 86, 898, 8, 86, 1, 86, 1, 86, 1, 86, 5, 86, 903, 8, 86, 10, 86, 12, 86, 906, 9, 86, 1, 87, 1, 87, 1, 87, 1, 87, 1, 87, 1, 87, 5, 87, 914, 8, 87, 10, 87, 12, 87, 917, 9, 87, 1, 87, 1, 87, 3, 87, 921, 8, 87, 3, 87, 923, 8, 87, 1, 87, 1, 87, 1, 88, 1, 88, 1, 88, 3, 88, 930, 8, 88, 1, 89, 1, 89, 1, 89, 1, 89, 5, 89, 936, 8, 89, 10, 89, 12, 89, 939, 9, 89, 3, 89, 941, 8, 89, 1, 89, 1, 89, 1, 90, 1, 90, 1, 90, 1, 90, 1, 91, 1, 91, 3, 91, 951, 8, 91, 1, 92, 1, 92, 1, 92, 1, 92, 1, 92, 1, 92, 1, 92, 1, 92, 1, 92, 1, 92, 1, 92, 1, 92, 1, 92, 5, 92, 966, 8, 92, 10, 92, 12, 92, 969, 9, 92, 1, 92, 1, 92, 1, 92, 1, 92, 1, 92, 1, 92, 5, 92, 977, 8, 92, 10, 92, 12, 92, 980, 9, 92, 1, 92, 1, 92, 1, 92, 1, 92, 1, 92, 1, 92, 5, 92, 988, 8, 92, 10, 92, 12, 92, 991, 9, 92, 1, 92, 1, 92, 3, 92, 995, 8, 92, 1, 93, 1, 93, 1, 94, 1, 94, 3, 94, 1001, 8, 94, 1, 95, 3, 95, 1004, 8, 95, 1, 95, 1, 95, 1, 96, 3, 96, 1009, 8, 96, 1, 96, 1, 96, 1, 97, 1, 97, 1, 98, 1, 98, 1, 99, 1, 99, 1, 99, 1, 99, 1, 99, 1, 100, 1, 100, 1, 100, 3, 100, 1025, 8, 100, 1, 100, 1, 100, 1, 100, 3, 100, 1030, 8, 100, 1, 101, 1, 101, 1, 101, 1, 101, 5, 101, 1036, 8, 101, 10, 101, 12, 101, 1039, 9, 101, 1, 102, 1, 102, 5, 102, 1043, 8, 102, 10, 102, 12, 102, 1046, 9, 102, 1, 102, 1, 102, 1, 102, 3, 102, 1051, 8, 102, 1, 102, 1, 102, 1, 102, 1, 102, 1, 102, 5, 102, 1058, 8, 102, 10, 102, 12, 102, 1061, 9, 102, 1, 102, 1, 102, 1, 102, 3, 102, 1066, 8, 102, 1, 102, 1, 102, 1, 102, 5, 102, 1071, 8, 102, 10, 102, 12, 102, 1074, 9, 102, 1, 102, 1, 102, 1, 102, 3, 102, 1079, 8, 102, 1, 102, 1, 102, 4, 102, 1083, 8, 102, 11, 102, 12, 102, 1084, 1, 102, 1, 102, 1, 102, 1, 102, 5, 102, 1091, 8, 102, 10, 102, 12, 102, 1094, 9, 102, 1, 102, 4, 102, 1097, 8, 102, 11, 102, 12, 102, 1098, 3, 102, 1101, 8, 102, 1, 103, 1, 103, 1, 104, 1, 104, 1, 104, 1, 104, 1, 105, 1, 105, 1, 106, 1, 106, 1, 106, 5, 106, 1114, 8, 106, 10, 106, 12, 106, 1117, 9, 106, 1, 106, 1, 106, 3, 106, 1121, 8, 106, 1, 107, 1, 107, 1, 108, 4, 108, 1126, 8, 108, 11, 108, 12, 108, 1127, 1, 108, 1, 108, 5, 108, 1132, 8, 108, 10, 108, 12, 108, 1135, 9, 108, 1, 108, 3, 108, 1138, 8, 108, 1, 109, 1, 109, 1, 109, 1, 109, 1, 109, 1, 109, 1, 109, 1, 109, 1, 109, 3, 109, 1149, 8, 109, 1, 110, 1, 110, 1, 111, 1, 111, 1, 112, 1, 112, 1, 113, 1, 113, 1, 113, 0, 5, 4, 126, 162, 170, 172, 114, 0, 2, 4, 6, 8, 10, 12, 14, 16, 18, 20, 22, 24, 26, 28, 30, 32, 34, 36, 38, 40, 42, 44, 46, 48, 50, 52, 54, 56, 58, 60, 62, 64, 66, 68, 70, 72, 74, 76, 78, 80, 82, 84, 86, 88, 90, 92, 94, 96, 98, 100, 102, 104, 106, 108, 110, 112, 114, 116, 118, 120, 122, 124, 126, 128, 130, 132, 134, 136, 138, 140, 142, 144, 146, 148, 150, 152, 154, 156, 158, 160, 162, 164, 166, 168, 170, 172, 174, 176, 178, 180, 182, 184, 186, 188, 190, 192, 194, 196, 198, 200, 202, 204, 206, 208, 210, 212, 214, 216, 218, 220, 222, 224, 226, 0, 14, 2, 0, 58, 58, 113, 113, 1, 0, 107, 108, 2, 0, 62, 62, 69, 69, 2, 0, 72, 72, 75, 75, 2, 0, 47, 47, 58, 58, 1, 0, 93, 94, 1, 0, 95, 97, 2, 0, 71, 71, 84, 84, 2, 0, 86, 86, 88, 92, 2, 0, 29, 29, 31, 32, 3, 0, 58, 58, 101, 101, 107, 108, 8, 0, 58, 58, 63, 63, 65, 66, 68, 68, 101, 101, 107, 108, 113, 113, 155, 157, 2, 0, 107, 107, 113, 113, 3, 0, 58, 58, 107, 107, 113, 113, 1214, 0, 231, 1, 0, 0, 0, 2, 237, 1, 0, 0, 0, 4, 240, 1, 0, 0, 0, 6, 260, 1, 0, 0, 0, 8, 291, 1, 0, 0, 0, 10, 293, 1, 0, 0, 0, 12, 296, 1, 0, 0, 0, 14, 298, 1, 0, 0, 0, 16, 301, 1, 0, 0, 0, 18, 312, 1, 0, 0, 0, 20, 316, 1, 0, 0, 0, 22, 319, 1, 0, 0, 0, 24, 322, 1, 0, 0, 0, 26, 326, 1, 0, 0, 0, 28, 340, 1, 0, 0, 0, 30, 342, 1, 0, 0, 0, 32, 364, 1, 0, 0, 0, 34, 366, 1, 0, 0, 0, 36, 368, 1, 0, 0, 0, 38, 370, 1, 0, 0, 0, 40, 372, 1, 0, 0, 0, 42, 374, 1, 0, 0, 0, 44, 383, 1, 0, 0, 0, 46, 386, 1, 0, 0, 0, 48, 394, 1, 0, 0, 0, 50, 402, 1, 0, 0, 0, 52, 419, 1, 0, 0, 0, 54, 421, 1, 0, 0, 0, 56, 441, 1, 0, 0, 0, 58, 443, 1, 0, 0, 0, 60, 451, 1, 0, 0, 0, 62, 459, 1, 0, 0, 0, 64, 464, 1, 0, 0, 0, 66, 468, 1, 0, 0, 0, 68, 472, 1, 0, 0, 0, 70, 477, 1, 0, 0, 0, 72, 481, 1, 0, 0, 0, 74, 483, 1, 0, 0, 0, 76, 488, 1, 0, 0, 0, 78, 497, 1, 0, 0, 0, 80, 506, 1, 0, 0, 0, 82, 514, 1, 0, 0, 0, 84, 517, 1, 0, 0, 0, 86, 520, 1, 0, 0, 0, 88, 537, 1, 0, 0, 0, 90, 539, 1, 0, 0, 0, 92, 545, 1, 0, 0, 0, 94, 553, 1, 0, 0, 0, 96, 559, 1, 0, 0, 0, 98, 561, 1, 0, 0, 0, 100, 571, 1, 0, 0, 0, 102, 574, 1, 0, 0, 0, 104, 577, 1, 0, 0, 0, 106, 581, 1, 0, 0, 0, 108, 584, 1, 0, 0, 0, 110, 601, 1, 0, 0, 0, 112, 606, 1, 0, 0, 0, 114, 610, 1, 0, 0, 0, 116, 613, 1, 0, 0, 0, 118, 628, 1, 0, 0, 0, 120, 630, 1, 0, 0, 0, 122, 634, 1, 0, 0, 0, 124, 638, 1, 0, 0, 0, 126, 642, 1, 0, 0, 0, 128, 653, 1, 0, 0, 0, 130, 655, 1, 0, 0, 0, 132, 666, 1, 0, 0, 0, 134, 688, 1, 0, 0, 0, 136, 690, 1, 0, 0, 0, 138, 711, 1, 0, 0, 0, 140, 713, 1, 0, 0, 0, 142, 721, 1, 0, 0, 0, 144, 723, 1, 0, 0, 0, 146, 725, 1, 0, 0, 0, 148, 730, 1, 0, 0, 0, 150, 733, 1, 0, 0, 0, 152, 738, 1, 0, 0, 0, 154, 743, 1, 0, 0, 0, 156, 747, 1, 0, 0, 0, 158, 753, 1, 0, 0, 0, 160, 765, 1, 0, 0, 0, 162, 796, 1, 0, 0, 0, 164, 855, 1, 0, 0, 0, 166, 857, 1, 0, 0, 0, 168, 870, 1, 0, 0, 0, 170, 876, 1, 0, 0, 0, 172, 897, 1, 0, 0, 0, 174, 907, 1, 0, 0, 0, 176, 929, 1, 0, 0, 0, 178, 931, 1, 0, 0, 0, 180, 944, 1, 0, 0, 0, 182, 950, 1, 0, 0, 0, 184, 994, 1, 0, 0, 0, 186, 996, 1, 0, 0, 0, 188, 1000, 1, 0, 0, 0, 190, 1003, 1, 0, 0, 0, 192, 1008, 1, 0, 0, 0, 194, 1012, 1, 0, 0, 0, 196, 1014, 1, 0, 0, 0, 198, 1016, 1, 0, 0, 0, 200, 1029, 1, 0, 0, 0, 202, 1031, 1, 0, 0, 0, 204, 1100, 1, 0, 0, 0, 206, 1102, 1, 0, 0, 0, 208, 1104, 1, 0, 0, 0, 210, 1108, 1, 0, 0, 0, 212, 1120, 1, 0, 0, 0, 214, 1122, 1, 0, 0, 0, 216, 1137, 1, 0, 0, 0, 218, 1148, 1, 0, 0, 0, 220, 1150, 1, 0, 0, 0, 222, 1152, 1, 0, 0, 0, 224, 1154, 1, 0, 0, 0, 226, 1156, 1, 0, 0, 0, 228, 230, 3, 154, 77, 0, 229, 228, 1, 0, 0, 0, 230, 233, 1, 0, 0, 0, 231, 229, 1, 0, 0, 0, 231, 232, 1, 0, 0, 0, 232, 234, 1, 0, 0, 0, 233, 231, 1, 0, 0, 0, 234, 235, 3, 2, 1, 0, 235, 236, 5, 0, 0, 1, 236, 1, 1, 0, 0, 0, 237, 238, 3, 4, 2, 0, 238, 239, 5, 0, 0, 1, 239, 3, 1, 0, 0, 0, 240, 241, 6, 2, -1, 0, 241, 242, 3, 6, 3, 0, 242, 248, 1, 0, 0, 0, 243, 244, 10, 1, 0, 0, 244, 245, 5, 57, 0, 0, 245, 247, 3, 8, 4, 0, 246, 243, 1, 0, 0, 0, 247, 250, 1, 0, 0, 0, 248, 246, 1, 0, 0, 0, 248, 249, 1, 0, 0, 0, 249, 5, 1, 0, 0, 0, 250, 248, 1, 0, 0, 0, 251, 261, 3, 20, 10, 0, 252, 261, 3, 14, 7, 0, 253, 261, 3, 106, 53, 0, 254, 261, 3, 22, 11, 0, 255, 261, 3, 204, 102, 0, 256, 257, 4, 3, 1, 0, 257, 261, 3, 102, 51, 0, 258, 259, 4, 3, 2, 0, 259, 261, 3, 24, 12, 0, 260, 251, 1, 0, 0, 0, 260, 252, 1, 0, 0, 0, 260, 253, 1, 0, 0, 0, 260, 254, 1, 0, 0, 0, 260, 255, 1, 0, 0, 0, 260, 256, 1, 0, 0, 0, 260, 258, 1, 0, 0, 0, 261, 7, 1, 0, 0, 0, 262, 292, 3, 44, 22, 0, 263, 292, 3, 10, 5, 0, 264, 292, 3, 82, 41, 0, 265, 292, 3, 74, 37, 0, 266, 292, 3, 46, 23, 0, 267, 292, 3, 78, 39, 0, 268, 292, 3, 84, 42, 0, 269, 292, 3, 86, 43, 0, 270, 292, 3, 90, 45, 0, 271, 292, 3, 98, 49, 0, 272, 292, 3, 108, 54, 0, 273, 292, 3, 100, 50, 0, 274, 292, 3, 198, 99, 0, 275, 292, 3, 116, 58, 0, 276, 292, 3, 132, 66, 0, 277, 292, 3, 114, 57, 0, 278, 292, 3, 120, 60, 0, 279, 292, 3, 130, 65, 0, 280, 292, 3, 134, 67, 0, 281, 292, 3, 136, 68, 0, 282, 292, 3, 150, 75, 0, 283, 292, 3, 142, 71, 0, 284, 292, 3, 152, 76, 0, 285, 292, 3, 144, 72, 0, 286, 292, 3, 158, 79, 0, 287, 288, 4, 4, 3, 0, 288, 292, 3, 146, 73, 0, 289, 290, 4, 4, 4, 0, 290, 292, 3, 148, 74, 0, 291, 262, 1, 0, 0, 0, 291, 263, 1, 0, 0, 0, 291, 264, 1, 0, 0, 0, 291, 265, 1, 0, 0, 0, 291, 266, 1, 0, 0, 0, 291, 267, 1, 0, 0, 0, 291, 268, 1, 0, 0, 0, 291, 269, 1, 0, 0, 0, 291, 270, 1, 0, 0, 0, 291, 271, 1, 0, 0, 0, 291, 272, 1, 0, 0, 0, 291, 273, 1, 0, 0, 0, 291, 274, 1, 0, 0, 0, 291, 275, 1, 0, 0, 0, 291, 276, 1, 0, 0, 0, 291, 277, 1, 0, 0, 0, 291, 278, 1, 0, 0, 0, 291, 279, 1, 0, 0, 0, 291, 280, 1, 0, 0, 0, 291, 281, 1, 0, 0, 0, 291, 282, 1, 0, 0, 0, 291, 283, 1, 0, 0, 0, 291, 284, 1, 0, 0, 0, 291, 285, 1, 0, 0, 0, 291, 286, 1, 0, 0, 0, 291, 287, 1, 0, 0, 0, 291, 289, 1, 0, 0, 0, 292, 9, 1, 0, 0, 0, 293, 294, 5, 17, 0, 0, 294, 295, 3, 162, 81, 0, 295, 11, 1, 0, 0, 0, 296, 297, 3, 62, 31, 0, 297, 13, 1, 0, 0, 0, 298, 299, 5, 13, 0, 0, 299, 300, 3, 16, 8, 0, 300, 15, 1, 0, 0, 0, 301, 306, 3, 18, 9, 0, 302, 303, 5, 68, 0, 0, 303, 305, 3, 18, 9, 0, 304, 302, 1, 0, 0, 0, 305, 308, 1, 0, 0, 0, 306, 304, 1, 0, 0, 0, 306, 307, 1, 0, 0, 0, 307, 17, 1, 0, 0, 0, 308, 306, 1, 0, 0, 0, 309, 310, 3, 52, 26, 0, 310, 311, 5, 63, 0, 0, 311, 313, 1, 0, 0, 0, 312, 309, 1, 0, 0, 0, 312, 313, 1, 0, 0, 0, 313, 314, 1, 0, 0, 0, 314, 315, 3, 162, 81, 0, 315, 19, 1, 0, 0, 0, 316, 317, 5, 22, 0, 0, 317, 318, 3, 26, 13, 0, 318, 21, 1, 0, 0, 0, 319, 320, 5, 23, 0, 0, 320, 321, 3, 26, 13, 0, 321, 23, 1, 0, 0, 0, 322, 323, 5, 24, 0, 0, 323, 324, 3, 72, 36, 0, 324, 325, 3, 96, 48, 0, 325, 25, 1, 0, 0, 0, 326, 331, 3, 28, 14, 0, 327, 328, 5, 68, 0, 0, 328, 330, 3, 28, 14, 0, 329, 327, 1, 0, 0, 0, 330, 333, 1, 0, 0, 0, 331, 329, 1, 0, 0, 0, 331, 332, 1, 0, 0, 0, 332, 335, 1, 0, 0, 0, 333, 331, 1, 0, 0, 0, 334, 336, 3, 42, 21, 0, 335, 334, 1, 0, 0, 0, 335, 336, 1, 0, 0, 0, 336, 27, 1, 0, 0, 0, 337, 341, 3, 32, 16, 0, 338, 339, 4, 14, 5, 0, 339, 341, 3, 30, 15, 0, 340, 337, 1, 0, 0, 0, 340, 338, 1, 0, 0, 0, 341, 29, 1, 0, 0, 0, 342, 343, 5, 105, 0, 0, 343, 348, 3, 20, 10, 0, 344, 345, 5, 57, 0, 0, 345, 347, 3, 8, 4, 0, 346, 344, 1, 0, 0, 0, 347, 350, 1, 0, 0, 0, 348, 346, 1, 0, 0, 0, 348, 349, 1, 0, 0, 0, 349, 351, 1, 0, 0, 0, 350, 348, 1, 0, 0, 0, 351, 352, 5, 106, 0, 0, 352, 31, 1, 0, 0, 0, 353, 354, 3, 34, 17, 0, 354, 355, 5, 66, 0, 0, 355, 357, 1, 0, 0, 0, 356, 353, 1, 0, 0, 0, 356, 357, 1, 0, 0, 0, 357, 358, 1, 0, 0, 0, 358, 361, 3, 38, 19, 0, 359, 360, 5, 65, 0, 0, 360, 362, 3, 36, 18, 0, 361, 359, 1, 0, 0, 0, 361, 362, 1, 0, 0, 0, 362, 365, 1, 0, 0, 0, 363, 365, 3, 40, 20, 0, 364, 356, 1, 0, 0, 0, 364, 363, 1, 0, 0, 0, 365, 33, 1, 0, 0, 0, 366, 367, 5, 113, 0, 0, 367, 35, 1, 0, 0, 0, 368, 369, 5, 113, 0, 0, 369, 37, 1, 0, 0, 0, 370, 371, 5, 113, 0, 0, 371, 39, 1, 0, 0, 0, 372, 373, 7, 0, 0, 0, 373, 41, 1, 0, 0, 0, 374, 375, 5, 112, 0, 0, 375, 380, 5, 113, 0, 0, 376, 377, 5, 68, 0, 0, 377, 379, 5, 113, 0, 0, 378, 376, 1, 0, 0, 0, 379, 382, 1, 0, 0, 0, 380, 378, 1, 0, 0, 0, 380, 381, 1, 0, 0, 0, 381, 43, 1, 0, 0, 0, 382, 380, 1, 0, 0, 0, 383, 384, 5, 9, 0, 0, 384, 385, 3, 16, 8, 0, 385, 45, 1, 0, 0, 0, 386, 388, 5, 16, 0, 0, 387, 389, 3, 48, 24, 0, 388, 387, 1, 0, 0, 0, 388, 389, 1, 0, 0, 0, 389, 392, 1, 0, 0, 0, 390, 391, 5, 64, 0, 0, 391, 393, 3, 16, 8, 0, 392, 390, 1, 0, 0, 0, 392, 393, 1, 0, 0, 0, 393, 47, 1, 0, 0, 0, 394, 399, 3, 50, 25, 0, 395, 396, 5, 68, 0, 0, 396, 398, 3, 50, 25, 0, 397, 395, 1, 0, 0, 0, 398, 401, 1, 0, 0, 0, 399, 397, 1, 0, 0, 0, 399, 400, 1, 0, 0, 0, 400, 49, 1, 0, 0, 0, 401, 399, 1, 0, 0, 0, 402, 405, 3, 18, 9, 0, 403, 404, 5, 17, 0, 0, 404, 406, 3, 162, 81, 0, 405, 403, 1, 0, 0, 0, 405, 406, 1, 0, 0, 0, 406, 51, 1, 0, 0, 0, 407, 408, 4, 26, 6, 0, 408, 410, 5, 103, 0, 0, 409, 411, 5, 107, 0, 0, 410, 409, 1, 0, 0, 0, 410, 411, 1, 0, 0, 0, 411, 412, 1, 0, 0, 0, 412, 413, 5, 104, 0, 0, 413, 414, 5, 70, 0, 0, 414, 415, 5, 103, 0, 0, 415, 416, 3, 54, 27, 0, 416, 417, 5, 104, 0, 0, 417, 420, 1, 0, 0, 0, 418, 420, 3, 54, 27, 0, 419, 407, 1, 0, 0, 0, 419, 418, 1, 0, 0, 0, 420, 53, 1, 0, 0, 0, 421, 426, 3, 70, 35, 0, 422, 423, 5, 70, 0, 0, 423, 425, 3, 70, 35, 0, 424, 422, 1, 0, 0, 0, 425, 428, 1, 0, 0, 0, 426, 424, 1, 0, 0, 0, 426, 427, 1, 0, 0, 0, 427, 55, 1, 0, 0, 0, 428, 426, 1, 0, 0, 0, 429, 430, 4, 28, 7, 0, 430, 432, 5, 103, 0, 0, 431, 433, 5, 148, 0, 0, 432, 431, 1, 0, 0, 0, 432, 433, 1, 0, 0, 0, 433, 434, 1, 0, 0, 0, 434, 435, 5, 104, 0, 0, 435, 436, 5, 70, 0, 0, 436, 437, 5, 103, 0, 0, 437, 438, 3, 58, 29, 0, 438, 439, 5, 104, 0, 0, 439, 442, 1, 0, 0, 0, 440, 442, 3, 58, 29, 0, 441, 429, 1, 0, 0, 0, 441, 440, 1, 0, 0, 0, 442, 57, 1, 0, 0, 0, 443, 448, 3, 64, 32, 0, 444, 445, 5, 70, 0, 0, 445, 447, 3, 64, 32, 0, 446, 444, 1, 0, 0, 0, 447, 450, 1, 0, 0, 0, 448, 446, 1, 0, 0, 0, 448, 449, 1, 0, 0, 0, 449, 59, 1, 0, 0, 0, 450, 448, 1, 0, 0, 0, 451, 456, 3, 56, 28, 0, 452, 453, 5, 68, 0, 0, 453, 455, 3, 56, 28, 0, 454, 452, 1, 0, 0, 0, 455, 458, 1, 0, 0, 0, 456, 454, 1, 0, 0, 0, 456, 457, 1, 0, 0, 0, 457, 61, 1, 0, 0, 0, 458, 456, 1, 0, 0, 0, 459, 460, 7, 1, 0, 0, 460, 63, 1, 0, 0, 0, 461, 465, 5, 148, 0, 0, 462, 465, 3, 66, 33, 0, 463, 465, 3, 68, 34, 0, 464, 461, 1, 0, 0, 0, 464, 462, 1, 0, 0, 0, 464, 463, 1, 0, 0, 0, 465, 65, 1, 0, 0, 0, 466, 469, 5, 82, 0, 0, 467, 469, 5, 101, 0, 0, 468, 466, 1, 0, 0, 0, 468, 467, 1, 0, 0, 0, 469, 67, 1, 0, 0, 0, 470, 473, 5, 100, 0, 0, 471, 473, 5, 102, 0, 0, 472, 470, 1, 0, 0, 0, 472, 471, 1, 0, 0, 0, 473, 69, 1, 0, 0, 0, 474, 478, 3, 62, 31, 0, 475, 478, 3, 66, 33, 0, 476, 478, 3, 68, 34, 0, 477, 474, 1, 0, 0, 0, 477, 475, 1, 0, 0, 0, 477, 476, 1, 0, 0, 0, 478, 71, 1, 0, 0, 0, 479, 482, 3, 194, 97, 0, 480, 482, 3, 66, 33, 0, 481, 479, 1, 0, 0, 0, 481, 480, 1, 0, 0, 0, 482, 73, 1, 0, 0, 0, 483, 484, 5, 11, 0, 0, 484, 486, 3, 184, 92, 0, 485, 487, 3, 76, 38, 0, 486, 485, 1, 0, 0, 0, 486, 487, 1, 0, 0, 0, 487, 75, 1, 0, 0, 0, 488, 489, 5, 64, 0, 0, 489, 494, 3, 162, 81, 0, 490, 491, 5, 68, 0, 0, 491, 493, 3, 162, 81, 0, 492, 490, 1, 0, 0, 0, 493, 496, 1, 0, 0, 0, 494, 492, 1, 0, 0, 0, 494, 495, 1, 0, 0, 0, 495, 77, 1, 0, 0, 0, 496, 494, 1, 0, 0, 0, 497, 498, 5, 15, 0, 0, 498, 503, 3, 80, 40, 0, 499, 500, 5, 68, 0, 0, 500, 502, 3, 80, 40, 0, 501, 499, 1, 0, 0, 0, 502, 505, 1, 0, 0, 0, 503, 501, 1, 0, 0, 0, 503, 504, 1, 0, 0, 0, 504, 79, 1, 0, 0, 0, 505, 503, 1, 0, 0, 0, 506, 508, 3, 162, 81, 0, 507, 509, 7, 2, 0, 0, 508, 507, 1, 0, 0, 0, 508, 509, 1, 0, 0, 0, 509, 512, 1, 0, 0, 0, 510, 511, 5, 79, 0, 0, 511, 513, 7, 3, 0, 0, 512, 510, 1, 0, 0, 0, 512, 513, 1, 0, 0, 0, 513, 81, 1, 0, 0, 0, 514, 515, 5, 37, 0, 0, 515, 516, 3, 60, 30, 0, 516, 83, 1, 0, 0, 0, 517, 518, 5, 36, 0, 0, 518, 519, 3, 60, 30, 0, 519, 85, 1, 0, 0, 0, 520, 521, 5, 40, 0, 0, 521, 526, 3, 88, 44, 0, 522, 523, 5, 68, 0, 0, 523, 525, 3, 88, 44, 0, 524, 522, 1, 0, 0, 0, 525, 528, 1, 0, 0, 0, 526, 524, 1, 0, 0, 0, 526, 527, 1, 0, 0, 0, 527, 87, 1, 0, 0, 0, 528, 526, 1, 0, 0, 0, 529, 530, 3, 56, 28, 0, 530, 531, 5, 158, 0, 0, 531, 532, 3, 56, 28, 0, 532, 538, 1, 0, 0, 0, 533, 534, 3, 56, 28, 0, 534, 535, 5, 63, 0, 0, 535, 536, 3, 56, 28, 0, 536, 538, 1, 0, 0, 0, 537, 529, 1, 0, 0, 0, 537, 533, 1, 0, 0, 0, 538, 89, 1, 0, 0, 0, 539, 540, 5, 8, 0, 0, 540, 541, 3, 172, 86, 0, 541, 543, 3, 194, 97, 0, 542, 544, 3, 92, 46, 0, 543, 542, 1, 0, 0, 0, 543, 544, 1, 0, 0, 0, 544, 91, 1, 0, 0, 0, 545, 550, 3, 94, 47, 0, 546, 547, 5, 68, 0, 0, 547, 549, 3, 94, 47, 0, 548, 546, 1, 0, 0, 0, 549, 552, 1, 0, 0, 0, 550, 548, 1, 0, 0, 0, 550, 551, 1, 0, 0, 0, 551, 93, 1, 0, 0, 0, 552, 550, 1, 0, 0, 0, 553, 554, 3, 62, 31, 0, 554, 555, 5, 63, 0, 0, 555, 556, 3, 184, 92, 0, 556, 95, 1, 0, 0, 0, 557, 558, 5, 85, 0, 0, 558, 560, 3, 178, 89, 0, 559, 557, 1, 0, 0, 0, 559, 560, 1, 0, 0, 0, 560, 97, 1, 0, 0, 0, 561, 562, 5, 10, 0, 0, 562, 563, 3, 172, 86, 0, 563, 568, 3, 194, 97, 0, 564, 565, 5, 68, 0, 0, 565, 567, 3, 194, 97, 0, 566, 564, 1, 0, 0, 0, 567, 570, 1, 0, 0, 0, 568, 566, 1, 0, 0, 0, 568, 569, 1, 0, 0, 0, 569, 99, 1, 0, 0, 0, 570, 568, 1, 0, 0, 0, 571, 572, 5, 35, 0, 0, 572, 573, 3, 52, 26, 0, 573, 101, 1, 0, 0, 0, 574, 575, 5, 6, 0, 0, 575, 576, 3, 104, 52, 0, 576, 103, 1, 0, 0, 0, 577, 578, 5, 105, 0, 0, 578, 579, 3, 4, 2, 0, 579, 580, 5, 106, 0, 0, 580, 105, 1, 0, 0, 0, 581, 582, 5, 42, 0, 0, 582, 583, 5, 165, 0, 0, 583, 107, 1, 0, 0, 0, 584, 585, 5, 5, 0, 0, 585, 588, 3, 110, 55, 0, 586, 587, 5, 80, 0, 0, 587, 589, 3, 56, 28, 0, 588, 586, 1, 0, 0, 0, 588, 589, 1, 0, 0, 0, 589, 599, 1, 0, 0, 0, 590, 591, 5, 85, 0, 0, 591, 596, 3, 112, 56, 0, 592, 593, 5, 68, 0, 0, 593, 595, 3, 112, 56, 0, 594, 592, 1, 0, 0, 0, 595, 598, 1, 0, 0, 0, 596, 594, 1, 0, 0, 0, 596, 597, 1, 0, 0, 0, 597, 600, 1, 0, 0, 0, 598, 596, 1, 0, 0, 0, 599, 590, 1, 0, 0, 0, 599, 600, 1, 0, 0, 0, 600, 109, 1, 0, 0, 0, 601, 602, 7, 4, 0, 0, 602, 111, 1, 0, 0, 0, 603, 604, 3, 56, 28, 0, 604, 605, 5, 63, 0, 0, 605, 607, 1, 0, 0, 0, 606, 603, 1, 0, 0, 0, 606, 607, 1, 0, 0, 0, 607, 608, 1, 0, 0, 0, 608, 609, 3, 56, 28, 0, 609, 113, 1, 0, 0, 0, 610, 611, 5, 14, 0, 0, 611, 612, 3, 184, 92, 0, 612, 115, 1, 0, 0, 0, 613, 614, 5, 4, 0, 0, 614, 618, 3, 52, 26, 0, 615, 617, 3, 118, 59, 0, 616, 615, 1, 0, 0, 0, 617, 620, 1, 0, 0, 0, 618, 616, 1, 0, 0, 0, 618, 619, 1, 0, 0, 0, 619, 117, 1, 0, 0, 0, 620, 618, 1, 0, 0, 0, 621, 622, 5, 80, 0, 0, 622, 629, 3, 52, 26, 0, 623, 624, 5, 158, 0, 0, 624, 625, 3, 52, 26, 0, 625, 626, 5, 68, 0, 0, 626, 627, 3, 52, 26, 0, 627, 629, 1, 0, 0, 0, 628, 621, 1, 0, 0, 0, 628, 623, 1, 0, 0, 0, 629, 119, 1, 0, 0, 0, 630, 631, 5, 25, 0, 0, 631, 632, 3, 122, 61, 0, 632, 121, 1, 0, 0, 0, 633, 635, 3, 124, 62, 0, 634, 633, 1, 0, 0, 0, 635, 636, 1, 0, 0, 0, 636, 634, 1, 0, 0, 0, 636, 637, 1, 0, 0, 0, 637, 123, 1, 0, 0, 0, 638, 639, 5, 105, 0, 0, 639, 640, 3, 126, 63, 0, 640, 641, 5, 106, 0, 0, 641, 125, 1, 0, 0, 0, 642, 643, 6, 63, -1, 0, 643, 644, 3, 128, 64, 0, 644, 650, 1, 0, 0, 0, 645, 646, 10, 1, 0, 0, 646, 647, 5, 57, 0, 0, 647, 649, 3, 128, 64, 0, 648, 645, 1, 0, 0, 0, 649, 652, 1, 0, 0, 0, 650, 648, 1, 0, 0, 0, 650, 651, 1, 0, 0, 0, 651, 127, 1, 0, 0, 0, 652, 650, 1, 0, 0, 0, 653, 654, 3, 8, 4, 0, 654, 129, 1, 0, 0, 0, 655, 659, 5, 12, 0, 0, 656, 657, 3, 52, 26, 0, 657, 658, 5, 63, 0, 0, 658, 660, 1, 0, 0, 0, 659, 656, 1, 0, 0, 0, 659, 660, 1, 0, 0, 0, 660, 661, 1, 0, 0, 0, 661, 662, 3, 184, 92, 0, 662, 663, 5, 80, 0, 0, 663, 664, 3, 16, 8, 0, 664, 665, 3, 96, 48, 0, 665, 131, 1, 0, 0, 0, 666, 670, 5, 7, 0, 0, 667, 668, 3, 52, 26, 0, 668, 669, 5, 63, 0, 0, 669, 671, 1, 0, 0, 0, 670, 667, 1, 0, 0, 0, 670, 671, 1, 0, 0, 0, 671, 672, 1, 0, 0, 0, 672, 673, 3, 172, 86, 0, 673, 674, 3, 96, 48, 0, 674, 133, 1, 0, 0, 0, 675, 676, 5, 27, 0, 0, 676, 677, 5, 126, 0, 0, 677, 680, 3, 48, 24, 0, 678, 679, 5, 64, 0, 0, 679, 681, 3, 16, 8, 0, 680, 678, 1, 0, 0, 0, 680, 681, 1, 0, 0, 0, 681, 689, 1, 0, 0, 0, 682, 683, 5, 28, 0, 0, 683, 686, 3, 48, 24, 0, 684, 685, 5, 64, 0, 0, 685, 687, 3, 16, 8, 0, 686, 684, 1, 0, 0, 0, 686, 687, 1, 0, 0, 0, 687, 689, 1, 0, 0, 0, 688, 675, 1, 0, 0, 0, 688, 682, 1, 0, 0, 0, 689, 135, 1, 0, 0, 0, 690, 692, 5, 26, 0, 0, 691, 693, 3, 62, 31, 0, 692, 691, 1, 0, 0, 0, 692, 693, 1, 0, 0, 0, 693, 697, 1, 0, 0, 0, 694, 696, 3, 138, 69, 0, 695, 694, 1, 0, 0, 0, 696, 699, 1, 0, 0, 0, 697, 695, 1, 0, 0, 0, 697, 698, 1, 0, 0, 0, 698, 137, 1, 0, 0, 0, 699, 697, 1, 0, 0, 0, 700, 701, 5, 121, 0, 0, 701, 702, 5, 64, 0, 0, 702, 712, 3, 52, 26, 0, 703, 704, 5, 122, 0, 0, 704, 705, 5, 64, 0, 0, 705, 712, 3, 140, 70, 0, 706, 707, 5, 120, 0, 0, 707, 708, 5, 64, 0, 0, 708, 712, 3, 52, 26, 0, 709, 710, 5, 85, 0, 0, 710, 712, 3, 178, 89, 0, 711, 700, 1, 0, 0, 0, 711, 703, 1, 0, 0, 0, 711, 706, 1, 0, 0, 0, 711, 709, 1, 0, 0, 0, 712, 139, 1, 0, 0, 0, 713, 718, 3, 52, 26, 0, 714, 715, 5, 68, 0, 0, 715, 717, 3, 52, 26, 0, 716, 714, 1, 0, 0, 0, 717, 720, 1, 0, 0, 0, 718, 716, 1, 0, 0, 0, 718, 719, 1, 0, 0, 0, 719, 141, 1, 0, 0, 0, 720, 718, 1, 0, 0, 0, 721, 722, 5, 19, 0, 0, 722, 143, 1, 0, 0, 0, 723, 724, 5, 21, 0, 0, 724, 145, 1, 0, 0, 0, 725, 726, 5, 33, 0, 0, 726, 727, 3, 32, 16, 0, 727, 728, 5, 80, 0, 0, 728, 729, 3, 60, 30, 0, 729, 147, 1, 0, 0, 0, 730, 731, 5, 38, 0, 0, 731, 732, 3, 60, 30, 0, 732, 149, 1, 0, 0, 0, 733, 734, 5, 18, 0, 0, 734, 735, 3, 52, 26, 0, 735, 736, 5, 63, 0, 0, 736, 737, 3, 172, 86, 0, 737, 151, 1, 0, 0, 0, 738, 739, 5, 20, 0, 0, 739, 740, 3, 52, 26, 0, 740, 741, 5, 63, 0, 0, 741, 742, 3, 172, 86, 0, 742, 153, 1, 0, 0, 0, 743, 744, 5, 41, 0, 0, 744, 745, 3, 156, 78, 0, 745, 746, 5, 67, 0, 0, 746, 155, 1, 0, 0, 0, 747, 748, 3, 62, 31, 0, 748, 751, 5, 63, 0, 0, 749, 752, 3, 184, 92, 0, 750, 752, 3, 178, 89, 0, 751, 749, 1, 0, 0, 0, 751, 750, 1, 0, 0, 0, 752, 157, 1, 0, 0, 0, 753, 755, 5, 34, 0, 0, 754, 756, 3, 160, 80, 0, 755, 754, 1, 0, 0, 0, 755, 756, 1, 0, 0, 0, 756, 757, 1, 0, 0, 0, 757, 758, 5, 80, 0, 0, 758, 759, 3, 52, 26, 0, 759, 760, 5, 141, 0, 0, 760, 761, 3, 192, 96, 0, 761, 762, 3, 96, 48, 0, 762, 159, 1, 0, 0, 0, 763, 766, 3, 66, 33, 0, 764, 766, 3, 172, 86, 0, 765, 763, 1, 0, 0, 0, 765, 764, 1, 0, 0, 0, 766, 161, 1, 0, 0, 0, 767, 768, 6, 81, -1, 0, 768, 769, 5, 77, 0, 0, 769, 797, 3, 162, 81, 8, 770, 797, 3, 168, 84, 0, 771, 797, 3, 164, 82, 0, 772, 774, 3, 168, 84, 0, 773, 775, 5, 77, 0, 0, 774, 773, 1, 0, 0, 0, 774, 775, 1, 0, 0, 0, 775, 776, 1, 0, 0, 0, 776, 777, 5, 73, 0, 0, 777, 778, 5, 105, 0, 0, 778, 783, 3, 168, 84, 0, 779, 780, 5, 68, 0, 0, 780, 782, 3, 168, 84, 0, 781, 779, 1, 0, 0, 0, 782, 785, 1, 0, 0, 0, 783, 781, 1, 0, 0, 0, 783, 784, 1, 0, 0, 0, 784, 786, 1, 0, 0, 0, 785, 783, 1, 0, 0, 0, 786, 787, 5, 106, 0, 0, 787, 797, 1, 0, 0, 0, 788, 789, 3, 168, 84, 0, 789, 791, 5, 74, 0, 0, 790, 792, 5, 77, 0, 0, 791, 790, 1, 0, 0, 0, 791, 792, 1, 0, 0, 0, 792, 793, 1, 0, 0, 0, 793, 794, 5, 78, 0, 0, 794, 797, 1, 0, 0, 0, 795, 797, 3, 166, 83, 0, 796, 767, 1, 0, 0, 0, 796, 770, 1, 0, 0, 0, 796, 771, 1, 0, 0, 0, 796, 772, 1, 0, 0, 0, 796, 788, 1, 0, 0, 0, 796, 795, 1, 0, 0, 0, 797, 806, 1, 0, 0, 0, 798, 799, 10, 5, 0, 0, 799, 800, 5, 61, 0, 0, 800, 805, 3, 162, 81, 6, 801, 802, 10, 4, 0, 0, 802, 803, 5, 81, 0, 0, 803, 805, 3, 162, 81, 5, 804, 798, 1, 0, 0, 0, 804, 801, 1, 0, 0, 0, 805, 808, 1, 0, 0, 0, 806, 804, 1, 0, 0, 0, 806, 807, 1, 0, 0, 0, 807, 163, 1, 0, 0, 0, 808, 806, 1, 0, 0, 0, 809, 811, 3, 168, 84, 0, 810, 812, 5, 77, 0, 0, 811, 810, 1, 0, 0, 0, 811, 812, 1, 0, 0, 0, 812, 813, 1, 0, 0, 0, 813, 814, 5, 76, 0, 0, 814, 815, 3, 72, 36, 0, 815, 856, 1, 0, 0, 0, 816, 818, 3, 168, 84, 0, 817, 819, 5, 77, 0, 0, 818, 817, 1, 0, 0, 0, 818, 819, 1, 0, 0, 0, 819, 820, 1, 0, 0, 0, 820, 821, 5, 83, 0, 0, 821, 822, 3, 72, 36, 0, 822, 856, 1, 0, 0, 0, 823, 825, 3, 168, 84, 0, 824, 826, 5, 77, 0, 0, 825, 824, 1, 0, 0, 0, 825, 826, 1, 0, 0, 0, 826, 827, 1, 0, 0, 0, 827, 828, 5, 76, 0, 0, 828, 829, 5, 105, 0, 0, 829, 834, 3, 72, 36, 0, 830, 831, 5, 68, 0, 0, 831, 833, 3, 72, 36, 0, 832, 830, 1, 0, 0, 0, 833, 836, 1, 0, 0, 0, 834, 832, 1, 0, 0, 0, 834, 835, 1, 0, 0, 0, 835, 837, 1, 0, 0, 0, 836, 834, 1, 0, 0, 0, 837, 838, 5, 106, 0, 0, 838, 856, 1, 0, 0, 0, 839, 841, 3, 168, 84, 0, 840, 842, 5, 77, 0, 0, 841, 840, 1, 0, 0, 0, 841, 842, 1, 0, 0, 0, 842, 843, 1, 0, 0, 0, 843, 844, 5, 83, 0, 0, 844, 845, 5, 105, 0, 0, 845, 850, 3, 72, 36, 0, 846, 847, 5, 68, 0, 0, 847, 849, 3, 72, 36, 0, 848, 846, 1, 0, 0, 0, 849, 852, 1, 0, 0, 0, 850, 848, 1, 0, 0, 0, 850, 851, 1, 0, 0, 0, 851, 853, 1, 0, 0, 0, 852, 850, 1, 0, 0, 0, 853, 854, 5, 106, 0, 0, 854, 856, 1, 0, 0, 0, 855, 809, 1, 0, 0, 0, 855, 816, 1, 0, 0, 0, 855, 823, 1, 0, 0, 0, 855, 839, 1, 0, 0, 0, 856, 165, 1, 0, 0, 0, 857, 860, 3, 52, 26, 0, 858, 859, 5, 65, 0, 0, 859, 861, 3, 12, 6, 0, 860, 858, 1, 0, 0, 0, 860, 861, 1, 0, 0, 0, 861, 862, 1, 0, 0, 0, 862, 863, 5, 66, 0, 0, 863, 864, 3, 184, 92, 0, 864, 167, 1, 0, 0, 0, 865, 871, 3, 170, 85, 0, 866, 867, 3, 170, 85, 0, 867, 868, 3, 196, 98, 0, 868, 869, 3, 170, 85, 0, 869, 871, 1, 0, 0, 0, 870, 865, 1, 0, 0, 0, 870, 866, 1, 0, 0, 0, 871, 169, 1, 0, 0, 0, 872, 873, 6, 85, -1, 0, 873, 877, 3, 172, 86, 0, 874, 875, 7, 5, 0, 0, 875, 877, 3, 170, 85, 3, 876, 872, 1, 0, 0, 0, 876, 874, 1, 0, 0, 0, 877, 886, 1, 0, 0, 0, 878, 879, 10, 2, 0, 0, 879, 880, 7, 6, 0, 0, 880, 885, 3, 170, 85, 3, 881, 882, 10, 1, 0, 0, 882, 883, 7, 5, 0, 0, 883, 885, 3, 170, 85, 2, 884, 878, 1, 0, 0, 0, 884, 881, 1, 0, 0, 0, 885, 888, 1, 0, 0, 0, 886, 884, 1, 0, 0, 0, 886, 887, 1, 0, 0, 0, 887, 171, 1, 0, 0, 0, 888, 886, 1, 0, 0, 0, 889, 890, 6, 86, -1, 0, 890, 898, 3, 184, 92, 0, 891, 898, 3, 52, 26, 0, 892, 898, 3, 174, 87, 0, 893, 894, 5, 105, 0, 0, 894, 895, 3, 162, 81, 0, 895, 896, 5, 106, 0, 0, 896, 898, 1, 0, 0, 0, 897, 889, 1, 0, 0, 0, 897, 891, 1, 0, 0, 0, 897, 892, 1, 0, 0, 0, 897, 893, 1, 0, 0, 0, 898, 904, 1, 0, 0, 0, 899, 900, 10, 1, 0, 0, 900, 901, 5, 65, 0, 0, 901, 903, 3, 12, 6, 0, 902, 899, 1, 0, 0, 0, 903, 906, 1, 0, 0, 0, 904, 902, 1, 0, 0, 0, 904, 905, 1, 0, 0, 0, 905, 173, 1, 0, 0, 0, 906, 904, 1, 0, 0, 0, 907, 908, 3, 176, 88, 0, 908, 922, 5, 105, 0, 0, 909, 923, 5, 95, 0, 0, 910, 915, 3, 162, 81, 0, 911, 912, 5, 68, 0, 0, 912, 914, 3, 162, 81, 0, 913, 911, 1, 0, 0, 0, 914, 917, 1, 0, 0, 0, 915, 913, 1, 0, 0, 0, 915, 916, 1, 0, 0, 0, 916, 920, 1, 0, 0, 0, 917, 915, 1, 0, 0, 0, 918, 919, 5, 68, 0, 0, 919, 921, 3, 178, 89, 0, 920, 918, 1, 0, 0, 0, 920, 921, 1, 0, 0, 0, 921, 923, 1, 0, 0, 0, 922, 909, 1, 0, 0, 0, 922, 910, 1, 0, 0, 0, 922, 923, 1, 0, 0, 0, 923, 924, 1, 0, 0, 0, 924, 925, 5, 106, 0, 0, 925, 175, 1, 0, 0, 0, 926, 930, 3, 70, 35, 0, 927, 930, 5, 72, 0, 0, 928, 930, 5, 75, 0, 0, 929, 926, 1, 0, 0, 0, 929, 927, 1, 0, 0, 0, 929, 928, 1, 0, 0, 0, 930, 177, 1, 0, 0, 0, 931, 940, 5, 98, 0, 0, 932, 937, 3, 180, 90, 0, 933, 934, 5, 68, 0, 0, 934, 936, 3, 180, 90, 0, 935, 933, 1, 0, 0, 0, 936, 939, 1, 0, 0, 0, 937, 935, 1, 0, 0, 0, 937, 938, 1, 0, 0, 0, 938, 941, 1, 0, 0, 0, 939, 937, 1, 0, 0, 0, 940, 932, 1, 0, 0, 0, 940, 941, 1, 0, 0, 0, 941, 942, 1, 0, 0, 0, 942, 943, 5, 99, 0, 0, 943, 179, 1, 0, 0, 0, 944, 945, 3, 194, 97, 0, 945, 946, 5, 66, 0, 0, 946, 947, 3, 182, 91, 0, 947, 181, 1, 0, 0, 0, 948, 951, 3, 184, 92, 0, 949, 951, 3, 178, 89, 0, 950, 948, 1, 0, 0, 0, 950, 949, 1, 0, 0, 0, 951, 183, 1, 0, 0, 0, 952, 995, 5, 78, 0, 0, 953, 954, 3, 192, 96, 0, 954, 955, 5, 107, 0, 0, 955, 995, 1, 0, 0, 0, 956, 995, 3, 190, 95, 0, 957, 995, 3, 192, 96, 0, 958, 995, 3, 186, 93, 0, 959, 995, 3, 66, 33, 0, 960, 995, 3, 194, 97, 0, 961, 962, 5, 103, 0, 0, 962, 967, 3, 188, 94, 0, 963, 964, 5, 68, 0, 0, 964, 966, 3, 188, 94, 0, 965, 963, 1, 0, 0, 0, 966, 969, 1, 0, 0, 0, 967, 965, 1, 0, 0, 0, 967, 968, 1, 0, 0, 0, 968, 970, 1, 0, 0, 0, 969, 967, 1, 0, 0, 0, 970, 971, 5, 104, 0, 0, 971, 995, 1, 0, 0, 0, 972, 973, 5, 103, 0, 0, 973, 978, 3, 186, 93, 0, 974, 975, 5, 68, 0, 0, 975, 977, 3, 186, 93, 0, 976, 974, 1, 0, 0, 0, 977, 980, 1, 0, 0, 0, 978, 976, 1, 0, 0, 0, 978, 979, 1, 0, 0, 0, 979, 981, 1, 0, 0, 0, 980, 978, 1, 0, 0, 0, 981, 982, 5, 104, 0, 0, 982, 995, 1, 0, 0, 0, 983, 984, 5, 103, 0, 0, 984, 989, 3, 194, 97, 0, 985, 986, 5, 68, 0, 0, 986, 988, 3, 194, 97, 0, 987, 985, 1, 0, 0, 0, 988, 991, 1, 0, 0, 0, 989, 987, 1, 0, 0, 0, 989, 990, 1, 0, 0, 0, 990, 992, 1, 0, 0, 0, 991, 989, 1, 0, 0, 0, 992, 993, 5, 104, 0, 0, 993, 995, 1, 0, 0, 0, 994, 952, 1, 0, 0, 0, 994, 953, 1, 0, 0, 0, 994, 956, 1, 0, 0, 0, 994, 957, 1, 0, 0, 0, 994, 958, 1, 0, 0, 0, 994, 959, 1, 0, 0, 0, 994, 960, 1, 0, 0, 0, 994, 961, 1, 0, 0, 0, 994, 972, 1, 0, 0, 0, 994, 983, 1, 0, 0, 0, 995, 185, 1, 0, 0, 0, 996, 997, 7, 7, 0, 0, 997, 187, 1, 0, 0, 0, 998, 1001, 3, 190, 95, 0, 999, 1001, 3, 192, 96, 0, 1000, 998, 1, 0, 0, 0, 1000, 999, 1, 0, 0, 0, 1001, 189, 1, 0, 0, 0, 1002, 1004, 7, 5, 0, 0, 1003, 1002, 1, 0, 0, 0, 1003, 1004, 1, 0, 0, 0, 1004, 1005, 1, 0, 0, 0, 1005, 1006, 5, 60, 0, 0, 1006, 191, 1, 0, 0, 0, 1007, 1009, 7, 5, 0, 0, 1008, 1007, 1, 0, 0, 0, 1008, 1009, 1, 0, 0, 0, 1009, 1010, 1, 0, 0, 0, 1010, 1011, 5, 59, 0, 0, 1011, 193, 1, 0, 0, 0, 1012, 1013, 5, 58, 0, 0, 1013, 195, 1, 0, 0, 0, 1014, 1015, 7, 8, 0, 0, 1015, 197, 1, 0, 0, 0, 1016, 1017, 7, 9, 0, 0, 1017, 1018, 5, 130, 0, 0, 1018, 1019, 3, 200, 100, 0, 1019, 1020, 3, 202, 101, 0, 1020, 199, 1, 0, 0, 0, 1021, 1022, 4, 100, 14, 0, 1022, 1024, 3, 32, 16, 0, 1023, 1025, 5, 158, 0, 0, 1024, 1023, 1, 0, 0, 0, 1024, 1025, 1, 0, 0, 0, 1025, 1026, 1, 0, 0, 0, 1026, 1027, 5, 113, 0, 0, 1027, 1030, 1, 0, 0, 0, 1028, 1030, 3, 32, 16, 0, 1029, 1021, 1, 0, 0, 0, 1029, 1028, 1, 0, 0, 0, 1030, 201, 1, 0, 0, 0, 1031, 1032, 5, 80, 0, 0, 1032, 1037, 3, 162, 81, 0, 1033, 1034, 5, 68, 0, 0, 1034, 1036, 3, 162, 81, 0, 1035, 1033, 1, 0, 0, 0, 1036, 1039, 1, 0, 0, 0, 1037, 1035, 1, 0, 0, 0, 1037, 1038, 1, 0, 0, 0, 1038, 203, 1, 0, 0, 0, 1039, 1037, 1, 0, 0, 0, 1040, 1044, 5, 39, 0, 0, 1041, 1043, 3, 208, 104, 0, 1042, 1041, 1, 0, 0, 0, 1043, 1046, 1, 0, 0, 0, 1044, 1042, 1, 0, 0, 0, 1044, 1045, 1, 0, 0, 0, 1045, 1050, 1, 0, 0, 0, 1046, 1044, 1, 0, 0, 0, 1047, 1048, 3, 206, 103, 0, 1048, 1049, 5, 63, 0, 0, 1049, 1051, 1, 0, 0, 0, 1050, 1047, 1, 0, 0, 0, 1050, 1051, 1, 0, 0, 0, 1051, 1052, 1, 0, 0, 0, 1052, 1053, 5, 105, 0, 0, 1053, 1054, 5, 101, 0, 0, 1054, 1101, 5, 106, 0, 0, 1055, 1059, 5, 39, 0, 0, 1056, 1058, 3, 208, 104, 0, 1057, 1056, 1, 0, 0, 0, 1058, 1061, 1, 0, 0, 0, 1059, 1057, 1, 0, 0, 0, 1059, 1060, 1, 0, 0, 0, 1060, 1065, 1, 0, 0, 0, 1061, 1059, 1, 0, 0, 0, 1062, 1063, 3, 206, 103, 0, 1063, 1064, 5, 63, 0, 0, 1064, 1066, 1, 0, 0, 0, 1065, 1062, 1, 0, 0, 0, 1065, 1066, 1, 0, 0, 0, 1066, 1067, 1, 0, 0, 0, 1067, 1101, 5, 101, 0, 0, 1068, 1072, 5, 39, 0, 0, 1069, 1071, 3, 208, 104, 0, 1070, 1069, 1, 0, 0, 0, 1071, 1074, 1, 0, 0, 0, 1072, 1070, 1, 0, 0, 0, 1072, 1073, 1, 0, 0, 0, 1073, 1078, 1, 0, 0, 0, 1074, 1072, 1, 0, 0, 0, 1075, 1076, 3, 206, 103, 0, 1076, 1077, 5, 63, 0, 0, 1077, 1079, 1, 0, 0, 0, 1078, 1075, 1, 0, 0, 0, 1078, 1079, 1, 0, 0, 0, 1079, 1080, 1, 0, 0, 0, 1080, 1082, 5, 105, 0, 0, 1081, 1083, 3, 216, 108, 0, 1082, 1081, 1, 0, 0, 0, 1083, 1084, 1, 0, 0, 0, 1084, 1082, 1, 0, 0, 0, 1084, 1085, 1, 0, 0, 0, 1085, 1086, 1, 0, 0, 0, 1086, 1087, 5, 106, 0, 0, 1087, 1101, 1, 0, 0, 0, 1088, 1092, 5, 39, 0, 0, 1089, 1091, 3, 208, 104, 0, 1090, 1089, 1, 0, 0, 0, 1091, 1094, 1, 0, 0, 0, 1092, 1090, 1, 0, 0, 0, 1092, 1093, 1, 0, 0, 0, 1093, 1096, 1, 0, 0, 0, 1094, 1092, 1, 0, 0, 0, 1095, 1097, 3, 216, 108, 0, 1096, 1095, 1, 0, 0, 0, 1097, 1098, 1, 0, 0, 0, 1098, 1096, 1, 0, 0, 0, 1098, 1099, 1, 0, 0, 0, 1099, 1101, 1, 0, 0, 0, 1100, 1040, 1, 0, 0, 0, 1100, 1055, 1, 0, 0, 0, 1100, 1068, 1, 0, 0, 0, 1100, 1088, 1, 0, 0, 0, 1101, 205, 1, 0, 0, 0, 1102, 1103, 7, 1, 0, 0, 1103, 207, 1, 0, 0, 0, 1104, 1105, 3, 210, 105, 0, 1105, 1106, 5, 63, 0, 0, 1106, 1107, 3, 212, 106, 0, 1107, 209, 1, 0, 0, 0, 1108, 1109, 7, 10, 0, 0, 1109, 211, 1, 0, 0, 0, 1110, 1115, 3, 218, 109, 0, 1111, 1112, 5, 68, 0, 0, 1112, 1114, 3, 218, 109, 0, 1113, 1111, 1, 0, 0, 0, 1114, 1117, 1, 0, 0, 0, 1115, 1113, 1, 0, 0, 0, 1115, 1116, 1, 0, 0, 0, 1116, 1121, 1, 0, 0, 0, 1117, 1115, 1, 0, 0, 0, 1118, 1121, 5, 108, 0, 0, 1119, 1121, 5, 101, 0, 0, 1120, 1110, 1, 0, 0, 0, 1120, 1118, 1, 0, 0, 0, 1120, 1119, 1, 0, 0, 0, 1121, 213, 1, 0, 0, 0, 1122, 1123, 7, 11, 0, 0, 1123, 215, 1, 0, 0, 0, 1124, 1126, 3, 214, 107, 0, 1125, 1124, 1, 0, 0, 0, 1126, 1127, 1, 0, 0, 0, 1127, 1125, 1, 0, 0, 0, 1127, 1128, 1, 0, 0, 0, 1128, 1138, 1, 0, 0, 0, 1129, 1133, 5, 105, 0, 0, 1130, 1132, 3, 216, 108, 0, 1131, 1130, 1, 0, 0, 0, 1132, 1135, 1, 0, 0, 0, 1133, 1131, 1, 0, 0, 0, 1133, 1134, 1, 0, 0, 0, 1134, 1136, 1, 0, 0, 0, 1135, 1133, 1, 0, 0, 0, 1136, 1138, 5, 106, 0, 0, 1137, 1125, 1, 0, 0, 0, 1137, 1129, 1, 0, 0, 0, 1138, 217, 1, 0, 0, 0, 1139, 1140, 3, 220, 110, 0, 1140, 1141, 5, 66, 0, 0, 1141, 1142, 3, 224, 112, 0, 1142, 1149, 1, 0, 0, 0, 1143, 1144, 3, 224, 112, 0, 1144, 1145, 5, 65, 0, 0, 1145, 1146, 3, 222, 111, 0, 1146, 1149, 1, 0, 0, 0, 1147, 1149, 3, 226, 113, 0, 1148, 1139, 1, 0, 0, 0, 1148, 1143, 1, 0, 0, 0, 1148, 1147, 1, 0, 0, 0, 1149, 219, 1, 0, 0, 0, 1150, 1151, 7, 12, 0, 0, 1151, 221, 1, 0, 0, 0, 1152, 1153, 7, 12, 0, 0, 1153, 223, 1, 0, 0, 0, 1154, 1155, 7, 12, 0, 0, 1155, 225, 1, 0, 0, 0, 1156, 1157, 7, 13, 0, 0, 1157, 227, 1, 0, 0, 0, 114, 231, 248, 260, 291, 306, 312, 331, 335, 340, 348, 356, 361, 364, 380, 388, 392, 399, 405, 410, 419, 426, 432, 441, 448, 456, 464, 468, 472, 477, 481, 486, 494, 503, 508, 512, 526, 537, 543, 550, 559, 568, 588, 596, 599, 606, 618, 628, 636, 650, 659, 670, 680, 686, 688, 692, 697, 711, 718, 751, 755, 765, 774, 783, 791, 796, 804, 806, 811, 818, 825, 834, 841, 850, 855, 860, 870, 876, 884, 886, 897, 904, 915, 920, 922, 929, 937, 940, 950, 967, 978, 989, 994, 1000, 1003, 1008, 1024, 1029, 1037, 1044, 1050, 1059, 1065, 1072, 1078, 1084, 1092, 1098, 1100, 1115, 1120, 1127, 1133, 1137, 1148] \ No newline at end of file diff --git a/x-pack/plugin/esql/src/main/java/org/elasticsearch/xpack/esql/parser/EsqlBaseParser.java b/x-pack/plugin/esql/src/main/java/org/elasticsearch/xpack/esql/parser/EsqlBaseParser.java index 53d12f59a9fc7..b9ea92fbb698a 100644 --- a/x-pack/plugin/esql/src/main/java/org/elasticsearch/xpack/esql/parser/EsqlBaseParser.java +++ b/x-pack/plugin/esql/src/main/java/org/elasticsearch/xpack/esql/parser/EsqlBaseParser.java @@ -3160,26 +3160,24 @@ public final LimitByGroupKeyContext limitByGroupKey() throws RecognitionExceptio enterOuterAlt(_localctx, 1); { setState(488); - if (!(this.isDevVersion())) throw new FailedPredicateException(this, "this.isDevVersion()"); - setState(489); match(BY); - setState(490); + setState(489); booleanExpression(0); - setState(495); + setState(494); _errHandler.sync(this); _alt = getInterpreter().adaptivePredict(_input,31,_ctx); while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) { if ( _alt==1 ) { { { - setState(491); + setState(490); match(COMMA); - setState(492); + setState(491); booleanExpression(0); } } } - setState(497); + setState(496); _errHandler.sync(this); _alt = getInterpreter().adaptivePredict(_input,31,_ctx); } @@ -3236,25 +3234,25 @@ public final SortCommandContext sortCommand() throws RecognitionException { int _alt; enterOuterAlt(_localctx, 1); { - setState(498); + setState(497); match(SORT); - setState(499); + setState(498); orderExpression(); - setState(504); + setState(503); _errHandler.sync(this); _alt = getInterpreter().adaptivePredict(_input,32,_ctx); while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) { if ( _alt==1 ) { { { - setState(500); + setState(499); match(COMMA); - setState(501); + setState(500); orderExpression(); } } } - setState(506); + setState(505); _errHandler.sync(this); _alt = getInterpreter().adaptivePredict(_input,32,_ctx); } @@ -3310,14 +3308,14 @@ public final OrderExpressionContext orderExpression() throws RecognitionExceptio try { enterOuterAlt(_localctx, 1); { - setState(507); + setState(506); booleanExpression(0); - setState(509); + setState(508); _errHandler.sync(this); switch ( getInterpreter().adaptivePredict(_input,33,_ctx) ) { case 1: { - setState(508); + setState(507); ((OrderExpressionContext)_localctx).ordering = _input.LT(1); _la = _input.LA(1); if ( !(_la==ASC || _la==DESC) ) { @@ -3331,14 +3329,14 @@ public final OrderExpressionContext orderExpression() throws RecognitionExceptio } break; } - setState(513); + setState(512); _errHandler.sync(this); switch ( getInterpreter().adaptivePredict(_input,34,_ctx) ) { case 1: { - setState(511); + setState(510); match(NULLS); - setState(512); + setState(511); ((OrderExpressionContext)_localctx).nullOrdering = _input.LT(1); _la = _input.LA(1); if ( !(_la==FIRST || _la==LAST) ) { @@ -3397,9 +3395,9 @@ public final KeepCommandContext keepCommand() throws RecognitionException { try { enterOuterAlt(_localctx, 1); { - setState(515); + setState(514); match(KEEP); - setState(516); + setState(515); qualifiedNamePatterns(); } } @@ -3446,9 +3444,9 @@ public final DropCommandContext dropCommand() throws RecognitionException { try { enterOuterAlt(_localctx, 1); { - setState(518); + setState(517); match(DROP); - setState(519); + setState(518); qualifiedNamePatterns(); } } @@ -3503,25 +3501,25 @@ public final RenameCommandContext renameCommand() throws RecognitionException { int _alt; enterOuterAlt(_localctx, 1); { - setState(521); + setState(520); match(RENAME); - setState(522); + setState(521); renameClause(); - setState(527); + setState(526); _errHandler.sync(this); _alt = getInterpreter().adaptivePredict(_input,35,_ctx); while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) { if ( _alt==1 ) { { { - setState(523); + setState(522); match(COMMA); - setState(524); + setState(523); renameClause(); } } } - setState(529); + setState(528); _errHandler.sync(this); _alt = getInterpreter().adaptivePredict(_input,35,_ctx); } @@ -3574,28 +3572,28 @@ public final RenameClauseContext renameClause() throws RecognitionException { RenameClauseContext _localctx = new RenameClauseContext(_ctx, getState()); enterRule(_localctx, 88, RULE_renameClause); try { - setState(538); + setState(537); _errHandler.sync(this); switch ( getInterpreter().adaptivePredict(_input,36,_ctx) ) { case 1: enterOuterAlt(_localctx, 1); { - setState(530); + setState(529); ((RenameClauseContext)_localctx).oldName = qualifiedNamePattern(); - setState(531); + setState(530); match(AS); - setState(532); + setState(531); ((RenameClauseContext)_localctx).newName = qualifiedNamePattern(); } break; case 2: enterOuterAlt(_localctx, 2); { - setState(534); + setState(533); ((RenameClauseContext)_localctx).newName = qualifiedNamePattern(); - setState(535); + setState(534); match(ASSIGN); - setState(536); + setState(535); ((RenameClauseContext)_localctx).oldName = qualifiedNamePattern(); } break; @@ -3650,18 +3648,18 @@ public final DissectCommandContext dissectCommand() throws RecognitionException try { enterOuterAlt(_localctx, 1); { - setState(540); + setState(539); match(DISSECT); - setState(541); + setState(540); primaryExpression(0); - setState(542); + setState(541); string(); - setState(544); + setState(543); _errHandler.sync(this); switch ( getInterpreter().adaptivePredict(_input,37,_ctx) ) { case 1: { - setState(543); + setState(542); dissectCommandOptions(); } break; @@ -3718,23 +3716,23 @@ public final DissectCommandOptionsContext dissectCommandOptions() throws Recogni int _alt; enterOuterAlt(_localctx, 1); { - setState(546); + setState(545); dissectCommandOption(); - setState(551); + setState(550); _errHandler.sync(this); _alt = getInterpreter().adaptivePredict(_input,38,_ctx); while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) { if ( _alt==1 ) { { { - setState(547); + setState(546); match(COMMA); - setState(548); + setState(547); dissectCommandOption(); } } } - setState(553); + setState(552); _errHandler.sync(this); _alt = getInterpreter().adaptivePredict(_input,38,_ctx); } @@ -3786,11 +3784,11 @@ public final DissectCommandOptionContext dissectCommandOption() throws Recogniti try { enterOuterAlt(_localctx, 1); { - setState(554); + setState(553); identifier(); - setState(555); + setState(554); match(ASSIGN); - setState(556); + setState(555); constant(); } } @@ -3837,14 +3835,14 @@ public final CommandNamedParametersContext commandNamedParameters() throws Recog try { enterOuterAlt(_localctx, 1); { - setState(560); + setState(559); _errHandler.sync(this); switch ( getInterpreter().adaptivePredict(_input,39,_ctx) ) { case 1: { - setState(558); + setState(557); match(WITH); - setState(559); + setState(558); mapExpression(); } break; @@ -3905,27 +3903,27 @@ public final GrokCommandContext grokCommand() throws RecognitionException { int _alt; enterOuterAlt(_localctx, 1); { - setState(562); + setState(561); match(GROK); - setState(563); + setState(562); primaryExpression(0); - setState(564); + setState(563); string(); - setState(569); + setState(568); _errHandler.sync(this); _alt = getInterpreter().adaptivePredict(_input,40,_ctx); while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) { if ( _alt==1 ) { { { - setState(565); + setState(564); match(COMMA); - setState(566); + setState(565); string(); } } } - setState(571); + setState(570); _errHandler.sync(this); _alt = getInterpreter().adaptivePredict(_input,40,_ctx); } @@ -3974,9 +3972,9 @@ public final MvExpandCommandContext mvExpandCommand() throws RecognitionExceptio try { enterOuterAlt(_localctx, 1); { - setState(572); + setState(571); match(MV_EXPAND); - setState(573); + setState(572); qualifiedName(); } } @@ -4023,9 +4021,9 @@ public final ExplainCommandContext explainCommand() throws RecognitionException try { enterOuterAlt(_localctx, 1); { - setState(575); + setState(574); match(DEV_EXPLAIN); - setState(576); + setState(575); subqueryExpression(); } } @@ -4073,11 +4071,11 @@ public final SubqueryExpressionContext subqueryExpression() throws RecognitionEx try { enterOuterAlt(_localctx, 1); { - setState(578); + setState(577); match(LP); - setState(579); + setState(578); query(0); - setState(580); + setState(579); match(RP); } } @@ -4134,9 +4132,9 @@ public final ShowCommandContext showCommand() throws RecognitionException { _localctx = new ShowInfoContext(_localctx); enterOuterAlt(_localctx, 1); { - setState(582); + setState(581); match(SHOW); - setState(583); + setState(582); match(INFO); } } @@ -4201,46 +4199,46 @@ public final EnrichCommandContext enrichCommand() throws RecognitionException { int _alt; enterOuterAlt(_localctx, 1); { - setState(585); + setState(584); match(ENRICH); - setState(586); + setState(585); ((EnrichCommandContext)_localctx).policyName = enrichPolicyName(); - setState(589); + setState(588); _errHandler.sync(this); switch ( getInterpreter().adaptivePredict(_input,41,_ctx) ) { case 1: { - setState(587); + setState(586); match(ON); - setState(588); + setState(587); ((EnrichCommandContext)_localctx).matchField = qualifiedNamePattern(); } break; } - setState(600); + setState(599); _errHandler.sync(this); switch ( getInterpreter().adaptivePredict(_input,43,_ctx) ) { case 1: { - setState(591); + setState(590); match(WITH); - setState(592); + setState(591); enrichWithClause(); - setState(597); + setState(596); _errHandler.sync(this); _alt = getInterpreter().adaptivePredict(_input,42,_ctx); while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) { if ( _alt==1 ) { { { - setState(593); + setState(592); match(COMMA); - setState(594); + setState(593); enrichWithClause(); } } } - setState(599); + setState(598); _errHandler.sync(this); _alt = getInterpreter().adaptivePredict(_input,42,_ctx); } @@ -4291,7 +4289,7 @@ public final EnrichPolicyNameContext enrichPolicyName() throws RecognitionExcept try { enterOuterAlt(_localctx, 1); { - setState(602); + setState(601); _la = _input.LA(1); if ( !(_la==ENRICH_POLICY_NAME || _la==QUOTED_STRING) ) { _errHandler.recoverInline(this); @@ -4351,19 +4349,19 @@ public final EnrichWithClauseContext enrichWithClause() throws RecognitionExcept try { enterOuterAlt(_localctx, 1); { - setState(607); + setState(606); _errHandler.sync(this); switch ( getInterpreter().adaptivePredict(_input,44,_ctx) ) { case 1: { - setState(604); + setState(603); ((EnrichWithClauseContext)_localctx).newName = qualifiedNamePattern(); - setState(605); + setState(604); match(ASSIGN); } break; } - setState(609); + setState(608); ((EnrichWithClauseContext)_localctx).enrichField = qualifiedNamePattern(); } } @@ -4411,9 +4409,9 @@ public final SampleCommandContext sampleCommand() throws RecognitionException { try { enterOuterAlt(_localctx, 1); { - setState(611); + setState(610); match(SAMPLE); - setState(612); + setState(611); ((SampleCommandContext)_localctx).probability = constant(); } } @@ -4468,23 +4466,23 @@ public final ChangePointCommandContext changePointCommand() throws RecognitionEx int _alt; enterOuterAlt(_localctx, 1); { - setState(614); + setState(613); match(CHANGE_POINT); - setState(615); + setState(614); ((ChangePointCommandContext)_localctx).value = qualifiedName(); - setState(619); + setState(618); _errHandler.sync(this); _alt = getInterpreter().adaptivePredict(_input,45,_ctx); while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) { if ( _alt==1 ) { { { - setState(616); + setState(615); changePointConfiguration(); } } } - setState(621); + setState(620); _errHandler.sync(this); _alt = getInterpreter().adaptivePredict(_input,45,_ctx); } @@ -4539,28 +4537,28 @@ public final ChangePointConfigurationContext changePointConfiguration() throws R ChangePointConfigurationContext _localctx = new ChangePointConfigurationContext(_ctx, getState()); enterRule(_localctx, 118, RULE_changePointConfiguration); try { - setState(629); + setState(628); _errHandler.sync(this); switch (_input.LA(1)) { case ON: enterOuterAlt(_localctx, 1); { - setState(622); + setState(621); match(ON); - setState(623); + setState(622); ((ChangePointConfigurationContext)_localctx).key = qualifiedName(); } break; case AS: enterOuterAlt(_localctx, 2); { - setState(624); + setState(623); match(AS); - setState(625); + setState(624); ((ChangePointConfigurationContext)_localctx).targetType = qualifiedName(); - setState(626); + setState(625); match(COMMA); - setState(627); + setState(626); ((ChangePointConfigurationContext)_localctx).targetPvalue = qualifiedName(); } break; @@ -4611,9 +4609,9 @@ public final ForkCommandContext forkCommand() throws RecognitionException { try { enterOuterAlt(_localctx, 1); { - setState(631); + setState(630); match(FORK); - setState(632); + setState(631); forkSubQueries(); } } @@ -4663,7 +4661,7 @@ public final ForkSubQueriesContext forkSubQueries() throws RecognitionException int _alt; enterOuterAlt(_localctx, 1); { - setState(635); + setState(634); _errHandler.sync(this); _alt = 1; do { @@ -4671,7 +4669,7 @@ public final ForkSubQueriesContext forkSubQueries() throws RecognitionException case 1: { { - setState(634); + setState(633); forkSubQuery(); } } @@ -4679,7 +4677,7 @@ public final ForkSubQueriesContext forkSubQueries() throws RecognitionException default: throw new NoViableAltException(this); } - setState(637); + setState(636); _errHandler.sync(this); _alt = getInterpreter().adaptivePredict(_input,47,_ctx); } while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ); @@ -4729,11 +4727,11 @@ public final ForkSubQueryContext forkSubQuery() throws RecognitionException { try { enterOuterAlt(_localctx, 1); { - setState(639); + setState(638); match(LP); - setState(640); + setState(639); forkSubQueryCommand(0); - setState(641); + setState(640); match(RP); } } @@ -4829,11 +4827,11 @@ private ForkSubQueryCommandContext forkSubQueryCommand(int _p) throws Recognitio _ctx = _localctx; _prevctx = _localctx; - setState(644); + setState(643); forkSubQueryProcessingCommand(); } _ctx.stop = _input.LT(-1); - setState(651); + setState(650); _errHandler.sync(this); _alt = getInterpreter().adaptivePredict(_input,48,_ctx); while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) { @@ -4844,16 +4842,16 @@ private ForkSubQueryCommandContext forkSubQueryCommand(int _p) throws Recognitio { _localctx = new CompositeForkSubQueryContext(new ForkSubQueryCommandContext(_parentctx, _parentState)); pushNewRecursionContext(_localctx, _startState, RULE_forkSubQueryCommand); - setState(646); + setState(645); if (!(precpred(_ctx, 1))) throw new FailedPredicateException(this, "precpred(_ctx, 1)"); - setState(647); + setState(646); match(PIPE); - setState(648); + setState(647); forkSubQueryProcessingCommand(); } } } - setState(653); + setState(652); _errHandler.sync(this); _alt = getInterpreter().adaptivePredict(_input,48,_ctx); } @@ -4901,7 +4899,7 @@ public final ForkSubQueryProcessingCommandContext forkSubQueryProcessingCommand( try { enterOuterAlt(_localctx, 1); { - setState(654); + setState(653); processingCommand(); } } @@ -4962,27 +4960,27 @@ public final RerankCommandContext rerankCommand() throws RecognitionException { try { enterOuterAlt(_localctx, 1); { - setState(656); + setState(655); match(RERANK); - setState(660); + setState(659); _errHandler.sync(this); switch ( getInterpreter().adaptivePredict(_input,49,_ctx) ) { case 1: { - setState(657); + setState(656); ((RerankCommandContext)_localctx).targetField = qualifiedName(); - setState(658); + setState(657); match(ASSIGN); } break; } - setState(662); + setState(661); ((RerankCommandContext)_localctx).queryText = constant(); - setState(663); + setState(662); match(ON); - setState(664); + setState(663); ((RerankCommandContext)_localctx).rerankFields = fields(); - setState(665); + setState(664); commandNamedParameters(); } } @@ -5038,23 +5036,23 @@ public final CompletionCommandContext completionCommand() throws RecognitionExce try { enterOuterAlt(_localctx, 1); { - setState(667); + setState(666); match(COMPLETION); - setState(671); + setState(670); _errHandler.sync(this); switch ( getInterpreter().adaptivePredict(_input,50,_ctx) ) { case 1: { - setState(668); + setState(667); ((CompletionCommandContext)_localctx).targetField = qualifiedName(); - setState(669); + setState(668); match(ASSIGN); } break; } - setState(673); + setState(672); ((CompletionCommandContext)_localctx).prompt = primaryExpression(0); - setState(674); + setState(673); commandNamedParameters(); } } @@ -5107,26 +5105,26 @@ public final InlineStatsCommandContext inlineStatsCommand() throws RecognitionEx InlineStatsCommandContext _localctx = new InlineStatsCommandContext(_ctx, getState()); enterRule(_localctx, 134, RULE_inlineStatsCommand); try { - setState(689); + setState(688); _errHandler.sync(this); switch (_input.LA(1)) { case INLINE: enterOuterAlt(_localctx, 1); { - setState(676); + setState(675); match(INLINE); - setState(677); + setState(676); match(INLINE_STATS); - setState(678); + setState(677); ((InlineStatsCommandContext)_localctx).stats = aggFields(); - setState(681); + setState(680); _errHandler.sync(this); switch ( getInterpreter().adaptivePredict(_input,51,_ctx) ) { case 1: { - setState(679); + setState(678); match(BY); - setState(680); + setState(679); ((InlineStatsCommandContext)_localctx).grouping = fields(); } break; @@ -5136,18 +5134,18 @@ public final InlineStatsCommandContext inlineStatsCommand() throws RecognitionEx case INLINESTATS: enterOuterAlt(_localctx, 2); { - setState(683); + setState(682); match(INLINESTATS); - setState(684); + setState(683); ((InlineStatsCommandContext)_localctx).stats = aggFields(); - setState(687); + setState(686); _errHandler.sync(this); switch ( getInterpreter().adaptivePredict(_input,52,_ctx) ) { case 1: { - setState(685); + setState(684); match(BY); - setState(686); + setState(685); ((InlineStatsCommandContext)_localctx).grouping = fields(); } break; @@ -5209,31 +5207,31 @@ public final FuseCommandContext fuseCommand() throws RecognitionException { int _alt; enterOuterAlt(_localctx, 1); { - setState(691); + setState(690); match(FUSE); - setState(693); + setState(692); _errHandler.sync(this); switch ( getInterpreter().adaptivePredict(_input,54,_ctx) ) { case 1: { - setState(692); + setState(691); ((FuseCommandContext)_localctx).fuseType = identifier(); } break; } - setState(698); + setState(697); _errHandler.sync(this); _alt = getInterpreter().adaptivePredict(_input,55,_ctx); while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) { if ( _alt==1 ) { { { - setState(695); + setState(694); fuseConfiguration(); } } } - setState(700); + setState(699); _errHandler.sync(this); _alt = getInterpreter().adaptivePredict(_input,55,_ctx); } @@ -5294,48 +5292,48 @@ public final FuseConfigurationContext fuseConfiguration() throws RecognitionExce FuseConfigurationContext _localctx = new FuseConfigurationContext(_ctx, getState()); enterRule(_localctx, 138, RULE_fuseConfiguration); try { - setState(712); + setState(711); _errHandler.sync(this); switch (_input.LA(1)) { case SCORE: enterOuterAlt(_localctx, 1); { - setState(701); + setState(700); match(SCORE); - setState(702); + setState(701); match(BY); - setState(703); + setState(702); ((FuseConfigurationContext)_localctx).score = qualifiedName(); } break; case KEY: enterOuterAlt(_localctx, 2); { - setState(704); + setState(703); match(KEY); - setState(705); + setState(704); match(BY); - setState(706); + setState(705); ((FuseConfigurationContext)_localctx).key = fuseKeyByFields(); } break; case GROUP: enterOuterAlt(_localctx, 3); { - setState(707); + setState(706); match(GROUP); - setState(708); + setState(707); match(BY); - setState(709); + setState(708); ((FuseConfigurationContext)_localctx).group = qualifiedName(); } break; case WITH: enterOuterAlt(_localctx, 4); { - setState(710); + setState(709); match(WITH); - setState(711); + setState(710); ((FuseConfigurationContext)_localctx).options = mapExpression(); } break; @@ -5393,23 +5391,23 @@ public final FuseKeyByFieldsContext fuseKeyByFields() throws RecognitionExceptio int _alt; enterOuterAlt(_localctx, 1); { - setState(714); + setState(713); qualifiedName(); - setState(719); + setState(718); _errHandler.sync(this); _alt = getInterpreter().adaptivePredict(_input,57,_ctx); while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) { if ( _alt==1 ) { { { - setState(715); + setState(714); match(COMMA); - setState(716); + setState(715); qualifiedName(); } } } - setState(721); + setState(720); _errHandler.sync(this); _alt = getInterpreter().adaptivePredict(_input,57,_ctx); } @@ -5455,7 +5453,7 @@ public final MetricsInfoCommandContext metricsInfoCommand() throws RecognitionEx try { enterOuterAlt(_localctx, 1); { - setState(722); + setState(721); match(METRICS_INFO); } } @@ -5499,7 +5497,7 @@ public final TsInfoCommandContext tsInfoCommand() throws RecognitionException { try { enterOuterAlt(_localctx, 1); { - setState(724); + setState(723); match(TS_INFO); } } @@ -5552,13 +5550,13 @@ public final LookupCommandContext lookupCommand() throws RecognitionException { try { enterOuterAlt(_localctx, 1); { - setState(726); + setState(725); match(DEV_LOOKUP); - setState(727); + setState(726); ((LookupCommandContext)_localctx).tableName = indexPattern(); - setState(728); + setState(727); match(ON); - setState(729); + setState(728); ((LookupCommandContext)_localctx).matchFields = qualifiedNamePatterns(); } } @@ -5605,9 +5603,9 @@ public final InsistCommandContext insistCommand() throws RecognitionException { try { enterOuterAlt(_localctx, 1); { - setState(731); + setState(730); match(DEV_INSIST); - setState(732); + setState(731); qualifiedNamePatterns(); } } @@ -5658,13 +5656,13 @@ public final UriPartsCommandContext uriPartsCommand() throws RecognitionExceptio try { enterOuterAlt(_localctx, 1); { - setState(734); + setState(733); match(URI_PARTS); - setState(735); + setState(734); qualifiedName(); - setState(736); + setState(735); match(ASSIGN); - setState(737); + setState(736); primaryExpression(0); } } @@ -5715,13 +5713,13 @@ public final RegisteredDomainCommandContext registeredDomainCommand() throws Rec try { enterOuterAlt(_localctx, 1); { - setState(739); + setState(738); match(REGISTERED_DOMAIN); - setState(740); + setState(739); qualifiedName(); - setState(741); + setState(740); match(ASSIGN); - setState(742); + setState(741); primaryExpression(0); } } @@ -5769,11 +5767,11 @@ public final SetCommandContext setCommand() throws RecognitionException { try { enterOuterAlt(_localctx, 1); { - setState(744); + setState(743); match(SET); - setState(745); + setState(744); setField(); - setState(746); + setState(745); match(SEMICOLON); } } @@ -5826,11 +5824,11 @@ public final SetFieldContext setField() throws RecognitionException { try { enterOuterAlt(_localctx, 1); { - setState(748); + setState(747); identifier(); - setState(749); + setState(748); match(ASSIGN); - setState(752); + setState(751); _errHandler.sync(this); switch (_input.LA(1)) { case QUOTED_STRING: @@ -5845,13 +5843,13 @@ public final SetFieldContext setField() throws RecognitionException { case NAMED_OR_POSITIONAL_PARAM: case OPENING_BRACKET: { - setState(750); + setState(749); constant(); } break; case LEFT_BRACES: { - setState(751); + setState(750); mapExpression(); } break; @@ -5917,27 +5915,27 @@ public final MmrCommandContext mmrCommand() throws RecognitionException { try { enterOuterAlt(_localctx, 1); { - setState(754); + setState(753); match(MMR); - setState(756); + setState(755); _errHandler.sync(this); switch ( getInterpreter().adaptivePredict(_input,59,_ctx) ) { case 1: { - setState(755); + setState(754); ((MmrCommandContext)_localctx).queryVector = mmrQueryVectorParams(); } break; } - setState(758); + setState(757); match(ON); - setState(759); + setState(758); ((MmrCommandContext)_localctx).diversifyField = qualifiedName(); - setState(760); + setState(759); match(MMR_LIMIT); - setState(761); + setState(760); ((MmrCommandContext)_localctx).limitValue = integerValue(); - setState(762); + setState(761); commandNamedParameters(); } } @@ -6013,14 +6011,14 @@ public final MmrQueryVectorParamsContext mmrQueryVectorParams() throws Recogniti MmrQueryVectorParamsContext _localctx = new MmrQueryVectorParamsContext(_ctx, getState()); enterRule(_localctx, 160, RULE_mmrQueryVectorParams); try { - setState(766); + setState(765); _errHandler.sync(this); switch ( getInterpreter().adaptivePredict(_input,60,_ctx) ) { case 1: _localctx = new MmrQueryVectorParameterContext(_localctx); enterOuterAlt(_localctx, 1); { - setState(764); + setState(763); parameter(); } break; @@ -6028,7 +6026,7 @@ public final MmrQueryVectorParamsContext mmrQueryVectorParams() throws Recogniti _localctx = new MmrQueryVectorExpressionContext(_localctx); enterOuterAlt(_localctx, 2); { - setState(765); + setState(764); primaryExpression(0); } break; @@ -6246,7 +6244,7 @@ private BooleanExpressionContext booleanExpression(int _p) throws RecognitionExc int _alt; enterOuterAlt(_localctx, 1); { - setState(797); + setState(796); _errHandler.sync(this); switch ( getInterpreter().adaptivePredict(_input,64,_ctx) ) { case 1: @@ -6255,9 +6253,9 @@ private BooleanExpressionContext booleanExpression(int _p) throws RecognitionExc _ctx = _localctx; _prevctx = _localctx; - setState(769); + setState(768); match(NOT); - setState(770); + setState(769); booleanExpression(8); } break; @@ -6266,7 +6264,7 @@ private BooleanExpressionContext booleanExpression(int _p) throws RecognitionExc _localctx = new BooleanDefaultContext(_localctx); _ctx = _localctx; _prevctx = _localctx; - setState(771); + setState(770); valueExpression(); } break; @@ -6275,7 +6273,7 @@ private BooleanExpressionContext booleanExpression(int _p) throws RecognitionExc _localctx = new RegexExpressionContext(_localctx); _ctx = _localctx; _prevctx = _localctx; - setState(772); + setState(771); regexBooleanExpression(); } break; @@ -6284,41 +6282,41 @@ private BooleanExpressionContext booleanExpression(int _p) throws RecognitionExc _localctx = new LogicalInContext(_localctx); _ctx = _localctx; _prevctx = _localctx; - setState(773); + setState(772); valueExpression(); - setState(775); + setState(774); _errHandler.sync(this); _la = _input.LA(1); if (_la==NOT) { { - setState(774); + setState(773); match(NOT); } } - setState(777); + setState(776); match(IN); - setState(778); + setState(777); match(LP); - setState(779); + setState(778); valueExpression(); - setState(784); + setState(783); _errHandler.sync(this); _la = _input.LA(1); while (_la==COMMA) { { { - setState(780); + setState(779); match(COMMA); - setState(781); + setState(780); valueExpression(); } } - setState(786); + setState(785); _errHandler.sync(this); _la = _input.LA(1); } - setState(787); + setState(786); match(RP); } break; @@ -6327,21 +6325,21 @@ private BooleanExpressionContext booleanExpression(int _p) throws RecognitionExc _localctx = new IsNullContext(_localctx); _ctx = _localctx; _prevctx = _localctx; - setState(789); + setState(788); valueExpression(); - setState(790); + setState(789); match(IS); - setState(792); + setState(791); _errHandler.sync(this); _la = _input.LA(1); if (_la==NOT) { { - setState(791); + setState(790); match(NOT); } } - setState(794); + setState(793); match(NULL); } break; @@ -6350,13 +6348,13 @@ private BooleanExpressionContext booleanExpression(int _p) throws RecognitionExc _localctx = new MatchExpressionContext(_localctx); _ctx = _localctx; _prevctx = _localctx; - setState(796); + setState(795); matchBooleanExpression(); } break; } _ctx.stop = _input.LT(-1); - setState(807); + setState(806); _errHandler.sync(this); _alt = getInterpreter().adaptivePredict(_input,66,_ctx); while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) { @@ -6364,7 +6362,7 @@ private BooleanExpressionContext booleanExpression(int _p) throws RecognitionExc if ( _parseListeners!=null ) triggerExitRuleEvent(); _prevctx = _localctx; { - setState(805); + setState(804); _errHandler.sync(this); switch ( getInterpreter().adaptivePredict(_input,65,_ctx) ) { case 1: @@ -6372,11 +6370,11 @@ private BooleanExpressionContext booleanExpression(int _p) throws RecognitionExc _localctx = new LogicalBinaryContext(new BooleanExpressionContext(_parentctx, _parentState)); ((LogicalBinaryContext)_localctx).left = _prevctx; pushNewRecursionContext(_localctx, _startState, RULE_booleanExpression); - setState(799); + setState(798); if (!(precpred(_ctx, 5))) throw new FailedPredicateException(this, "precpred(_ctx, 5)"); - setState(800); + setState(799); ((LogicalBinaryContext)_localctx).operator = match(AND); - setState(801); + setState(800); ((LogicalBinaryContext)_localctx).right = booleanExpression(6); } break; @@ -6385,18 +6383,18 @@ private BooleanExpressionContext booleanExpression(int _p) throws RecognitionExc _localctx = new LogicalBinaryContext(new BooleanExpressionContext(_parentctx, _parentState)); ((LogicalBinaryContext)_localctx).left = _prevctx; pushNewRecursionContext(_localctx, _startState, RULE_booleanExpression); - setState(802); + setState(801); if (!(precpred(_ctx, 4))) throw new FailedPredicateException(this, "precpred(_ctx, 4)"); - setState(803); + setState(802); ((LogicalBinaryContext)_localctx).operator = match(OR); - setState(804); + setState(803); ((LogicalBinaryContext)_localctx).right = booleanExpression(5); } break; } } } - setState(809); + setState(808); _errHandler.sync(this); _alt = getInterpreter().adaptivePredict(_input,66,_ctx); } @@ -6555,28 +6553,28 @@ public final RegexBooleanExpressionContext regexBooleanExpression() throws Recog enterRule(_localctx, 164, RULE_regexBooleanExpression); int _la; try { - setState(856); + setState(855); _errHandler.sync(this); switch ( getInterpreter().adaptivePredict(_input,73,_ctx) ) { case 1: _localctx = new LikeExpressionContext(_localctx); enterOuterAlt(_localctx, 1); { - setState(810); + setState(809); valueExpression(); - setState(812); + setState(811); _errHandler.sync(this); _la = _input.LA(1); if (_la==NOT) { { - setState(811); + setState(810); match(NOT); } } - setState(814); + setState(813); match(LIKE); - setState(815); + setState(814); stringOrParameter(); } break; @@ -6584,21 +6582,21 @@ public final RegexBooleanExpressionContext regexBooleanExpression() throws Recog _localctx = new RlikeExpressionContext(_localctx); enterOuterAlt(_localctx, 2); { - setState(817); + setState(816); valueExpression(); - setState(819); + setState(818); _errHandler.sync(this); _la = _input.LA(1); if (_la==NOT) { { - setState(818); + setState(817); match(NOT); } } - setState(821); + setState(820); match(RLIKE); - setState(822); + setState(821); stringOrParameter(); } break; @@ -6606,41 +6604,41 @@ public final RegexBooleanExpressionContext regexBooleanExpression() throws Recog _localctx = new LikeListExpressionContext(_localctx); enterOuterAlt(_localctx, 3); { - setState(824); + setState(823); valueExpression(); - setState(826); + setState(825); _errHandler.sync(this); _la = _input.LA(1); if (_la==NOT) { { - setState(825); + setState(824); match(NOT); } } - setState(828); + setState(827); match(LIKE); - setState(829); + setState(828); match(LP); - setState(830); + setState(829); stringOrParameter(); - setState(835); + setState(834); _errHandler.sync(this); _la = _input.LA(1); while (_la==COMMA) { { { - setState(831); + setState(830); match(COMMA); - setState(832); + setState(831); stringOrParameter(); } } - setState(837); + setState(836); _errHandler.sync(this); _la = _input.LA(1); } - setState(838); + setState(837); match(RP); } break; @@ -6648,41 +6646,41 @@ public final RegexBooleanExpressionContext regexBooleanExpression() throws Recog _localctx = new RlikeListExpressionContext(_localctx); enterOuterAlt(_localctx, 4); { - setState(840); + setState(839); valueExpression(); - setState(842); + setState(841); _errHandler.sync(this); _la = _input.LA(1); if (_la==NOT) { { - setState(841); + setState(840); match(NOT); } } - setState(844); + setState(843); match(RLIKE); - setState(845); + setState(844); match(LP); - setState(846); + setState(845); stringOrParameter(); - setState(851); + setState(850); _errHandler.sync(this); _la = _input.LA(1); while (_la==COMMA) { { { - setState(847); + setState(846); match(COMMA); - setState(848); + setState(847); stringOrParameter(); } } - setState(853); + setState(852); _errHandler.sync(this); _la = _input.LA(1); } - setState(854); + setState(853); match(RP); } break; @@ -6742,23 +6740,23 @@ public final MatchBooleanExpressionContext matchBooleanExpression() throws Recog try { enterOuterAlt(_localctx, 1); { - setState(858); + setState(857); ((MatchBooleanExpressionContext)_localctx).fieldExp = qualifiedName(); - setState(861); + setState(860); _errHandler.sync(this); _la = _input.LA(1); if (_la==CAST_OP) { { - setState(859); + setState(858); match(CAST_OP); - setState(860); + setState(859); ((MatchBooleanExpressionContext)_localctx).fieldType = dataType(); } } - setState(863); + setState(862); match(COLON); - setState(864); + setState(863); ((MatchBooleanExpressionContext)_localctx).matchQuery = constant(); } } @@ -6842,14 +6840,14 @@ public final ValueExpressionContext valueExpression() throws RecognitionExceptio ValueExpressionContext _localctx = new ValueExpressionContext(_ctx, getState()); enterRule(_localctx, 168, RULE_valueExpression); try { - setState(871); + setState(870); _errHandler.sync(this); switch ( getInterpreter().adaptivePredict(_input,75,_ctx) ) { case 1: _localctx = new ValueExpressionDefaultContext(_localctx); enterOuterAlt(_localctx, 1); { - setState(866); + setState(865); operatorExpression(0); } break; @@ -6857,11 +6855,11 @@ public final ValueExpressionContext valueExpression() throws RecognitionExceptio _localctx = new ComparisonContext(_localctx); enterOuterAlt(_localctx, 2); { - setState(867); + setState(866); ((ComparisonContext)_localctx).left = operatorExpression(0); - setState(868); + setState(867); comparisonOperator(); - setState(869); + setState(868); ((ComparisonContext)_localctx).right = operatorExpression(0); } break; @@ -6986,7 +6984,7 @@ private OperatorExpressionContext operatorExpression(int _p) throws RecognitionE int _alt; enterOuterAlt(_localctx, 1); { - setState(877); + setState(876); _errHandler.sync(this); switch ( getInterpreter().adaptivePredict(_input,76,_ctx) ) { case 1: @@ -6995,7 +6993,7 @@ private OperatorExpressionContext operatorExpression(int _p) throws RecognitionE _ctx = _localctx; _prevctx = _localctx; - setState(874); + setState(873); primaryExpression(0); } break; @@ -7004,7 +7002,7 @@ private OperatorExpressionContext operatorExpression(int _p) throws RecognitionE _localctx = new ArithmeticUnaryContext(_localctx); _ctx = _localctx; _prevctx = _localctx; - setState(875); + setState(874); ((ArithmeticUnaryContext)_localctx).operator = _input.LT(1); _la = _input.LA(1); if ( !(_la==PLUS || _la==MINUS) ) { @@ -7015,13 +7013,13 @@ private OperatorExpressionContext operatorExpression(int _p) throws RecognitionE _errHandler.reportMatch(this); consume(); } - setState(876); + setState(875); operatorExpression(3); } break; } _ctx.stop = _input.LT(-1); - setState(887); + setState(886); _errHandler.sync(this); _alt = getInterpreter().adaptivePredict(_input,78,_ctx); while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) { @@ -7029,7 +7027,7 @@ private OperatorExpressionContext operatorExpression(int _p) throws RecognitionE if ( _parseListeners!=null ) triggerExitRuleEvent(); _prevctx = _localctx; { - setState(885); + setState(884); _errHandler.sync(this); switch ( getInterpreter().adaptivePredict(_input,77,_ctx) ) { case 1: @@ -7037,9 +7035,9 @@ private OperatorExpressionContext operatorExpression(int _p) throws RecognitionE _localctx = new ArithmeticBinaryContext(new OperatorExpressionContext(_parentctx, _parentState)); ((ArithmeticBinaryContext)_localctx).left = _prevctx; pushNewRecursionContext(_localctx, _startState, RULE_operatorExpression); - setState(879); + setState(878); if (!(precpred(_ctx, 2))) throw new FailedPredicateException(this, "precpred(_ctx, 2)"); - setState(880); + setState(879); ((ArithmeticBinaryContext)_localctx).operator = _input.LT(1); _la = _input.LA(1); if ( !(((((_la - 95)) & ~0x3f) == 0 && ((1L << (_la - 95)) & 7L) != 0)) ) { @@ -7050,7 +7048,7 @@ private OperatorExpressionContext operatorExpression(int _p) throws RecognitionE _errHandler.reportMatch(this); consume(); } - setState(881); + setState(880); ((ArithmeticBinaryContext)_localctx).right = operatorExpression(3); } break; @@ -7059,9 +7057,9 @@ private OperatorExpressionContext operatorExpression(int _p) throws RecognitionE _localctx = new ArithmeticBinaryContext(new OperatorExpressionContext(_parentctx, _parentState)); ((ArithmeticBinaryContext)_localctx).left = _prevctx; pushNewRecursionContext(_localctx, _startState, RULE_operatorExpression); - setState(882); + setState(881); if (!(precpred(_ctx, 1))) throw new FailedPredicateException(this, "precpred(_ctx, 1)"); - setState(883); + setState(882); ((ArithmeticBinaryContext)_localctx).operator = _input.LT(1); _la = _input.LA(1); if ( !(_la==PLUS || _la==MINUS) ) { @@ -7072,14 +7070,14 @@ private OperatorExpressionContext operatorExpression(int _p) throws RecognitionE _errHandler.reportMatch(this); consume(); } - setState(884); + setState(883); ((ArithmeticBinaryContext)_localctx).right = operatorExpression(2); } break; } } } - setState(889); + setState(888); _errHandler.sync(this); _alt = getInterpreter().adaptivePredict(_input,78,_ctx); } @@ -7237,7 +7235,7 @@ private PrimaryExpressionContext primaryExpression(int _p) throws RecognitionExc int _alt; enterOuterAlt(_localctx, 1); { - setState(898); + setState(897); _errHandler.sync(this); switch ( getInterpreter().adaptivePredict(_input,79,_ctx) ) { case 1: @@ -7246,7 +7244,7 @@ private PrimaryExpressionContext primaryExpression(int _p) throws RecognitionExc _ctx = _localctx; _prevctx = _localctx; - setState(891); + setState(890); constant(); } break; @@ -7255,7 +7253,7 @@ private PrimaryExpressionContext primaryExpression(int _p) throws RecognitionExc _localctx = new DereferenceContext(_localctx); _ctx = _localctx; _prevctx = _localctx; - setState(892); + setState(891); qualifiedName(); } break; @@ -7264,7 +7262,7 @@ private PrimaryExpressionContext primaryExpression(int _p) throws RecognitionExc _localctx = new FunctionContext(_localctx); _ctx = _localctx; _prevctx = _localctx; - setState(893); + setState(892); functionExpression(); } break; @@ -7273,17 +7271,17 @@ private PrimaryExpressionContext primaryExpression(int _p) throws RecognitionExc _localctx = new ParenthesizedExpressionContext(_localctx); _ctx = _localctx; _prevctx = _localctx; - setState(894); + setState(893); match(LP); - setState(895); + setState(894); booleanExpression(0); - setState(896); + setState(895); match(RP); } break; } _ctx.stop = _input.LT(-1); - setState(905); + setState(904); _errHandler.sync(this); _alt = getInterpreter().adaptivePredict(_input,80,_ctx); while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) { @@ -7294,16 +7292,16 @@ private PrimaryExpressionContext primaryExpression(int _p) throws RecognitionExc { _localctx = new InlineCastContext(new PrimaryExpressionContext(_parentctx, _parentState)); pushNewRecursionContext(_localctx, _startState, RULE_primaryExpression); - setState(900); + setState(899); if (!(precpred(_ctx, 1))) throw new FailedPredicateException(this, "precpred(_ctx, 1)"); - setState(901); + setState(900); match(CAST_OP); - setState(902); + setState(901); dataType(); } } } - setState(907); + setState(906); _errHandler.sync(this); _alt = getInterpreter().adaptivePredict(_input,80,_ctx); } @@ -7369,50 +7367,50 @@ public final FunctionExpressionContext functionExpression() throws RecognitionEx int _alt; enterOuterAlt(_localctx, 1); { - setState(908); + setState(907); functionName(); - setState(909); + setState(908); match(LP); - setState(923); + setState(922); _errHandler.sync(this); switch ( getInterpreter().adaptivePredict(_input,83,_ctx) ) { case 1: { - setState(910); + setState(909); match(ASTERISK); } break; case 2: { { - setState(911); + setState(910); booleanExpression(0); - setState(916); + setState(915); _errHandler.sync(this); _alt = getInterpreter().adaptivePredict(_input,81,_ctx); while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) { if ( _alt==1 ) { { { - setState(912); + setState(911); match(COMMA); - setState(913); + setState(912); booleanExpression(0); } } } - setState(918); + setState(917); _errHandler.sync(this); _alt = getInterpreter().adaptivePredict(_input,81,_ctx); } - setState(921); + setState(920); _errHandler.sync(this); _la = _input.LA(1); if (_la==COMMA) { { - setState(919); + setState(918); match(COMMA); - setState(920); + setState(919); mapExpression(); } } @@ -7421,7 +7419,7 @@ public final FunctionExpressionContext functionExpression() throws RecognitionEx } break; } - setState(925); + setState(924); match(RP); } } @@ -7467,7 +7465,7 @@ public final FunctionNameContext functionName() throws RecognitionException { FunctionNameContext _localctx = new FunctionNameContext(_ctx, getState()); enterRule(_localctx, 176, RULE_functionName); try { - setState(930); + setState(929); _errHandler.sync(this); switch (_input.LA(1)) { case PARAM: @@ -7478,21 +7476,21 @@ public final FunctionNameContext functionName() throws RecognitionException { case QUOTED_IDENTIFIER: enterOuterAlt(_localctx, 1); { - setState(927); + setState(926); identifierOrParameter(); } break; case FIRST: enterOuterAlt(_localctx, 2); { - setState(928); + setState(927); match(FIRST); } break; case LAST: enterOuterAlt(_localctx, 3); { - setState(929); + setState(928); match(LAST); } break; @@ -7552,35 +7550,35 @@ public final MapExpressionContext mapExpression() throws RecognitionException { try { enterOuterAlt(_localctx, 1); { - setState(932); + setState(931); match(LEFT_BRACES); - setState(941); + setState(940); _errHandler.sync(this); _la = _input.LA(1); if (_la==QUOTED_STRING) { { - setState(933); + setState(932); entryExpression(); - setState(938); + setState(937); _errHandler.sync(this); _la = _input.LA(1); while (_la==COMMA) { { { - setState(934); + setState(933); match(COMMA); - setState(935); + setState(934); entryExpression(); } } - setState(940); + setState(939); _errHandler.sync(this); _la = _input.LA(1); } } } - setState(943); + setState(942); match(RIGHT_BRACES); } } @@ -7632,11 +7630,11 @@ public final EntryExpressionContext entryExpression() throws RecognitionExceptio try { enterOuterAlt(_localctx, 1); { - setState(945); + setState(944); ((EntryExpressionContext)_localctx).key = string(); - setState(946); + setState(945); match(COLON); - setState(947); + setState(946); ((EntryExpressionContext)_localctx).value = mapValue(); } } @@ -7683,7 +7681,7 @@ public final MapValueContext mapValue() throws RecognitionException { MapValueContext _localctx = new MapValueContext(_ctx, getState()); enterRule(_localctx, 182, RULE_mapValue); try { - setState(951); + setState(950); _errHandler.sync(this); switch (_input.LA(1)) { case QUOTED_STRING: @@ -7699,14 +7697,14 @@ public final MapValueContext mapValue() throws RecognitionException { case OPENING_BRACKET: enterOuterAlt(_localctx, 1); { - setState(949); + setState(948); constant(); } break; case LEFT_BRACES: enterOuterAlt(_localctx, 2); { - setState(950); + setState(949); mapExpression(); } break; @@ -7981,14 +7979,14 @@ public final ConstantContext constant() throws RecognitionException { enterRule(_localctx, 184, RULE_constant); int _la; try { - setState(995); + setState(994); _errHandler.sync(this); switch ( getInterpreter().adaptivePredict(_input,91,_ctx) ) { case 1: _localctx = new NullLiteralContext(_localctx); enterOuterAlt(_localctx, 1); { - setState(953); + setState(952); match(NULL); } break; @@ -7996,9 +7994,9 @@ public final ConstantContext constant() throws RecognitionException { _localctx = new QualifiedIntegerLiteralContext(_localctx); enterOuterAlt(_localctx, 2); { - setState(954); + setState(953); integerValue(); - setState(955); + setState(954); match(UNQUOTED_IDENTIFIER); } break; @@ -8006,7 +8004,7 @@ public final ConstantContext constant() throws RecognitionException { _localctx = new DecimalLiteralContext(_localctx); enterOuterAlt(_localctx, 3); { - setState(957); + setState(956); decimalValue(); } break; @@ -8014,7 +8012,7 @@ public final ConstantContext constant() throws RecognitionException { _localctx = new IntegerLiteralContext(_localctx); enterOuterAlt(_localctx, 4); { - setState(958); + setState(957); integerValue(); } break; @@ -8022,7 +8020,7 @@ public final ConstantContext constant() throws RecognitionException { _localctx = new BooleanLiteralContext(_localctx); enterOuterAlt(_localctx, 5); { - setState(959); + setState(958); booleanValue(); } break; @@ -8030,7 +8028,7 @@ public final ConstantContext constant() throws RecognitionException { _localctx = new InputParameterContext(_localctx); enterOuterAlt(_localctx, 6); { - setState(960); + setState(959); parameter(); } break; @@ -8038,7 +8036,7 @@ public final ConstantContext constant() throws RecognitionException { _localctx = new StringLiteralContext(_localctx); enterOuterAlt(_localctx, 7); { - setState(961); + setState(960); string(); } break; @@ -8046,27 +8044,27 @@ public final ConstantContext constant() throws RecognitionException { _localctx = new NumericArrayLiteralContext(_localctx); enterOuterAlt(_localctx, 8); { - setState(962); + setState(961); match(OPENING_BRACKET); - setState(963); + setState(962); numericValue(); - setState(968); + setState(967); _errHandler.sync(this); _la = _input.LA(1); while (_la==COMMA) { { { - setState(964); + setState(963); match(COMMA); - setState(965); + setState(964); numericValue(); } } - setState(970); + setState(969); _errHandler.sync(this); _la = _input.LA(1); } - setState(971); + setState(970); match(CLOSING_BRACKET); } break; @@ -8074,27 +8072,27 @@ public final ConstantContext constant() throws RecognitionException { _localctx = new BooleanArrayLiteralContext(_localctx); enterOuterAlt(_localctx, 9); { - setState(973); + setState(972); match(OPENING_BRACKET); - setState(974); + setState(973); booleanValue(); - setState(979); + setState(978); _errHandler.sync(this); _la = _input.LA(1); while (_la==COMMA) { { { - setState(975); + setState(974); match(COMMA); - setState(976); + setState(975); booleanValue(); } } - setState(981); + setState(980); _errHandler.sync(this); _la = _input.LA(1); } - setState(982); + setState(981); match(CLOSING_BRACKET); } break; @@ -8102,27 +8100,27 @@ public final ConstantContext constant() throws RecognitionException { _localctx = new StringArrayLiteralContext(_localctx); enterOuterAlt(_localctx, 10); { - setState(984); + setState(983); match(OPENING_BRACKET); - setState(985); + setState(984); string(); - setState(990); + setState(989); _errHandler.sync(this); _la = _input.LA(1); while (_la==COMMA) { { { - setState(986); + setState(985); match(COMMA); - setState(987); + setState(986); string(); } } - setState(992); + setState(991); _errHandler.sync(this); _la = _input.LA(1); } - setState(993); + setState(992); match(CLOSING_BRACKET); } break; @@ -8170,7 +8168,7 @@ public final BooleanValueContext booleanValue() throws RecognitionException { try { enterOuterAlt(_localctx, 1); { - setState(997); + setState(996); _la = _input.LA(1); if ( !(_la==FALSE || _la==TRUE) ) { _errHandler.recoverInline(this); @@ -8225,20 +8223,20 @@ public final NumericValueContext numericValue() throws RecognitionException { NumericValueContext _localctx = new NumericValueContext(_ctx, getState()); enterRule(_localctx, 188, RULE_numericValue); try { - setState(1001); + setState(1000); _errHandler.sync(this); switch ( getInterpreter().adaptivePredict(_input,92,_ctx) ) { case 1: enterOuterAlt(_localctx, 1); { - setState(999); + setState(998); decimalValue(); } break; case 2: enterOuterAlt(_localctx, 2); { - setState(1000); + setState(999); integerValue(); } break; @@ -8287,12 +8285,12 @@ public final DecimalValueContext decimalValue() throws RecognitionException { try { enterOuterAlt(_localctx, 1); { - setState(1004); + setState(1003); _errHandler.sync(this); _la = _input.LA(1); if (_la==PLUS || _la==MINUS) { { - setState(1003); + setState(1002); _la = _input.LA(1); if ( !(_la==PLUS || _la==MINUS) ) { _errHandler.recoverInline(this); @@ -8305,7 +8303,7 @@ public final DecimalValueContext decimalValue() throws RecognitionException { } } - setState(1006); + setState(1005); match(DECIMAL_LITERAL); } } @@ -8352,12 +8350,12 @@ public final IntegerValueContext integerValue() throws RecognitionException { try { enterOuterAlt(_localctx, 1); { - setState(1009); + setState(1008); _errHandler.sync(this); _la = _input.LA(1); if (_la==PLUS || _la==MINUS) { { - setState(1008); + setState(1007); _la = _input.LA(1); if ( !(_la==PLUS || _la==MINUS) ) { _errHandler.recoverInline(this); @@ -8370,7 +8368,7 @@ public final IntegerValueContext integerValue() throws RecognitionException { } } - setState(1011); + setState(1010); match(INTEGER_LITERAL); } } @@ -8414,7 +8412,7 @@ public final StringContext string() throws RecognitionException { try { enterOuterAlt(_localctx, 1); { - setState(1013); + setState(1012); match(QUOTED_STRING); } } @@ -8464,7 +8462,7 @@ public final ComparisonOperatorContext comparisonOperator() throws RecognitionEx try { enterOuterAlt(_localctx, 1); { - setState(1015); + setState(1014); _la = _input.LA(1); if ( !(((((_la - 86)) & ~0x3f) == 0 && ((1L << (_la - 86)) & 125L) != 0)) ) { _errHandler.recoverInline(this); @@ -8527,7 +8525,7 @@ public final JoinCommandContext joinCommand() throws RecognitionException { try { enterOuterAlt(_localctx, 1); { - setState(1017); + setState(1016); ((JoinCommandContext)_localctx).type = _input.LT(1); _la = _input.LA(1); if ( !((((_la) & ~0x3f) == 0 && ((1L << _la) & 6979321856L) != 0)) ) { @@ -8538,11 +8536,11 @@ public final JoinCommandContext joinCommand() throws RecognitionException { _errHandler.reportMatch(this); consume(); } - setState(1018); + setState(1017); match(JOIN); - setState(1019); + setState(1018); joinTarget(); - setState(1020); + setState(1019); joinCondition(); } } @@ -8591,34 +8589,34 @@ public final JoinTargetContext joinTarget() throws RecognitionException { enterRule(_localctx, 200, RULE_joinTarget); int _la; try { - setState(1030); + setState(1029); _errHandler.sync(this); switch ( getInterpreter().adaptivePredict(_input,96,_ctx) ) { case 1: enterOuterAlt(_localctx, 1); { - setState(1022); + setState(1021); if (!(this.isDevVersion())) throw new FailedPredicateException(this, "this.isDevVersion()"); - setState(1023); + setState(1022); ((JoinTargetContext)_localctx).index = indexPattern(); - setState(1025); + setState(1024); _errHandler.sync(this); _la = _input.LA(1); if (_la==AS) { { - setState(1024); + setState(1023); match(AS); } } - setState(1027); + setState(1026); ((JoinTargetContext)_localctx).qualifier = match(UNQUOTED_SOURCE); } break; case 2: enterOuterAlt(_localctx, 2); { - setState(1029); + setState(1028); ((JoinTargetContext)_localctx).index = indexPattern(); } break; @@ -8675,25 +8673,25 @@ public final JoinConditionContext joinCondition() throws RecognitionException { int _alt; enterOuterAlt(_localctx, 1); { - setState(1032); + setState(1031); match(ON); - setState(1033); + setState(1032); booleanExpression(0); - setState(1038); + setState(1037); _errHandler.sync(this); _alt = getInterpreter().adaptivePredict(_input,97,_ctx); while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) { if ( _alt==1 ) { { { - setState(1034); + setState(1033); match(COMMA); - setState(1035); + setState(1034); booleanExpression(0); } } } - setState(1040); + setState(1039); _errHandler.sync(this); _alt = getInterpreter().adaptivePredict(_input,97,_ctx); } @@ -8758,162 +8756,162 @@ public final PromqlCommandContext promqlCommand() throws RecognitionException { int _la; try { int _alt; - setState(1101); + setState(1100); _errHandler.sync(this); switch ( getInterpreter().adaptivePredict(_input,107,_ctx) ) { case 1: enterOuterAlt(_localctx, 1); { - setState(1041); + setState(1040); match(PROMQL); - setState(1045); + setState(1044); _errHandler.sync(this); _alt = getInterpreter().adaptivePredict(_input,98,_ctx); while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) { if ( _alt==1 ) { { { - setState(1042); + setState(1041); promqlParam(); } } } - setState(1047); + setState(1046); _errHandler.sync(this); _alt = getInterpreter().adaptivePredict(_input,98,_ctx); } - setState(1051); + setState(1050); _errHandler.sync(this); _la = _input.LA(1); if (_la==UNQUOTED_IDENTIFIER || _la==QUOTED_IDENTIFIER) { { - setState(1048); + setState(1047); valueName(); - setState(1049); + setState(1048); match(ASSIGN); } } - setState(1053); + setState(1052); match(LP); - setState(1054); + setState(1053); match(NAMED_OR_POSITIONAL_PARAM); - setState(1055); + setState(1054); match(RP); } break; case 2: enterOuterAlt(_localctx, 2); { - setState(1056); + setState(1055); match(PROMQL); - setState(1060); + setState(1059); _errHandler.sync(this); _alt = getInterpreter().adaptivePredict(_input,100,_ctx); while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) { if ( _alt==1 ) { { { - setState(1057); + setState(1056); promqlParam(); } } } - setState(1062); + setState(1061); _errHandler.sync(this); _alt = getInterpreter().adaptivePredict(_input,100,_ctx); } - setState(1066); + setState(1065); _errHandler.sync(this); _la = _input.LA(1); if (_la==UNQUOTED_IDENTIFIER || _la==QUOTED_IDENTIFIER) { { - setState(1063); + setState(1062); valueName(); - setState(1064); + setState(1063); match(ASSIGN); } } - setState(1068); + setState(1067); match(NAMED_OR_POSITIONAL_PARAM); } break; case 3: enterOuterAlt(_localctx, 3); { - setState(1069); + setState(1068); match(PROMQL); - setState(1073); + setState(1072); _errHandler.sync(this); _alt = getInterpreter().adaptivePredict(_input,102,_ctx); while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) { if ( _alt==1 ) { { { - setState(1070); + setState(1069); promqlParam(); } } } - setState(1075); + setState(1074); _errHandler.sync(this); _alt = getInterpreter().adaptivePredict(_input,102,_ctx); } - setState(1079); + setState(1078); _errHandler.sync(this); _la = _input.LA(1); if (_la==UNQUOTED_IDENTIFIER || _la==QUOTED_IDENTIFIER) { { - setState(1076); + setState(1075); valueName(); - setState(1077); + setState(1076); match(ASSIGN); } } - setState(1081); + setState(1080); match(LP); - setState(1083); + setState(1082); _errHandler.sync(this); _la = _input.LA(1); do { { { - setState(1082); + setState(1081); promqlQueryPart(); } } - setState(1085); + setState(1084); _errHandler.sync(this); _la = _input.LA(1); } while ( ((((_la - 58)) & ~0x3f) == 0 && ((1L << (_la - 58)) & 37867180460606881L) != 0) || ((((_la - 155)) & ~0x3f) == 0 && ((1L << (_la - 155)) & 7L) != 0) ); - setState(1087); + setState(1086); match(RP); } break; case 4: enterOuterAlt(_localctx, 4); { - setState(1089); + setState(1088); match(PROMQL); - setState(1093); + setState(1092); _errHandler.sync(this); _alt = getInterpreter().adaptivePredict(_input,105,_ctx); while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) { if ( _alt==1 ) { { { - setState(1090); + setState(1089); promqlParam(); } } } - setState(1095); + setState(1094); _errHandler.sync(this); _alt = getInterpreter().adaptivePredict(_input,105,_ctx); } - setState(1097); + setState(1096); _errHandler.sync(this); _alt = 1; do { @@ -8921,7 +8919,7 @@ public final PromqlCommandContext promqlCommand() throws RecognitionException { case 1: { { - setState(1096); + setState(1095); promqlQueryPart(); } } @@ -8929,7 +8927,7 @@ public final PromqlCommandContext promqlCommand() throws RecognitionException { default: throw new NoViableAltException(this); } - setState(1099); + setState(1098); _errHandler.sync(this); _alt = getInterpreter().adaptivePredict(_input,106,_ctx); } while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ); @@ -8979,7 +8977,7 @@ public final ValueNameContext valueName() throws RecognitionException { try { enterOuterAlt(_localctx, 1); { - setState(1103); + setState(1102); _la = _input.LA(1); if ( !(_la==UNQUOTED_IDENTIFIER || _la==QUOTED_IDENTIFIER) ) { _errHandler.recoverInline(this); @@ -9039,11 +9037,11 @@ public final PromqlParamContext promqlParam() throws RecognitionException { try { enterOuterAlt(_localctx, 1); { - setState(1105); + setState(1104); ((PromqlParamContext)_localctx).name = promqlParamName(); - setState(1106); + setState(1105); match(ASSIGN); - setState(1107); + setState(1106); ((PromqlParamContext)_localctx).value = promqlParamValue(); } } @@ -9091,7 +9089,7 @@ public final PromqlParamNameContext promqlParamName() throws RecognitionExceptio try { enterOuterAlt(_localctx, 1); { - setState(1109); + setState(1108); _la = _input.LA(1); if ( !(((((_la - 58)) & ~0x3f) == 0 && ((1L << (_la - 58)) & 1697645953286145L) != 0)) ) { _errHandler.recoverInline(this); @@ -9153,7 +9151,7 @@ public final PromqlParamValueContext promqlParamValue() throws RecognitionExcept enterRule(_localctx, 212, RULE_promqlParamValue); try { int _alt; - setState(1121); + setState(1120); _errHandler.sync(this); switch (_input.LA(1)) { case QUOTED_STRING: @@ -9161,23 +9159,23 @@ public final PromqlParamValueContext promqlParamValue() throws RecognitionExcept case UNQUOTED_SOURCE: enterOuterAlt(_localctx, 1); { - setState(1111); + setState(1110); promqlIndexPattern(); - setState(1116); + setState(1115); _errHandler.sync(this); _alt = getInterpreter().adaptivePredict(_input,108,_ctx); while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) { if ( _alt==1 ) { { { - setState(1112); + setState(1111); match(COMMA); - setState(1113); + setState(1112); promqlIndexPattern(); } } } - setState(1118); + setState(1117); _errHandler.sync(this); _alt = getInterpreter().adaptivePredict(_input,108,_ctx); } @@ -9186,14 +9184,14 @@ public final PromqlParamValueContext promqlParamValue() throws RecognitionExcept case QUOTED_IDENTIFIER: enterOuterAlt(_localctx, 2); { - setState(1119); + setState(1118); match(QUOTED_IDENTIFIER); } break; case NAMED_OR_POSITIONAL_PARAM: enterOuterAlt(_localctx, 3); { - setState(1120); + setState(1119); match(NAMED_OR_POSITIONAL_PARAM); } break; @@ -9253,7 +9251,7 @@ public final PromqlQueryContentContext promqlQueryContent() throws RecognitionEx try { enterOuterAlt(_localctx, 1); { - setState(1123); + setState(1122); _la = _input.LA(1); if ( !(((((_la - 58)) & ~0x3f) == 0 && ((1L << (_la - 58)) & 37726442972251553L) != 0) || ((((_la - 155)) & ~0x3f) == 0 && ((1L << (_la - 155)) & 7L) != 0)) ) { _errHandler.recoverInline(this); @@ -9318,7 +9316,7 @@ public final PromqlQueryPartContext promqlQueryPart() throws RecognitionExceptio int _la; try { int _alt; - setState(1138); + setState(1137); _errHandler.sync(this); switch (_input.LA(1)) { case QUOTED_STRING: @@ -9335,7 +9333,7 @@ public final PromqlQueryPartContext promqlQueryPart() throws RecognitionExceptio case PROMQL_OTHER_QUERY_CONTENT: enterOuterAlt(_localctx, 1); { - setState(1126); + setState(1125); _errHandler.sync(this); _alt = 1; do { @@ -9343,7 +9341,7 @@ public final PromqlQueryPartContext promqlQueryPart() throws RecognitionExceptio case 1: { { - setState(1125); + setState(1124); promqlQueryContent(); } } @@ -9351,7 +9349,7 @@ public final PromqlQueryPartContext promqlQueryPart() throws RecognitionExceptio default: throw new NoViableAltException(this); } - setState(1128); + setState(1127); _errHandler.sync(this); _alt = getInterpreter().adaptivePredict(_input,110,_ctx); } while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ); @@ -9360,23 +9358,23 @@ public final PromqlQueryPartContext promqlQueryPart() throws RecognitionExceptio case LP: enterOuterAlt(_localctx, 2); { - setState(1130); + setState(1129); match(LP); - setState(1134); + setState(1133); _errHandler.sync(this); _la = _input.LA(1); while (((((_la - 58)) & ~0x3f) == 0 && ((1L << (_la - 58)) & 37867180460606881L) != 0) || ((((_la - 155)) & ~0x3f) == 0 && ((1L << (_la - 155)) & 7L) != 0)) { { { - setState(1131); + setState(1130); promqlQueryPart(); } } - setState(1136); + setState(1135); _errHandler.sync(this); _la = _input.LA(1); } - setState(1137); + setState(1136); match(RP); } break; @@ -9435,35 +9433,35 @@ public final PromqlIndexPatternContext promqlIndexPattern() throws RecognitionEx PromqlIndexPatternContext _localctx = new PromqlIndexPatternContext(_ctx, getState()); enterRule(_localctx, 218, RULE_promqlIndexPattern); try { - setState(1149); + setState(1148); _errHandler.sync(this); switch ( getInterpreter().adaptivePredict(_input,113,_ctx) ) { case 1: enterOuterAlt(_localctx, 1); { - setState(1140); + setState(1139); promqlClusterString(); - setState(1141); + setState(1140); match(COLON); - setState(1142); + setState(1141); promqlUnquotedIndexString(); } break; case 2: enterOuterAlt(_localctx, 2); { - setState(1144); + setState(1143); promqlUnquotedIndexString(); - setState(1145); + setState(1144); match(CAST_OP); - setState(1146); + setState(1145); promqlSelectorString(); } break; case 3: enterOuterAlt(_localctx, 3); { - setState(1148); + setState(1147); promqlIndexString(); } break; @@ -9511,7 +9509,7 @@ public final PromqlClusterStringContext promqlClusterString() throws Recognition try { enterOuterAlt(_localctx, 1); { - setState(1151); + setState(1150); _la = _input.LA(1); if ( !(_la==UNQUOTED_IDENTIFIER || _la==UNQUOTED_SOURCE) ) { _errHandler.recoverInline(this); @@ -9565,7 +9563,7 @@ public final PromqlSelectorStringContext promqlSelectorString() throws Recogniti try { enterOuterAlt(_localctx, 1); { - setState(1153); + setState(1152); _la = _input.LA(1); if ( !(_la==UNQUOTED_IDENTIFIER || _la==UNQUOTED_SOURCE) ) { _errHandler.recoverInline(this); @@ -9619,7 +9617,7 @@ public final PromqlUnquotedIndexStringContext promqlUnquotedIndexString() throws try { enterOuterAlt(_localctx, 1); { - setState(1155); + setState(1154); _la = _input.LA(1); if ( !(_la==UNQUOTED_IDENTIFIER || _la==UNQUOTED_SOURCE) ) { _errHandler.recoverInline(this); @@ -9674,7 +9672,7 @@ public final PromqlIndexStringContext promqlIndexString() throws RecognitionExce try { enterOuterAlt(_localctx, 1); { - setState(1157); + setState(1156); _la = _input.LA(1); if ( !(((((_la - 58)) & ~0x3f) == 0 && ((1L << (_la - 58)) & 36591746972385281L) != 0)) ) { _errHandler.recoverInline(this); @@ -9711,8 +9709,6 @@ public boolean sempred(RuleContext _localctx, int ruleIndex, int predIndex) { return qualifiedName_sempred((QualifiedNameContext)_localctx, predIndex); case 28: return qualifiedNamePattern_sempred((QualifiedNamePatternContext)_localctx, predIndex); - case 38: - return limitByGroupKey_sempred((LimitByGroupKeyContext)_localctx, predIndex); case 63: return forkSubQueryCommand_sempred((ForkSubQueryCommandContext)_localctx, predIndex); case 81: @@ -9772,55 +9768,48 @@ private boolean qualifiedNamePattern_sempred(QualifiedNamePatternContext _localc } return true; } - private boolean limitByGroupKey_sempred(LimitByGroupKeyContext _localctx, int predIndex) { - switch (predIndex) { - case 8: - return this.isDevVersion(); - } - return true; - } private boolean forkSubQueryCommand_sempred(ForkSubQueryCommandContext _localctx, int predIndex) { switch (predIndex) { - case 9: + case 8: return precpred(_ctx, 1); } return true; } private boolean booleanExpression_sempred(BooleanExpressionContext _localctx, int predIndex) { switch (predIndex) { - case 10: + case 9: return precpred(_ctx, 5); - case 11: + case 10: return precpred(_ctx, 4); } return true; } private boolean operatorExpression_sempred(OperatorExpressionContext _localctx, int predIndex) { switch (predIndex) { - case 12: + case 11: return precpred(_ctx, 2); - case 13: + case 12: return precpred(_ctx, 1); } return true; } private boolean primaryExpression_sempred(PrimaryExpressionContext _localctx, int predIndex) { switch (predIndex) { - case 14: + case 13: return precpred(_ctx, 1); } return true; } private boolean joinTarget_sempred(JoinTargetContext _localctx, int predIndex) { switch (predIndex) { - case 15: + case 14: return this.isDevVersion(); } return true; } public static final String _serializedATN = - "\u0004\u0001\u00a8\u0488\u0002\u0000\u0007\u0000\u0002\u0001\u0007\u0001"+ + "\u0004\u0001\u00a8\u0487\u0002\u0000\u0007\u0000\u0002\u0001\u0007\u0001"+ "\u0002\u0002\u0007\u0002\u0002\u0003\u0007\u0003\u0002\u0004\u0007\u0004"+ "\u0002\u0005\u0007\u0005\u0002\u0006\u0007\u0006\u0002\u0007\u0007\u0007"+ "\u0002\b\u0007\b\u0002\t\u0007\t\u0002\n\u0007\n\u0002\u000b\u0007\u000b"+ @@ -9886,72 +9875,72 @@ private boolean joinTarget_sempred(JoinTargetContext _localctx, int predIndex) { "\u01ca\t\u001e\u0001\u001f\u0001\u001f\u0001 \u0001 \u0001 \u0003 \u01d1"+ "\b \u0001!\u0001!\u0003!\u01d5\b!\u0001\"\u0001\"\u0003\"\u01d9\b\"\u0001"+ "#\u0001#\u0001#\u0003#\u01de\b#\u0001$\u0001$\u0003$\u01e2\b$\u0001%\u0001"+ - "%\u0001%\u0003%\u01e7\b%\u0001&\u0001&\u0001&\u0001&\u0001&\u0005&\u01ee"+ - "\b&\n&\f&\u01f1\t&\u0001\'\u0001\'\u0001\'\u0001\'\u0005\'\u01f7\b\'\n"+ - "\'\f\'\u01fa\t\'\u0001(\u0001(\u0003(\u01fe\b(\u0001(\u0001(\u0003(\u0202"+ + "%\u0001%\u0003%\u01e7\b%\u0001&\u0001&\u0001&\u0001&\u0005&\u01ed\b&\n"+ + "&\f&\u01f0\t&\u0001\'\u0001\'\u0001\'\u0001\'\u0005\'\u01f6\b\'\n\'\f"+ + "\'\u01f9\t\'\u0001(\u0001(\u0003(\u01fd\b(\u0001(\u0001(\u0003(\u0201"+ "\b(\u0001)\u0001)\u0001)\u0001*\u0001*\u0001*\u0001+\u0001+\u0001+\u0001"+ - "+\u0005+\u020e\b+\n+\f+\u0211\t+\u0001,\u0001,\u0001,\u0001,\u0001,\u0001"+ - ",\u0001,\u0001,\u0003,\u021b\b,\u0001-\u0001-\u0001-\u0001-\u0003-\u0221"+ - "\b-\u0001.\u0001.\u0001.\u0005.\u0226\b.\n.\f.\u0229\t.\u0001/\u0001/"+ - "\u0001/\u0001/\u00010\u00010\u00030\u0231\b0\u00011\u00011\u00011\u0001"+ - "1\u00011\u00051\u0238\b1\n1\f1\u023b\t1\u00012\u00012\u00012\u00013\u0001"+ + "+\u0005+\u020d\b+\n+\f+\u0210\t+\u0001,\u0001,\u0001,\u0001,\u0001,\u0001"+ + ",\u0001,\u0001,\u0003,\u021a\b,\u0001-\u0001-\u0001-\u0001-\u0003-\u0220"+ + "\b-\u0001.\u0001.\u0001.\u0005.\u0225\b.\n.\f.\u0228\t.\u0001/\u0001/"+ + "\u0001/\u0001/\u00010\u00010\u00030\u0230\b0\u00011\u00011\u00011\u0001"+ + "1\u00011\u00051\u0237\b1\n1\f1\u023a\t1\u00012\u00012\u00012\u00013\u0001"+ "3\u00013\u00014\u00014\u00014\u00014\u00015\u00015\u00015\u00016\u0001"+ - "6\u00016\u00016\u00036\u024e\b6\u00016\u00016\u00016\u00016\u00056\u0254"+ - "\b6\n6\f6\u0257\t6\u00036\u0259\b6\u00017\u00017\u00018\u00018\u00018"+ - "\u00038\u0260\b8\u00018\u00018\u00019\u00019\u00019\u0001:\u0001:\u0001"+ - ":\u0005:\u026a\b:\n:\f:\u026d\t:\u0001;\u0001;\u0001;\u0001;\u0001;\u0001"+ - ";\u0001;\u0003;\u0276\b;\u0001<\u0001<\u0001<\u0001=\u0004=\u027c\b=\u000b"+ - "=\f=\u027d\u0001>\u0001>\u0001>\u0001>\u0001?\u0001?\u0001?\u0001?\u0001"+ - "?\u0001?\u0005?\u028a\b?\n?\f?\u028d\t?\u0001@\u0001@\u0001A\u0001A\u0001"+ - "A\u0001A\u0003A\u0295\bA\u0001A\u0001A\u0001A\u0001A\u0001A\u0001B\u0001"+ - "B\u0001B\u0001B\u0003B\u02a0\bB\u0001B\u0001B\u0001B\u0001C\u0001C\u0001"+ - "C\u0001C\u0001C\u0003C\u02aa\bC\u0001C\u0001C\u0001C\u0001C\u0003C\u02b0"+ - "\bC\u0003C\u02b2\bC\u0001D\u0001D\u0003D\u02b6\bD\u0001D\u0005D\u02b9"+ - "\bD\nD\fD\u02bc\tD\u0001E\u0001E\u0001E\u0001E\u0001E\u0001E\u0001E\u0001"+ - "E\u0001E\u0001E\u0001E\u0003E\u02c9\bE\u0001F\u0001F\u0001F\u0005F\u02ce"+ - "\bF\nF\fF\u02d1\tF\u0001G\u0001G\u0001H\u0001H\u0001I\u0001I\u0001I\u0001"+ + "6\u00016\u00016\u00036\u024d\b6\u00016\u00016\u00016\u00016\u00056\u0253"+ + "\b6\n6\f6\u0256\t6\u00036\u0258\b6\u00017\u00017\u00018\u00018\u00018"+ + "\u00038\u025f\b8\u00018\u00018\u00019\u00019\u00019\u0001:\u0001:\u0001"+ + ":\u0005:\u0269\b:\n:\f:\u026c\t:\u0001;\u0001;\u0001;\u0001;\u0001;\u0001"+ + ";\u0001;\u0003;\u0275\b;\u0001<\u0001<\u0001<\u0001=\u0004=\u027b\b=\u000b"+ + "=\f=\u027c\u0001>\u0001>\u0001>\u0001>\u0001?\u0001?\u0001?\u0001?\u0001"+ + "?\u0001?\u0005?\u0289\b?\n?\f?\u028c\t?\u0001@\u0001@\u0001A\u0001A\u0001"+ + "A\u0001A\u0003A\u0294\bA\u0001A\u0001A\u0001A\u0001A\u0001A\u0001B\u0001"+ + "B\u0001B\u0001B\u0003B\u029f\bB\u0001B\u0001B\u0001B\u0001C\u0001C\u0001"+ + "C\u0001C\u0001C\u0003C\u02a9\bC\u0001C\u0001C\u0001C\u0001C\u0003C\u02af"+ + "\bC\u0003C\u02b1\bC\u0001D\u0001D\u0003D\u02b5\bD\u0001D\u0005D\u02b8"+ + "\bD\nD\fD\u02bb\tD\u0001E\u0001E\u0001E\u0001E\u0001E\u0001E\u0001E\u0001"+ + "E\u0001E\u0001E\u0001E\u0003E\u02c8\bE\u0001F\u0001F\u0001F\u0005F\u02cd"+ + "\bF\nF\fF\u02d0\tF\u0001G\u0001G\u0001H\u0001H\u0001I\u0001I\u0001I\u0001"+ "I\u0001I\u0001J\u0001J\u0001J\u0001K\u0001K\u0001K\u0001K\u0001K\u0001"+ "L\u0001L\u0001L\u0001L\u0001L\u0001M\u0001M\u0001M\u0001M\u0001N\u0001"+ - "N\u0001N\u0001N\u0003N\u02f1\bN\u0001O\u0001O\u0003O\u02f5\bO\u0001O\u0001"+ - "O\u0001O\u0001O\u0001O\u0001O\u0001P\u0001P\u0003P\u02ff\bP\u0001Q\u0001"+ - "Q\u0001Q\u0001Q\u0001Q\u0001Q\u0001Q\u0003Q\u0308\bQ\u0001Q\u0001Q\u0001"+ - "Q\u0001Q\u0001Q\u0005Q\u030f\bQ\nQ\fQ\u0312\tQ\u0001Q\u0001Q\u0001Q\u0001"+ - "Q\u0001Q\u0003Q\u0319\bQ\u0001Q\u0001Q\u0001Q\u0003Q\u031e\bQ\u0001Q\u0001"+ - "Q\u0001Q\u0001Q\u0001Q\u0001Q\u0005Q\u0326\bQ\nQ\fQ\u0329\tQ\u0001R\u0001"+ - "R\u0003R\u032d\bR\u0001R\u0001R\u0001R\u0001R\u0001R\u0003R\u0334\bR\u0001"+ - "R\u0001R\u0001R\u0001R\u0001R\u0003R\u033b\bR\u0001R\u0001R\u0001R\u0001"+ - "R\u0001R\u0005R\u0342\bR\nR\fR\u0345\tR\u0001R\u0001R\u0001R\u0001R\u0003"+ - "R\u034b\bR\u0001R\u0001R\u0001R\u0001R\u0001R\u0005R\u0352\bR\nR\fR\u0355"+ - "\tR\u0001R\u0001R\u0003R\u0359\bR\u0001S\u0001S\u0001S\u0003S\u035e\b"+ - "S\u0001S\u0001S\u0001S\u0001T\u0001T\u0001T\u0001T\u0001T\u0003T\u0368"+ - "\bT\u0001U\u0001U\u0001U\u0001U\u0003U\u036e\bU\u0001U\u0001U\u0001U\u0001"+ - "U\u0001U\u0001U\u0005U\u0376\bU\nU\fU\u0379\tU\u0001V\u0001V\u0001V\u0001"+ - "V\u0001V\u0001V\u0001V\u0001V\u0003V\u0383\bV\u0001V\u0001V\u0001V\u0005"+ - "V\u0388\bV\nV\fV\u038b\tV\u0001W\u0001W\u0001W\u0001W\u0001W\u0001W\u0005"+ - "W\u0393\bW\nW\fW\u0396\tW\u0001W\u0001W\u0003W\u039a\bW\u0003W\u039c\b"+ - "W\u0001W\u0001W\u0001X\u0001X\u0001X\u0003X\u03a3\bX\u0001Y\u0001Y\u0001"+ - "Y\u0001Y\u0005Y\u03a9\bY\nY\fY\u03ac\tY\u0003Y\u03ae\bY\u0001Y\u0001Y"+ - "\u0001Z\u0001Z\u0001Z\u0001Z\u0001[\u0001[\u0003[\u03b8\b[\u0001\\\u0001"+ + "N\u0001N\u0001N\u0003N\u02f0\bN\u0001O\u0001O\u0003O\u02f4\bO\u0001O\u0001"+ + "O\u0001O\u0001O\u0001O\u0001O\u0001P\u0001P\u0003P\u02fe\bP\u0001Q\u0001"+ + "Q\u0001Q\u0001Q\u0001Q\u0001Q\u0001Q\u0003Q\u0307\bQ\u0001Q\u0001Q\u0001"+ + "Q\u0001Q\u0001Q\u0005Q\u030e\bQ\nQ\fQ\u0311\tQ\u0001Q\u0001Q\u0001Q\u0001"+ + "Q\u0001Q\u0003Q\u0318\bQ\u0001Q\u0001Q\u0001Q\u0003Q\u031d\bQ\u0001Q\u0001"+ + "Q\u0001Q\u0001Q\u0001Q\u0001Q\u0005Q\u0325\bQ\nQ\fQ\u0328\tQ\u0001R\u0001"+ + "R\u0003R\u032c\bR\u0001R\u0001R\u0001R\u0001R\u0001R\u0003R\u0333\bR\u0001"+ + "R\u0001R\u0001R\u0001R\u0001R\u0003R\u033a\bR\u0001R\u0001R\u0001R\u0001"+ + "R\u0001R\u0005R\u0341\bR\nR\fR\u0344\tR\u0001R\u0001R\u0001R\u0001R\u0003"+ + "R\u034a\bR\u0001R\u0001R\u0001R\u0001R\u0001R\u0005R\u0351\bR\nR\fR\u0354"+ + "\tR\u0001R\u0001R\u0003R\u0358\bR\u0001S\u0001S\u0001S\u0003S\u035d\b"+ + "S\u0001S\u0001S\u0001S\u0001T\u0001T\u0001T\u0001T\u0001T\u0003T\u0367"+ + "\bT\u0001U\u0001U\u0001U\u0001U\u0003U\u036d\bU\u0001U\u0001U\u0001U\u0001"+ + "U\u0001U\u0001U\u0005U\u0375\bU\nU\fU\u0378\tU\u0001V\u0001V\u0001V\u0001"+ + "V\u0001V\u0001V\u0001V\u0001V\u0003V\u0382\bV\u0001V\u0001V\u0001V\u0005"+ + "V\u0387\bV\nV\fV\u038a\tV\u0001W\u0001W\u0001W\u0001W\u0001W\u0001W\u0005"+ + "W\u0392\bW\nW\fW\u0395\tW\u0001W\u0001W\u0003W\u0399\bW\u0003W\u039b\b"+ + "W\u0001W\u0001W\u0001X\u0001X\u0001X\u0003X\u03a2\bX\u0001Y\u0001Y\u0001"+ + "Y\u0001Y\u0005Y\u03a8\bY\nY\fY\u03ab\tY\u0003Y\u03ad\bY\u0001Y\u0001Y"+ + "\u0001Z\u0001Z\u0001Z\u0001Z\u0001[\u0001[\u0003[\u03b7\b[\u0001\\\u0001"+ "\\\u0001\\\u0001\\\u0001\\\u0001\\\u0001\\\u0001\\\u0001\\\u0001\\\u0001"+ - "\\\u0001\\\u0001\\\u0005\\\u03c7\b\\\n\\\f\\\u03ca\t\\\u0001\\\u0001\\"+ - "\u0001\\\u0001\\\u0001\\\u0001\\\u0005\\\u03d2\b\\\n\\\f\\\u03d5\t\\\u0001"+ - "\\\u0001\\\u0001\\\u0001\\\u0001\\\u0001\\\u0005\\\u03dd\b\\\n\\\f\\\u03e0"+ - "\t\\\u0001\\\u0001\\\u0003\\\u03e4\b\\\u0001]\u0001]\u0001^\u0001^\u0003"+ - "^\u03ea\b^\u0001_\u0003_\u03ed\b_\u0001_\u0001_\u0001`\u0003`\u03f2\b"+ + "\\\u0001\\\u0001\\\u0005\\\u03c6\b\\\n\\\f\\\u03c9\t\\\u0001\\\u0001\\"+ + "\u0001\\\u0001\\\u0001\\\u0001\\\u0005\\\u03d1\b\\\n\\\f\\\u03d4\t\\\u0001"+ + "\\\u0001\\\u0001\\\u0001\\\u0001\\\u0001\\\u0005\\\u03dc\b\\\n\\\f\\\u03df"+ + "\t\\\u0001\\\u0001\\\u0003\\\u03e3\b\\\u0001]\u0001]\u0001^\u0001^\u0003"+ + "^\u03e9\b^\u0001_\u0003_\u03ec\b_\u0001_\u0001_\u0001`\u0003`\u03f1\b"+ "`\u0001`\u0001`\u0001a\u0001a\u0001b\u0001b\u0001c\u0001c\u0001c\u0001"+ - "c\u0001c\u0001d\u0001d\u0001d\u0003d\u0402\bd\u0001d\u0001d\u0001d\u0003"+ - "d\u0407\bd\u0001e\u0001e\u0001e\u0001e\u0005e\u040d\be\ne\fe\u0410\te"+ - "\u0001f\u0001f\u0005f\u0414\bf\nf\ff\u0417\tf\u0001f\u0001f\u0001f\u0003"+ - "f\u041c\bf\u0001f\u0001f\u0001f\u0001f\u0001f\u0005f\u0423\bf\nf\ff\u0426"+ - "\tf\u0001f\u0001f\u0001f\u0003f\u042b\bf\u0001f\u0001f\u0001f\u0005f\u0430"+ - "\bf\nf\ff\u0433\tf\u0001f\u0001f\u0001f\u0003f\u0438\bf\u0001f\u0001f"+ - "\u0004f\u043c\bf\u000bf\ff\u043d\u0001f\u0001f\u0001f\u0001f\u0005f\u0444"+ - "\bf\nf\ff\u0447\tf\u0001f\u0004f\u044a\bf\u000bf\ff\u044b\u0003f\u044e"+ + "c\u0001c\u0001d\u0001d\u0001d\u0003d\u0401\bd\u0001d\u0001d\u0001d\u0003"+ + "d\u0406\bd\u0001e\u0001e\u0001e\u0001e\u0005e\u040c\be\ne\fe\u040f\te"+ + "\u0001f\u0001f\u0005f\u0413\bf\nf\ff\u0416\tf\u0001f\u0001f\u0001f\u0003"+ + "f\u041b\bf\u0001f\u0001f\u0001f\u0001f\u0001f\u0005f\u0422\bf\nf\ff\u0425"+ + "\tf\u0001f\u0001f\u0001f\u0003f\u042a\bf\u0001f\u0001f\u0001f\u0005f\u042f"+ + "\bf\nf\ff\u0432\tf\u0001f\u0001f\u0001f\u0003f\u0437\bf\u0001f\u0001f"+ + "\u0004f\u043b\bf\u000bf\ff\u043c\u0001f\u0001f\u0001f\u0001f\u0005f\u0443"+ + "\bf\nf\ff\u0446\tf\u0001f\u0004f\u0449\bf\u000bf\ff\u044a\u0003f\u044d"+ "\bf\u0001g\u0001g\u0001h\u0001h\u0001h\u0001h\u0001i\u0001i\u0001j\u0001"+ - "j\u0001j\u0005j\u045b\bj\nj\fj\u045e\tj\u0001j\u0001j\u0003j\u0462\bj"+ - "\u0001k\u0001k\u0001l\u0004l\u0467\bl\u000bl\fl\u0468\u0001l\u0001l\u0005"+ - "l\u046d\bl\nl\fl\u0470\tl\u0001l\u0003l\u0473\bl\u0001m\u0001m\u0001m"+ - "\u0001m\u0001m\u0001m\u0001m\u0001m\u0001m\u0003m\u047e\bm\u0001n\u0001"+ + "j\u0001j\u0005j\u045a\bj\nj\fj\u045d\tj\u0001j\u0001j\u0003j\u0461\bj"+ + "\u0001k\u0001k\u0001l\u0004l\u0466\bl\u000bl\fl\u0467\u0001l\u0001l\u0005"+ + "l\u046c\bl\nl\fl\u046f\tl\u0001l\u0003l\u0472\bl\u0001m\u0001m\u0001m"+ + "\u0001m\u0001m\u0001m\u0001m\u0001m\u0001m\u0003m\u047d\bm\u0001n\u0001"+ "n\u0001o\u0001o\u0001p\u0001p\u0001q\u0001q\u0001q\u0000\u0005\u0004~"+ "\u00a2\u00aa\u00acr\u0000\u0002\u0004\u0006\b\n\f\u000e\u0010\u0012\u0014"+ "\u0016\u0018\u001a\u001c\u001e \"$&(*,.02468:<>@BDFHJLNPRTVXZ\\^`bdfh"+ @@ -9963,7 +9952,7 @@ private boolean joinTarget_sempred(JoinTargetContext _localctx, int predIndex) { "\u0000>>EE\u0002\u0000HHKK\u0002\u0000//::\u0001\u0000]^\u0001\u0000_"+ "a\u0002\u0000GGTT\u0002\u0000VVX\\\u0002\u0000\u001d\u001d\u001f \u0003"+ "\u0000::eekl\b\u0000::??ABDDeeklqq\u009b\u009d\u0002\u0000kkqq\u0003\u0000"+ - "::kkqq\u04bf\u0000\u00e7\u0001\u0000\u0000\u0000\u0002\u00ed\u0001\u0000"+ + "::kkqq\u04be\u0000\u00e7\u0001\u0000\u0000\u0000\u0002\u00ed\u0001\u0000"+ "\u0000\u0000\u0004\u00f0\u0001\u0000\u0000\u0000\u0006\u0104\u0001\u0000"+ "\u0000\u0000\b\u0123\u0001\u0000\u0000\u0000\n\u0125\u0001\u0000\u0000"+ "\u0000\f\u0128\u0001\u0000\u0000\u0000\u000e\u012a\u0001\u0000\u0000\u0000"+ @@ -9980,43 +9969,43 @@ private boolean joinTarget_sempred(JoinTargetContext _localctx, int predIndex) { "<\u01c3\u0001\u0000\u0000\u0000>\u01cb\u0001\u0000\u0000\u0000@\u01d0"+ "\u0001\u0000\u0000\u0000B\u01d4\u0001\u0000\u0000\u0000D\u01d8\u0001\u0000"+ "\u0000\u0000F\u01dd\u0001\u0000\u0000\u0000H\u01e1\u0001\u0000\u0000\u0000"+ - "J\u01e3\u0001\u0000\u0000\u0000L\u01e8\u0001\u0000\u0000\u0000N\u01f2"+ - "\u0001\u0000\u0000\u0000P\u01fb\u0001\u0000\u0000\u0000R\u0203\u0001\u0000"+ - "\u0000\u0000T\u0206\u0001\u0000\u0000\u0000V\u0209\u0001\u0000\u0000\u0000"+ - "X\u021a\u0001\u0000\u0000\u0000Z\u021c\u0001\u0000\u0000\u0000\\\u0222"+ - "\u0001\u0000\u0000\u0000^\u022a\u0001\u0000\u0000\u0000`\u0230\u0001\u0000"+ - "\u0000\u0000b\u0232\u0001\u0000\u0000\u0000d\u023c\u0001\u0000\u0000\u0000"+ - "f\u023f\u0001\u0000\u0000\u0000h\u0242\u0001\u0000\u0000\u0000j\u0246"+ - "\u0001\u0000\u0000\u0000l\u0249\u0001\u0000\u0000\u0000n\u025a\u0001\u0000"+ - "\u0000\u0000p\u025f\u0001\u0000\u0000\u0000r\u0263\u0001\u0000\u0000\u0000"+ - "t\u0266\u0001\u0000\u0000\u0000v\u0275\u0001\u0000\u0000\u0000x\u0277"+ - "\u0001\u0000\u0000\u0000z\u027b\u0001\u0000\u0000\u0000|\u027f\u0001\u0000"+ - "\u0000\u0000~\u0283\u0001\u0000\u0000\u0000\u0080\u028e\u0001\u0000\u0000"+ - "\u0000\u0082\u0290\u0001\u0000\u0000\u0000\u0084\u029b\u0001\u0000\u0000"+ - "\u0000\u0086\u02b1\u0001\u0000\u0000\u0000\u0088\u02b3\u0001\u0000\u0000"+ - "\u0000\u008a\u02c8\u0001\u0000\u0000\u0000\u008c\u02ca\u0001\u0000\u0000"+ - "\u0000\u008e\u02d2\u0001\u0000\u0000\u0000\u0090\u02d4\u0001\u0000\u0000"+ - "\u0000\u0092\u02d6\u0001\u0000\u0000\u0000\u0094\u02db\u0001\u0000\u0000"+ - "\u0000\u0096\u02de\u0001\u0000\u0000\u0000\u0098\u02e3\u0001\u0000\u0000"+ - "\u0000\u009a\u02e8\u0001\u0000\u0000\u0000\u009c\u02ec\u0001\u0000\u0000"+ - "\u0000\u009e\u02f2\u0001\u0000\u0000\u0000\u00a0\u02fe\u0001\u0000\u0000"+ - "\u0000\u00a2\u031d\u0001\u0000\u0000\u0000\u00a4\u0358\u0001\u0000\u0000"+ - "\u0000\u00a6\u035a\u0001\u0000\u0000\u0000\u00a8\u0367\u0001\u0000\u0000"+ - "\u0000\u00aa\u036d\u0001\u0000\u0000\u0000\u00ac\u0382\u0001\u0000\u0000"+ - "\u0000\u00ae\u038c\u0001\u0000\u0000\u0000\u00b0\u03a2\u0001\u0000\u0000"+ - "\u0000\u00b2\u03a4\u0001\u0000\u0000\u0000\u00b4\u03b1\u0001\u0000\u0000"+ - "\u0000\u00b6\u03b7\u0001\u0000\u0000\u0000\u00b8\u03e3\u0001\u0000\u0000"+ - "\u0000\u00ba\u03e5\u0001\u0000\u0000\u0000\u00bc\u03e9\u0001\u0000\u0000"+ - "\u0000\u00be\u03ec\u0001\u0000\u0000\u0000\u00c0\u03f1\u0001\u0000\u0000"+ - "\u0000\u00c2\u03f5\u0001\u0000\u0000\u0000\u00c4\u03f7\u0001\u0000\u0000"+ - "\u0000\u00c6\u03f9\u0001\u0000\u0000\u0000\u00c8\u0406\u0001\u0000\u0000"+ - "\u0000\u00ca\u0408\u0001\u0000\u0000\u0000\u00cc\u044d\u0001\u0000\u0000"+ - "\u0000\u00ce\u044f\u0001\u0000\u0000\u0000\u00d0\u0451\u0001\u0000\u0000"+ - "\u0000\u00d2\u0455\u0001\u0000\u0000\u0000\u00d4\u0461\u0001\u0000\u0000"+ - "\u0000\u00d6\u0463\u0001\u0000\u0000\u0000\u00d8\u0472\u0001\u0000\u0000"+ - "\u0000\u00da\u047d\u0001\u0000\u0000\u0000\u00dc\u047f\u0001\u0000\u0000"+ - "\u0000\u00de\u0481\u0001\u0000\u0000\u0000\u00e0\u0483\u0001\u0000\u0000"+ - "\u0000\u00e2\u0485\u0001\u0000\u0000\u0000\u00e4\u00e6\u0003\u009aM\u0000"+ + "J\u01e3\u0001\u0000\u0000\u0000L\u01e8\u0001\u0000\u0000\u0000N\u01f1"+ + "\u0001\u0000\u0000\u0000P\u01fa\u0001\u0000\u0000\u0000R\u0202\u0001\u0000"+ + "\u0000\u0000T\u0205\u0001\u0000\u0000\u0000V\u0208\u0001\u0000\u0000\u0000"+ + "X\u0219\u0001\u0000\u0000\u0000Z\u021b\u0001\u0000\u0000\u0000\\\u0221"+ + "\u0001\u0000\u0000\u0000^\u0229\u0001\u0000\u0000\u0000`\u022f\u0001\u0000"+ + "\u0000\u0000b\u0231\u0001\u0000\u0000\u0000d\u023b\u0001\u0000\u0000\u0000"+ + "f\u023e\u0001\u0000\u0000\u0000h\u0241\u0001\u0000\u0000\u0000j\u0245"+ + "\u0001\u0000\u0000\u0000l\u0248\u0001\u0000\u0000\u0000n\u0259\u0001\u0000"+ + "\u0000\u0000p\u025e\u0001\u0000\u0000\u0000r\u0262\u0001\u0000\u0000\u0000"+ + "t\u0265\u0001\u0000\u0000\u0000v\u0274\u0001\u0000\u0000\u0000x\u0276"+ + "\u0001\u0000\u0000\u0000z\u027a\u0001\u0000\u0000\u0000|\u027e\u0001\u0000"+ + "\u0000\u0000~\u0282\u0001\u0000\u0000\u0000\u0080\u028d\u0001\u0000\u0000"+ + "\u0000\u0082\u028f\u0001\u0000\u0000\u0000\u0084\u029a\u0001\u0000\u0000"+ + "\u0000\u0086\u02b0\u0001\u0000\u0000\u0000\u0088\u02b2\u0001\u0000\u0000"+ + "\u0000\u008a\u02c7\u0001\u0000\u0000\u0000\u008c\u02c9\u0001\u0000\u0000"+ + "\u0000\u008e\u02d1\u0001\u0000\u0000\u0000\u0090\u02d3\u0001\u0000\u0000"+ + "\u0000\u0092\u02d5\u0001\u0000\u0000\u0000\u0094\u02da\u0001\u0000\u0000"+ + "\u0000\u0096\u02dd\u0001\u0000\u0000\u0000\u0098\u02e2\u0001\u0000\u0000"+ + "\u0000\u009a\u02e7\u0001\u0000\u0000\u0000\u009c\u02eb\u0001\u0000\u0000"+ + "\u0000\u009e\u02f1\u0001\u0000\u0000\u0000\u00a0\u02fd\u0001\u0000\u0000"+ + "\u0000\u00a2\u031c\u0001\u0000\u0000\u0000\u00a4\u0357\u0001\u0000\u0000"+ + "\u0000\u00a6\u0359\u0001\u0000\u0000\u0000\u00a8\u0366\u0001\u0000\u0000"+ + "\u0000\u00aa\u036c\u0001\u0000\u0000\u0000\u00ac\u0381\u0001\u0000\u0000"+ + "\u0000\u00ae\u038b\u0001\u0000\u0000\u0000\u00b0\u03a1\u0001\u0000\u0000"+ + "\u0000\u00b2\u03a3\u0001\u0000\u0000\u0000\u00b4\u03b0\u0001\u0000\u0000"+ + "\u0000\u00b6\u03b6\u0001\u0000\u0000\u0000\u00b8\u03e2\u0001\u0000\u0000"+ + "\u0000\u00ba\u03e4\u0001\u0000\u0000\u0000\u00bc\u03e8\u0001\u0000\u0000"+ + "\u0000\u00be\u03eb\u0001\u0000\u0000\u0000\u00c0\u03f0\u0001\u0000\u0000"+ + "\u0000\u00c2\u03f4\u0001\u0000\u0000\u0000\u00c4\u03f6\u0001\u0000\u0000"+ + "\u0000\u00c6\u03f8\u0001\u0000\u0000\u0000\u00c8\u0405\u0001\u0000\u0000"+ + "\u0000\u00ca\u0407\u0001\u0000\u0000\u0000\u00cc\u044c\u0001\u0000\u0000"+ + "\u0000\u00ce\u044e\u0001\u0000\u0000\u0000\u00d0\u0450\u0001\u0000\u0000"+ + "\u0000\u00d2\u0454\u0001\u0000\u0000\u0000\u00d4\u0460\u0001\u0000\u0000"+ + "\u0000\u00d6\u0462\u0001\u0000\u0000\u0000\u00d8\u0471\u0001\u0000\u0000"+ + "\u0000\u00da\u047c\u0001\u0000\u0000\u0000\u00dc\u047e\u0001\u0000\u0000"+ + "\u0000\u00de\u0480\u0001\u0000\u0000\u0000\u00e0\u0482\u0001\u0000\u0000"+ + "\u0000\u00e2\u0484\u0001\u0000\u0000\u0000\u00e4\u00e6\u0003\u009aM\u0000"+ "\u00e5\u00e4\u0001\u0000\u0000\u0000\u00e6\u00e9\u0001\u0000\u0000\u0000"+ "\u00e7\u00e5\u0001\u0000\u0000\u0000\u00e7\u00e8\u0001\u0000\u0000\u0000"+ "\u00e8\u00ea\u0001\u0000\u0000\u0000\u00e9\u00e7\u0001\u0000\u0000\u0000"+ @@ -10166,379 +10155,379 @@ private boolean joinTarget_sempred(JoinTargetContext _localctx, int predIndex) { "\u0000\u0000\u0000\u01e2I\u0001\u0000\u0000\u0000\u01e3\u01e4\u0005\u000b"+ "\u0000\u0000\u01e4\u01e6\u0003\u00b8\\\u0000\u01e5\u01e7\u0003L&\u0000"+ "\u01e6\u01e5\u0001\u0000\u0000\u0000\u01e6\u01e7\u0001\u0000\u0000\u0000"+ - "\u01e7K\u0001\u0000\u0000\u0000\u01e8\u01e9\u0004&\b\u0000\u01e9\u01ea"+ - "\u0005@\u0000\u0000\u01ea\u01ef\u0003\u00a2Q\u0000\u01eb\u01ec\u0005D"+ - "\u0000\u0000\u01ec\u01ee\u0003\u00a2Q\u0000\u01ed\u01eb\u0001\u0000\u0000"+ - "\u0000\u01ee\u01f1\u0001\u0000\u0000\u0000\u01ef\u01ed\u0001\u0000\u0000"+ - "\u0000\u01ef\u01f0\u0001\u0000\u0000\u0000\u01f0M\u0001\u0000\u0000\u0000"+ - "\u01f1\u01ef\u0001\u0000\u0000\u0000\u01f2\u01f3\u0005\u000f\u0000\u0000"+ - "\u01f3\u01f8\u0003P(\u0000\u01f4\u01f5\u0005D\u0000\u0000\u01f5\u01f7"+ - "\u0003P(\u0000\u01f6\u01f4\u0001\u0000\u0000\u0000\u01f7\u01fa\u0001\u0000"+ - "\u0000\u0000\u01f8\u01f6\u0001\u0000\u0000\u0000\u01f8\u01f9\u0001\u0000"+ - "\u0000\u0000\u01f9O\u0001\u0000\u0000\u0000\u01fa\u01f8\u0001\u0000\u0000"+ - "\u0000\u01fb\u01fd\u0003\u00a2Q\u0000\u01fc\u01fe\u0007\u0002\u0000\u0000"+ - "\u01fd\u01fc\u0001\u0000\u0000\u0000\u01fd\u01fe\u0001\u0000\u0000\u0000"+ - "\u01fe\u0201\u0001\u0000\u0000\u0000\u01ff\u0200\u0005O\u0000\u0000\u0200"+ - "\u0202\u0007\u0003\u0000\u0000\u0201\u01ff\u0001\u0000\u0000\u0000\u0201"+ - "\u0202\u0001\u0000\u0000\u0000\u0202Q\u0001\u0000\u0000\u0000\u0203\u0204"+ - "\u0005%\u0000\u0000\u0204\u0205\u0003<\u001e\u0000\u0205S\u0001\u0000"+ - "\u0000\u0000\u0206\u0207\u0005$\u0000\u0000\u0207\u0208\u0003<\u001e\u0000"+ - "\u0208U\u0001\u0000\u0000\u0000\u0209\u020a\u0005(\u0000\u0000\u020a\u020f"+ - "\u0003X,\u0000\u020b\u020c\u0005D\u0000\u0000\u020c\u020e\u0003X,\u0000"+ - "\u020d\u020b\u0001\u0000\u0000\u0000\u020e\u0211\u0001\u0000\u0000\u0000"+ - "\u020f\u020d\u0001\u0000\u0000\u0000\u020f\u0210\u0001\u0000\u0000\u0000"+ - "\u0210W\u0001\u0000\u0000\u0000\u0211\u020f\u0001\u0000\u0000\u0000\u0212"+ - "\u0213\u00038\u001c\u0000\u0213\u0214\u0005\u009e\u0000\u0000\u0214\u0215"+ - "\u00038\u001c\u0000\u0215\u021b\u0001\u0000\u0000\u0000\u0216\u0217\u0003"+ - "8\u001c\u0000\u0217\u0218\u0005?\u0000\u0000\u0218\u0219\u00038\u001c"+ - "\u0000\u0219\u021b\u0001\u0000\u0000\u0000\u021a\u0212\u0001\u0000\u0000"+ - "\u0000\u021a\u0216\u0001\u0000\u0000\u0000\u021bY\u0001\u0000\u0000\u0000"+ - "\u021c\u021d\u0005\b\u0000\u0000\u021d\u021e\u0003\u00acV\u0000\u021e"+ - "\u0220\u0003\u00c2a\u0000\u021f\u0221\u0003\\.\u0000\u0220\u021f\u0001"+ - "\u0000\u0000\u0000\u0220\u0221\u0001\u0000\u0000\u0000\u0221[\u0001\u0000"+ - "\u0000\u0000\u0222\u0227\u0003^/\u0000\u0223\u0224\u0005D\u0000\u0000"+ - "\u0224\u0226\u0003^/\u0000\u0225\u0223\u0001\u0000\u0000\u0000\u0226\u0229"+ - "\u0001\u0000\u0000\u0000\u0227\u0225\u0001\u0000\u0000\u0000\u0227\u0228"+ - "\u0001\u0000\u0000\u0000\u0228]\u0001\u0000\u0000\u0000\u0229\u0227\u0001"+ - "\u0000\u0000\u0000\u022a\u022b\u0003>\u001f\u0000\u022b\u022c\u0005?\u0000"+ - "\u0000\u022c\u022d\u0003\u00b8\\\u0000\u022d_\u0001\u0000\u0000\u0000"+ - "\u022e\u022f\u0005U\u0000\u0000\u022f\u0231\u0003\u00b2Y\u0000\u0230\u022e"+ - "\u0001\u0000\u0000\u0000\u0230\u0231\u0001\u0000\u0000\u0000\u0231a\u0001"+ - "\u0000\u0000\u0000\u0232\u0233\u0005\n\u0000\u0000\u0233\u0234\u0003\u00ac"+ - "V\u0000\u0234\u0239\u0003\u00c2a\u0000\u0235\u0236\u0005D\u0000\u0000"+ - "\u0236\u0238\u0003\u00c2a\u0000\u0237\u0235\u0001\u0000\u0000\u0000\u0238"+ - "\u023b\u0001\u0000\u0000\u0000\u0239\u0237\u0001\u0000\u0000\u0000\u0239"+ - "\u023a\u0001\u0000\u0000\u0000\u023ac\u0001\u0000\u0000\u0000\u023b\u0239"+ - "\u0001\u0000\u0000\u0000\u023c\u023d\u0005#\u0000\u0000\u023d\u023e\u0003"+ - "4\u001a\u0000\u023ee\u0001\u0000\u0000\u0000\u023f\u0240\u0005\u0006\u0000"+ - "\u0000\u0240\u0241\u0003h4\u0000\u0241g\u0001\u0000\u0000\u0000\u0242"+ - "\u0243\u0005i\u0000\u0000\u0243\u0244\u0003\u0004\u0002\u0000\u0244\u0245"+ - "\u0005j\u0000\u0000\u0245i\u0001\u0000\u0000\u0000\u0246\u0247\u0005*"+ - "\u0000\u0000\u0247\u0248\u0005\u00a5\u0000\u0000\u0248k\u0001\u0000\u0000"+ - "\u0000\u0249\u024a\u0005\u0005\u0000\u0000\u024a\u024d\u0003n7\u0000\u024b"+ - "\u024c\u0005P\u0000\u0000\u024c\u024e\u00038\u001c\u0000\u024d\u024b\u0001"+ - "\u0000\u0000\u0000\u024d\u024e\u0001\u0000\u0000\u0000\u024e\u0258\u0001"+ - "\u0000\u0000\u0000\u024f\u0250\u0005U\u0000\u0000\u0250\u0255\u0003p8"+ - "\u0000\u0251\u0252\u0005D\u0000\u0000\u0252\u0254\u0003p8\u0000\u0253"+ - "\u0251\u0001\u0000\u0000\u0000\u0254\u0257\u0001\u0000\u0000\u0000\u0255"+ - "\u0253\u0001\u0000\u0000\u0000\u0255\u0256\u0001\u0000\u0000\u0000\u0256"+ - "\u0259\u0001\u0000\u0000\u0000\u0257\u0255\u0001\u0000\u0000\u0000\u0258"+ - "\u024f\u0001\u0000\u0000\u0000\u0258\u0259\u0001\u0000\u0000\u0000\u0259"+ - "m\u0001\u0000\u0000\u0000\u025a\u025b\u0007\u0004\u0000\u0000\u025bo\u0001"+ - "\u0000\u0000\u0000\u025c\u025d\u00038\u001c\u0000\u025d\u025e\u0005?\u0000"+ - "\u0000\u025e\u0260\u0001\u0000\u0000\u0000\u025f\u025c\u0001\u0000\u0000"+ - "\u0000\u025f\u0260\u0001\u0000\u0000\u0000\u0260\u0261\u0001\u0000\u0000"+ - "\u0000\u0261\u0262\u00038\u001c\u0000\u0262q\u0001\u0000\u0000\u0000\u0263"+ - "\u0264\u0005\u000e\u0000\u0000\u0264\u0265\u0003\u00b8\\\u0000\u0265s"+ - "\u0001\u0000\u0000\u0000\u0266\u0267\u0005\u0004\u0000\u0000\u0267\u026b"+ - "\u00034\u001a\u0000\u0268\u026a\u0003v;\u0000\u0269\u0268\u0001\u0000"+ - "\u0000\u0000\u026a\u026d\u0001\u0000\u0000\u0000\u026b\u0269\u0001\u0000"+ - "\u0000\u0000\u026b\u026c\u0001\u0000\u0000\u0000\u026cu\u0001\u0000\u0000"+ - "\u0000\u026d\u026b\u0001\u0000\u0000\u0000\u026e\u026f\u0005P\u0000\u0000"+ - "\u026f\u0276\u00034\u001a\u0000\u0270\u0271\u0005\u009e\u0000\u0000\u0271"+ - "\u0272\u00034\u001a\u0000\u0272\u0273\u0005D\u0000\u0000\u0273\u0274\u0003"+ - "4\u001a\u0000\u0274\u0276\u0001\u0000\u0000\u0000\u0275\u026e\u0001\u0000"+ - "\u0000\u0000\u0275\u0270\u0001\u0000\u0000\u0000\u0276w\u0001\u0000\u0000"+ - "\u0000\u0277\u0278\u0005\u0019\u0000\u0000\u0278\u0279\u0003z=\u0000\u0279"+ - "y\u0001\u0000\u0000\u0000\u027a\u027c\u0003|>\u0000\u027b\u027a\u0001"+ - "\u0000\u0000\u0000\u027c\u027d\u0001\u0000\u0000\u0000\u027d\u027b\u0001"+ - "\u0000\u0000\u0000\u027d\u027e\u0001\u0000\u0000\u0000\u027e{\u0001\u0000"+ - "\u0000\u0000\u027f\u0280\u0005i\u0000\u0000\u0280\u0281\u0003~?\u0000"+ - "\u0281\u0282\u0005j\u0000\u0000\u0282}\u0001\u0000\u0000\u0000\u0283\u0284"+ - "\u0006?\uffff\uffff\u0000\u0284\u0285\u0003\u0080@\u0000\u0285\u028b\u0001"+ - "\u0000\u0000\u0000\u0286\u0287\n\u0001\u0000\u0000\u0287\u0288\u00059"+ - "\u0000\u0000\u0288\u028a\u0003\u0080@\u0000\u0289\u0286\u0001\u0000\u0000"+ - "\u0000\u028a\u028d\u0001\u0000\u0000\u0000\u028b\u0289\u0001\u0000\u0000"+ - "\u0000\u028b\u028c\u0001\u0000\u0000\u0000\u028c\u007f\u0001\u0000\u0000"+ - "\u0000\u028d\u028b\u0001\u0000\u0000\u0000\u028e\u028f\u0003\b\u0004\u0000"+ - "\u028f\u0081\u0001\u0000\u0000\u0000\u0290\u0294\u0005\f\u0000\u0000\u0291"+ - "\u0292\u00034\u001a\u0000\u0292\u0293\u0005?\u0000\u0000\u0293\u0295\u0001"+ - "\u0000\u0000\u0000\u0294\u0291\u0001\u0000\u0000\u0000\u0294\u0295\u0001"+ - "\u0000\u0000\u0000\u0295\u0296\u0001\u0000\u0000\u0000\u0296\u0297\u0003"+ - "\u00b8\\\u0000\u0297\u0298\u0005P\u0000\u0000\u0298\u0299\u0003\u0010"+ - "\b\u0000\u0299\u029a\u0003`0\u0000\u029a\u0083\u0001\u0000\u0000\u0000"+ - "\u029b\u029f\u0005\u0007\u0000\u0000\u029c\u029d\u00034\u001a\u0000\u029d"+ - "\u029e\u0005?\u0000\u0000\u029e\u02a0\u0001\u0000\u0000\u0000\u029f\u029c"+ - "\u0001\u0000\u0000\u0000\u029f\u02a0\u0001\u0000\u0000\u0000\u02a0\u02a1"+ - "\u0001\u0000\u0000\u0000\u02a1\u02a2\u0003\u00acV\u0000\u02a2\u02a3\u0003"+ - "`0\u0000\u02a3\u0085\u0001\u0000\u0000\u0000\u02a4\u02a5\u0005\u001b\u0000"+ - "\u0000\u02a5\u02a6\u0005~\u0000\u0000\u02a6\u02a9\u00030\u0018\u0000\u02a7"+ - "\u02a8\u0005@\u0000\u0000\u02a8\u02aa\u0003\u0010\b\u0000\u02a9\u02a7"+ - "\u0001\u0000\u0000\u0000\u02a9\u02aa\u0001\u0000\u0000\u0000\u02aa\u02b2"+ - "\u0001\u0000\u0000\u0000\u02ab\u02ac\u0005\u001c\u0000\u0000\u02ac\u02af"+ - "\u00030\u0018\u0000\u02ad\u02ae\u0005@\u0000\u0000\u02ae\u02b0\u0003\u0010"+ - "\b\u0000\u02af\u02ad\u0001\u0000\u0000\u0000\u02af\u02b0\u0001\u0000\u0000"+ - "\u0000\u02b0\u02b2\u0001\u0000\u0000\u0000\u02b1\u02a4\u0001\u0000\u0000"+ - "\u0000\u02b1\u02ab\u0001\u0000\u0000\u0000\u02b2\u0087\u0001\u0000\u0000"+ - "\u0000\u02b3\u02b5\u0005\u001a\u0000\u0000\u02b4\u02b6\u0003>\u001f\u0000"+ - "\u02b5\u02b4\u0001\u0000\u0000\u0000\u02b5\u02b6\u0001\u0000\u0000\u0000"+ - "\u02b6\u02ba\u0001\u0000\u0000\u0000\u02b7\u02b9\u0003\u008aE\u0000\u02b8"+ - "\u02b7\u0001\u0000\u0000\u0000\u02b9\u02bc\u0001\u0000\u0000\u0000\u02ba"+ - "\u02b8\u0001\u0000\u0000\u0000\u02ba\u02bb\u0001\u0000\u0000\u0000\u02bb"+ - "\u0089\u0001\u0000\u0000\u0000\u02bc\u02ba\u0001\u0000\u0000\u0000\u02bd"+ - "\u02be\u0005y\u0000\u0000\u02be\u02bf\u0005@\u0000\u0000\u02bf\u02c9\u0003"+ - "4\u001a\u0000\u02c0\u02c1\u0005z\u0000\u0000\u02c1\u02c2\u0005@\u0000"+ - "\u0000\u02c2\u02c9\u0003\u008cF\u0000\u02c3\u02c4\u0005x\u0000\u0000\u02c4"+ - "\u02c5\u0005@\u0000\u0000\u02c5\u02c9\u00034\u001a\u0000\u02c6\u02c7\u0005"+ - "U\u0000\u0000\u02c7\u02c9\u0003\u00b2Y\u0000\u02c8\u02bd\u0001\u0000\u0000"+ - "\u0000\u02c8\u02c0\u0001\u0000\u0000\u0000\u02c8\u02c3\u0001\u0000\u0000"+ - "\u0000\u02c8\u02c6\u0001\u0000\u0000\u0000\u02c9\u008b\u0001\u0000\u0000"+ - "\u0000\u02ca\u02cf\u00034\u001a\u0000\u02cb\u02cc\u0005D\u0000\u0000\u02cc"+ - "\u02ce\u00034\u001a\u0000\u02cd\u02cb\u0001\u0000\u0000\u0000\u02ce\u02d1"+ - "\u0001\u0000\u0000\u0000\u02cf\u02cd\u0001\u0000\u0000\u0000\u02cf\u02d0"+ - "\u0001\u0000\u0000\u0000\u02d0\u008d\u0001\u0000\u0000\u0000\u02d1\u02cf"+ - "\u0001\u0000\u0000\u0000\u02d2\u02d3\u0005\u0013\u0000\u0000\u02d3\u008f"+ - "\u0001\u0000\u0000\u0000\u02d4\u02d5\u0005\u0015\u0000\u0000\u02d5\u0091"+ - "\u0001\u0000\u0000\u0000\u02d6\u02d7\u0005!\u0000\u0000\u02d7\u02d8\u0003"+ - " \u0010\u0000\u02d8\u02d9\u0005P\u0000\u0000\u02d9\u02da\u0003<\u001e"+ - "\u0000\u02da\u0093\u0001\u0000\u0000\u0000\u02db\u02dc\u0005&\u0000\u0000"+ - "\u02dc\u02dd\u0003<\u001e\u0000\u02dd\u0095\u0001\u0000\u0000\u0000\u02de"+ - "\u02df\u0005\u0012\u0000\u0000\u02df\u02e0\u00034\u001a\u0000\u02e0\u02e1"+ - "\u0005?\u0000\u0000\u02e1\u02e2\u0003\u00acV\u0000\u02e2\u0097\u0001\u0000"+ - "\u0000\u0000\u02e3\u02e4\u0005\u0014\u0000\u0000\u02e4\u02e5\u00034\u001a"+ - "\u0000\u02e5\u02e6\u0005?\u0000\u0000\u02e6\u02e7\u0003\u00acV\u0000\u02e7"+ - "\u0099\u0001\u0000\u0000\u0000\u02e8\u02e9\u0005)\u0000\u0000\u02e9\u02ea"+ - "\u0003\u009cN\u0000\u02ea\u02eb\u0005C\u0000\u0000\u02eb\u009b\u0001\u0000"+ - "\u0000\u0000\u02ec\u02ed\u0003>\u001f\u0000\u02ed\u02f0\u0005?\u0000\u0000"+ - "\u02ee\u02f1\u0003\u00b8\\\u0000\u02ef\u02f1\u0003\u00b2Y\u0000\u02f0"+ - "\u02ee\u0001\u0000\u0000\u0000\u02f0\u02ef\u0001\u0000\u0000\u0000\u02f1"+ - "\u009d\u0001\u0000\u0000\u0000\u02f2\u02f4\u0005\"\u0000\u0000\u02f3\u02f5"+ - "\u0003\u00a0P\u0000\u02f4\u02f3\u0001\u0000\u0000\u0000\u02f4\u02f5\u0001"+ - "\u0000\u0000\u0000\u02f5\u02f6\u0001\u0000\u0000\u0000\u02f6\u02f7\u0005"+ - "P\u0000\u0000\u02f7\u02f8\u00034\u001a\u0000\u02f8\u02f9\u0005\u008d\u0000"+ - "\u0000\u02f9\u02fa\u0003\u00c0`\u0000\u02fa\u02fb\u0003`0\u0000\u02fb"+ - "\u009f\u0001\u0000\u0000\u0000\u02fc\u02ff\u0003B!\u0000\u02fd\u02ff\u0003"+ - "\u00acV\u0000\u02fe\u02fc\u0001\u0000\u0000\u0000\u02fe\u02fd\u0001\u0000"+ - "\u0000\u0000\u02ff\u00a1\u0001\u0000\u0000\u0000\u0300\u0301\u0006Q\uffff"+ - "\uffff\u0000\u0301\u0302\u0005M\u0000\u0000\u0302\u031e\u0003\u00a2Q\b"+ - "\u0303\u031e\u0003\u00a8T\u0000\u0304\u031e\u0003\u00a4R\u0000\u0305\u0307"+ - "\u0003\u00a8T\u0000\u0306\u0308\u0005M\u0000\u0000\u0307\u0306\u0001\u0000"+ - "\u0000\u0000\u0307\u0308\u0001\u0000\u0000\u0000\u0308\u0309\u0001\u0000"+ - "\u0000\u0000\u0309\u030a\u0005I\u0000\u0000\u030a\u030b\u0005i\u0000\u0000"+ - "\u030b\u0310\u0003\u00a8T\u0000\u030c\u030d\u0005D\u0000\u0000\u030d\u030f"+ - "\u0003\u00a8T\u0000\u030e\u030c\u0001\u0000\u0000\u0000\u030f\u0312\u0001"+ - "\u0000\u0000\u0000\u0310\u030e\u0001\u0000\u0000\u0000\u0310\u0311\u0001"+ - "\u0000\u0000\u0000\u0311\u0313\u0001\u0000\u0000\u0000\u0312\u0310\u0001"+ - "\u0000\u0000\u0000\u0313\u0314\u0005j\u0000\u0000\u0314\u031e\u0001\u0000"+ - "\u0000\u0000\u0315\u0316\u0003\u00a8T\u0000\u0316\u0318\u0005J\u0000\u0000"+ - "\u0317\u0319\u0005M\u0000\u0000\u0318\u0317\u0001\u0000\u0000\u0000\u0318"+ - "\u0319\u0001\u0000\u0000\u0000\u0319\u031a\u0001\u0000\u0000\u0000\u031a"+ - "\u031b\u0005N\u0000\u0000\u031b\u031e\u0001\u0000\u0000\u0000\u031c\u031e"+ - "\u0003\u00a6S\u0000\u031d\u0300\u0001\u0000\u0000\u0000\u031d\u0303\u0001"+ - "\u0000\u0000\u0000\u031d\u0304\u0001\u0000\u0000\u0000\u031d\u0305\u0001"+ - "\u0000\u0000\u0000\u031d\u0315\u0001\u0000\u0000\u0000\u031d\u031c\u0001"+ - "\u0000\u0000\u0000\u031e\u0327\u0001\u0000\u0000\u0000\u031f\u0320\n\u0005"+ - "\u0000\u0000\u0320\u0321\u0005=\u0000\u0000\u0321\u0326\u0003\u00a2Q\u0006"+ - "\u0322\u0323\n\u0004\u0000\u0000\u0323\u0324\u0005Q\u0000\u0000\u0324"+ - "\u0326\u0003\u00a2Q\u0005\u0325\u031f\u0001\u0000\u0000\u0000\u0325\u0322"+ - "\u0001\u0000\u0000\u0000\u0326\u0329\u0001\u0000\u0000\u0000\u0327\u0325"+ - "\u0001\u0000\u0000\u0000\u0327\u0328\u0001\u0000\u0000\u0000\u0328\u00a3"+ - "\u0001\u0000\u0000\u0000\u0329\u0327\u0001\u0000\u0000\u0000\u032a\u032c"+ - "\u0003\u00a8T\u0000\u032b\u032d\u0005M\u0000\u0000\u032c\u032b\u0001\u0000"+ - "\u0000\u0000\u032c\u032d\u0001\u0000\u0000\u0000\u032d\u032e\u0001\u0000"+ - "\u0000\u0000\u032e\u032f\u0005L\u0000\u0000\u032f\u0330\u0003H$\u0000"+ - "\u0330\u0359\u0001\u0000\u0000\u0000\u0331\u0333\u0003\u00a8T\u0000\u0332"+ - "\u0334\u0005M\u0000\u0000\u0333\u0332\u0001\u0000\u0000\u0000\u0333\u0334"+ - "\u0001\u0000\u0000\u0000\u0334\u0335\u0001\u0000\u0000\u0000\u0335\u0336"+ - "\u0005S\u0000\u0000\u0336\u0337\u0003H$\u0000\u0337\u0359\u0001\u0000"+ - "\u0000\u0000\u0338\u033a\u0003\u00a8T\u0000\u0339\u033b\u0005M\u0000\u0000"+ - "\u033a\u0339\u0001\u0000\u0000\u0000\u033a\u033b\u0001\u0000\u0000\u0000"+ - "\u033b\u033c\u0001\u0000\u0000\u0000\u033c\u033d\u0005L\u0000\u0000\u033d"+ - "\u033e\u0005i\u0000\u0000\u033e\u0343\u0003H$\u0000\u033f\u0340\u0005"+ - "D\u0000\u0000\u0340\u0342\u0003H$\u0000\u0341\u033f\u0001\u0000\u0000"+ - "\u0000\u0342\u0345\u0001\u0000\u0000\u0000\u0343\u0341\u0001\u0000\u0000"+ - "\u0000\u0343\u0344\u0001\u0000\u0000\u0000\u0344\u0346\u0001\u0000\u0000"+ - "\u0000\u0345\u0343\u0001\u0000\u0000\u0000\u0346\u0347\u0005j\u0000\u0000"+ - "\u0347\u0359\u0001\u0000\u0000\u0000\u0348\u034a\u0003\u00a8T\u0000\u0349"+ - "\u034b\u0005M\u0000\u0000\u034a\u0349\u0001\u0000\u0000\u0000\u034a\u034b"+ - "\u0001\u0000\u0000\u0000\u034b\u034c\u0001\u0000\u0000\u0000\u034c\u034d"+ - "\u0005S\u0000\u0000\u034d\u034e\u0005i\u0000\u0000\u034e\u0353\u0003H"+ - "$\u0000\u034f\u0350\u0005D\u0000\u0000\u0350\u0352\u0003H$\u0000\u0351"+ - "\u034f\u0001\u0000\u0000\u0000\u0352\u0355\u0001\u0000\u0000\u0000\u0353"+ - "\u0351\u0001\u0000\u0000\u0000\u0353\u0354\u0001\u0000\u0000\u0000\u0354"+ - "\u0356\u0001\u0000\u0000\u0000\u0355\u0353\u0001\u0000\u0000\u0000\u0356"+ - "\u0357\u0005j\u0000\u0000\u0357\u0359\u0001\u0000\u0000\u0000\u0358\u032a"+ - "\u0001\u0000\u0000\u0000\u0358\u0331\u0001\u0000\u0000\u0000\u0358\u0338"+ - "\u0001\u0000\u0000\u0000\u0358\u0348\u0001\u0000\u0000\u0000\u0359\u00a5"+ - "\u0001\u0000\u0000\u0000\u035a\u035d\u00034\u001a\u0000\u035b\u035c\u0005"+ - "A\u0000\u0000\u035c\u035e\u0003\f\u0006\u0000\u035d\u035b\u0001\u0000"+ - "\u0000\u0000\u035d\u035e\u0001\u0000\u0000\u0000\u035e\u035f\u0001\u0000"+ - "\u0000\u0000\u035f\u0360\u0005B\u0000\u0000\u0360\u0361\u0003\u00b8\\"+ - "\u0000\u0361\u00a7\u0001\u0000\u0000\u0000\u0362\u0368\u0003\u00aaU\u0000"+ - "\u0363\u0364\u0003\u00aaU\u0000\u0364\u0365\u0003\u00c4b\u0000\u0365\u0366"+ - "\u0003\u00aaU\u0000\u0366\u0368\u0001\u0000\u0000\u0000\u0367\u0362\u0001"+ - "\u0000\u0000\u0000\u0367\u0363\u0001\u0000\u0000\u0000\u0368\u00a9\u0001"+ - "\u0000\u0000\u0000\u0369\u036a\u0006U\uffff\uffff\u0000\u036a\u036e\u0003"+ - "\u00acV\u0000\u036b\u036c\u0007\u0005\u0000\u0000\u036c\u036e\u0003\u00aa"+ - "U\u0003\u036d\u0369\u0001\u0000\u0000\u0000\u036d\u036b\u0001\u0000\u0000"+ - "\u0000\u036e\u0377\u0001\u0000\u0000\u0000\u036f\u0370\n\u0002\u0000\u0000"+ - "\u0370\u0371\u0007\u0006\u0000\u0000\u0371\u0376\u0003\u00aaU\u0003\u0372"+ - "\u0373\n\u0001\u0000\u0000\u0373\u0374\u0007\u0005\u0000\u0000\u0374\u0376"+ - "\u0003\u00aaU\u0002\u0375\u036f\u0001\u0000\u0000\u0000\u0375\u0372\u0001"+ - "\u0000\u0000\u0000\u0376\u0379\u0001\u0000\u0000\u0000\u0377\u0375\u0001"+ - "\u0000\u0000\u0000\u0377\u0378\u0001\u0000\u0000\u0000\u0378\u00ab\u0001"+ - "\u0000\u0000\u0000\u0379\u0377\u0001\u0000\u0000\u0000\u037a\u037b\u0006"+ - "V\uffff\uffff\u0000\u037b\u0383\u0003\u00b8\\\u0000\u037c\u0383\u0003"+ - "4\u001a\u0000\u037d\u0383\u0003\u00aeW\u0000\u037e\u037f\u0005i\u0000"+ - "\u0000\u037f\u0380\u0003\u00a2Q\u0000\u0380\u0381\u0005j\u0000\u0000\u0381"+ - "\u0383\u0001\u0000\u0000\u0000\u0382\u037a\u0001\u0000\u0000\u0000\u0382"+ - "\u037c\u0001\u0000\u0000\u0000\u0382\u037d\u0001\u0000\u0000\u0000\u0382"+ - "\u037e\u0001\u0000\u0000\u0000\u0383\u0389\u0001\u0000\u0000\u0000\u0384"+ - "\u0385\n\u0001\u0000\u0000\u0385\u0386\u0005A\u0000\u0000\u0386\u0388"+ - "\u0003\f\u0006\u0000\u0387\u0384\u0001\u0000\u0000\u0000\u0388\u038b\u0001"+ - "\u0000\u0000\u0000\u0389\u0387\u0001\u0000\u0000\u0000\u0389\u038a\u0001"+ - "\u0000\u0000\u0000\u038a\u00ad\u0001\u0000\u0000\u0000\u038b\u0389\u0001"+ - "\u0000\u0000\u0000\u038c\u038d\u0003\u00b0X\u0000\u038d\u039b\u0005i\u0000"+ - "\u0000\u038e\u039c\u0005_\u0000\u0000\u038f\u0394\u0003\u00a2Q\u0000\u0390"+ - "\u0391\u0005D\u0000\u0000\u0391\u0393\u0003\u00a2Q\u0000\u0392\u0390\u0001"+ - "\u0000\u0000\u0000\u0393\u0396\u0001\u0000\u0000\u0000\u0394\u0392\u0001"+ - "\u0000\u0000\u0000\u0394\u0395\u0001\u0000\u0000\u0000\u0395\u0399\u0001"+ - "\u0000\u0000\u0000\u0396\u0394\u0001\u0000\u0000\u0000\u0397\u0398\u0005"+ - "D\u0000\u0000\u0398\u039a\u0003\u00b2Y\u0000\u0399\u0397\u0001\u0000\u0000"+ - "\u0000\u0399\u039a\u0001\u0000\u0000\u0000\u039a\u039c\u0001\u0000\u0000"+ - "\u0000\u039b\u038e\u0001\u0000\u0000\u0000\u039b\u038f\u0001\u0000\u0000"+ - "\u0000\u039b\u039c\u0001\u0000\u0000\u0000\u039c\u039d\u0001\u0000\u0000"+ - "\u0000\u039d\u039e\u0005j\u0000\u0000\u039e\u00af\u0001\u0000\u0000\u0000"+ - "\u039f\u03a3\u0003F#\u0000\u03a0\u03a3\u0005H\u0000\u0000\u03a1\u03a3"+ - "\u0005K\u0000\u0000\u03a2\u039f\u0001\u0000\u0000\u0000\u03a2\u03a0\u0001"+ - "\u0000\u0000\u0000\u03a2\u03a1\u0001\u0000\u0000\u0000\u03a3\u00b1\u0001"+ - "\u0000\u0000\u0000\u03a4\u03ad\u0005b\u0000\u0000\u03a5\u03aa\u0003\u00b4"+ - "Z\u0000\u03a6\u03a7\u0005D\u0000\u0000\u03a7\u03a9\u0003\u00b4Z\u0000"+ - "\u03a8\u03a6\u0001\u0000\u0000\u0000\u03a9\u03ac\u0001\u0000\u0000\u0000"+ - "\u03aa\u03a8\u0001\u0000\u0000\u0000\u03aa\u03ab\u0001\u0000\u0000\u0000"+ - "\u03ab\u03ae\u0001\u0000\u0000\u0000\u03ac\u03aa\u0001\u0000\u0000\u0000"+ - "\u03ad\u03a5\u0001\u0000\u0000\u0000\u03ad\u03ae\u0001\u0000\u0000\u0000"+ - "\u03ae\u03af\u0001\u0000\u0000\u0000\u03af\u03b0\u0005c\u0000\u0000\u03b0"+ - "\u00b3\u0001\u0000\u0000\u0000\u03b1\u03b2\u0003\u00c2a\u0000\u03b2\u03b3"+ - "\u0005B\u0000\u0000\u03b3\u03b4\u0003\u00b6[\u0000\u03b4\u00b5\u0001\u0000"+ - "\u0000\u0000\u03b5\u03b8\u0003\u00b8\\\u0000\u03b6\u03b8\u0003\u00b2Y"+ - "\u0000\u03b7\u03b5\u0001\u0000\u0000\u0000\u03b7\u03b6\u0001\u0000\u0000"+ - "\u0000\u03b8\u00b7\u0001\u0000\u0000\u0000\u03b9\u03e4\u0005N\u0000\u0000"+ - "\u03ba\u03bb\u0003\u00c0`\u0000\u03bb\u03bc\u0005k\u0000\u0000\u03bc\u03e4"+ - "\u0001\u0000\u0000\u0000\u03bd\u03e4\u0003\u00be_\u0000\u03be\u03e4\u0003"+ - "\u00c0`\u0000\u03bf\u03e4\u0003\u00ba]\u0000\u03c0\u03e4\u0003B!\u0000"+ - "\u03c1\u03e4\u0003\u00c2a\u0000\u03c2\u03c3\u0005g\u0000\u0000\u03c3\u03c8"+ - "\u0003\u00bc^\u0000\u03c4\u03c5\u0005D\u0000\u0000\u03c5\u03c7\u0003\u00bc"+ - "^\u0000\u03c6\u03c4\u0001\u0000\u0000\u0000\u03c7\u03ca\u0001\u0000\u0000"+ - "\u0000\u03c8\u03c6\u0001\u0000\u0000\u0000\u03c8\u03c9\u0001\u0000\u0000"+ - "\u0000\u03c9\u03cb\u0001\u0000\u0000\u0000\u03ca\u03c8\u0001\u0000\u0000"+ - "\u0000\u03cb\u03cc\u0005h\u0000\u0000\u03cc\u03e4\u0001\u0000\u0000\u0000"+ - "\u03cd\u03ce\u0005g\u0000\u0000\u03ce\u03d3\u0003\u00ba]\u0000\u03cf\u03d0"+ - "\u0005D\u0000\u0000\u03d0\u03d2\u0003\u00ba]\u0000\u03d1\u03cf\u0001\u0000"+ - "\u0000\u0000\u03d2\u03d5\u0001\u0000\u0000\u0000\u03d3\u03d1\u0001\u0000"+ - "\u0000\u0000\u03d3\u03d4\u0001\u0000\u0000\u0000\u03d4\u03d6\u0001\u0000"+ - "\u0000\u0000\u03d5\u03d3\u0001\u0000\u0000\u0000\u03d6\u03d7\u0005h\u0000"+ - "\u0000\u03d7\u03e4\u0001\u0000\u0000\u0000\u03d8\u03d9\u0005g\u0000\u0000"+ - "\u03d9\u03de\u0003\u00c2a\u0000\u03da\u03db\u0005D\u0000\u0000\u03db\u03dd"+ - "\u0003\u00c2a\u0000\u03dc\u03da\u0001\u0000\u0000\u0000\u03dd\u03e0\u0001"+ - "\u0000\u0000\u0000\u03de\u03dc\u0001\u0000\u0000\u0000\u03de\u03df\u0001"+ - "\u0000\u0000\u0000\u03df\u03e1\u0001\u0000\u0000\u0000\u03e0\u03de\u0001"+ - "\u0000\u0000\u0000\u03e1\u03e2\u0005h\u0000\u0000\u03e2\u03e4\u0001\u0000"+ - "\u0000\u0000\u03e3\u03b9\u0001\u0000\u0000\u0000\u03e3\u03ba\u0001\u0000"+ - "\u0000\u0000\u03e3\u03bd\u0001\u0000\u0000\u0000\u03e3\u03be\u0001\u0000"+ - "\u0000\u0000\u03e3\u03bf\u0001\u0000\u0000\u0000\u03e3\u03c0\u0001\u0000"+ - "\u0000\u0000\u03e3\u03c1\u0001\u0000\u0000\u0000\u03e3\u03c2\u0001\u0000"+ - "\u0000\u0000\u03e3\u03cd\u0001\u0000\u0000\u0000\u03e3\u03d8\u0001\u0000"+ - "\u0000\u0000\u03e4\u00b9\u0001\u0000\u0000\u0000\u03e5\u03e6\u0007\u0007"+ - "\u0000\u0000\u03e6\u00bb\u0001\u0000\u0000\u0000\u03e7\u03ea\u0003\u00be"+ - "_\u0000\u03e8\u03ea\u0003\u00c0`\u0000\u03e9\u03e7\u0001\u0000\u0000\u0000"+ - "\u03e9\u03e8\u0001\u0000\u0000\u0000\u03ea\u00bd\u0001\u0000\u0000\u0000"+ - "\u03eb\u03ed\u0007\u0005\u0000\u0000\u03ec\u03eb\u0001\u0000\u0000\u0000"+ - "\u03ec\u03ed\u0001\u0000\u0000\u0000\u03ed\u03ee\u0001\u0000\u0000\u0000"+ - "\u03ee\u03ef\u0005<\u0000\u0000\u03ef\u00bf\u0001\u0000\u0000\u0000\u03f0"+ - "\u03f2\u0007\u0005\u0000\u0000\u03f1\u03f0\u0001\u0000\u0000\u0000\u03f1"+ - "\u03f2\u0001\u0000\u0000\u0000\u03f2\u03f3\u0001\u0000\u0000\u0000\u03f3"+ - "\u03f4\u0005;\u0000\u0000\u03f4\u00c1\u0001\u0000\u0000\u0000\u03f5\u03f6"+ - "\u0005:\u0000\u0000\u03f6\u00c3\u0001\u0000\u0000\u0000\u03f7\u03f8\u0007"+ - "\b\u0000\u0000\u03f8\u00c5\u0001\u0000\u0000\u0000\u03f9\u03fa\u0007\t"+ - "\u0000\u0000\u03fa\u03fb\u0005\u0082\u0000\u0000\u03fb\u03fc\u0003\u00c8"+ - "d\u0000\u03fc\u03fd\u0003\u00cae\u0000\u03fd\u00c7\u0001\u0000\u0000\u0000"+ - "\u03fe\u03ff\u0004d\u000f\u0000\u03ff\u0401\u0003 \u0010\u0000\u0400\u0402"+ - "\u0005\u009e\u0000\u0000\u0401\u0400\u0001\u0000\u0000\u0000\u0401\u0402"+ - "\u0001\u0000\u0000\u0000\u0402\u0403\u0001\u0000\u0000\u0000\u0403\u0404"+ - "\u0005q\u0000\u0000\u0404\u0407\u0001\u0000\u0000\u0000\u0405\u0407\u0003"+ - " \u0010\u0000\u0406\u03fe\u0001\u0000\u0000\u0000\u0406\u0405\u0001\u0000"+ - "\u0000\u0000\u0407\u00c9\u0001\u0000\u0000\u0000\u0408\u0409\u0005P\u0000"+ - "\u0000\u0409\u040e\u0003\u00a2Q\u0000\u040a\u040b\u0005D\u0000\u0000\u040b"+ - "\u040d\u0003\u00a2Q\u0000\u040c\u040a\u0001\u0000\u0000\u0000\u040d\u0410"+ - "\u0001\u0000\u0000\u0000\u040e\u040c\u0001\u0000\u0000\u0000\u040e\u040f"+ - "\u0001\u0000\u0000\u0000\u040f\u00cb\u0001\u0000\u0000\u0000\u0410\u040e"+ - "\u0001\u0000\u0000\u0000\u0411\u0415\u0005\'\u0000\u0000\u0412\u0414\u0003"+ - "\u00d0h\u0000\u0413\u0412\u0001\u0000\u0000\u0000\u0414\u0417\u0001\u0000"+ - "\u0000\u0000\u0415\u0413\u0001\u0000\u0000\u0000\u0415\u0416\u0001\u0000"+ - "\u0000\u0000\u0416\u041b\u0001\u0000\u0000\u0000\u0417\u0415\u0001\u0000"+ - "\u0000\u0000\u0418\u0419\u0003\u00ceg\u0000\u0419\u041a\u0005?\u0000\u0000"+ - "\u041a\u041c\u0001\u0000\u0000\u0000\u041b\u0418\u0001\u0000\u0000\u0000"+ - "\u041b\u041c\u0001\u0000\u0000\u0000\u041c\u041d\u0001\u0000\u0000\u0000"+ - "\u041d\u041e\u0005i\u0000\u0000\u041e\u041f\u0005e\u0000\u0000\u041f\u044e"+ - "\u0005j\u0000\u0000\u0420\u0424\u0005\'\u0000\u0000\u0421\u0423\u0003"+ - "\u00d0h\u0000\u0422\u0421\u0001\u0000\u0000\u0000\u0423\u0426\u0001\u0000"+ - "\u0000\u0000\u0424\u0422\u0001\u0000\u0000\u0000\u0424\u0425\u0001\u0000"+ - "\u0000\u0000\u0425\u042a\u0001\u0000\u0000\u0000\u0426\u0424\u0001\u0000"+ - "\u0000\u0000\u0427\u0428\u0003\u00ceg\u0000\u0428\u0429\u0005?\u0000\u0000"+ - "\u0429\u042b\u0001\u0000\u0000\u0000\u042a\u0427\u0001\u0000\u0000\u0000"+ - "\u042a\u042b\u0001\u0000\u0000\u0000\u042b\u042c\u0001\u0000\u0000\u0000"+ - "\u042c\u044e\u0005e\u0000\u0000\u042d\u0431\u0005\'\u0000\u0000\u042e"+ - "\u0430\u0003\u00d0h\u0000\u042f\u042e\u0001\u0000\u0000\u0000\u0430\u0433"+ - "\u0001\u0000\u0000\u0000\u0431\u042f\u0001\u0000\u0000\u0000\u0431\u0432"+ - "\u0001\u0000\u0000\u0000\u0432\u0437\u0001\u0000\u0000\u0000\u0433\u0431"+ - "\u0001\u0000\u0000\u0000\u0434\u0435\u0003\u00ceg\u0000\u0435\u0436\u0005"+ - "?\u0000\u0000\u0436\u0438\u0001\u0000\u0000\u0000\u0437\u0434\u0001\u0000"+ - "\u0000\u0000\u0437\u0438\u0001\u0000\u0000\u0000\u0438\u0439\u0001\u0000"+ - "\u0000\u0000\u0439\u043b\u0005i\u0000\u0000\u043a\u043c\u0003\u00d8l\u0000"+ - "\u043b\u043a\u0001\u0000\u0000\u0000\u043c\u043d\u0001\u0000\u0000\u0000"+ - "\u043d\u043b\u0001\u0000\u0000\u0000\u043d\u043e\u0001\u0000\u0000\u0000"+ - "\u043e\u043f\u0001\u0000\u0000\u0000\u043f\u0440\u0005j\u0000\u0000\u0440"+ - "\u044e\u0001\u0000\u0000\u0000\u0441\u0445\u0005\'\u0000\u0000\u0442\u0444"+ - "\u0003\u00d0h\u0000\u0443\u0442\u0001\u0000\u0000\u0000\u0444\u0447\u0001"+ - "\u0000\u0000\u0000\u0445\u0443\u0001\u0000\u0000\u0000\u0445\u0446\u0001"+ - "\u0000\u0000\u0000\u0446\u0449\u0001\u0000\u0000\u0000\u0447\u0445\u0001"+ - "\u0000\u0000\u0000\u0448\u044a\u0003\u00d8l\u0000\u0449\u0448\u0001\u0000"+ - "\u0000\u0000\u044a\u044b\u0001\u0000\u0000\u0000\u044b\u0449\u0001\u0000"+ - "\u0000\u0000\u044b\u044c\u0001\u0000\u0000\u0000\u044c\u044e\u0001\u0000"+ - "\u0000\u0000\u044d\u0411\u0001\u0000\u0000\u0000\u044d\u0420\u0001\u0000"+ - "\u0000\u0000\u044d\u042d\u0001\u0000\u0000\u0000\u044d\u0441\u0001\u0000"+ - "\u0000\u0000\u044e\u00cd\u0001\u0000\u0000\u0000\u044f\u0450\u0007\u0001"+ - "\u0000\u0000\u0450\u00cf\u0001\u0000\u0000\u0000\u0451\u0452\u0003\u00d2"+ - "i\u0000\u0452\u0453\u0005?\u0000\u0000\u0453\u0454\u0003\u00d4j\u0000"+ - "\u0454\u00d1\u0001\u0000\u0000\u0000\u0455\u0456\u0007\n\u0000\u0000\u0456"+ - "\u00d3\u0001\u0000\u0000\u0000\u0457\u045c\u0003\u00dam\u0000\u0458\u0459"+ - "\u0005D\u0000\u0000\u0459\u045b\u0003\u00dam\u0000\u045a\u0458\u0001\u0000"+ - "\u0000\u0000\u045b\u045e\u0001\u0000\u0000\u0000\u045c\u045a\u0001\u0000"+ - "\u0000\u0000\u045c\u045d\u0001\u0000\u0000\u0000\u045d\u0462\u0001\u0000"+ - "\u0000\u0000\u045e\u045c\u0001\u0000\u0000\u0000\u045f\u0462\u0005l\u0000"+ - "\u0000\u0460\u0462\u0005e\u0000\u0000\u0461\u0457\u0001\u0000\u0000\u0000"+ - "\u0461\u045f\u0001\u0000\u0000\u0000\u0461\u0460\u0001\u0000\u0000\u0000"+ - "\u0462\u00d5\u0001\u0000\u0000\u0000\u0463\u0464\u0007\u000b\u0000\u0000"+ - "\u0464\u00d7\u0001\u0000\u0000\u0000\u0465\u0467\u0003\u00d6k\u0000\u0466"+ - "\u0465\u0001\u0000\u0000\u0000\u0467\u0468\u0001\u0000\u0000\u0000\u0468"+ - "\u0466\u0001\u0000\u0000\u0000\u0468\u0469\u0001\u0000\u0000\u0000\u0469"+ - "\u0473\u0001\u0000\u0000\u0000\u046a\u046e\u0005i\u0000\u0000\u046b\u046d"+ - "\u0003\u00d8l\u0000\u046c\u046b\u0001\u0000\u0000\u0000\u046d\u0470\u0001"+ - "\u0000\u0000\u0000\u046e\u046c\u0001\u0000\u0000\u0000\u046e\u046f\u0001"+ - "\u0000\u0000\u0000\u046f\u0471\u0001\u0000\u0000\u0000\u0470\u046e\u0001"+ - "\u0000\u0000\u0000\u0471\u0473\u0005j\u0000\u0000\u0472\u0466\u0001\u0000"+ - "\u0000\u0000\u0472\u046a\u0001\u0000\u0000\u0000\u0473\u00d9\u0001\u0000"+ - "\u0000\u0000\u0474\u0475\u0003\u00dcn\u0000\u0475\u0476\u0005B\u0000\u0000"+ - "\u0476\u0477\u0003\u00e0p\u0000\u0477\u047e\u0001\u0000\u0000\u0000\u0478"+ - "\u0479\u0003\u00e0p\u0000\u0479\u047a\u0005A\u0000\u0000\u047a\u047b\u0003"+ - "\u00deo\u0000\u047b\u047e\u0001\u0000\u0000\u0000\u047c\u047e\u0003\u00e2"+ - "q\u0000\u047d\u0474\u0001\u0000\u0000\u0000\u047d\u0478\u0001\u0000\u0000"+ - "\u0000\u047d\u047c\u0001\u0000\u0000\u0000\u047e\u00db\u0001\u0000\u0000"+ - "\u0000\u047f\u0480\u0007\f\u0000\u0000\u0480\u00dd\u0001\u0000\u0000\u0000"+ - "\u0481\u0482\u0007\f\u0000\u0000\u0482\u00df\u0001\u0000\u0000\u0000\u0483"+ - "\u0484\u0007\f\u0000\u0000\u0484\u00e1\u0001\u0000\u0000\u0000\u0485\u0486"+ - "\u0007\r\u0000\u0000\u0486\u00e3\u0001\u0000\u0000\u0000r\u00e7\u00f8"+ - "\u0104\u0123\u0132\u0138\u014b\u014f\u0154\u015c\u0164\u0169\u016c\u017c"+ - "\u0184\u0188\u018f\u0195\u019a\u01a3\u01aa\u01b0\u01b9\u01c0\u01c8\u01d0"+ - "\u01d4\u01d8\u01dd\u01e1\u01e6\u01ef\u01f8\u01fd\u0201\u020f\u021a\u0220"+ - "\u0227\u0230\u0239\u024d\u0255\u0258\u025f\u026b\u0275\u027d\u028b\u0294"+ - "\u029f\u02a9\u02af\u02b1\u02b5\u02ba\u02c8\u02cf\u02f0\u02f4\u02fe\u0307"+ - "\u0310\u0318\u031d\u0325\u0327\u032c\u0333\u033a\u0343\u034a\u0353\u0358"+ - "\u035d\u0367\u036d\u0375\u0377\u0382\u0389\u0394\u0399\u039b\u03a2\u03aa"+ - "\u03ad\u03b7\u03c8\u03d3\u03de\u03e3\u03e9\u03ec\u03f1\u0401\u0406\u040e"+ - "\u0415\u041b\u0424\u042a\u0431\u0437\u043d\u0445\u044b\u044d\u045c\u0461"+ - "\u0468\u046e\u0472\u047d"; + "\u01e7K\u0001\u0000\u0000\u0000\u01e8\u01e9\u0005@\u0000\u0000\u01e9\u01ee"+ + "\u0003\u00a2Q\u0000\u01ea\u01eb\u0005D\u0000\u0000\u01eb\u01ed\u0003\u00a2"+ + "Q\u0000\u01ec\u01ea\u0001\u0000\u0000\u0000\u01ed\u01f0\u0001\u0000\u0000"+ + "\u0000\u01ee\u01ec\u0001\u0000\u0000\u0000\u01ee\u01ef\u0001\u0000\u0000"+ + "\u0000\u01efM\u0001\u0000\u0000\u0000\u01f0\u01ee\u0001\u0000\u0000\u0000"+ + "\u01f1\u01f2\u0005\u000f\u0000\u0000\u01f2\u01f7\u0003P(\u0000\u01f3\u01f4"+ + "\u0005D\u0000\u0000\u01f4\u01f6\u0003P(\u0000\u01f5\u01f3\u0001\u0000"+ + "\u0000\u0000\u01f6\u01f9\u0001\u0000\u0000\u0000\u01f7\u01f5\u0001\u0000"+ + "\u0000\u0000\u01f7\u01f8\u0001\u0000\u0000\u0000\u01f8O\u0001\u0000\u0000"+ + "\u0000\u01f9\u01f7\u0001\u0000\u0000\u0000\u01fa\u01fc\u0003\u00a2Q\u0000"+ + "\u01fb\u01fd\u0007\u0002\u0000\u0000\u01fc\u01fb\u0001\u0000\u0000\u0000"+ + "\u01fc\u01fd\u0001\u0000\u0000\u0000\u01fd\u0200\u0001\u0000\u0000\u0000"+ + "\u01fe\u01ff\u0005O\u0000\u0000\u01ff\u0201\u0007\u0003\u0000\u0000\u0200"+ + "\u01fe\u0001\u0000\u0000\u0000\u0200\u0201\u0001\u0000\u0000\u0000\u0201"+ + "Q\u0001\u0000\u0000\u0000\u0202\u0203\u0005%\u0000\u0000\u0203\u0204\u0003"+ + "<\u001e\u0000\u0204S\u0001\u0000\u0000\u0000\u0205\u0206\u0005$\u0000"+ + "\u0000\u0206\u0207\u0003<\u001e\u0000\u0207U\u0001\u0000\u0000\u0000\u0208"+ + "\u0209\u0005(\u0000\u0000\u0209\u020e\u0003X,\u0000\u020a\u020b\u0005"+ + "D\u0000\u0000\u020b\u020d\u0003X,\u0000\u020c\u020a\u0001\u0000\u0000"+ + "\u0000\u020d\u0210\u0001\u0000\u0000\u0000\u020e\u020c\u0001\u0000\u0000"+ + "\u0000\u020e\u020f\u0001\u0000\u0000\u0000\u020fW\u0001\u0000\u0000\u0000"+ + "\u0210\u020e\u0001\u0000\u0000\u0000\u0211\u0212\u00038\u001c\u0000\u0212"+ + "\u0213\u0005\u009e\u0000\u0000\u0213\u0214\u00038\u001c\u0000\u0214\u021a"+ + "\u0001\u0000\u0000\u0000\u0215\u0216\u00038\u001c\u0000\u0216\u0217\u0005"+ + "?\u0000\u0000\u0217\u0218\u00038\u001c\u0000\u0218\u021a\u0001\u0000\u0000"+ + "\u0000\u0219\u0211\u0001\u0000\u0000\u0000\u0219\u0215\u0001\u0000\u0000"+ + "\u0000\u021aY\u0001\u0000\u0000\u0000\u021b\u021c\u0005\b\u0000\u0000"+ + "\u021c\u021d\u0003\u00acV\u0000\u021d\u021f\u0003\u00c2a\u0000\u021e\u0220"+ + "\u0003\\.\u0000\u021f\u021e\u0001\u0000\u0000\u0000\u021f\u0220\u0001"+ + "\u0000\u0000\u0000\u0220[\u0001\u0000\u0000\u0000\u0221\u0226\u0003^/"+ + "\u0000\u0222\u0223\u0005D\u0000\u0000\u0223\u0225\u0003^/\u0000\u0224"+ + "\u0222\u0001\u0000\u0000\u0000\u0225\u0228\u0001\u0000\u0000\u0000\u0226"+ + "\u0224\u0001\u0000\u0000\u0000\u0226\u0227\u0001\u0000\u0000\u0000\u0227"+ + "]\u0001\u0000\u0000\u0000\u0228\u0226\u0001\u0000\u0000\u0000\u0229\u022a"+ + "\u0003>\u001f\u0000\u022a\u022b\u0005?\u0000\u0000\u022b\u022c\u0003\u00b8"+ + "\\\u0000\u022c_\u0001\u0000\u0000\u0000\u022d\u022e\u0005U\u0000\u0000"+ + "\u022e\u0230\u0003\u00b2Y\u0000\u022f\u022d\u0001\u0000\u0000\u0000\u022f"+ + "\u0230\u0001\u0000\u0000\u0000\u0230a\u0001\u0000\u0000\u0000\u0231\u0232"+ + "\u0005\n\u0000\u0000\u0232\u0233\u0003\u00acV\u0000\u0233\u0238\u0003"+ + "\u00c2a\u0000\u0234\u0235\u0005D\u0000\u0000\u0235\u0237\u0003\u00c2a"+ + "\u0000\u0236\u0234\u0001\u0000\u0000\u0000\u0237\u023a\u0001\u0000\u0000"+ + "\u0000\u0238\u0236\u0001\u0000\u0000\u0000\u0238\u0239\u0001\u0000\u0000"+ + "\u0000\u0239c\u0001\u0000\u0000\u0000\u023a\u0238\u0001\u0000\u0000\u0000"+ + "\u023b\u023c\u0005#\u0000\u0000\u023c\u023d\u00034\u001a\u0000\u023de"+ + "\u0001\u0000\u0000\u0000\u023e\u023f\u0005\u0006\u0000\u0000\u023f\u0240"+ + "\u0003h4\u0000\u0240g\u0001\u0000\u0000\u0000\u0241\u0242\u0005i\u0000"+ + "\u0000\u0242\u0243\u0003\u0004\u0002\u0000\u0243\u0244\u0005j\u0000\u0000"+ + "\u0244i\u0001\u0000\u0000\u0000\u0245\u0246\u0005*\u0000\u0000\u0246\u0247"+ + "\u0005\u00a5\u0000\u0000\u0247k\u0001\u0000\u0000\u0000\u0248\u0249\u0005"+ + "\u0005\u0000\u0000\u0249\u024c\u0003n7\u0000\u024a\u024b\u0005P\u0000"+ + "\u0000\u024b\u024d\u00038\u001c\u0000\u024c\u024a\u0001\u0000\u0000\u0000"+ + "\u024c\u024d\u0001\u0000\u0000\u0000\u024d\u0257\u0001\u0000\u0000\u0000"+ + "\u024e\u024f\u0005U\u0000\u0000\u024f\u0254\u0003p8\u0000\u0250\u0251"+ + "\u0005D\u0000\u0000\u0251\u0253\u0003p8\u0000\u0252\u0250\u0001\u0000"+ + "\u0000\u0000\u0253\u0256\u0001\u0000\u0000\u0000\u0254\u0252\u0001\u0000"+ + "\u0000\u0000\u0254\u0255\u0001\u0000\u0000\u0000\u0255\u0258\u0001\u0000"+ + "\u0000\u0000\u0256\u0254\u0001\u0000\u0000\u0000\u0257\u024e\u0001\u0000"+ + "\u0000\u0000\u0257\u0258\u0001\u0000\u0000\u0000\u0258m\u0001\u0000\u0000"+ + "\u0000\u0259\u025a\u0007\u0004\u0000\u0000\u025ao\u0001\u0000\u0000\u0000"+ + "\u025b\u025c\u00038\u001c\u0000\u025c\u025d\u0005?\u0000\u0000\u025d\u025f"+ + "\u0001\u0000\u0000\u0000\u025e\u025b\u0001\u0000\u0000\u0000\u025e\u025f"+ + "\u0001\u0000\u0000\u0000\u025f\u0260\u0001\u0000\u0000\u0000\u0260\u0261"+ + "\u00038\u001c\u0000\u0261q\u0001\u0000\u0000\u0000\u0262\u0263\u0005\u000e"+ + "\u0000\u0000\u0263\u0264\u0003\u00b8\\\u0000\u0264s\u0001\u0000\u0000"+ + "\u0000\u0265\u0266\u0005\u0004\u0000\u0000\u0266\u026a\u00034\u001a\u0000"+ + "\u0267\u0269\u0003v;\u0000\u0268\u0267\u0001\u0000\u0000\u0000\u0269\u026c"+ + "\u0001\u0000\u0000\u0000\u026a\u0268\u0001\u0000\u0000\u0000\u026a\u026b"+ + "\u0001\u0000\u0000\u0000\u026bu\u0001\u0000\u0000\u0000\u026c\u026a\u0001"+ + "\u0000\u0000\u0000\u026d\u026e\u0005P\u0000\u0000\u026e\u0275\u00034\u001a"+ + "\u0000\u026f\u0270\u0005\u009e\u0000\u0000\u0270\u0271\u00034\u001a\u0000"+ + "\u0271\u0272\u0005D\u0000\u0000\u0272\u0273\u00034\u001a\u0000\u0273\u0275"+ + "\u0001\u0000\u0000\u0000\u0274\u026d\u0001\u0000\u0000\u0000\u0274\u026f"+ + "\u0001\u0000\u0000\u0000\u0275w\u0001\u0000\u0000\u0000\u0276\u0277\u0005"+ + "\u0019\u0000\u0000\u0277\u0278\u0003z=\u0000\u0278y\u0001\u0000\u0000"+ + "\u0000\u0279\u027b\u0003|>\u0000\u027a\u0279\u0001\u0000\u0000\u0000\u027b"+ + "\u027c\u0001\u0000\u0000\u0000\u027c\u027a\u0001\u0000\u0000\u0000\u027c"+ + "\u027d\u0001\u0000\u0000\u0000\u027d{\u0001\u0000\u0000\u0000\u027e\u027f"+ + "\u0005i\u0000\u0000\u027f\u0280\u0003~?\u0000\u0280\u0281\u0005j\u0000"+ + "\u0000\u0281}\u0001\u0000\u0000\u0000\u0282\u0283\u0006?\uffff\uffff\u0000"+ + "\u0283\u0284\u0003\u0080@\u0000\u0284\u028a\u0001\u0000\u0000\u0000\u0285"+ + "\u0286\n\u0001\u0000\u0000\u0286\u0287\u00059\u0000\u0000\u0287\u0289"+ + "\u0003\u0080@\u0000\u0288\u0285\u0001\u0000\u0000\u0000\u0289\u028c\u0001"+ + "\u0000\u0000\u0000\u028a\u0288\u0001\u0000\u0000\u0000\u028a\u028b\u0001"+ + "\u0000\u0000\u0000\u028b\u007f\u0001\u0000\u0000\u0000\u028c\u028a\u0001"+ + "\u0000\u0000\u0000\u028d\u028e\u0003\b\u0004\u0000\u028e\u0081\u0001\u0000"+ + "\u0000\u0000\u028f\u0293\u0005\f\u0000\u0000\u0290\u0291\u00034\u001a"+ + "\u0000\u0291\u0292\u0005?\u0000\u0000\u0292\u0294\u0001\u0000\u0000\u0000"+ + "\u0293\u0290\u0001\u0000\u0000\u0000\u0293\u0294\u0001\u0000\u0000\u0000"+ + "\u0294\u0295\u0001\u0000\u0000\u0000\u0295\u0296\u0003\u00b8\\\u0000\u0296"+ + "\u0297\u0005P\u0000\u0000\u0297\u0298\u0003\u0010\b\u0000\u0298\u0299"+ + "\u0003`0\u0000\u0299\u0083\u0001\u0000\u0000\u0000\u029a\u029e\u0005\u0007"+ + "\u0000\u0000\u029b\u029c\u00034\u001a\u0000\u029c\u029d\u0005?\u0000\u0000"+ + "\u029d\u029f\u0001\u0000\u0000\u0000\u029e\u029b\u0001\u0000\u0000\u0000"+ + "\u029e\u029f\u0001\u0000\u0000\u0000\u029f\u02a0\u0001\u0000\u0000\u0000"+ + "\u02a0\u02a1\u0003\u00acV\u0000\u02a1\u02a2\u0003`0\u0000\u02a2\u0085"+ + "\u0001\u0000\u0000\u0000\u02a3\u02a4\u0005\u001b\u0000\u0000\u02a4\u02a5"+ + "\u0005~\u0000\u0000\u02a5\u02a8\u00030\u0018\u0000\u02a6\u02a7\u0005@"+ + "\u0000\u0000\u02a7\u02a9\u0003\u0010\b\u0000\u02a8\u02a6\u0001\u0000\u0000"+ + "\u0000\u02a8\u02a9\u0001\u0000\u0000\u0000\u02a9\u02b1\u0001\u0000\u0000"+ + "\u0000\u02aa\u02ab\u0005\u001c\u0000\u0000\u02ab\u02ae\u00030\u0018\u0000"+ + "\u02ac\u02ad\u0005@\u0000\u0000\u02ad\u02af\u0003\u0010\b\u0000\u02ae"+ + "\u02ac\u0001\u0000\u0000\u0000\u02ae\u02af\u0001\u0000\u0000\u0000\u02af"+ + "\u02b1\u0001\u0000\u0000\u0000\u02b0\u02a3\u0001\u0000\u0000\u0000\u02b0"+ + "\u02aa\u0001\u0000\u0000\u0000\u02b1\u0087\u0001\u0000\u0000\u0000\u02b2"+ + "\u02b4\u0005\u001a\u0000\u0000\u02b3\u02b5\u0003>\u001f\u0000\u02b4\u02b3"+ + "\u0001\u0000\u0000\u0000\u02b4\u02b5\u0001\u0000\u0000\u0000\u02b5\u02b9"+ + "\u0001\u0000\u0000\u0000\u02b6\u02b8\u0003\u008aE\u0000\u02b7\u02b6\u0001"+ + "\u0000\u0000\u0000\u02b8\u02bb\u0001\u0000\u0000\u0000\u02b9\u02b7\u0001"+ + "\u0000\u0000\u0000\u02b9\u02ba\u0001\u0000\u0000\u0000\u02ba\u0089\u0001"+ + "\u0000\u0000\u0000\u02bb\u02b9\u0001\u0000\u0000\u0000\u02bc\u02bd\u0005"+ + "y\u0000\u0000\u02bd\u02be\u0005@\u0000\u0000\u02be\u02c8\u00034\u001a"+ + "\u0000\u02bf\u02c0\u0005z\u0000\u0000\u02c0\u02c1\u0005@\u0000\u0000\u02c1"+ + "\u02c8\u0003\u008cF\u0000\u02c2\u02c3\u0005x\u0000\u0000\u02c3\u02c4\u0005"+ + "@\u0000\u0000\u02c4\u02c8\u00034\u001a\u0000\u02c5\u02c6\u0005U\u0000"+ + "\u0000\u02c6\u02c8\u0003\u00b2Y\u0000\u02c7\u02bc\u0001\u0000\u0000\u0000"+ + "\u02c7\u02bf\u0001\u0000\u0000\u0000\u02c7\u02c2\u0001\u0000\u0000\u0000"+ + "\u02c7\u02c5\u0001\u0000\u0000\u0000\u02c8\u008b\u0001\u0000\u0000\u0000"+ + "\u02c9\u02ce\u00034\u001a\u0000\u02ca\u02cb\u0005D\u0000\u0000\u02cb\u02cd"+ + "\u00034\u001a\u0000\u02cc\u02ca\u0001\u0000\u0000\u0000\u02cd\u02d0\u0001"+ + "\u0000\u0000\u0000\u02ce\u02cc\u0001\u0000\u0000\u0000\u02ce\u02cf\u0001"+ + "\u0000\u0000\u0000\u02cf\u008d\u0001\u0000\u0000\u0000\u02d0\u02ce\u0001"+ + "\u0000\u0000\u0000\u02d1\u02d2\u0005\u0013\u0000\u0000\u02d2\u008f\u0001"+ + "\u0000\u0000\u0000\u02d3\u02d4\u0005\u0015\u0000\u0000\u02d4\u0091\u0001"+ + "\u0000\u0000\u0000\u02d5\u02d6\u0005!\u0000\u0000\u02d6\u02d7\u0003 \u0010"+ + "\u0000\u02d7\u02d8\u0005P\u0000\u0000\u02d8\u02d9\u0003<\u001e\u0000\u02d9"+ + "\u0093\u0001\u0000\u0000\u0000\u02da\u02db\u0005&\u0000\u0000\u02db\u02dc"+ + "\u0003<\u001e\u0000\u02dc\u0095\u0001\u0000\u0000\u0000\u02dd\u02de\u0005"+ + "\u0012\u0000\u0000\u02de\u02df\u00034\u001a\u0000\u02df\u02e0\u0005?\u0000"+ + "\u0000\u02e0\u02e1\u0003\u00acV\u0000\u02e1\u0097\u0001\u0000\u0000\u0000"+ + "\u02e2\u02e3\u0005\u0014\u0000\u0000\u02e3\u02e4\u00034\u001a\u0000\u02e4"+ + "\u02e5\u0005?\u0000\u0000\u02e5\u02e6\u0003\u00acV\u0000\u02e6\u0099\u0001"+ + "\u0000\u0000\u0000\u02e7\u02e8\u0005)\u0000\u0000\u02e8\u02e9\u0003\u009c"+ + "N\u0000\u02e9\u02ea\u0005C\u0000\u0000\u02ea\u009b\u0001\u0000\u0000\u0000"+ + "\u02eb\u02ec\u0003>\u001f\u0000\u02ec\u02ef\u0005?\u0000\u0000\u02ed\u02f0"+ + "\u0003\u00b8\\\u0000\u02ee\u02f0\u0003\u00b2Y\u0000\u02ef\u02ed\u0001"+ + "\u0000\u0000\u0000\u02ef\u02ee\u0001\u0000\u0000\u0000\u02f0\u009d\u0001"+ + "\u0000\u0000\u0000\u02f1\u02f3\u0005\"\u0000\u0000\u02f2\u02f4\u0003\u00a0"+ + "P\u0000\u02f3\u02f2\u0001\u0000\u0000\u0000\u02f3\u02f4\u0001\u0000\u0000"+ + "\u0000\u02f4\u02f5\u0001\u0000\u0000\u0000\u02f5\u02f6\u0005P\u0000\u0000"+ + "\u02f6\u02f7\u00034\u001a\u0000\u02f7\u02f8\u0005\u008d\u0000\u0000\u02f8"+ + "\u02f9\u0003\u00c0`\u0000\u02f9\u02fa\u0003`0\u0000\u02fa\u009f\u0001"+ + "\u0000\u0000\u0000\u02fb\u02fe\u0003B!\u0000\u02fc\u02fe\u0003\u00acV"+ + "\u0000\u02fd\u02fb\u0001\u0000\u0000\u0000\u02fd\u02fc\u0001\u0000\u0000"+ + "\u0000\u02fe\u00a1\u0001\u0000\u0000\u0000\u02ff\u0300\u0006Q\uffff\uffff"+ + "\u0000\u0300\u0301\u0005M\u0000\u0000\u0301\u031d\u0003\u00a2Q\b\u0302"+ + "\u031d\u0003\u00a8T\u0000\u0303\u031d\u0003\u00a4R\u0000\u0304\u0306\u0003"+ + "\u00a8T\u0000\u0305\u0307\u0005M\u0000\u0000\u0306\u0305\u0001\u0000\u0000"+ + "\u0000\u0306\u0307\u0001\u0000\u0000\u0000\u0307\u0308\u0001\u0000\u0000"+ + "\u0000\u0308\u0309\u0005I\u0000\u0000\u0309\u030a\u0005i\u0000\u0000\u030a"+ + "\u030f\u0003\u00a8T\u0000\u030b\u030c\u0005D\u0000\u0000\u030c\u030e\u0003"+ + "\u00a8T\u0000\u030d\u030b\u0001\u0000\u0000\u0000\u030e\u0311\u0001\u0000"+ + "\u0000\u0000\u030f\u030d\u0001\u0000\u0000\u0000\u030f\u0310\u0001\u0000"+ + "\u0000\u0000\u0310\u0312\u0001\u0000\u0000\u0000\u0311\u030f\u0001\u0000"+ + "\u0000\u0000\u0312\u0313\u0005j\u0000\u0000\u0313\u031d\u0001\u0000\u0000"+ + "\u0000\u0314\u0315\u0003\u00a8T\u0000\u0315\u0317\u0005J\u0000\u0000\u0316"+ + "\u0318\u0005M\u0000\u0000\u0317\u0316\u0001\u0000\u0000\u0000\u0317\u0318"+ + "\u0001\u0000\u0000\u0000\u0318\u0319\u0001\u0000\u0000\u0000\u0319\u031a"+ + "\u0005N\u0000\u0000\u031a\u031d\u0001\u0000\u0000\u0000\u031b\u031d\u0003"+ + "\u00a6S\u0000\u031c\u02ff\u0001\u0000\u0000\u0000\u031c\u0302\u0001\u0000"+ + "\u0000\u0000\u031c\u0303\u0001\u0000\u0000\u0000\u031c\u0304\u0001\u0000"+ + "\u0000\u0000\u031c\u0314\u0001\u0000\u0000\u0000\u031c\u031b\u0001\u0000"+ + "\u0000\u0000\u031d\u0326\u0001\u0000\u0000\u0000\u031e\u031f\n\u0005\u0000"+ + "\u0000\u031f\u0320\u0005=\u0000\u0000\u0320\u0325\u0003\u00a2Q\u0006\u0321"+ + "\u0322\n\u0004\u0000\u0000\u0322\u0323\u0005Q\u0000\u0000\u0323\u0325"+ + "\u0003\u00a2Q\u0005\u0324\u031e\u0001\u0000\u0000\u0000\u0324\u0321\u0001"+ + "\u0000\u0000\u0000\u0325\u0328\u0001\u0000\u0000\u0000\u0326\u0324\u0001"+ + "\u0000\u0000\u0000\u0326\u0327\u0001\u0000\u0000\u0000\u0327\u00a3\u0001"+ + "\u0000\u0000\u0000\u0328\u0326\u0001\u0000\u0000\u0000\u0329\u032b\u0003"+ + "\u00a8T\u0000\u032a\u032c\u0005M\u0000\u0000\u032b\u032a\u0001\u0000\u0000"+ + "\u0000\u032b\u032c\u0001\u0000\u0000\u0000\u032c\u032d\u0001\u0000\u0000"+ + "\u0000\u032d\u032e\u0005L\u0000\u0000\u032e\u032f\u0003H$\u0000\u032f"+ + "\u0358\u0001\u0000\u0000\u0000\u0330\u0332\u0003\u00a8T\u0000\u0331\u0333"+ + "\u0005M\u0000\u0000\u0332\u0331\u0001\u0000\u0000\u0000\u0332\u0333\u0001"+ + "\u0000\u0000\u0000\u0333\u0334\u0001\u0000\u0000\u0000\u0334\u0335\u0005"+ + "S\u0000\u0000\u0335\u0336\u0003H$\u0000\u0336\u0358\u0001\u0000\u0000"+ + "\u0000\u0337\u0339\u0003\u00a8T\u0000\u0338\u033a\u0005M\u0000\u0000\u0339"+ + "\u0338\u0001\u0000\u0000\u0000\u0339\u033a\u0001\u0000\u0000\u0000\u033a"+ + "\u033b\u0001\u0000\u0000\u0000\u033b\u033c\u0005L\u0000\u0000\u033c\u033d"+ + "\u0005i\u0000\u0000\u033d\u0342\u0003H$\u0000\u033e\u033f\u0005D\u0000"+ + "\u0000\u033f\u0341\u0003H$\u0000\u0340\u033e\u0001\u0000\u0000\u0000\u0341"+ + "\u0344\u0001\u0000\u0000\u0000\u0342\u0340\u0001\u0000\u0000\u0000\u0342"+ + "\u0343\u0001\u0000\u0000\u0000\u0343\u0345\u0001\u0000\u0000\u0000\u0344"+ + "\u0342\u0001\u0000\u0000\u0000\u0345\u0346\u0005j\u0000\u0000\u0346\u0358"+ + "\u0001\u0000\u0000\u0000\u0347\u0349\u0003\u00a8T\u0000\u0348\u034a\u0005"+ + "M\u0000\u0000\u0349\u0348\u0001\u0000\u0000\u0000\u0349\u034a\u0001\u0000"+ + "\u0000\u0000\u034a\u034b\u0001\u0000\u0000\u0000\u034b\u034c\u0005S\u0000"+ + "\u0000\u034c\u034d\u0005i\u0000\u0000\u034d\u0352\u0003H$\u0000\u034e"+ + "\u034f\u0005D\u0000\u0000\u034f\u0351\u0003H$\u0000\u0350\u034e\u0001"+ + "\u0000\u0000\u0000\u0351\u0354\u0001\u0000\u0000\u0000\u0352\u0350\u0001"+ + "\u0000\u0000\u0000\u0352\u0353\u0001\u0000\u0000\u0000\u0353\u0355\u0001"+ + "\u0000\u0000\u0000\u0354\u0352\u0001\u0000\u0000\u0000\u0355\u0356\u0005"+ + "j\u0000\u0000\u0356\u0358\u0001\u0000\u0000\u0000\u0357\u0329\u0001\u0000"+ + "\u0000\u0000\u0357\u0330\u0001\u0000\u0000\u0000\u0357\u0337\u0001\u0000"+ + "\u0000\u0000\u0357\u0347\u0001\u0000\u0000\u0000\u0358\u00a5\u0001\u0000"+ + "\u0000\u0000\u0359\u035c\u00034\u001a\u0000\u035a\u035b\u0005A\u0000\u0000"+ + "\u035b\u035d\u0003\f\u0006\u0000\u035c\u035a\u0001\u0000\u0000\u0000\u035c"+ + "\u035d\u0001\u0000\u0000\u0000\u035d\u035e\u0001\u0000\u0000\u0000\u035e"+ + "\u035f\u0005B\u0000\u0000\u035f\u0360\u0003\u00b8\\\u0000\u0360\u00a7"+ + "\u0001\u0000\u0000\u0000\u0361\u0367\u0003\u00aaU\u0000\u0362\u0363\u0003"+ + "\u00aaU\u0000\u0363\u0364\u0003\u00c4b\u0000\u0364\u0365\u0003\u00aaU"+ + "\u0000\u0365\u0367\u0001\u0000\u0000\u0000\u0366\u0361\u0001\u0000\u0000"+ + "\u0000\u0366\u0362\u0001\u0000\u0000\u0000\u0367\u00a9\u0001\u0000\u0000"+ + "\u0000\u0368\u0369\u0006U\uffff\uffff\u0000\u0369\u036d\u0003\u00acV\u0000"+ + "\u036a\u036b\u0007\u0005\u0000\u0000\u036b\u036d\u0003\u00aaU\u0003\u036c"+ + "\u0368\u0001\u0000\u0000\u0000\u036c\u036a\u0001\u0000\u0000\u0000\u036d"+ + "\u0376\u0001\u0000\u0000\u0000\u036e\u036f\n\u0002\u0000\u0000\u036f\u0370"+ + "\u0007\u0006\u0000\u0000\u0370\u0375\u0003\u00aaU\u0003\u0371\u0372\n"+ + "\u0001\u0000\u0000\u0372\u0373\u0007\u0005\u0000\u0000\u0373\u0375\u0003"+ + "\u00aaU\u0002\u0374\u036e\u0001\u0000\u0000\u0000\u0374\u0371\u0001\u0000"+ + "\u0000\u0000\u0375\u0378\u0001\u0000\u0000\u0000\u0376\u0374\u0001\u0000"+ + "\u0000\u0000\u0376\u0377\u0001\u0000\u0000\u0000\u0377\u00ab\u0001\u0000"+ + "\u0000\u0000\u0378\u0376\u0001\u0000\u0000\u0000\u0379\u037a\u0006V\uffff"+ + "\uffff\u0000\u037a\u0382\u0003\u00b8\\\u0000\u037b\u0382\u00034\u001a"+ + "\u0000\u037c\u0382\u0003\u00aeW\u0000\u037d\u037e\u0005i\u0000\u0000\u037e"+ + "\u037f\u0003\u00a2Q\u0000\u037f\u0380\u0005j\u0000\u0000\u0380\u0382\u0001"+ + "\u0000\u0000\u0000\u0381\u0379\u0001\u0000\u0000\u0000\u0381\u037b\u0001"+ + "\u0000\u0000\u0000\u0381\u037c\u0001\u0000\u0000\u0000\u0381\u037d\u0001"+ + "\u0000\u0000\u0000\u0382\u0388\u0001\u0000\u0000\u0000\u0383\u0384\n\u0001"+ + "\u0000\u0000\u0384\u0385\u0005A\u0000\u0000\u0385\u0387\u0003\f\u0006"+ + "\u0000\u0386\u0383\u0001\u0000\u0000\u0000\u0387\u038a\u0001\u0000\u0000"+ + "\u0000\u0388\u0386\u0001\u0000\u0000\u0000\u0388\u0389\u0001\u0000\u0000"+ + "\u0000\u0389\u00ad\u0001\u0000\u0000\u0000\u038a\u0388\u0001\u0000\u0000"+ + "\u0000\u038b\u038c\u0003\u00b0X\u0000\u038c\u039a\u0005i\u0000\u0000\u038d"+ + "\u039b\u0005_\u0000\u0000\u038e\u0393\u0003\u00a2Q\u0000\u038f\u0390\u0005"+ + "D\u0000\u0000\u0390\u0392\u0003\u00a2Q\u0000\u0391\u038f\u0001\u0000\u0000"+ + "\u0000\u0392\u0395\u0001\u0000\u0000\u0000\u0393\u0391\u0001\u0000\u0000"+ + "\u0000\u0393\u0394\u0001\u0000\u0000\u0000\u0394\u0398\u0001\u0000\u0000"+ + "\u0000\u0395\u0393\u0001\u0000\u0000\u0000\u0396\u0397\u0005D\u0000\u0000"+ + "\u0397\u0399\u0003\u00b2Y\u0000\u0398\u0396\u0001\u0000\u0000\u0000\u0398"+ + "\u0399\u0001\u0000\u0000\u0000\u0399\u039b\u0001\u0000\u0000\u0000\u039a"+ + "\u038d\u0001\u0000\u0000\u0000\u039a\u038e\u0001\u0000\u0000\u0000\u039a"+ + "\u039b\u0001\u0000\u0000\u0000\u039b\u039c\u0001\u0000\u0000\u0000\u039c"+ + "\u039d\u0005j\u0000\u0000\u039d\u00af\u0001\u0000\u0000\u0000\u039e\u03a2"+ + "\u0003F#\u0000\u039f\u03a2\u0005H\u0000\u0000\u03a0\u03a2\u0005K\u0000"+ + "\u0000\u03a1\u039e\u0001\u0000\u0000\u0000\u03a1\u039f\u0001\u0000\u0000"+ + "\u0000\u03a1\u03a0\u0001\u0000\u0000\u0000\u03a2\u00b1\u0001\u0000\u0000"+ + "\u0000\u03a3\u03ac\u0005b\u0000\u0000\u03a4\u03a9\u0003\u00b4Z\u0000\u03a5"+ + "\u03a6\u0005D\u0000\u0000\u03a6\u03a8\u0003\u00b4Z\u0000\u03a7\u03a5\u0001"+ + "\u0000\u0000\u0000\u03a8\u03ab\u0001\u0000\u0000\u0000\u03a9\u03a7\u0001"+ + "\u0000\u0000\u0000\u03a9\u03aa\u0001\u0000\u0000\u0000\u03aa\u03ad\u0001"+ + "\u0000\u0000\u0000\u03ab\u03a9\u0001\u0000\u0000\u0000\u03ac\u03a4\u0001"+ + "\u0000\u0000\u0000\u03ac\u03ad\u0001\u0000\u0000\u0000\u03ad\u03ae\u0001"+ + "\u0000\u0000\u0000\u03ae\u03af\u0005c\u0000\u0000\u03af\u00b3\u0001\u0000"+ + "\u0000\u0000\u03b0\u03b1\u0003\u00c2a\u0000\u03b1\u03b2\u0005B\u0000\u0000"+ + "\u03b2\u03b3\u0003\u00b6[\u0000\u03b3\u00b5\u0001\u0000\u0000\u0000\u03b4"+ + "\u03b7\u0003\u00b8\\\u0000\u03b5\u03b7\u0003\u00b2Y\u0000\u03b6\u03b4"+ + "\u0001\u0000\u0000\u0000\u03b6\u03b5\u0001\u0000\u0000\u0000\u03b7\u00b7"+ + "\u0001\u0000\u0000\u0000\u03b8\u03e3\u0005N\u0000\u0000\u03b9\u03ba\u0003"+ + "\u00c0`\u0000\u03ba\u03bb\u0005k\u0000\u0000\u03bb\u03e3\u0001\u0000\u0000"+ + "\u0000\u03bc\u03e3\u0003\u00be_\u0000\u03bd\u03e3\u0003\u00c0`\u0000\u03be"+ + "\u03e3\u0003\u00ba]\u0000\u03bf\u03e3\u0003B!\u0000\u03c0\u03e3\u0003"+ + "\u00c2a\u0000\u03c1\u03c2\u0005g\u0000\u0000\u03c2\u03c7\u0003\u00bc^"+ + "\u0000\u03c3\u03c4\u0005D\u0000\u0000\u03c4\u03c6\u0003\u00bc^\u0000\u03c5"+ + "\u03c3\u0001\u0000\u0000\u0000\u03c6\u03c9\u0001\u0000\u0000\u0000\u03c7"+ + "\u03c5\u0001\u0000\u0000\u0000\u03c7\u03c8\u0001\u0000\u0000\u0000\u03c8"+ + "\u03ca\u0001\u0000\u0000\u0000\u03c9\u03c7\u0001\u0000\u0000\u0000\u03ca"+ + "\u03cb\u0005h\u0000\u0000\u03cb\u03e3\u0001\u0000\u0000\u0000\u03cc\u03cd"+ + "\u0005g\u0000\u0000\u03cd\u03d2\u0003\u00ba]\u0000\u03ce\u03cf\u0005D"+ + "\u0000\u0000\u03cf\u03d1\u0003\u00ba]\u0000\u03d0\u03ce\u0001\u0000\u0000"+ + "\u0000\u03d1\u03d4\u0001\u0000\u0000\u0000\u03d2\u03d0\u0001\u0000\u0000"+ + "\u0000\u03d2\u03d3\u0001\u0000\u0000\u0000\u03d3\u03d5\u0001\u0000\u0000"+ + "\u0000\u03d4\u03d2\u0001\u0000\u0000\u0000\u03d5\u03d6\u0005h\u0000\u0000"+ + "\u03d6\u03e3\u0001\u0000\u0000\u0000\u03d7\u03d8\u0005g\u0000\u0000\u03d8"+ + "\u03dd\u0003\u00c2a\u0000\u03d9\u03da\u0005D\u0000\u0000\u03da\u03dc\u0003"+ + "\u00c2a\u0000\u03db\u03d9\u0001\u0000\u0000\u0000\u03dc\u03df\u0001\u0000"+ + "\u0000\u0000\u03dd\u03db\u0001\u0000\u0000\u0000\u03dd\u03de\u0001\u0000"+ + "\u0000\u0000\u03de\u03e0\u0001\u0000\u0000\u0000\u03df\u03dd\u0001\u0000"+ + "\u0000\u0000\u03e0\u03e1\u0005h\u0000\u0000\u03e1\u03e3\u0001\u0000\u0000"+ + "\u0000\u03e2\u03b8\u0001\u0000\u0000\u0000\u03e2\u03b9\u0001\u0000\u0000"+ + "\u0000\u03e2\u03bc\u0001\u0000\u0000\u0000\u03e2\u03bd\u0001\u0000\u0000"+ + "\u0000\u03e2\u03be\u0001\u0000\u0000\u0000\u03e2\u03bf\u0001\u0000\u0000"+ + "\u0000\u03e2\u03c0\u0001\u0000\u0000\u0000\u03e2\u03c1\u0001\u0000\u0000"+ + "\u0000\u03e2\u03cc\u0001\u0000\u0000\u0000\u03e2\u03d7\u0001\u0000\u0000"+ + "\u0000\u03e3\u00b9\u0001\u0000\u0000\u0000\u03e4\u03e5\u0007\u0007\u0000"+ + "\u0000\u03e5\u00bb\u0001\u0000\u0000\u0000\u03e6\u03e9\u0003\u00be_\u0000"+ + "\u03e7\u03e9\u0003\u00c0`\u0000\u03e8\u03e6\u0001\u0000\u0000\u0000\u03e8"+ + "\u03e7\u0001\u0000\u0000\u0000\u03e9\u00bd\u0001\u0000\u0000\u0000\u03ea"+ + "\u03ec\u0007\u0005\u0000\u0000\u03eb\u03ea\u0001\u0000\u0000\u0000\u03eb"+ + "\u03ec\u0001\u0000\u0000\u0000\u03ec\u03ed\u0001\u0000\u0000\u0000\u03ed"+ + "\u03ee\u0005<\u0000\u0000\u03ee\u00bf\u0001\u0000\u0000\u0000\u03ef\u03f1"+ + "\u0007\u0005\u0000\u0000\u03f0\u03ef\u0001\u0000\u0000\u0000\u03f0\u03f1"+ + "\u0001\u0000\u0000\u0000\u03f1\u03f2\u0001\u0000\u0000\u0000\u03f2\u03f3"+ + "\u0005;\u0000\u0000\u03f3\u00c1\u0001\u0000\u0000\u0000\u03f4\u03f5\u0005"+ + ":\u0000\u0000\u03f5\u00c3\u0001\u0000\u0000\u0000\u03f6\u03f7\u0007\b"+ + "\u0000\u0000\u03f7\u00c5\u0001\u0000\u0000\u0000\u03f8\u03f9\u0007\t\u0000"+ + "\u0000\u03f9\u03fa\u0005\u0082\u0000\u0000\u03fa\u03fb\u0003\u00c8d\u0000"+ + "\u03fb\u03fc\u0003\u00cae\u0000\u03fc\u00c7\u0001\u0000\u0000\u0000\u03fd"+ + "\u03fe\u0004d\u000e\u0000\u03fe\u0400\u0003 \u0010\u0000\u03ff\u0401\u0005"+ + "\u009e\u0000\u0000\u0400\u03ff\u0001\u0000\u0000\u0000\u0400\u0401\u0001"+ + "\u0000\u0000\u0000\u0401\u0402\u0001\u0000\u0000\u0000\u0402\u0403\u0005"+ + "q\u0000\u0000\u0403\u0406\u0001\u0000\u0000\u0000\u0404\u0406\u0003 \u0010"+ + "\u0000\u0405\u03fd\u0001\u0000\u0000\u0000\u0405\u0404\u0001\u0000\u0000"+ + "\u0000\u0406\u00c9\u0001\u0000\u0000\u0000\u0407\u0408\u0005P\u0000\u0000"+ + "\u0408\u040d\u0003\u00a2Q\u0000\u0409\u040a\u0005D\u0000\u0000\u040a\u040c"+ + "\u0003\u00a2Q\u0000\u040b\u0409\u0001\u0000\u0000\u0000\u040c\u040f\u0001"+ + "\u0000\u0000\u0000\u040d\u040b\u0001\u0000\u0000\u0000\u040d\u040e\u0001"+ + "\u0000\u0000\u0000\u040e\u00cb\u0001\u0000\u0000\u0000\u040f\u040d\u0001"+ + "\u0000\u0000\u0000\u0410\u0414\u0005\'\u0000\u0000\u0411\u0413\u0003\u00d0"+ + "h\u0000\u0412\u0411\u0001\u0000\u0000\u0000\u0413\u0416\u0001\u0000\u0000"+ + "\u0000\u0414\u0412\u0001\u0000\u0000\u0000\u0414\u0415\u0001\u0000\u0000"+ + "\u0000\u0415\u041a\u0001\u0000\u0000\u0000\u0416\u0414\u0001\u0000\u0000"+ + "\u0000\u0417\u0418\u0003\u00ceg\u0000\u0418\u0419\u0005?\u0000\u0000\u0419"+ + "\u041b\u0001\u0000\u0000\u0000\u041a\u0417\u0001\u0000\u0000\u0000\u041a"+ + "\u041b\u0001\u0000\u0000\u0000\u041b\u041c\u0001\u0000\u0000\u0000\u041c"+ + "\u041d\u0005i\u0000\u0000\u041d\u041e\u0005e\u0000\u0000\u041e\u044d\u0005"+ + "j\u0000\u0000\u041f\u0423\u0005\'\u0000\u0000\u0420\u0422\u0003\u00d0"+ + "h\u0000\u0421\u0420\u0001\u0000\u0000\u0000\u0422\u0425\u0001\u0000\u0000"+ + "\u0000\u0423\u0421\u0001\u0000\u0000\u0000\u0423\u0424\u0001\u0000\u0000"+ + "\u0000\u0424\u0429\u0001\u0000\u0000\u0000\u0425\u0423\u0001\u0000\u0000"+ + "\u0000\u0426\u0427\u0003\u00ceg\u0000\u0427\u0428\u0005?\u0000\u0000\u0428"+ + "\u042a\u0001\u0000\u0000\u0000\u0429\u0426\u0001\u0000\u0000\u0000\u0429"+ + "\u042a\u0001\u0000\u0000\u0000\u042a\u042b\u0001\u0000\u0000\u0000\u042b"+ + "\u044d\u0005e\u0000\u0000\u042c\u0430\u0005\'\u0000\u0000\u042d\u042f"+ + "\u0003\u00d0h\u0000\u042e\u042d\u0001\u0000\u0000\u0000\u042f\u0432\u0001"+ + "\u0000\u0000\u0000\u0430\u042e\u0001\u0000\u0000\u0000\u0430\u0431\u0001"+ + "\u0000\u0000\u0000\u0431\u0436\u0001\u0000\u0000\u0000\u0432\u0430\u0001"+ + "\u0000\u0000\u0000\u0433\u0434\u0003\u00ceg\u0000\u0434\u0435\u0005?\u0000"+ + "\u0000\u0435\u0437\u0001\u0000\u0000\u0000\u0436\u0433\u0001\u0000\u0000"+ + "\u0000\u0436\u0437\u0001\u0000\u0000\u0000\u0437\u0438\u0001\u0000\u0000"+ + "\u0000\u0438\u043a\u0005i\u0000\u0000\u0439\u043b\u0003\u00d8l\u0000\u043a"+ + "\u0439\u0001\u0000\u0000\u0000\u043b\u043c\u0001\u0000\u0000\u0000\u043c"+ + "\u043a\u0001\u0000\u0000\u0000\u043c\u043d\u0001\u0000\u0000\u0000\u043d"+ + "\u043e\u0001\u0000\u0000\u0000\u043e\u043f\u0005j\u0000\u0000\u043f\u044d"+ + "\u0001\u0000\u0000\u0000\u0440\u0444\u0005\'\u0000\u0000\u0441\u0443\u0003"+ + "\u00d0h\u0000\u0442\u0441\u0001\u0000\u0000\u0000\u0443\u0446\u0001\u0000"+ + "\u0000\u0000\u0444\u0442\u0001\u0000\u0000\u0000\u0444\u0445\u0001\u0000"+ + "\u0000\u0000\u0445\u0448\u0001\u0000\u0000\u0000\u0446\u0444\u0001\u0000"+ + "\u0000\u0000\u0447\u0449\u0003\u00d8l\u0000\u0448\u0447\u0001\u0000\u0000"+ + "\u0000\u0449\u044a\u0001\u0000\u0000\u0000\u044a\u0448\u0001\u0000\u0000"+ + "\u0000\u044a\u044b\u0001\u0000\u0000\u0000\u044b\u044d\u0001\u0000\u0000"+ + "\u0000\u044c\u0410\u0001\u0000\u0000\u0000\u044c\u041f\u0001\u0000\u0000"+ + "\u0000\u044c\u042c\u0001\u0000\u0000\u0000\u044c\u0440\u0001\u0000\u0000"+ + "\u0000\u044d\u00cd\u0001\u0000\u0000\u0000\u044e\u044f\u0007\u0001\u0000"+ + "\u0000\u044f\u00cf\u0001\u0000\u0000\u0000\u0450\u0451\u0003\u00d2i\u0000"+ + "\u0451\u0452\u0005?\u0000\u0000\u0452\u0453\u0003\u00d4j\u0000\u0453\u00d1"+ + "\u0001\u0000\u0000\u0000\u0454\u0455\u0007\n\u0000\u0000\u0455\u00d3\u0001"+ + "\u0000\u0000\u0000\u0456\u045b\u0003\u00dam\u0000\u0457\u0458\u0005D\u0000"+ + "\u0000\u0458\u045a\u0003\u00dam\u0000\u0459\u0457\u0001\u0000\u0000\u0000"+ + "\u045a\u045d\u0001\u0000\u0000\u0000\u045b\u0459\u0001\u0000\u0000\u0000"+ + "\u045b\u045c\u0001\u0000\u0000\u0000\u045c\u0461\u0001\u0000\u0000\u0000"+ + "\u045d\u045b\u0001\u0000\u0000\u0000\u045e\u0461\u0005l\u0000\u0000\u045f"+ + "\u0461\u0005e\u0000\u0000\u0460\u0456\u0001\u0000\u0000\u0000\u0460\u045e"+ + "\u0001\u0000\u0000\u0000\u0460\u045f\u0001\u0000\u0000\u0000\u0461\u00d5"+ + "\u0001\u0000\u0000\u0000\u0462\u0463\u0007\u000b\u0000\u0000\u0463\u00d7"+ + "\u0001\u0000\u0000\u0000\u0464\u0466\u0003\u00d6k\u0000\u0465\u0464\u0001"+ + "\u0000\u0000\u0000\u0466\u0467\u0001\u0000\u0000\u0000\u0467\u0465\u0001"+ + "\u0000\u0000\u0000\u0467\u0468\u0001\u0000\u0000\u0000\u0468\u0472\u0001"+ + "\u0000\u0000\u0000\u0469\u046d\u0005i\u0000\u0000\u046a\u046c\u0003\u00d8"+ + "l\u0000\u046b\u046a\u0001\u0000\u0000\u0000\u046c\u046f\u0001\u0000\u0000"+ + "\u0000\u046d\u046b\u0001\u0000\u0000\u0000\u046d\u046e\u0001\u0000\u0000"+ + "\u0000\u046e\u0470\u0001\u0000\u0000\u0000\u046f\u046d\u0001\u0000\u0000"+ + "\u0000\u0470\u0472\u0005j\u0000\u0000\u0471\u0465\u0001\u0000\u0000\u0000"+ + "\u0471\u0469\u0001\u0000\u0000\u0000\u0472\u00d9\u0001\u0000\u0000\u0000"+ + "\u0473\u0474\u0003\u00dcn\u0000\u0474\u0475\u0005B\u0000\u0000\u0475\u0476"+ + "\u0003\u00e0p\u0000\u0476\u047d\u0001\u0000\u0000\u0000\u0477\u0478\u0003"+ + "\u00e0p\u0000\u0478\u0479\u0005A\u0000\u0000\u0479\u047a\u0003\u00deo"+ + "\u0000\u047a\u047d\u0001\u0000\u0000\u0000\u047b\u047d\u0003\u00e2q\u0000"+ + "\u047c\u0473\u0001\u0000\u0000\u0000\u047c\u0477\u0001\u0000\u0000\u0000"+ + "\u047c\u047b\u0001\u0000\u0000\u0000\u047d\u00db\u0001\u0000\u0000\u0000"+ + "\u047e\u047f\u0007\f\u0000\u0000\u047f\u00dd\u0001\u0000\u0000\u0000\u0480"+ + "\u0481\u0007\f\u0000\u0000\u0481\u00df\u0001\u0000\u0000\u0000\u0482\u0483"+ + "\u0007\f\u0000\u0000\u0483\u00e1\u0001\u0000\u0000\u0000\u0484\u0485\u0007"+ + "\r\u0000\u0000\u0485\u00e3\u0001\u0000\u0000\u0000r\u00e7\u00f8\u0104"+ + "\u0123\u0132\u0138\u014b\u014f\u0154\u015c\u0164\u0169\u016c\u017c\u0184"+ + "\u0188\u018f\u0195\u019a\u01a3\u01aa\u01b0\u01b9\u01c0\u01c8\u01d0\u01d4"+ + "\u01d8\u01dd\u01e1\u01e6\u01ee\u01f7\u01fc\u0200\u020e\u0219\u021f\u0226"+ + "\u022f\u0238\u024c\u0254\u0257\u025e\u026a\u0274\u027c\u028a\u0293\u029e"+ + "\u02a8\u02ae\u02b0\u02b4\u02b9\u02c7\u02ce\u02ef\u02f3\u02fd\u0306\u030f"+ + "\u0317\u031c\u0324\u0326\u032b\u0332\u0339\u0342\u0349\u0352\u0357\u035c"+ + "\u0366\u036c\u0374\u0376\u0381\u0388\u0393\u0398\u039a\u03a1\u03a9\u03ac"+ + "\u03b6\u03c7\u03d2\u03dd\u03e2\u03e8\u03eb\u03f0\u0400\u0405\u040d\u0414"+ + "\u041a\u0423\u0429\u0430\u0436\u043c\u0444\u044a\u044c\u045b\u0460\u0467"+ + "\u046d\u0471\u047c"; public static final ATN _ATN = new ATNDeserializer().deserialize(_serializedATN.toCharArray()); static { diff --git a/x-pack/plugin/esql/src/test/java/org/elasticsearch/xpack/esql/analysis/AnalyzerTests.java b/x-pack/plugin/esql/src/test/java/org/elasticsearch/xpack/esql/analysis/AnalyzerTests.java index 14bbeeafb0f33..bd868648bf39a 100644 --- a/x-pack/plugin/esql/src/test/java/org/elasticsearch/xpack/esql/analysis/AnalyzerTests.java +++ b/x-pack/plugin/esql/src/test/java/org/elasticsearch/xpack/esql/analysis/AnalyzerTests.java @@ -1364,7 +1364,6 @@ public void testImplicitDefaultLimitAfterBreakerAndNonBreakers() { } public void testImplicitDefaultLimitAfterLimitBy() { - assumeTrue("LIMIT BY requires snapshot builds", EsqlCapabilities.Cap.ESQL_LIMIT_BY.isEnabled()); var plan = basic().query("from test | limit 1 by emp_no"); var defaultLimit = as(plan, Limit.class); diff --git a/x-pack/plugin/esql/src/test/java/org/elasticsearch/xpack/esql/optimizer/LocalPhysicalPlanOptimizerTests.java b/x-pack/plugin/esql/src/test/java/org/elasticsearch/xpack/esql/optimizer/LocalPhysicalPlanOptimizerTests.java index 0036dded10bbf..22c7ada7c1690 100644 --- a/x-pack/plugin/esql/src/test/java/org/elasticsearch/xpack/esql/optimizer/LocalPhysicalPlanOptimizerTests.java +++ b/x-pack/plugin/esql/src/test/java/org/elasticsearch/xpack/esql/optimizer/LocalPhysicalPlanOptimizerTests.java @@ -2483,7 +2483,6 @@ public void testTopNUsesSortedInputFromDataNodes() { } public void testLimitByNotPushedToSource() { - assumeTrue("LIMIT BY requires snapshot builds", EsqlCapabilities.Cap.ESQL_LIMIT_BY.isEnabled()); var plan = plannerOptimizer.plan(""" from test | limit 10 by first_name @@ -2503,7 +2502,6 @@ public void testLimitByNotPushedToSource() { } public void testLimitByMultipleKeys() { - assumeTrue("LIMIT BY requires snapshot builds", EsqlCapabilities.Cap.ESQL_LIMIT_BY.isEnabled()); var plan = plannerOptimizer.plan(""" from test | limit 5 by first_name, last_name @@ -2522,7 +2520,6 @@ public void testLimitByMultipleKeys() { } public void testLimitByWithFilter() { - assumeTrue("LIMIT BY requires snapshot builds", EsqlCapabilities.Cap.ESQL_LIMIT_BY.isEnabled()); var plan = plannerOptimizer.plan(""" from test | where salary > 1000 @@ -2558,7 +2555,6 @@ public void testLimitByWithFilter() { * } */ public void testSortWithLimitBy() { - assumeTrue("SORT | LIMIT BY requires snapshot builds", EsqlCapabilities.Cap.ESQL_TOPN_BY.isEnabled()); String query = """ FROM test | SORT salary DESC NULLS LAST diff --git a/x-pack/plugin/esql/src/test/java/org/elasticsearch/xpack/esql/optimizer/LogicalPlanOptimizerTests.java b/x-pack/plugin/esql/src/test/java/org/elasticsearch/xpack/esql/optimizer/LogicalPlanOptimizerTests.java index 58888387f7d48..117701037b9d8 100644 --- a/x-pack/plugin/esql/src/test/java/org/elasticsearch/xpack/esql/optimizer/LogicalPlanOptimizerTests.java +++ b/x-pack/plugin/esql/src/test/java/org/elasticsearch/xpack/esql/optimizer/LogicalPlanOptimizerTests.java @@ -10819,7 +10819,6 @@ public void testCombineOrderByThroughRegisteredDomain() { * } */ public void testLimitByZero() { - assumeTrue("LIMIT BY requires snapshot builds", EsqlCapabilities.Cap.ESQL_LIMIT_BY.isEnabled()); var plan = plan(""" FROM test | LIMIT 0 BY emp_no @@ -10852,7 +10851,6 @@ public void testTopSnippetsQueryMustBeFoldable() { * } */ public void testOnlyLastSortPreservedTopNBy() { - assumeTrue("SORT | LIMIT BY requires snapshot builds", EsqlCapabilities.Cap.ESQL_TOPN_BY.isEnabled()); var query = """ FROM employees | SORT emp_no DESC @@ -10894,7 +10892,6 @@ public void testOnlyLastSortPreservedTopNBy() { * } */ public void testOnlyLastNonContiguousSortPreservedTopNBy() { - assumeTrue("SORT | LIMIT BY requires snapshot builds", EsqlCapabilities.Cap.ESQL_TOPN_BY.isEnabled()); var query = """ FROM employees | SORT emp_no DESC @@ -10943,7 +10940,6 @@ public void testOnlyLastNonContiguousSortPreservedTopNBy() { * } */ public void testOnlyLastNonContiguousSortPreservedTopNByWithExprs() { - assumeTrue("SORT | LIMIT BY requires snapshot builds", EsqlCapabilities.Cap.ESQL_TOPN_BY.isEnabled()); var query = """ FROM employees | SORT emp_no DESC @@ -10992,7 +10988,6 @@ public void testOnlyLastNonContiguousSortPreservedTopNByWithExprs() { } public void testTopNByWorksWithQualifiedNames() { - assumeTrue("SORT | LIMIT BY requires snapshot builds", EsqlCapabilities.Cap.ESQL_TOPN_BY.isEnabled()); var query = """ FROM employees | SORT salary DESC diff --git a/x-pack/plugin/esql/src/test/java/org/elasticsearch/xpack/esql/optimizer/PhysicalPlanOptimizerTests.java b/x-pack/plugin/esql/src/test/java/org/elasticsearch/xpack/esql/optimizer/PhysicalPlanOptimizerTests.java index ab142a379662b..d3b12d5efa0f5 100644 --- a/x-pack/plugin/esql/src/test/java/org/elasticsearch/xpack/esql/optimizer/PhysicalPlanOptimizerTests.java +++ b/x-pack/plugin/esql/src/test/java/org/elasticsearch/xpack/esql/optimizer/PhysicalPlanOptimizerTests.java @@ -1553,7 +1553,6 @@ public void testPushLimitToSource() { * } */ public void testLimitByNotPushedToSource() { - assumeTrue("LIMIT BY requires snapshot builds", EsqlCapabilities.Cap.ESQL_LIMIT_BY.isEnabled()); var optimized = optimizedPlan(physicalPlan(""" from test | limit 10 by emp_no @@ -1578,7 +1577,6 @@ public void testLimitByNotPushedToSource() { * } */ public void testLimitByMultipleKeys() { - assumeTrue("LIMIT BY requires snapshot builds", EsqlCapabilities.Cap.ESQL_LIMIT_BY.isEnabled()); var optimized = optimizedPlan(physicalPlan(""" from test | limit 5 by first_name, last_name @@ -1613,7 +1611,6 @@ public void testLimitByMultipleKeys() { * } */ public void testLimitByAfterStats() { - assumeTrue("LIMIT BY requires snapshot builds", EsqlCapabilities.Cap.ESQL_LIMIT_BY.isEnabled()); var optimized = optimizedPlan(physicalPlan(""" from test | stats avg_salary = avg(salary) by first_name @@ -1652,7 +1649,6 @@ public void testLimitByAfterStats() { * } */ public void testLimitByAfterEval() { - assumeTrue("LIMIT BY requires snapshot builds", EsqlCapabilities.Cap.ESQL_LIMIT_BY.isEnabled()); var optimized = optimizedPlan(physicalPlan(""" from test | eval x = salary + 1 @@ -1689,7 +1685,6 @@ public void testLimitByAfterEval() { * } */ public void testLimitByWithFilter() { - assumeTrue("LIMIT BY requires snapshot builds", EsqlCapabilities.Cap.ESQL_LIMIT_BY.isEnabled()); var optimized = optimizedPlan(physicalPlan(""" from test | where emp_no > 0 @@ -1722,7 +1717,6 @@ public void testLimitByWithFilter() { * } */ public void testLimitByExpressionWithEval() { - assumeTrue("LIMIT BY requires snapshot builds", EsqlCapabilities.Cap.ESQL_LIMIT_BY.isEnabled()); var optimized = optimizedPlan(physicalPlan(""" from test | where emp_no > 0 @@ -1759,7 +1753,6 @@ public void testLimitByExpressionWithEval() { * } */ public void testLimitByZero() { - assumeTrue("LIMIT BY requires snapshot builds", EsqlCapabilities.Cap.ESQL_LIMIT_BY.isEnabled()); var plan = optimizedPlan(physicalPlan(""" FROM test | LIMIT 0 BY emp_no diff --git a/x-pack/plugin/esql/src/test/java/org/elasticsearch/xpack/esql/optimizer/rules/logical/CombineLimitTopNTests.java b/x-pack/plugin/esql/src/test/java/org/elasticsearch/xpack/esql/optimizer/rules/logical/CombineLimitTopNTests.java index 1a313165b4b59..b6a687a7c9ee7 100644 --- a/x-pack/plugin/esql/src/test/java/org/elasticsearch/xpack/esql/optimizer/rules/logical/CombineLimitTopNTests.java +++ b/x-pack/plugin/esql/src/test/java/org/elasticsearch/xpack/esql/optimizer/rules/logical/CombineLimitTopNTests.java @@ -27,7 +27,6 @@ public class CombineLimitTopNTests extends AbstractLogicalPlanOptimizerTests { public void testCombineLimitByTopNBySameGroupings() { - assumeTrue("SORT | LIMIT BY requires snapshot builds", EsqlCapabilities.Cap.ESQL_TOPN_BY.isEnabled()); var attr = getFieldAttribute("a"); var groupings = List.of(attr); var order = List.of(new Order(EMPTY, attr, Order.OrderDirection.ASC, null)); @@ -40,7 +39,6 @@ public void testCombineLimitByTopNBySameGroupings() { } public void testCombineLimitByTopNByDifferentGroupings() { - assumeTrue("SORT | LIMIT BY requires snapshot builds", EsqlCapabilities.Cap.ESQL_TOPN_BY.isEnabled()); var attr = getFieldAttribute("a"); var groupings = List.of(attr); var otherGroupings = List.of(getFieldAttribute("b")); @@ -59,7 +57,6 @@ public void testCombineLimitByTopNByDifferentGroupings() { * the rule should still combine them. Ensures Expressions.semanticEquals(List, List) is used. */ public void testCombineLimitTopNSemanticallyEqualGroupings() { - assumeTrue("SORT | LIMIT BY requires snapshot builds", EsqlCapabilities.Cap.ESQL_TOPN_BY.isEnabled()); var a = getFieldAttribute("a"); var b = getFieldAttribute("b"); var topNGroupings = List.of(b, a); @@ -78,7 +75,6 @@ public void testCombineLimitTopNSemanticallyEqualGroupings() { } public void testLowerLimitIsChosenForCombiningTopNByAndLimitBy() { - assumeTrue("SORT | LIMIT BY requires snapshot builds", EsqlCapabilities.Cap.ESQL_TOPN_BY.isEnabled()); var attr = getFieldAttribute("a"); var groupings = List.of(attr); var order = List.of(new Order(EMPTY, attr, Order.OrderDirection.ASC, null)); @@ -91,7 +87,6 @@ public void testLowerLimitIsChosenForCombiningTopNByAndLimitBy() { } public void testLowerLimitIsChosenForCombiningTopNByAndLimitBy2() { - assumeTrue("SORT | LIMIT BY requires snapshot builds", EsqlCapabilities.Cap.ESQL_TOPN_BY.isEnabled()); var attr = getFieldAttribute("a"); var groupings = List.of(attr); var order = List.of(new Order(EMPTY, attr, Order.OrderDirection.ASC, null)); diff --git a/x-pack/plugin/esql/src/test/java/org/elasticsearch/xpack/esql/optimizer/rules/logical/PruneColumnsTests.java b/x-pack/plugin/esql/src/test/java/org/elasticsearch/xpack/esql/optimizer/rules/logical/PruneColumnsTests.java index b0551297a5a92..c646740532254 100644 --- a/x-pack/plugin/esql/src/test/java/org/elasticsearch/xpack/esql/optimizer/rules/logical/PruneColumnsTests.java +++ b/x-pack/plugin/esql/src/test/java/org/elasticsearch/xpack/esql/optimizer/rules/logical/PruneColumnsTests.java @@ -2514,7 +2514,6 @@ public void testPruneColumnsInExternalRelationWithFilter() { * } */ public void testPruneColumnsKeepsLimitByGrouping() { - assumeTrue("LIMIT BY requires snapshot builds", EsqlCapabilities.Cap.ESQL_LIMIT_BY.isEnabled()); var plan = plan(""" from test | eval x = salary + 4 diff --git a/x-pack/plugin/esql/src/test/java/org/elasticsearch/xpack/esql/optimizer/rules/logical/PruneLiteralsInLimitByTests.java b/x-pack/plugin/esql/src/test/java/org/elasticsearch/xpack/esql/optimizer/rules/logical/PruneLiteralsInLimitByTests.java index 702d39c30621b..37dcf34bbc690 100644 --- a/x-pack/plugin/esql/src/test/java/org/elasticsearch/xpack/esql/optimizer/rules/logical/PruneLiteralsInLimitByTests.java +++ b/x-pack/plugin/esql/src/test/java/org/elasticsearch/xpack/esql/optimizer/rules/logical/PruneLiteralsInLimitByTests.java @@ -27,7 +27,6 @@ public class PruneLiteralsInLimitByTests extends AbstractLogicalPlanOptimizerTes @BeforeClass public static void checkLimitByCapability() { - assumeTrue("LIMIT BY requires snapshot builds", EsqlCapabilities.Cap.ESQL_LIMIT_BY.isEnabled()); } /** diff --git a/x-pack/plugin/esql/src/test/java/org/elasticsearch/xpack/esql/optimizer/rules/logical/PushDownAndCombineLimitByGoldenTests.java b/x-pack/plugin/esql/src/test/java/org/elasticsearch/xpack/esql/optimizer/rules/logical/PushDownAndCombineLimitByGoldenTests.java index d8f9b20712474..03953ac585e87 100644 --- a/x-pack/plugin/esql/src/test/java/org/elasticsearch/xpack/esql/optimizer/rules/logical/PushDownAndCombineLimitByGoldenTests.java +++ b/x-pack/plugin/esql/src/test/java/org/elasticsearch/xpack/esql/optimizer/rules/logical/PushDownAndCombineLimitByGoldenTests.java @@ -21,7 +21,6 @@ public class PushDownAndCombineLimitByGoldenTests extends GoldenTestCase { @BeforeClass public static void checkLimitByCapability() { - assumeTrue("SORT | LIMIT BY requires snapshot builds", EsqlCapabilities.Cap.ESQL_TOPN_BY.isEnabled()); } private static final EnumSet STAGES = EnumSet.of(Stage.LOGICAL_OPTIMIZATION); diff --git a/x-pack/plugin/esql/src/test/java/org/elasticsearch/xpack/esql/optimizer/rules/logical/PushDownAndCombineLimitByTests.java b/x-pack/plugin/esql/src/test/java/org/elasticsearch/xpack/esql/optimizer/rules/logical/PushDownAndCombineLimitByTests.java index 4ed4529a7ef96..5a0c33241fd83 100644 --- a/x-pack/plugin/esql/src/test/java/org/elasticsearch/xpack/esql/optimizer/rules/logical/PushDownAndCombineLimitByTests.java +++ b/x-pack/plugin/esql/src/test/java/org/elasticsearch/xpack/esql/optimizer/rules/logical/PushDownAndCombineLimitByTests.java @@ -36,7 +36,6 @@ public class PushDownAndCombineLimitByTests extends AbstractLogicalPlanOptimizer @BeforeClass public static void checkLimitByCapability() { - assumeTrue("LIMIT BY requires snapshot builds", EsqlCapabilities.Cap.ESQL_LIMIT_BY.isEnabled()); } /** diff --git a/x-pack/plugin/esql/src/test/java/org/elasticsearch/xpack/esql/optimizer/rules/logical/ReplaceLimitByExpressionWithEvalGoldenTests.java b/x-pack/plugin/esql/src/test/java/org/elasticsearch/xpack/esql/optimizer/rules/logical/ReplaceLimitByExpressionWithEvalGoldenTests.java index 2249fa3fa4df1..9729f6ed61137 100644 --- a/x-pack/plugin/esql/src/test/java/org/elasticsearch/xpack/esql/optimizer/rules/logical/ReplaceLimitByExpressionWithEvalGoldenTests.java +++ b/x-pack/plugin/esql/src/test/java/org/elasticsearch/xpack/esql/optimizer/rules/logical/ReplaceLimitByExpressionWithEvalGoldenTests.java @@ -19,7 +19,6 @@ public class ReplaceLimitByExpressionWithEvalGoldenTests extends GoldenTestCase @BeforeClass public static void checkLimitByCapability() { - assumeTrue("SORT | LIMIT BY requires snapshot builds", EsqlCapabilities.Cap.ESQL_TOPN_BY.isEnabled()); } public void testAttributeGroupingUnchanged() { @@ -113,7 +112,6 @@ public void testFoldableAttributeAndExpressionGroupingsMixed() { } public void testTopNByAttributeDoesNotIntroduceEval() { - assumeTrue("SORT | LIMIT BY requires snapshot builds", EsqlCapabilities.Cap.ESQL_TOPN_BY.isEnabled()); runGoldenTest(""" FROM employees | SORT salary DESC @@ -122,7 +120,6 @@ public void testTopNByAttributeDoesNotIntroduceEval() { } public void testTopNByExpressionIntroducesEval() { - assumeTrue("SORT | LIMIT BY requires snapshot builds", EsqlCapabilities.Cap.ESQL_TOPN_BY.isEnabled()); runGoldenTest(""" FROM employees | SORT salary DESC @@ -131,7 +128,6 @@ public void testTopNByExpressionIntroducesEval() { } public void testTopNByMixedAttrAndExpression() { - assumeTrue("SORT | LIMIT BY requires snapshot builds", EsqlCapabilities.Cap.ESQL_TOPN_BY.isEnabled()); runGoldenTest(""" FROM employees | SORT salary DESC @@ -140,7 +136,6 @@ public void testTopNByMixedAttrAndExpression() { } public void testTopNByFoldableExprs() { - assumeTrue("SORT | LIMIT BY requires snapshot builds", EsqlCapabilities.Cap.ESQL_TOPN_BY.isEnabled()); runGoldenTest(""" FROM employees | SORT salary DESC @@ -149,7 +144,6 @@ public void testTopNByFoldableExprs() { } public void testTopNByMixedAttrAndFoldable() { - assumeTrue("SORT | LIMIT BY requires snapshot builds", EsqlCapabilities.Cap.ESQL_TOPN_BY.isEnabled()); runGoldenTest(""" FROM employees | SORT salary DESC @@ -158,7 +152,6 @@ public void testTopNByMixedAttrAndFoldable() { } public void testTopNByMixedExprsAttr() { - assumeTrue("SORT | LIMIT BY requires snapshot builds", EsqlCapabilities.Cap.ESQL_TOPN_BY.isEnabled()); runGoldenTest(""" FROM employees | SORT salary DESC diff --git a/x-pack/plugin/esql/src/test/java/org/elasticsearch/xpack/esql/optimizer/rules/physical/local/LimitByGoldenTests.java b/x-pack/plugin/esql/src/test/java/org/elasticsearch/xpack/esql/optimizer/rules/physical/local/LimitByGoldenTests.java index 711b199a123db..b592484254ea4 100644 --- a/x-pack/plugin/esql/src/test/java/org/elasticsearch/xpack/esql/optimizer/rules/physical/local/LimitByGoldenTests.java +++ b/x-pack/plugin/esql/src/test/java/org/elasticsearch/xpack/esql/optimizer/rules/physical/local/LimitByGoldenTests.java @@ -19,7 +19,6 @@ public class LimitByGoldenTests extends GoldenTestCase { public void testLimitByWithoutSort() { - assumeTrue("LIMIT BY requires snapshot builds", EsqlCapabilities.Cap.ESQL_LIMIT_BY.isEnabled()); runGoldenTest( """ FROM employees @@ -38,7 +37,6 @@ public void testLimitByWithoutSort() { } public void testSortLimitBy() { - assumeTrue("SORT | LIMIT BY requires snapshot builds", EsqlCapabilities.Cap.ESQL_TOPN_BY.isEnabled()); runGoldenTest( """ FROM employees diff --git a/x-pack/plugin/esql/src/test/java/org/elasticsearch/xpack/esql/optimizer/rules/physical/local/ReorderLimitProjectAndOrderByGoldenTests.java b/x-pack/plugin/esql/src/test/java/org/elasticsearch/xpack/esql/optimizer/rules/physical/local/ReorderLimitProjectAndOrderByGoldenTests.java index 4521ff4856ebc..f6e30124347af 100644 --- a/x-pack/plugin/esql/src/test/java/org/elasticsearch/xpack/esql/optimizer/rules/physical/local/ReorderLimitProjectAndOrderByGoldenTests.java +++ b/x-pack/plugin/esql/src/test/java/org/elasticsearch/xpack/esql/optimizer/rules/physical/local/ReorderLimitProjectAndOrderByGoldenTests.java @@ -23,7 +23,6 @@ public class ReorderLimitProjectAndOrderByGoldenTests extends GoldenTestCase { * In this case the 2*salary AS language_name ends up in a Project and LimitBy references it, so LimitBy -> Project cannot be swapped */ public void testLimitByAndProjectNotSwapped() { - assumeTrue("LIMIT BY requires snapshot builds", EsqlCapabilities.Cap.ESQL_LIMIT_BY.isEnabled()); runGoldenTest(""" FROM employees | RENAME languages AS language_code @@ -38,7 +37,6 @@ public void testLimitByAndProjectNotSwapped() { * referenced by LimitBy, so the only way to fix the query is to swap LimitBy and OrderBy */ public void testProjectAndOrderBySwapped() { - assumeTrue("SORT | LIMIT BY requires snapshot builds", EsqlCapabilities.Cap.ESQL_TOPN_BY.isEnabled()); runGoldenTest(""" FROM employees | RENAME languages AS language_code diff --git a/x-pack/plugin/esql/src/test/java/org/elasticsearch/xpack/esql/parser/StatementParserTests.java b/x-pack/plugin/esql/src/test/java/org/elasticsearch/xpack/esql/parser/StatementParserTests.java index 91c6f77a0a429..a509def5af586 100644 --- a/x-pack/plugin/esql/src/test/java/org/elasticsearch/xpack/esql/parser/StatementParserTests.java +++ b/x-pack/plugin/esql/src/test/java/org/elasticsearch/xpack/esql/parser/StatementParserTests.java @@ -1088,7 +1088,6 @@ public void testBasicLimitCommand() { } public void testLimitBy() { - assumeTrue("LIMIT BY requires snapshot builds", EsqlCapabilities.Cap.ESQL_LIMIT_BY.isEnabled()); LogicalPlan plan = query(""" FROM foo | SORT @timestamp DESC @@ -1126,7 +1125,6 @@ public void testLimitBy() { } public void testLimitByQualifiedName() { - assumeTrue("LIMIT BY requires snapshot builds", EsqlCapabilities.Cap.ESQL_LIMIT_BY.isEnabled()); LogicalPlan plan = query(""" FROM foo | SORT @timestamp DESC @@ -1160,7 +1158,6 @@ public void testLimitByQualifiedName() { } public void testLimitByNegativeValue() { - assumeTrue("LIMIT BY requires snapshot builds", EsqlCapabilities.Cap.ESQL_LIMIT_BY.isEnabled()); expectThrows( ParsingException.class, containsString("value of [LIMIT -1 BY languages] must be a non negative integer, found value [-1] type [integer]"), @@ -1172,7 +1169,6 @@ public void testLimitByNegativeValue() { } public void testLimitByExpressionForN() { - assumeTrue("LIMIT BY requires snapshot builds", EsqlCapabilities.Cap.ESQL_LIMIT_BY.isEnabled()); expectThrows(ParsingException.class, containsString("mismatched input '*'"), () -> query(""" FROM foo | LIMIT -1 * 42 BY languages From ee0257d5881e94322996087aaaba5adcd3dded4c Mon Sep 17 00:00:00 2001 From: ncordon Date: Mon, 30 Mar 2026 19:12:21 +0200 Subject: [PATCH 2/7] Adds changelog --- docs/changelog/145225.yaml | 6 ++++++ 1 file changed, 6 insertions(+) create mode 100644 docs/changelog/145225.yaml diff --git a/docs/changelog/145225.yaml b/docs/changelog/145225.yaml new file mode 100644 index 0000000000000..a7cb3d25bfed6 --- /dev/null +++ b/docs/changelog/145225.yaml @@ -0,0 +1,6 @@ +area: ES|QL +issues: + - 112918 +pr: 145225 +summary: Adds LIMIT BY ESQL command in Tech Preview +type: enhancement From a41988c26512b219ec3c8ed5a47d30b37313cb44 Mon Sep 17 00:00:00 2001 From: elasticsearchmachine Date: Mon, 30 Mar 2026 17:21:50 +0000 Subject: [PATCH 3/7] [CI] Auto commit changes from spotless --- .../esql/optimizer/rules/logical/CombineLimitTopNTests.java | 1 - .../xpack/esql/optimizer/rules/logical/PruneColumnsTests.java | 1 - .../optimizer/rules/logical/PruneLiteralsInLimitByTests.java | 4 +--- .../rules/logical/PushDownAndCombineLimitByGoldenTests.java | 4 +--- .../rules/logical/PushDownAndCombineLimitByTests.java | 4 +--- .../logical/ReplaceLimitByExpressionWithEvalGoldenTests.java | 4 +--- .../optimizer/rules/physical/local/LimitByGoldenTests.java | 1 - .../local/ReorderLimitProjectAndOrderByGoldenTests.java | 1 - 8 files changed, 4 insertions(+), 16 deletions(-) diff --git a/x-pack/plugin/esql/src/test/java/org/elasticsearch/xpack/esql/optimizer/rules/logical/CombineLimitTopNTests.java b/x-pack/plugin/esql/src/test/java/org/elasticsearch/xpack/esql/optimizer/rules/logical/CombineLimitTopNTests.java index b6a687a7c9ee7..47e8c1d1d2c29 100644 --- a/x-pack/plugin/esql/src/test/java/org/elasticsearch/xpack/esql/optimizer/rules/logical/CombineLimitTopNTests.java +++ b/x-pack/plugin/esql/src/test/java/org/elasticsearch/xpack/esql/optimizer/rules/logical/CombineLimitTopNTests.java @@ -7,7 +7,6 @@ package org.elasticsearch.xpack.esql.optimizer.rules.logical; -import org.elasticsearch.xpack.esql.action.EsqlCapabilities; import org.elasticsearch.xpack.esql.core.expression.Expression; import org.elasticsearch.xpack.esql.core.expression.ReferenceAttribute; import org.elasticsearch.xpack.esql.expression.Order; diff --git a/x-pack/plugin/esql/src/test/java/org/elasticsearch/xpack/esql/optimizer/rules/logical/PruneColumnsTests.java b/x-pack/plugin/esql/src/test/java/org/elasticsearch/xpack/esql/optimizer/rules/logical/PruneColumnsTests.java index c646740532254..d1c7e888e6abd 100644 --- a/x-pack/plugin/esql/src/test/java/org/elasticsearch/xpack/esql/optimizer/rules/logical/PruneColumnsTests.java +++ b/x-pack/plugin/esql/src/test/java/org/elasticsearch/xpack/esql/optimizer/rules/logical/PruneColumnsTests.java @@ -8,7 +8,6 @@ package org.elasticsearch.xpack.esql.optimizer.rules.logical; import org.elasticsearch.index.IndexMode; -import org.elasticsearch.xpack.esql.action.EsqlCapabilities; import org.elasticsearch.xpack.esql.core.expression.Alias; import org.elasticsearch.xpack.esql.core.expression.Attribute; import org.elasticsearch.xpack.esql.core.expression.Expressions; diff --git a/x-pack/plugin/esql/src/test/java/org/elasticsearch/xpack/esql/optimizer/rules/logical/PruneLiteralsInLimitByTests.java b/x-pack/plugin/esql/src/test/java/org/elasticsearch/xpack/esql/optimizer/rules/logical/PruneLiteralsInLimitByTests.java index 37dcf34bbc690..42ccf47e6978d 100644 --- a/x-pack/plugin/esql/src/test/java/org/elasticsearch/xpack/esql/optimizer/rules/logical/PruneLiteralsInLimitByTests.java +++ b/x-pack/plugin/esql/src/test/java/org/elasticsearch/xpack/esql/optimizer/rules/logical/PruneLiteralsInLimitByTests.java @@ -7,7 +7,6 @@ package org.elasticsearch.xpack.esql.optimizer.rules.logical; -import org.elasticsearch.xpack.esql.action.EsqlCapabilities; import org.elasticsearch.xpack.esql.core.expression.Expressions; import org.elasticsearch.xpack.esql.core.expression.Literal; import org.elasticsearch.xpack.esql.optimizer.AbstractLogicalPlanOptimizerTests; @@ -26,8 +25,7 @@ public class PruneLiteralsInLimitByTests extends AbstractLogicalPlanOptimizerTests { @BeforeClass - public static void checkLimitByCapability() { - } + public static void checkLimitByCapability() {} /** * A foldable eval alias used in LIMIT BY should be propagated by {@code PropagateEvalFoldables} diff --git a/x-pack/plugin/esql/src/test/java/org/elasticsearch/xpack/esql/optimizer/rules/logical/PushDownAndCombineLimitByGoldenTests.java b/x-pack/plugin/esql/src/test/java/org/elasticsearch/xpack/esql/optimizer/rules/logical/PushDownAndCombineLimitByGoldenTests.java index 03953ac585e87..ea60b6c7110fa 100644 --- a/x-pack/plugin/esql/src/test/java/org/elasticsearch/xpack/esql/optimizer/rules/logical/PushDownAndCombineLimitByGoldenTests.java +++ b/x-pack/plugin/esql/src/test/java/org/elasticsearch/xpack/esql/optimizer/rules/logical/PushDownAndCombineLimitByGoldenTests.java @@ -8,7 +8,6 @@ package org.elasticsearch.xpack.esql.optimizer.rules.logical; import org.elasticsearch.xpack.esql.EsqlTestUtils; -import org.elasticsearch.xpack.esql.action.EsqlCapabilities; import org.elasticsearch.xpack.esql.optimizer.GoldenTestCase; import org.junit.BeforeClass; @@ -20,8 +19,7 @@ public class PushDownAndCombineLimitByGoldenTests extends GoldenTestCase { @BeforeClass - public static void checkLimitByCapability() { - } + public static void checkLimitByCapability() {} private static final EnumSet STAGES = EnumSet.of(Stage.LOGICAL_OPTIMIZATION); diff --git a/x-pack/plugin/esql/src/test/java/org/elasticsearch/xpack/esql/optimizer/rules/logical/PushDownAndCombineLimitByTests.java b/x-pack/plugin/esql/src/test/java/org/elasticsearch/xpack/esql/optimizer/rules/logical/PushDownAndCombineLimitByTests.java index 5a0c33241fd83..826f3d49aedd7 100644 --- a/x-pack/plugin/esql/src/test/java/org/elasticsearch/xpack/esql/optimizer/rules/logical/PushDownAndCombineLimitByTests.java +++ b/x-pack/plugin/esql/src/test/java/org/elasticsearch/xpack/esql/optimizer/rules/logical/PushDownAndCombineLimitByTests.java @@ -7,7 +7,6 @@ package org.elasticsearch.xpack.esql.optimizer.rules.logical; -import org.elasticsearch.xpack.esql.action.EsqlCapabilities; import org.elasticsearch.xpack.esql.core.expression.Expressions; import org.elasticsearch.xpack.esql.core.expression.FoldContext; import org.elasticsearch.xpack.esql.core.expression.Literal; @@ -35,8 +34,7 @@ public class PushDownAndCombineLimitByTests extends AbstractLogicalPlanOptimizerTests { @BeforeClass - public static void checkLimitByCapability() { - } + public static void checkLimitByCapability() {} /** *
{@code
diff --git a/x-pack/plugin/esql/src/test/java/org/elasticsearch/xpack/esql/optimizer/rules/logical/ReplaceLimitByExpressionWithEvalGoldenTests.java b/x-pack/plugin/esql/src/test/java/org/elasticsearch/xpack/esql/optimizer/rules/logical/ReplaceLimitByExpressionWithEvalGoldenTests.java
index 9729f6ed61137..ea1a725cb79d4 100644
--- a/x-pack/plugin/esql/src/test/java/org/elasticsearch/xpack/esql/optimizer/rules/logical/ReplaceLimitByExpressionWithEvalGoldenTests.java
+++ b/x-pack/plugin/esql/src/test/java/org/elasticsearch/xpack/esql/optimizer/rules/logical/ReplaceLimitByExpressionWithEvalGoldenTests.java
@@ -7,7 +7,6 @@
 
 package org.elasticsearch.xpack.esql.optimizer.rules.logical;
 
-import org.elasticsearch.xpack.esql.action.EsqlCapabilities;
 import org.elasticsearch.xpack.esql.optimizer.GoldenTestCase;
 import org.junit.BeforeClass;
 
@@ -18,8 +17,7 @@ public class ReplaceLimitByExpressionWithEvalGoldenTests extends GoldenTestCase
     private static final EnumSet STAGES = EnumSet.of(Stage.ANALYSIS, Stage.LOGICAL_OPTIMIZATION);
 
     @BeforeClass
-    public static void checkLimitByCapability() {
-    }
+    public static void checkLimitByCapability() {}
 
     public void testAttributeGroupingUnchanged() {
         runGoldenTest("""
diff --git a/x-pack/plugin/esql/src/test/java/org/elasticsearch/xpack/esql/optimizer/rules/physical/local/LimitByGoldenTests.java b/x-pack/plugin/esql/src/test/java/org/elasticsearch/xpack/esql/optimizer/rules/physical/local/LimitByGoldenTests.java
index b592484254ea4..e69ee2b44e321 100644
--- a/x-pack/plugin/esql/src/test/java/org/elasticsearch/xpack/esql/optimizer/rules/physical/local/LimitByGoldenTests.java
+++ b/x-pack/plugin/esql/src/test/java/org/elasticsearch/xpack/esql/optimizer/rules/physical/local/LimitByGoldenTests.java
@@ -8,7 +8,6 @@
 package org.elasticsearch.xpack.esql.optimizer.rules.physical.local;
 
 import org.elasticsearch.xpack.esql.EsqlTestUtils;
-import org.elasticsearch.xpack.esql.action.EsqlCapabilities;
 import org.elasticsearch.xpack.esql.optimizer.GoldenTestCase;
 
 import java.util.EnumSet;
diff --git a/x-pack/plugin/esql/src/test/java/org/elasticsearch/xpack/esql/optimizer/rules/physical/local/ReorderLimitProjectAndOrderByGoldenTests.java b/x-pack/plugin/esql/src/test/java/org/elasticsearch/xpack/esql/optimizer/rules/physical/local/ReorderLimitProjectAndOrderByGoldenTests.java
index f6e30124347af..d6a37d01c223a 100644
--- a/x-pack/plugin/esql/src/test/java/org/elasticsearch/xpack/esql/optimizer/rules/physical/local/ReorderLimitProjectAndOrderByGoldenTests.java
+++ b/x-pack/plugin/esql/src/test/java/org/elasticsearch/xpack/esql/optimizer/rules/physical/local/ReorderLimitProjectAndOrderByGoldenTests.java
@@ -8,7 +8,6 @@
 package org.elasticsearch.xpack.esql.optimizer.rules.physical.local;
 
 import org.elasticsearch.xpack.esql.EsqlTestUtils;
-import org.elasticsearch.xpack.esql.action.EsqlCapabilities;
 import org.elasticsearch.xpack.esql.optimizer.GoldenTestCase;
 
 import java.util.EnumSet;

From ee40db4c8d7937fd78cc5b025b5e3aa7adaf4155 Mon Sep 17 00:00:00 2001
From: ncordon 
Date: Wed, 1 Apr 2026 02:13:31 +0200
Subject: [PATCH 4/7] ESQL: Added LIMIT BY docs (Tech preview)
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit

Co-authored-by: Iván Cea Fontenla 
---
 .../examples/limit.csv-spec/limitBy.md        |   14 +
 .../limit.csv-spec/limitByMultipleGroups.md   |    7 +
 .../esql/_snippets/commands/layout/limit.md   |   43 +-
 .../src/main/resources/limit.csv-spec         | 1097 +----------------
 4 files changed, 83 insertions(+), 1078 deletions(-)
 create mode 100644 docs/reference/query-languages/esql/_snippets/commands/examples/limit.csv-spec/limitBy.md
 create mode 100644 docs/reference/query-languages/esql/_snippets/commands/examples/limit.csv-spec/limitByMultipleGroups.md

diff --git a/docs/reference/query-languages/esql/_snippets/commands/examples/limit.csv-spec/limitBy.md b/docs/reference/query-languages/esql/_snippets/commands/examples/limit.csv-spec/limitBy.md
new file mode 100644
index 0000000000000..89ff59c1766c7
--- /dev/null
+++ b/docs/reference/query-languages/esql/_snippets/commands/examples/limit.csv-spec/limitBy.md
@@ -0,0 +1,14 @@
+% This is generated by ESQL's AbstractFunctionTestCase. Do not edit it. See ../README.md for how to regenerate it.
+
+```esql
+FROM employees
+| SORT salary DESC
+| LIMIT 1 BY gender
+| KEEP first_name, last_name, salary, gender
+```
+
+| first_name:keyword | last_name:keyword | salary:integer | gender:keyword |
+| --- | --- | --- | --- |
+| Otmar | Herbst | 74999 | M |
+| Tzvetan | Zielinski | 74572 | F |
+| Lillian | Haddadi | 73717 | null |
diff --git a/docs/reference/query-languages/esql/_snippets/commands/examples/limit.csv-spec/limitByMultipleGroups.md b/docs/reference/query-languages/esql/_snippets/commands/examples/limit.csv-spec/limitByMultipleGroups.md
new file mode 100644
index 0000000000000..329d4a0781617
--- /dev/null
+++ b/docs/reference/query-languages/esql/_snippets/commands/examples/limit.csv-spec/limitByMultipleGroups.md
@@ -0,0 +1,7 @@
+% This is generated by ESQL's AbstractFunctionTestCase. Do not edit it. See ../README.md for how to regenerate it.
+
+```esql
+FROM employees
+| SORT salary DESC
+| LIMIT 1 BY languages, gender
+```
diff --git a/docs/reference/query-languages/esql/_snippets/commands/layout/limit.md b/docs/reference/query-languages/esql/_snippets/commands/layout/limit.md
index 267eeea22c7d9..5ee84fbbcea0a 100644
--- a/docs/reference/query-languages/esql/_snippets/commands/layout/limit.md
+++ b/docs/reference/query-languages/esql/_snippets/commands/layout/limit.md
@@ -7,23 +7,62 @@ The `LIMIT` processing command limits the number of rows returned.
 
 ## Syntax
 
+::::{applies-switch}
+
+:::{applies-item} { stack: ga, "serverless": "ga"}
 ```esql
 LIMIT max_number_of_rows
 ```
+:::
+
+:::{applies-item} { "stack": "preview 9.4+", "serverless": "preview" }
+```esql
+LIMIT max_number_of_rows [BY grouping_expr1[, ..., grouping_exprN]]
+```
+:::
+::::
 
 ## Parameters
 
 `max_number_of_rows`
-:   The maximum number of rows to return.
+:   The maximum number of rows to return. When `BY` is specified, the maximum
+number of rows to return **per group**.
+
+`grouping_exprX` {applies_to}`serverless: preview` {applies_to}`stack: preview 9.4+`
+:   An expression that outputs the values to group by.
 
 ## Description
 
 Use the `LIMIT` processing command to limit the number of rows returned.
 
+When `BY` is specified, up to `max_number_of_rows` rows are retained for each
+distinct combination of the grouping expressions.
+Precede `LIMIT  BY` with a `SORT` to keep the top N for each group.
+
 :::{include} ../../common/result-set-size-limitation.md
 :::
 
-## Example
+## Examples
+
+### Limit
 
 :::{include} ../examples/limit.csv-spec/basic.md
 :::
+
+### With groups
+```{applies_to}
+stack: preview 9.4
+serverless: preview
+```
+
+:::{include} ../examples/limit.csv-spec/limitBy.md
+:::
+
+### Group by multiple values
+```{applies_to}
+stack: preview 9.4
+serverless: preview
+```
+
+:::{include} ../examples/limit.csv-spec/limitByMultipleGroups.md
+:::
diff --git a/x-pack/plugin/esql/qa/testFixtures/src/main/resources/limit.csv-spec b/x-pack/plugin/esql/qa/testFixtures/src/main/resources/limit.csv-spec
index e6dae15567f5d..fdda25749cc8b 100644
--- a/x-pack/plugin/esql/qa/testFixtures/src/main/resources/limit.csv-spec
+++ b/x-pack/plugin/esql/qa/testFixtures/src/main/resources/limit.csv-spec
@@ -15,1107 +15,52 @@ emp_no:integer
 10005
 ;
 
-//
-// LIMIT BY
-//
-
-limitBy
-required_capability: esql_limit_by
-
-FROM employees
-| WHERE emp_no IN (10001, 10002, 10003, 10005, 10006)
-| SORT emp_no
-| LIMIT 1000
-| LIMIT 5 BY languages
-| KEEP emp_no, first_name, languages
-;
-
-emp_no:integer | first_name:keyword | languages:integer
-10001          | Georgi             | 2
-10002          | Bezalel            | 5
-10003          | Parto              | 4
-10005          | Kyoichi            | 1
-10006          | Anneke             | 3
-;
-
-limitByLimit0
-required_capability: esql_limit_by
-
-FROM employees
-| WHERE emp_no IN (10001, 10002, 10003)
-| SORT emp_no
-| LIMIT 1000
-| LIMIT 0 BY languages
-| KEEP emp_no, languages
-;
-
-emp_no:integer | languages:integer
-;
-
-limitByMultipleColumns
-required_capability: esql_limit_by
-
-FROM employees
-| WHERE emp_no IN (10001, 10003, 10004, 10007)
-| SORT emp_no
-| LIMIT 1000
-| LIMIT 5 BY languages, gender
-| KEEP emp_no, first_name, languages, gender
-;
-
-emp_no:integer | first_name:keyword | languages:integer | gender:keyword
-10001          | Georgi             | 2                 | M
-10003          | Parto              | 4                 | M
-10004          | Chirstian          | 5                 | M
-10007          | Tzvetan            | 4                 | F
-;
-
-limitByWithExpression
-required_capability: esql_limit_by
-
-FROM employees
-| WHERE emp_no IN (10001, 10002, 10003, 10004, 10005)
-| SORT emp_no
-| LIMIT 1000
-| LIMIT 5 BY languages * 2
-| KEEP emp_no, first_name, languages
-;
-
-emp_no:integer | first_name:keyword | languages:integer
-10001          | Georgi             | 2
-10002          | Bezalel            | 5
-10003          | Parto              | 4
-10004          | Chirstian          | 5
-10005          | Kyoichi            | 1
-;
-
-limitByMultivalueGroupKey
-required_capability: esql_limit_by
-
-FROM employees
-| WHERE emp_no IN (10001, 10008)
-| SORT emp_no
-| LIMIT 1000
-| LIMIT 5 BY job_positions
-| KEEP emp_no, first_name, job_positions
-;
-
-emp_no:integer | first_name:keyword | job_positions:keyword
-10001          | Georgi             | [Accountant, Senior Python Developer]
-10008          | Saniya             | [Internship, Junior Developer, Purchase Manager, Senior Python Developer]
-;
-
-limitByNullGroup
-required_capability: esql_limit_by
-
-FROM employees
-| WHERE emp_no IN (10001, 10020)
-| SORT emp_no
-| LIMIT 1000
-| LIMIT 5 BY languages
-| KEEP emp_no, first_name, languages
-;
-
-emp_no:integer | first_name:keyword | languages:integer
-10001          | Georgi             | 2
-10020          | Mayuko             | null
-;
-
-limitByConstant
-required_capability: esql_limit_by
-
-FROM employees
-| WHERE emp_no IN (10001, 10002, 10003, 10005, 10006)
-| SORT emp_no
-| LIMIT 1000
-| LIMIT 2 BY 5*42
-| KEEP emp_no, first_name, languages
-;
-
-emp_no:integer | first_name:keyword | languages:integer
-10001          | Georgi             | 2
-10002          | Bezalel            | 5
-;
-
-limitByWithExpressionAndConstant
-required_capability: esql_limit_by
-
-FROM employees
-| WHERE emp_no IN (10001, 10002, 10003, 10004, 10005)
-| SORT emp_no
-| LIMIT 1000
-| LIMIT 5 BY languages * 2, 20 - 5 * 2
-| KEEP emp_no, first_name, languages
-;
-
-emp_no:integer | first_name:keyword | languages:integer
-10001          | Georgi             | 2
-10002          | Bezalel            | 5
-10003          | Parto              | 4
-10004          | Chirstian          | 5
-10005          | Kyoichi            | 1
-;
-
-limitByWithAlias
-required_capability: esql_limit_by
-
-FROM employees
-| WHERE emp_no IN (10001, 10002, 10003, 10004, 10005)
-| SORT emp_no
-| LIMIT 1000
-| EVAL g = languages * 2
-| LIMIT 5 BY g
-| KEEP emp_no, first_name, languages
-;
-
-emp_no:integer | first_name:keyword | languages:integer
-10001          | Georgi             | 2
-10002          | Bezalel            | 5
-10003          | Parto              | 4
-10004          | Chirstian          | 5
-10005          | Kyoichi            | 1
-;
-
-limitByThenStats
-required_capability: esql_limit_by
-
-FROM employees
-| LIMIT 2 BY languages
-| STATS c = COUNT(*) BY languages
-| SORT languages ASC NULLS LAST
-;
-
-c:long | languages:integer
-2      | 1
-2      | 2
-2      | 3
-2      | 4
-2      | 5
-2      | null
-;
-
-limitByPrecededByStats
-required_capability: esql_limit_by
-
-FROM employees
-| STATS cnt=COUNT(*) BY job_positions, languages
-| SORT job_positions, cnt DESC, languages
-| LIMIT 1000
-| LIMIT 1 BY job_positions
-| LIMIT 5
-;
-
-cnt:long | job_positions:keyword | languages:integer
-5        | Accountant            | 2
-5        | Architect             | 4
-4        | Business Analyst      | 2
-3        | Data Scientist        | 1
-5        | Head Human Resources  | 5
-;
-
-limitByWithLookupJoin
-required_capability: esql_limit_by
-required_capability: join_lookup_v12
-
-FROM employees
-| WHERE emp_no IN (10001, 10002, 10003, 10004, 10005)
-| EVAL language_code = languages
-| LOOKUP JOIN languages_lookup_non_unique_key ON language_code
-| SORT emp_no, language_code, language_name
-| LIMIT 1000
-| LIMIT 2 BY emp_no
-| KEEP emp_no, language_code, language_name
-;
-
-emp_no:integer | language_code:integer | language_name:keyword
-10001          | 2                     | German
-10001          | 2                     | German
-10002          | 5                     | null
-10003          | 4                     | Quenya
-10004          | 5                     | null
-10005          | 1                     | English
-10005          | 1                     | English
-;
-
-limitByShadowedNonJoinField
-required_capability: esql_limit_by
-required_capability: join_lookup_v12
-
-FROM employees
-| WHERE emp_no IN (10001, 10002, 10003, 10004, 10005)
-| EVAL language_code = languages
-| EVAL language_name = 2*salary
-| LOOKUP JOIN languages_lookup_non_unique_key ON language_code
-| SORT emp_no, language_code, language_name
-| LIMIT 1000
-| LIMIT 2 BY language_name
-| KEEP emp_no, language_code, language_name
-;
-
-emp_no:integer | language_code:integer | language_name:keyword
-10001          | 2                     | German
-10001          | 2                     | German
-10002          | 5                     | null
-10003          | 4                     | Quenya
-10004          | 5                     | null
-10005          | 1                     | English
-10005          | 1                     | English
-;
-
-limitByShadowedJoinField
-required_capability: esql_limit_by
-required_capability: join_lookup_v12
-
-FROM employees
-| WHERE emp_no IN (10001, 10002, 10003, 10004, 10005)
-| EVAL language_code = languages
-| LOOKUP JOIN languages_lookup_non_unique_key ON language_code
-| SORT emp_no, language_code, language_name
-| LIMIT 1000
-| LIMIT 2 BY language_code
-| KEEP emp_no, language_code, language_name
-;
-
-emp_no:integer | language_code:integer | language_name:keyword
-10001          | 2                     | German
-10001          | 2                     | German
-10002          | 5                     | null
-10003          | 4                     | Quenya
-10004          | 5                     | null
-10005          | 1                     | English
-10005          | 1                     | English
-;
-
-sortLimitBy
-required_capability: esql_topn_by
+docsLimitBy
+required_capability: limit_by
 
+// tag::limitBy[]
 FROM employees
 | SORT salary DESC
-| LIMIT 5 BY languages
-| KEEP first_name, last_name, salary, languages
-| SORT languages DESC nulls last, salary DESC
+| LIMIT 1 BY gender
+| KEEP first_name, last_name, salary, gender
+// end::limitBy[]
 ;
 
-first_name:keyword | last_name:keyword | salary:integer | languages:integer
-Arumugam           | Ossenbruggen      | 66817          | 5
-Bezalel            | Simmel            | 56371          | 5
-Hironoby           | Sidou             | 54518          | 5
-Premal             | Baek              | 52833          | 5
-Gao                | Dolinsky          | 51956          | 5
-Tzvetan            | Zielinski         | 74572          | 4
-Hironobu           | Haraldson         | 68431          | 4
-Mayumi             | Schueller         | 65367          | 4
-Parto              | Bamford           | 61805          | 4
-null               | Portugali         | 60781          | 4
-Moss               | Shanbhogue        | 74970          | 3
-Remzi              | Waschkowski       | 71165          | 3
-null               | Demeyer           | 67492          | 3
-Anoosh             | Peyn              | 65030          | 3
-Erez               | Ritzmann          | 62405          | 3
-Valter             | Sullins           | 73578          | 2
-Danel              | Mondadori         | 69904          | 2
-Kazuhito           | Cappelletti       | 61358          | 2
-Cristinel          | Bouloucos         | 58715          | 2
-Georgi             | Facello           | 57305          | 2
-Lillian            | Haddadi           | 73717          | 1
-null               | Merlo             | 70011          | 1
-Somnath            | Foote             | 68547          | 1
-Sumant             | Peac              | 66174          | 1
-Kyoichi            | Maliniak          | 63528          | 1
-Otmar              | Herbst            | 74999          | null
-Divier             | Reistad           | 73851          | null
-Suzette            | Pettey            | 64675          | null
-Ramzi              | Erde              | 60408          | null
-Shahaf             | Famili            | 48233          | null
+// tag::limitBy-result[]
+first_name:keyword | last_name:keyword | salary:integer | gender:keyword
+Otmar              | Herbst            | 74999          | M
+Tzvetan            | Zielinski         | 74572          | F
+Lillian            | Haddadi           | 73717          | null
+// end::limitBy-result[]
 ;
 
-sortLimitByMultiColumn
-required_capability: esql_topn_by
+docsLimitByMultipleGroups
+required_capability: limit_by
 
+// tag::limitByMultipleGroups[]
 FROM employees
 | SORT salary DESC
 | LIMIT 1 BY languages, gender
+// end::limitByMultipleGroups[]
+| SORT languages DESC NULLS LAST, gender DESC NULLS LAST, salary DESC
 | KEEP first_name, last_name, salary, languages, gender
-| LIMIT 10
-;
-
-first_name:keyword | last_name:keyword | salary:integer | languages:integer | gender:keyword
-Otmar              | Herbst            | 74999          | null              | M
-Moss               | Shanbhogue        | 74970          | 3                 | M
-Tzvetan            | Zielinski         | 74572          | 4                 | F
-Divier             | Reistad           | 73851          | null              | F
-Lillian            | Haddadi           | 73717          | 1                 | null
-Valter             | Sullins           | 73578          | 2                 | F
-null               | Merlo             | 70011          | 1                 | M
-Arumugam           | Ossenbruggen      | 66817          | 5                 | F
-Sumant             | Peac              | 66174          | 1                 | F
-Mayumi             | Schueller         | 65367          | 4                 | M
-;
-
-sortLimitByQualifiedName
-required_capability: esql_topn_by
-
-FROM employees
-| SORT salary DESC
-| LIMIT 1 BY [employees].[languages], [employees].[gender]
-| KEEP first_name, last_name, salary, languages, gender
-| LIMIT 10
-;
-
-first_name:keyword | last_name:keyword | salary:integer | languages:integer | gender:keyword
-Otmar              | Herbst            | 74999          | null              | M
-Moss               | Shanbhogue        | 74970          | 3                 | M
-Tzvetan            | Zielinski         | 74572          | 4                 | F
-Divier             | Reistad           | 73851          | null              | F
-Lillian            | Haddadi           | 73717          | 1                 | null
-Valter             | Sullins           | 73578          | 2                 | F
-null               | Merlo             | 70011          | 1                 | M
-Arumugam           | Ossenbruggen      | 66817          | 5                 | F
-Sumant             | Peac              | 66174          | 1                 | F
-Mayumi             | Schueller         | 65367          | 4                 | M
-;
-
-sortLimitByIsIdempotent
-required_capability: esql_topn_by
-
-FROM employees
-| SORT salary DESC
-| LIMIT 5 BY languages
-| SORT salary DESC
-| LIMIT 5 BY languages
-| KEEP first_name, last_name, salary, languages
-| SORT languages DESC nulls last, salary DESC, first_name, last_name
-;
-
-first_name:keyword | last_name:keyword | salary:integer | languages:integer
-Arumugam           | Ossenbruggen      | 66817          | 5
-Bezalel            | Simmel            | 56371          | 5
-Hironoby           | Sidou             | 54518          | 5
-Premal             | Baek              | 52833          | 5
-Gao                | Dolinsky          | 51956          | 5
-Tzvetan            | Zielinski         | 74572          | 4
-Hironobu           | Haraldson         | 68431          | 4
-Mayumi             | Schueller         | 65367          | 4
-Parto              | Bamford           | 61805          | 4
-null               | Portugali         | 60781          | 4
-Moss               | Shanbhogue        | 74970          | 3
-Remzi              | Waschkowski       | 71165          | 3
-null               | Demeyer           | 67492          | 3
-Anoosh             | Peyn              | 65030          | 3
-Erez               | Ritzmann          | 62405          | 3
-Valter             | Sullins           | 73578          | 2
-Danel              | Mondadori         | 69904          | 2
-Kazuhito           | Cappelletti       | 61358          | 2
-Cristinel          | Bouloucos         | 58715          | 2
-Georgi             | Facello           | 57305          | 2
-Lillian            | Haddadi           | 73717          | 1
-null               | Merlo             | 70011          | 1
-Somnath            | Foote             | 68547          | 1
-Sumant             | Peac              | 66174          | 1
-Kyoichi            | Maliniak          | 63528          | 1
-Otmar              | Herbst            | 74999          | null
-Divier             | Reistad           | 73851          | null
-Suzette            | Pettey            | 64675          | null
-Ramzi              | Erde              | 60408          | null
-Shahaf             | Famili            | 48233          | null
-;
-
-sortLimitByThenSortLimitBy
-required_capability: esql_topn_by
-
-FROM employees
-| SORT salary DESC
-| LIMIT 5 BY languages
-| SORT salary DESC
-| LIMIT 1 BY languages
-| KEEP first_name, last_name, salary, languages
-| SORT languages DESC nulls last
-;
-
-first_name:keyword | last_name:keyword | salary:integer | languages:integer
-Arumugam           | Ossenbruggen      | 66817          | 5
-Tzvetan            | Zielinski         | 74572          | 4
-Moss               | Shanbhogue        | 74970          | 3
-Valter             | Sullins           | 73578          | 2
-Lillian            | Haddadi           | 73717          | 1
-Otmar              | Herbst            | 74999          | null
-;
-
-sortLimitByZero
-required_capability: esql_topn_by
-
-FROM employees
-| SORT salary DESC
-| LIMIT 0 BY languages
-| KEEP first_name, last_name, salary, languages
-;
-
-first_name:keyword | last_name:keyword | salary:integer | languages:integer
-;
-
-sortLimitThenSortLimitBy
-required_capability: esql_topn_by
-
-FROM employees
-| SORT salary DESC
-| LIMIT 10
-| SORT salary DESC
-| LIMIT 1 BY languages
-| KEEP first_name, last_name, salary, languages
-| SORT languages DESC nulls last, salary DESC
-;
-
-first_name:keyword | last_name:keyword | salary:integer | languages:integer
-Tzvetan            | Zielinski         | 74572          | 4
-Moss               | Shanbhogue        | 74970          | 3
-Valter             | Sullins           | 73578          | 2
-Lillian            | Haddadi           | 73717          | 1
-Otmar              | Herbst            | 74999          | null
-;
-
-sortLimitByThenLimit
-required_capability: esql_topn_by
-
-FROM employees
-| SORT salary
-| LIMIT 5 BY languages
-| LIMIT 10
-| KEEP first_name, last_name, salary, languages
-;
-
-first_name:keyword | last_name:keyword | salary:integer | languages:integer
-Guoxiang           | Nooteboom         | 25324          | 5
-null               | Chappelet         | 25945          | 5
-Valdiodio          | Niizuma           | 25976          | 1
-Florian            | Syrotiuk          | 26436          | 3
-Ebbe               | Callaway          | 27215          | 4
-Tuval              | Kalloufi          | 28035          | 1
-Yongqiao           | Berztiss          | 28336          | null
-Charlene           | Brattka           | 28941          | 3
-Breannda           | Billingsley       | 29175          | 2
-Magy               | Stamatiou         | 30404          | 3
-;
-
-sortLimitByNullsFirst
-required_capability: esql_topn_by
-
-FROM employees
-| SORT is_rehired ASC NULLS FIRST, emp_no
-| LIMIT 2 BY languages
-| KEEP first_name, last_name, languages, is_rehired
-;
-
-first_name:keyword | last_name:keyword | languages:integer | is_rehired:boolean
-Parto              | Bamford           | 4                 | null
-Anneke             | Preusig           | 3                 | null
-Sumant             | Peac              | 1                 | null
-Berni              | Genin             | 5                 | null
-null               | Lortz             | 4                 | null
-Uri                | Lenart            | 1                 | null
-Magy               | Stamatiou         | 3                 | null
-Basil              | Tramer            | 5                 | null
-Georgi             | Facello           | 2                 | [false, true]
-Saniya             | Kalloufi          | 2                 | [false, true]
-Mayuko             | Warwick           | null              | [false, true, true]
-Shahaf             | Famili            | null              | [false, true]  
-;
-
-sortLimitByNullsLast
-required_capability: esql_topn_by
-
-FROM employees
-| SORT is_rehired ASC NULLS LAST, emp_no
-| LIMIT 2 BY languages
-| KEEP first_name, last_name, languages, is_rehired
-;
-
-first_name:keyword | last_name:keyword | languages:integer | is_rehired:boolean
-Georgi             | Facello           | 2                 | [false, true]
-Bezalel            | Simmel            | 5                 | [false, false]
-Kyoichi            | Maliniak          | 1                 | [false, false, false, true]
-Tzvetan            | Zielinski         | 4                 | [false, false, true, true]
-Saniya             | Kalloufi          | 2                 | [false, true]
-Duangkaew          | Piveteau          | 4                 | [false, false, true, true]
-Patricio           | Bridgland         | 5                 | [false, false, true, true]
-Lillian            | Haddadi           | 1                 | [false, false]
-Mayuko             | Warwick           | null              | [false, true, true]
-Shahaf             | Famili            | null              | [false, true]
-null               | Demeyer           | 3                 | [false, false, true]
-null               | Reistad           | 3                 | [false, false]        
-;
-
-sortLimitByExpression
-required_capability: esql_topn_by
-
-FROM employees
-| SORT salary DESC
-| LIMIT 5 BY languages * 2
-| KEEP first_name, last_name, salary, languages
-| SORT languages DESC nulls last, salary DESC
-;
-
-first_name:keyword | last_name:keyword | salary:integer | languages:integer
-Arumugam           | Ossenbruggen      | 66817          | 5
-Bezalel            | Simmel            | 56371          | 5
-Hironoby           | Sidou             | 54518          | 5
-Premal             | Baek              | 52833          | 5
-Gao                | Dolinsky          | 51956          | 5
-Tzvetan            | Zielinski         | 74572          | 4
-Hironobu           | Haraldson         | 68431          | 4
-Mayumi             | Schueller         | 65367          | 4
-Parto              | Bamford           | 61805          | 4
-null               | Portugali         | 60781          | 4
-Moss               | Shanbhogue        | 74970          | 3
-Remzi              | Waschkowski       | 71165          | 3
-null               | Demeyer           | 67492          | 3
-Anoosh             | Peyn              | 65030          | 3
-Erez               | Ritzmann          | 62405          | 3
-Valter             | Sullins           | 73578          | 2
-Danel              | Mondadori         | 69904          | 2
-Kazuhito           | Cappelletti       | 61358          | 2
-Cristinel          | Bouloucos         | 58715          | 2
-Georgi             | Facello           | 57305          | 2
-Lillian            | Haddadi           | 73717          | 1
-null               | Merlo             | 70011          | 1
-Somnath            | Foote             | 68547          | 1
-Sumant             | Peac              | 66174          | 1
-Kyoichi            | Maliniak          | 63528          | 1
-Otmar              | Herbst            | 74999          | null
-Divier             | Reistad           | 73851          | null
-Suzette            | Pettey            | 64675          | null
-Ramzi              | Erde              | 60408          | null
-Shahaf             | Famili            | 48233          | null
-;
-
-sortLimitByMixed
-required_capability: esql_topn_by
-
-FROM employees
-| SORT salary DESC
-| LIMIT 2 BY languages, gender
-| KEEP first_name, last_name, salary, languages, gender
-| SORT languages DESC nulls last, salary DESC
 ;
 
 first_name:keyword | last_name:keyword | salary:integer | languages:integer | gender:keyword
-Arumugam           | Ossenbruggen      | 66817          | 5                 | F
-Bezalel            | Simmel            | 56371          | 5                 | F
 Premal             | Baek              | 52833          | 5                 | M
-Georgy             | Dredge            | 49281          | 5                 | M
+Arumugam           | Ossenbruggen      | 66817          | 5                 | F
 Patricio           | Bridgland         | 48942          | 5                 | null
-Berni              | Genin             | 37137          | 5                 | null
-Tzvetan            | Zielinski         | 74572          | 4                 | F
-Hironobu           | Haraldson         | 68431          | 4                 | F
 Mayumi             | Schueller         | 65367          | 4                 | M
-Parto              | Bamford           | 61805          | 4                 | M
+Tzvetan            | Zielinski         | 74572          | 4                 | F
 Duangkaew          | Piveteau          | 45797          | 4                 | null
 Moss               | Shanbhogue        | 74970          | 3                 | M
-Remzi              | Waschkowski       | 71165          | 3                 | M
 Erez               | Ritzmann          | 62405          | 3                 | F
-null               | Reistad           | 62233          | 3                 | F
+Georgi             | Facello           | 57305          | 2                 | M
 Valter             | Sullins           | 73578          | 2                 | F
-Danel              | Mondadori         | 69904          | 2                 | F
 Kazuhito           | Cappelletti       | 61358          | 2                 | null
-Cristinel          | Bouloucos         | 58715          | 2                 | null
-Georgi             | Facello           | 57305          | 2                 | M
-Claudi             | Stavenow          | 52044          | 2                 | M
-Lillian            | Haddadi           | 73717          | 1                 | null
 null               | Merlo             | 70011          | 1                 | M
-Somnath            | Foote             | 68547          | 1                 | M
 Sumant             | Peac              | 66174          | 1                 | F
-Uri                | Lenart            | 56415          | 1                 | F
-Eberhardt          | Terkki            | 48735          | 1                 | null
+Lillian            | Haddadi           | 73717          | 1                 | null
 Otmar              | Herbst            | 74999          | null              | M
 Divier             | Reistad           | 73851          | null              | F
-Suzette            | Pettey            | 64675          | null              | F
-Ramzi              | Erde              | 60408          | null              | M
-;
-
-sortLimitByConstant
-required_capability: esql_topn_by
-
-FROM employees
-| SORT salary DESC
-| LIMIT 5 BY 20 * 5, 10
-| KEEP first_name, last_name, salary, languages
-;
-
-first_name:keyword | last_name:keyword | salary:integer | languages:integer
-Otmar              | Herbst            | 74999          | null
-Moss               | Shanbhogue        | 74970          | 3
-Tzvetan            | Zielinski         | 74572          | 4
-Divier             | Reistad           | 73851          | null
-Lillian            | Haddadi           | 73717          | 1
-;
-
-sortLimitByMixedFoldableAndAttribute
-required_capability: esql_topn_by
-
-FROM employees
-| SORT salary DESC
-| LIMIT 5 BY languages, 42
-| KEEP first_name, last_name, salary, languages
-| SORT languages DESC nulls last, salary DESC
-;
-
-first_name:keyword | last_name:keyword | salary:integer | languages:integer
-Arumugam           | Ossenbruggen      | 66817          | 5
-Bezalel            | Simmel            | 56371          | 5
-Hironoby           | Sidou             | 54518          | 5
-Premal             | Baek              | 52833          | 5
-Gao                | Dolinsky          | 51956          | 5
-Tzvetan            | Zielinski         | 74572          | 4
-Hironobu           | Haraldson         | 68431          | 4
-Mayumi             | Schueller         | 65367          | 4
-Parto              | Bamford           | 61805          | 4
-null               | Portugali         | 60781          | 4
-Moss               | Shanbhogue        | 74970          | 3
-Remzi              | Waschkowski       | 71165          | 3
-null               | Demeyer           | 67492          | 3
-Anoosh             | Peyn              | 65030          | 3
-Erez               | Ritzmann          | 62405          | 3
-Valter             | Sullins           | 73578          | 2
-Danel              | Mondadori         | 69904          | 2
-Kazuhito           | Cappelletti       | 61358          | 2
-Cristinel          | Bouloucos         | 58715          | 2
-Georgi             | Facello           | 57305          | 2
-Lillian            | Haddadi           | 73717          | 1
-null               | Merlo             | 70011          | 1
-Somnath            | Foote             | 68547          | 1
-Sumant             | Peac              | 66174          | 1
-Kyoichi            | Maliniak          | 63528          | 1
-Otmar              | Herbst            | 74999          | null
-Divier             | Reistad           | 73851          | null
-Suzette            | Pettey            | 64675          | null
-Ramzi              | Erde              | 60408          | null
-Shahaf             | Famili            | 48233          | null
-;
-
-sortLimitByMixedFoldableAndExpression
-required_capability: esql_topn_by
-
-FROM employees
-| SORT salary DESC
-| LIMIT 5 BY languages * 2, 42
-| KEEP first_name, last_name, salary, languages
-| SORT languages DESC nulls last, salary DESC
-;
-
-first_name:keyword | last_name:keyword | salary:integer | languages:integer
-Arumugam           | Ossenbruggen      | 66817          | 5
-Bezalel            | Simmel            | 56371          | 5
-Hironoby           | Sidou             | 54518          | 5
-Premal             | Baek              | 52833          | 5
-Gao                | Dolinsky          | 51956          | 5
-Tzvetan            | Zielinski         | 74572          | 4
-Hironobu           | Haraldson         | 68431          | 4
-Mayumi             | Schueller         | 65367          | 4
-Parto              | Bamford           | 61805          | 4
-null               | Portugali         | 60781          | 4
-Moss               | Shanbhogue        | 74970          | 3
-Remzi              | Waschkowski       | 71165          | 3
-null               | Demeyer           | 67492          | 3
-Anoosh             | Peyn              | 65030          | 3
-Erez               | Ritzmann          | 62405          | 3
-Valter             | Sullins           | 73578          | 2
-Danel              | Mondadori         | 69904          | 2
-Kazuhito           | Cappelletti       | 61358          | 2
-Cristinel          | Bouloucos         | 58715          | 2
-Georgi             | Facello           | 57305          | 2
-Lillian            | Haddadi           | 73717          | 1
-null               | Merlo             | 70011          | 1
-Somnath            | Foote             | 68547          | 1
-Sumant             | Peac              | 66174          | 1
-Kyoichi            | Maliniak          | 63528          | 1
-Otmar              | Herbst            | 74999          | null
-Divier             | Reistad           | 73851          | null
-Suzette            | Pettey            | 64675          | null
-Ramzi              | Erde              | 60408          | null
-Shahaf             | Famili            | 48233          | null
-;
-
-sortLimitBySeveralSorts
-required_capability: esql_topn_by
-
-FROM employees
-| SORT emp_no DESC
-| SORT salary DESC
-| LIMIT 5 BY languages
-| KEEP first_name, last_name, salary, languages
-;
-
-first_name:keyword | last_name:keyword | salary:integer | languages:integer
-Otmar              | Herbst            | 74999          | null
-Moss               | Shanbhogue        | 74970          | 3
-Tzvetan            | Zielinski         | 74572          | 4
-Divier             | Reistad           | 73851          | null
-Lillian            | Haddadi           | 73717          | 1
-Valter             | Sullins           | 73578          | 2
-Remzi              | Waschkowski       | 71165          | 3
-null               | Merlo             | 70011          | 1
-Danel              | Mondadori         | 69904          | 2
-Somnath            | Foote             | 68547          | 1
-Hironobu           | Haraldson         | 68431          | 4
-null               | Demeyer           | 67492          | 3
-Arumugam           | Ossenbruggen      | 66817          | 5
-Sumant             | Peac              | 66174          | 1
-Mayumi             | Schueller         | 65367          | 4
-Anoosh             | Peyn              | 65030          | 3
-Suzette            | Pettey            | 64675          | null
-Kyoichi            | Maliniak          | 63528          | 1
-Erez               | Ritzmann          | 62405          | 3
-Parto              | Bamford           | 61805          | 4
-Kazuhito           | Cappelletti       | 61358          | 2
-null               | Portugali         | 60781          | 4
-Ramzi              | Erde              | 60408          | null
-Cristinel          | Bouloucos         | 58715          | 2
-Georgi             | Facello           | 57305          | 2
-Bezalel            | Simmel            | 56371          | 5
-Hironoby           | Sidou             | 54518          | 5
-Premal             | Baek              | 52833          | 5
-Gao                | Dolinsky          | 51956          | 5
-Shahaf             | Famili            | 48233          | null
-;
-
-sortLimitByNonContiguousSorts
-required_capability: esql_topn_by
-
-FROM employees
-| SORT emp_no DESC
-| KEEP emp_no, salary, languages
-| SORT salary DESC
-| LIMIT 5 BY languages
-| KEEP emp_no, salary, languages
-| SORT languages DESC nulls last, salary DESC
-;
-
-emp_no:integer | salary:integer | languages:integer
-10094             | 66817          | 5
-10002             | 56371          | 5
-10072             | 54518          | 5
-10080             | 52833          | 5
-10075             | 51956          | 5
-10007             | 74572          | 4
-10100             | 68431          | 4
-10054             | 65367          | 4
-10003             | 61805          | 4
-10036             | 60781          | 4
-10045             | 74970          | 3
-10097             | 71165          | 3
-10030             | 67492          | 3
-10062             | 65030          | 3
-10076             | 62405          | 3
-10099             | 73578          | 2
-10078             | 69904          | 2
-10016             | 61358          | 2
-10017             | 58715          | 2
-10001             | 57305          | 2
-10019             | 73717          | 1
-10033             | 70011          | 1
-10086             | 68547          | 1
-10009             | 66174          | 1
-10005             | 63528          | 1
-10029             | 74999          | null
-10027             | 73851          | null
-10024             | 64675          | null
-10021             | 60408          | null
-10022             | 48233          | null
-;
-
-sortLimitByEvalAndNonEvalGroupings
-required_capability: esql_topn_by
-
-FROM employees
-| SORT emp_no DESC
-| KEEP emp_no, salary, languages, gender
-| SORT salary DESC
-| LIMIT 3 BY languages * 2, gender
-| SORT languages DESC nulls last, gender DESC nulls last, salary DESC
-;
-
-emp_no:integer | salary:integer | languages:integer | gender:keyword
-10080          | 52833          | 5                 | M
-10055          | 49281          | 5                 | M
-10077          | 46595          | 5                 | M
-10094          | 66817          | 5                 | F
-10002          | 56371          | 5                 | F
-10072          | 54518          | 5                 | F
-10012          | 48942          | 5                 | null
-10014          | 37137          | 5                 | null
-10011          | 31120          | 5                 | null
-10054          | 65367          | 4                 | M
-10003          | 61805          | 4                 | M
-10036          | 60781          | 4                 | M
-10007          | 74572          | 4                 | F
-10100          | 68431          | 4                 | F
-10098          | 44817          | 4                 | F
-10010          | 45797          | 4                 | null
-10045          | 74970          | 3                 | M
-10097          | 71165          | 3                 | M
-10030          | 67492          | 3                 | M
-10076          | 62405          | 3                 | F
-10032          | 62233          | 3                 | F
-10006          | 60335          | 3                 | F
-10001          | 57305          | 2                 | M
-10067          | 52044          | 2                 | M
-10065          | 50249          | 2                 | M
-10099          | 73578          | 2                 | F
-10078          | 69904          | 2                 | F
-10059          | 44307          | 2                 | F
-10016          | 61358          | 2                 | null
-10017          | 58715          | 2                 | null
-10018          | 56760          | 2                 | null
-10033          | 70011          | 1                 | M
-10086          | 68547          | 1                 | M
-10005          | 63528          | 1                 | M
-10009          | 66174          | 1                 | F
-10041          | 56415          | 1                 | F
-10044          | 39728          | 1                 | F
-10019          | 73717          | 1                 | null
-10013          | 48735          | 1                 | null
-10029          | 74999          | null              | M
-10021          | 60408          | null              | M
-10022          | 48233          | null              | M
-10027          | 73851          | null              | F
-10024          | 64675          | null              | F
-10023          | 47896          | null              | F
-;
-
-sortLimitByMultivalueGroupKeySimple
-required_capability: esql_topn_by
-
-ROW x = 1, g = [10, 20, 30]
-| SORT x DESC
-| LIMIT 1 BY g
-| SORT g ASC
-| KEEP x, g
-;
-
-x:integer | g:integer
-1         | [10, 20, 30]
-;
-
-sortLimitByMultivalueGroupKeySimpleFiltered
-required_capability: esql_topn_by
-
-ROW x = 1, g = [10, 20, 30]
-| SORT x DESC
-| LIMIT 1 BY g
-| WHERE g == 20
-| KEEP x, g
-;
-warning:Line 4:9: evaluation of [g == 20] failed, treating result as null. Only first 20 failures recorded.
-warning:Line 4:9: java.lang.IllegalArgumentException: single-value function encountered multi-value
-
-x:integer | g:integer
-;
-
-sortLimitByTwoMultivalueGroupKeysSimple
-required_capability: esql_topn_by
-
-ROW x = 1, g1 = [1, 2], g2 = [10, 20]
-| SORT x DESC
-| LIMIT 1 BY g1, g2
-| KEEP x, g1, g2
-| SORT g1 ASC, g2 ASC
-;
-
-x:integer | g1:integer | g2:integer
-1         | [1, 2]     | [10, 20]
-;
-
-sortLimitByMultivalueGroupKey
-required_capability: esql_topn_by
-
-FROM employees
-| WHERE emp_no IN (10001, 10002, 10006)
-| SORT salary DESC
-| LIMIT 2 BY job_positions
-| SORT emp_no, job_positions ASC
-| KEEP emp_no, first_name, salary, job_positions
-;
-
-emp_no:integer | first_name:keyword | salary:integer | job_positions:keyword
-10001          | Georgi             | 57305          | [Accountant, Senior Python Developer]
-10002          | Bezalel            | 56371          | [Senior Team Lead]
-10006          | Anneke             | 60335          | [Principal Support Engineer, Senior Team Lead, Tech Lead]
-;
-
-sortLimitByMultivalueGroupKeyFiltered
-required_capability: esql_topn_by
-
-FROM employees
-| WHERE emp_no IN (10001, 10002, 10006)
-| SORT salary DESC
-| LIMIT 1 BY job_positions
-| WHERE job_positions == "Senior Team Lead"
-| KEEP emp_no, first_name, salary, job_positions
-;
-warningRegex:Line 5:9: evaluation of \[job_positions == \\\"Senior Team Lead\\\"\] failed, treating result as null. Only first 20 failures recorded.
-warningRegex:Line 5:9: java.lang.IllegalArgumentException: single-value function encountered multi-value
-
-emp_no:integer | first_name:keyword | salary:integer | job_positions:keyword
-10002          | Bezalel            | 56371          | Senior Team Lead
-;
-
-sortLimitByMultivalueGroupKeyWithIntersection
-required_capability: esql_topn_by
-
-FROM employees
-| WHERE emp_no IN (10001, 10008)
-| SORT salary DESC
-| LIMIT 1 BY job_positions
-| KEEP emp_no, first_name, salary, job_positions
-;
-
-emp_no:integer | first_name:keyword | salary:integer | job_positions:keyword
-10001          | Georgi             | 57305          | [Accountant, Senior Python Developer]
-10008          | Saniya             | 43906          | [Internship, Junior Developer, Purchase Manager, Senior Python Developer]
-;
-
-sortLimitByMultipleMultivalueGroupKeys
-required_capability: esql_topn_by
-
-FROM employees
-| WHERE emp_no IN (10001, 10002)
-| SORT salary DESC
-| LIMIT 1 BY job_positions, is_rehired
-| KEEP emp_no, first_name, salary, job_positions, is_rehired
-;
-
-emp_no:integer | first_name:keyword | salary:integer | job_positions:keyword                 | is_rehired:boolean
-10001          | Georgi             | 57305          | [Accountant, Senior Python Developer] | [false, true]
-10002          | Bezalel            | 56371          | Senior Team Lead                      | [false, false]
-;
-
-sortLimitByWithLookupJoin
-required_capability: esql_topn_by
-required_capability: join_lookup_v12
-
-FROM employees
-| WHERE emp_no IN (10001, 10002, 10003, 10004, 10005)
-| EVAL language_code = languages
-| LOOKUP JOIN languages_lookup_non_unique_key ON language_code
-| SORT emp_no, language_code, language_name
-| LIMIT 2 BY emp_no
-| KEEP emp_no, language_code, language_name
-;
-
-emp_no:integer | language_code:integer | language_name:keyword
-10001          | 2                     | German
-10001          | 2                     | German
-10002          | 5                     | null
-10003          | 4                     | Quenya
-10004          | 5                     | null
-10005          | 1                     | English
-10005          | 1                     | English
-;
-
-sortLimitByShadowedNonJoinField
-required_capability: esql_topn_by
-required_capability: join_lookup_v12
-
-FROM employees
-| WHERE emp_no IN (10001, 10002, 10003, 10004, 10005)
-| EVAL language_code = languages
-| EVAL language_name = 2*salary
-| LOOKUP JOIN languages_lookup_non_unique_key ON language_code
-| SORT emp_no, language_code, language_name
-| LIMIT 2 BY language_name
-| KEEP emp_no, language_code, language_name
-;
-
-emp_no:integer | language_code:integer | language_name:keyword
-10001          | 2                     | German
-10001          | 2                     | German
-10002          | 5                     | null
-10003          | 4                     | Quenya
-10004          | 5                     | null
-10005          | 1                     | English
-10005          | 1                     | English
-;
-
-limitByWithEnrich
-required_capability: enrich_load
-required_capability: limit_by_enrich_fix
-
-FROM *
-| ENRICH languages_policy on street
-| KEEP abbrev, integer, year
-| LIMIT 1 BY abbrev
-| SORT abbrev
-| LIMIT 5
-;
-
-abbrev:keyword | integer:integer | year:integer
-ABJ            | null            | null
-ABQ            | null            | null
-ABV            | null            | null
-ACA            | null            | null
-ACC            | null            | null
-;
-
-limitByWithGrok
-required_capability: esql_topn_by
-
-FROM employees
-| SORT emp_no
-| GROK first_name "(?.)(?.*)"
-| LIMIT 2 BY first_letter
-| KEEP first_name, first_letter, emp_no
-| LIMIT 10
-;
-
-first_name:keyword | first_letter:keyword | emp_no:integer
-Georgi             | G                    | 10001
-Bezalel            | B                    | 10002
-Parto              | P                    | 10003
-Chirstian          | C                    | 10004
-Kyoichi            | K                    | 10005
-Anneke             | A                    | 10006
-Tzvetan            | T                    | 10007
-Saniya             | S                    | 10008
-Sumant             | S                    | 10009
-Duangkaew          | D                    | 10010
-;
-
-limitByWithUriParts
-required_capability: esql_topn_by
-
-FROM web_logs
-| SORT uri
-| URI_PARTS p = uri
-| LIMIT 1 BY p.domain
-| KEEP p.scheme, p.domain, p.path, p.query
-;
-
-p.scheme:keyword | p.domain:keyword   | p.path:keyword           | p.query:keyword
-null             | null               | /api/v1/users/123        | null
-ftp              | files.internal     | /data.zip                | null
-https            | discuss.elastic.co | /c/elasticsearch         | null
-https            | github.com         | /elastic/elasticsearch   | null
-https            | www.elastic.co     | /downloads/elasticsearch | null
-https            | www.google.com     | /search                  | q=elasticsearch
-https            | www.iana.org       | /domains/reserved        | null
-;
-
-limitByWithRerank
-required_capability: esql_topn_by
-required_capability: rerank
-required_capability: match_operator_colon
-
-FROM books
-| SORT book_no
-| LIMIT 5
-| RERANK "war and peace" ON title WITH { "inference_id" : "test_reranker" }
-| LIMIT 3 BY _score
-| KEEP book_no, title, author, _score
-;
-
-book_no:keyword | title:text                                            | author:text              | _score:double
-1211            | The brothers Karamazov                                | Fyodor Dostoevsky        | 0.04545454680919647
-1463            | Realms of Tolkien: Images of Middle-earth             | J. R. R. Tolkien         | 0.024390242993831635
-1502            | Selected Passages from Correspondence with Friends    | Nikolai Vasilevich Gogol | 0.019999999552965164
-1937            | The Best Short Stories of Dostoevsky (Modern Library) | Fyodor Dostoevsky        | 0.01886792480945587
-1985            | Brothers Karamazov                                    | Fyodor Dostoevsky        | 0.0555555559694767
 ;

From a433ae5ef82250a9db9899fbabb1f6e889ba3a0b Mon Sep 17 00:00:00 2001
From: ncordon 
Date: Wed, 1 Apr 2026 10:45:35 +0200
Subject: [PATCH 5/7] Fixes capability and things that were removed incorrectly

---
 .../src/main/resources/limit.csv-spec         | 1109 ++++++++++++++++-
 1 file changed, 1107 insertions(+), 2 deletions(-)

diff --git a/x-pack/plugin/esql/qa/testFixtures/src/main/resources/limit.csv-spec b/x-pack/plugin/esql/qa/testFixtures/src/main/resources/limit.csv-spec
index fdda25749cc8b..0379e0e2a01b5 100644
--- a/x-pack/plugin/esql/qa/testFixtures/src/main/resources/limit.csv-spec
+++ b/x-pack/plugin/esql/qa/testFixtures/src/main/resources/limit.csv-spec
@@ -15,8 +15,12 @@ emp_no:integer
 10005
 ;
 
+//
+// LIMIT BY
+//
+
 docsLimitBy
-required_capability: limit_by
+required_capability: esql_limit_by
 
 // tag::limitBy[]
 FROM employees
@@ -35,7 +39,7 @@ Lillian            | Haddadi           | 73717          | null
 ;
 
 docsLimitByMultipleGroups
-required_capability: limit_by
+required_capability: esql_limit_by
 
 // tag::limitByMultipleGroups[]
 FROM employees
@@ -64,3 +68,1104 @@ Lillian            | Haddadi           | 73717          | 1                 | nu
 Otmar              | Herbst            | 74999          | null              | M
 Divier             | Reistad           | 73851          | null              | F
 ;
+
+limitBy
+required_capability: esql_limit_by
+
+FROM employees
+| WHERE emp_no IN (10001, 10002, 10003, 10005, 10006)
+| SORT emp_no
+| LIMIT 1000
+| LIMIT 5 BY languages
+| KEEP emp_no, first_name, languages
+;
+
+emp_no:integer | first_name:keyword | languages:integer
+10001          | Georgi             | 2
+10002          | Bezalel            | 5
+10003          | Parto              | 4
+10005          | Kyoichi            | 1
+10006          | Anneke             | 3
+;
+
+limitByLimit0
+required_capability: esql_limit_by
+
+FROM employees
+| WHERE emp_no IN (10001, 10002, 10003)
+| SORT emp_no
+| LIMIT 1000
+| LIMIT 0 BY languages
+| KEEP emp_no, languages
+;
+
+emp_no:integer | languages:integer
+;
+
+limitByMultipleColumns
+required_capability: esql_limit_by
+
+FROM employees
+| WHERE emp_no IN (10001, 10003, 10004, 10007)
+| SORT emp_no
+| LIMIT 1000
+| LIMIT 5 BY languages, gender
+| KEEP emp_no, first_name, languages, gender
+;
+
+emp_no:integer | first_name:keyword | languages:integer | gender:keyword
+10001          | Georgi             | 2                 | M
+10003          | Parto              | 4                 | M
+10004          | Chirstian          | 5                 | M
+10007          | Tzvetan            | 4                 | F
+;
+
+limitByWithExpression
+required_capability: esql_limit_by
+
+FROM employees
+| WHERE emp_no IN (10001, 10002, 10003, 10004, 10005)
+| SORT emp_no
+| LIMIT 1000
+| LIMIT 5 BY languages * 2
+| KEEP emp_no, first_name, languages
+;
+
+emp_no:integer | first_name:keyword | languages:integer
+10001          | Georgi             | 2
+10002          | Bezalel            | 5
+10003          | Parto              | 4
+10004          | Chirstian          | 5
+10005          | Kyoichi            | 1
+;
+
+limitByMultivalueGroupKey
+required_capability: esql_limit_by
+
+FROM employees
+| WHERE emp_no IN (10001, 10008)
+| SORT emp_no
+| LIMIT 1000
+| LIMIT 5 BY job_positions
+| KEEP emp_no, first_name, job_positions
+;
+
+emp_no:integer | first_name:keyword | job_positions:keyword
+10001          | Georgi             | [Accountant, Senior Python Developer]
+10008          | Saniya             | [Internship, Junior Developer, Purchase Manager, Senior Python Developer]
+;
+
+limitByNullGroup
+required_capability: esql_limit_by
+
+FROM employees
+| WHERE emp_no IN (10001, 10020)
+| SORT emp_no
+| LIMIT 1000
+| LIMIT 5 BY languages
+| KEEP emp_no, first_name, languages
+;
+
+emp_no:integer | first_name:keyword | languages:integer
+10001          | Georgi             | 2
+10020          | Mayuko             | null
+;
+
+limitByConstant
+required_capability: esql_limit_by
+
+FROM employees
+| WHERE emp_no IN (10001, 10002, 10003, 10005, 10006)
+| SORT emp_no
+| LIMIT 1000
+| LIMIT 2 BY 5*42
+| KEEP emp_no, first_name, languages
+;
+
+emp_no:integer | first_name:keyword | languages:integer
+10001          | Georgi             | 2
+10002          | Bezalel            | 5
+;
+
+limitByWithExpressionAndConstant
+required_capability: esql_limit_by
+
+FROM employees
+| WHERE emp_no IN (10001, 10002, 10003, 10004, 10005)
+| SORT emp_no
+| LIMIT 1000
+| LIMIT 5 BY languages * 2, 20 - 5 * 2
+| KEEP emp_no, first_name, languages
+;
+
+emp_no:integer | first_name:keyword | languages:integer
+10001          | Georgi             | 2
+10002          | Bezalel            | 5
+10003          | Parto              | 4
+10004          | Chirstian          | 5
+10005          | Kyoichi            | 1
+;
+
+limitByWithAlias
+required_capability: esql_limit_by
+
+FROM employees
+| WHERE emp_no IN (10001, 10002, 10003, 10004, 10005)
+| SORT emp_no
+| LIMIT 1000
+| EVAL g = languages * 2
+| LIMIT 5 BY g
+| KEEP emp_no, first_name, languages
+;
+
+emp_no:integer | first_name:keyword | languages:integer
+10001          | Georgi             | 2
+10002          | Bezalel            | 5
+10003          | Parto              | 4
+10004          | Chirstian          | 5
+10005          | Kyoichi            | 1
+;
+
+limitByThenStats
+required_capability: esql_limit_by
+
+FROM employees
+| LIMIT 2 BY languages
+| STATS c = COUNT(*) BY languages
+| SORT languages ASC NULLS LAST
+;
+
+c:long | languages:integer
+2      | 1
+2      | 2
+2      | 3
+2      | 4
+2      | 5
+2      | null
+;
+
+limitByPrecededByStats
+required_capability: esql_limit_by
+
+FROM employees
+| STATS cnt=COUNT(*) BY job_positions, languages
+| SORT job_positions, cnt DESC, languages
+| LIMIT 1000
+| LIMIT 1 BY job_positions
+| LIMIT 5
+;
+
+cnt:long | job_positions:keyword | languages:integer
+5        | Accountant            | 2
+5        | Architect             | 4
+4        | Business Analyst      | 2
+3        | Data Scientist        | 1
+5        | Head Human Resources  | 5
+;
+
+limitByWithLookupJoin
+required_capability: esql_limit_by
+required_capability: join_lookup_v12
+
+FROM employees
+| WHERE emp_no IN (10001, 10002, 10003, 10004, 10005)
+| EVAL language_code = languages
+| LOOKUP JOIN languages_lookup_non_unique_key ON language_code
+| SORT emp_no, language_code, language_name
+| LIMIT 1000
+| LIMIT 2 BY emp_no
+| KEEP emp_no, language_code, language_name
+;
+
+emp_no:integer | language_code:integer | language_name:keyword
+10001          | 2                     | German
+10001          | 2                     | German
+10002          | 5                     | null
+10003          | 4                     | Quenya
+10004          | 5                     | null
+10005          | 1                     | English
+10005          | 1                     | English
+;
+
+limitByShadowedNonJoinField
+required_capability: esql_limit_by
+required_capability: join_lookup_v12
+
+FROM employees
+| WHERE emp_no IN (10001, 10002, 10003, 10004, 10005)
+| EVAL language_code = languages
+| EVAL language_name = 2*salary
+| LOOKUP JOIN languages_lookup_non_unique_key ON language_code
+| SORT emp_no, language_code, language_name
+| LIMIT 1000
+| LIMIT 2 BY language_name
+| KEEP emp_no, language_code, language_name
+;
+
+emp_no:integer | language_code:integer | language_name:keyword
+10001          | 2                     | German
+10001          | 2                     | German
+10002          | 5                     | null
+10003          | 4                     | Quenya
+10004          | 5                     | null
+10005          | 1                     | English
+10005          | 1                     | English
+;
+
+limitByShadowedJoinField
+required_capability: esql_limit_by
+required_capability: join_lookup_v12
+
+FROM employees
+| WHERE emp_no IN (10001, 10002, 10003, 10004, 10005)
+| EVAL language_code = languages
+| LOOKUP JOIN languages_lookup_non_unique_key ON language_code
+| SORT emp_no, language_code, language_name
+| LIMIT 1000
+| LIMIT 2 BY language_code
+| KEEP emp_no, language_code, language_name
+;
+
+emp_no:integer | language_code:integer | language_name:keyword
+10001          | 2                     | German
+10001          | 2                     | German
+10002          | 5                     | null
+10003          | 4                     | Quenya
+10004          | 5                     | null
+10005          | 1                     | English
+10005          | 1                     | English
+;
+
+sortLimitBy
+required_capability: esql_topn_by
+
+FROM employees
+| SORT salary DESC
+| LIMIT 5 BY languages
+| KEEP first_name, last_name, salary, languages
+| SORT languages DESC nulls last, salary DESC
+;
+
+first_name:keyword | last_name:keyword | salary:integer | languages:integer
+Arumugam           | Ossenbruggen      | 66817          | 5
+Bezalel            | Simmel            | 56371          | 5
+Hironoby           | Sidou             | 54518          | 5
+Premal             | Baek              | 52833          | 5
+Gao                | Dolinsky          | 51956          | 5
+Tzvetan            | Zielinski         | 74572          | 4
+Hironobu           | Haraldson         | 68431          | 4
+Mayumi             | Schueller         | 65367          | 4
+Parto              | Bamford           | 61805          | 4
+null               | Portugali         | 60781          | 4
+Moss               | Shanbhogue        | 74970          | 3
+Remzi              | Waschkowski       | 71165          | 3
+null               | Demeyer           | 67492          | 3
+Anoosh             | Peyn              | 65030          | 3
+Erez               | Ritzmann          | 62405          | 3
+Valter             | Sullins           | 73578          | 2
+Danel              | Mondadori         | 69904          | 2
+Kazuhito           | Cappelletti       | 61358          | 2
+Cristinel          | Bouloucos         | 58715          | 2
+Georgi             | Facello           | 57305          | 2
+Lillian            | Haddadi           | 73717          | 1
+null               | Merlo             | 70011          | 1
+Somnath            | Foote             | 68547          | 1
+Sumant             | Peac              | 66174          | 1
+Kyoichi            | Maliniak          | 63528          | 1
+Otmar              | Herbst            | 74999          | null
+Divier             | Reistad           | 73851          | null
+Suzette            | Pettey            | 64675          | null
+Ramzi              | Erde              | 60408          | null
+Shahaf             | Famili            | 48233          | null
+;
+
+sortLimitByMultiColumn
+required_capability: esql_topn_by
+
+FROM employees
+| SORT salary DESC
+| LIMIT 1 BY languages, gender
+| KEEP first_name, last_name, salary, languages, gender
+| LIMIT 10
+;
+
+first_name:keyword | last_name:keyword | salary:integer | languages:integer | gender:keyword
+Otmar              | Herbst            | 74999          | null              | M
+Moss               | Shanbhogue        | 74970          | 3                 | M
+Tzvetan            | Zielinski         | 74572          | 4                 | F
+Divier             | Reistad           | 73851          | null              | F
+Lillian            | Haddadi           | 73717          | 1                 | null
+Valter             | Sullins           | 73578          | 2                 | F
+null               | Merlo             | 70011          | 1                 | M
+Arumugam           | Ossenbruggen      | 66817          | 5                 | F
+Sumant             | Peac              | 66174          | 1                 | F
+Mayumi             | Schueller         | 65367          | 4                 | M
+;
+
+sortLimitByQualifiedName
+required_capability: esql_topn_by
+
+FROM employees
+| SORT salary DESC
+| LIMIT 1 BY [employees].[languages], [employees].[gender]
+| KEEP first_name, last_name, salary, languages, gender
+| LIMIT 10
+;
+
+first_name:keyword | last_name:keyword | salary:integer | languages:integer | gender:keyword
+Otmar              | Herbst            | 74999          | null              | M
+Moss               | Shanbhogue        | 74970          | 3                 | M
+Tzvetan            | Zielinski         | 74572          | 4                 | F
+Divier             | Reistad           | 73851          | null              | F
+Lillian            | Haddadi           | 73717          | 1                 | null
+Valter             | Sullins           | 73578          | 2                 | F
+null               | Merlo             | 70011          | 1                 | M
+Arumugam           | Ossenbruggen      | 66817          | 5                 | F
+Sumant             | Peac              | 66174          | 1                 | F
+Mayumi             | Schueller         | 65367          | 4                 | M
+;
+
+sortLimitByIsIdempotent
+required_capability: esql_topn_by
+
+FROM employees
+| SORT salary DESC
+| LIMIT 5 BY languages
+| SORT salary DESC
+| LIMIT 5 BY languages
+| KEEP first_name, last_name, salary, languages
+| SORT languages DESC nulls last, salary DESC, first_name, last_name
+;
+
+first_name:keyword | last_name:keyword | salary:integer | languages:integer
+Arumugam           | Ossenbruggen      | 66817          | 5
+Bezalel            | Simmel            | 56371          | 5
+Hironoby           | Sidou             | 54518          | 5
+Premal             | Baek              | 52833          | 5
+Gao                | Dolinsky          | 51956          | 5
+Tzvetan            | Zielinski         | 74572          | 4
+Hironobu           | Haraldson         | 68431          | 4
+Mayumi             | Schueller         | 65367          | 4
+Parto              | Bamford           | 61805          | 4
+null               | Portugali         | 60781          | 4
+Moss               | Shanbhogue        | 74970          | 3
+Remzi              | Waschkowski       | 71165          | 3
+null               | Demeyer           | 67492          | 3
+Anoosh             | Peyn              | 65030          | 3
+Erez               | Ritzmann          | 62405          | 3
+Valter             | Sullins           | 73578          | 2
+Danel              | Mondadori         | 69904          | 2
+Kazuhito           | Cappelletti       | 61358          | 2
+Cristinel          | Bouloucos         | 58715          | 2
+Georgi             | Facello           | 57305          | 2
+Lillian            | Haddadi           | 73717          | 1
+null               | Merlo             | 70011          | 1
+Somnath            | Foote             | 68547          | 1
+Sumant             | Peac              | 66174          | 1
+Kyoichi            | Maliniak          | 63528          | 1
+Otmar              | Herbst            | 74999          | null
+Divier             | Reistad           | 73851          | null
+Suzette            | Pettey            | 64675          | null
+Ramzi              | Erde              | 60408          | null
+Shahaf             | Famili            | 48233          | null
+;
+
+sortLimitByThenSortLimitBy
+required_capability: esql_topn_by
+
+FROM employees
+| SORT salary DESC
+| LIMIT 5 BY languages
+| SORT salary DESC
+| LIMIT 1 BY languages
+| KEEP first_name, last_name, salary, languages
+| SORT languages DESC nulls last
+;
+
+first_name:keyword | last_name:keyword | salary:integer | languages:integer
+Arumugam           | Ossenbruggen      | 66817          | 5
+Tzvetan            | Zielinski         | 74572          | 4
+Moss               | Shanbhogue        | 74970          | 3
+Valter             | Sullins           | 73578          | 2
+Lillian            | Haddadi           | 73717          | 1
+Otmar              | Herbst            | 74999          | null
+;
+
+sortLimitByZero
+required_capability: esql_topn_by
+
+FROM employees
+| SORT salary DESC
+| LIMIT 0 BY languages
+| KEEP first_name, last_name, salary, languages
+;
+
+first_name:keyword | last_name:keyword | salary:integer | languages:integer
+;
+
+sortLimitThenSortLimitBy
+required_capability: esql_topn_by
+
+FROM employees
+| SORT salary DESC
+| LIMIT 10
+| SORT salary DESC
+| LIMIT 1 BY languages
+| KEEP first_name, last_name, salary, languages
+| SORT languages DESC nulls last, salary DESC
+;
+
+first_name:keyword | last_name:keyword | salary:integer | languages:integer
+Tzvetan            | Zielinski         | 74572          | 4
+Moss               | Shanbhogue        | 74970          | 3
+Valter             | Sullins           | 73578          | 2
+Lillian            | Haddadi           | 73717          | 1
+Otmar              | Herbst            | 74999          | null
+;
+
+sortLimitByThenLimit
+required_capability: esql_topn_by
+
+FROM employees
+| SORT salary
+| LIMIT 5 BY languages
+| LIMIT 10
+| KEEP first_name, last_name, salary, languages
+;
+
+first_name:keyword | last_name:keyword | salary:integer | languages:integer
+Guoxiang           | Nooteboom         | 25324          | 5
+null               | Chappelet         | 25945          | 5
+Valdiodio          | Niizuma           | 25976          | 1
+Florian            | Syrotiuk          | 26436          | 3
+Ebbe               | Callaway          | 27215          | 4
+Tuval              | Kalloufi          | 28035          | 1
+Yongqiao           | Berztiss          | 28336          | null
+Charlene           | Brattka           | 28941          | 3
+Breannda           | Billingsley       | 29175          | 2
+Magy               | Stamatiou         | 30404          | 3
+;
+
+sortLimitByNullsFirst
+required_capability: esql_topn_by
+
+FROM employees
+| SORT is_rehired ASC NULLS FIRST, emp_no
+| LIMIT 2 BY languages
+| KEEP first_name, last_name, languages, is_rehired
+;
+
+first_name:keyword | last_name:keyword | languages:integer | is_rehired:boolean
+Parto              | Bamford           | 4                 | null
+Anneke             | Preusig           | 3                 | null
+Sumant             | Peac              | 1                 | null
+Berni              | Genin             | 5                 | null
+null               | Lortz             | 4                 | null
+Uri                | Lenart            | 1                 | null
+Magy               | Stamatiou         | 3                 | null
+Basil              | Tramer            | 5                 | null
+Georgi             | Facello           | 2                 | [false, true]
+Saniya             | Kalloufi          | 2                 | [false, true]
+Mayuko             | Warwick           | null              | [false, true, true]
+Shahaf             | Famili            | null              | [false, true]  
+;
+
+sortLimitByNullsLast
+required_capability: esql_topn_by
+
+FROM employees
+| SORT is_rehired ASC NULLS LAST, emp_no
+| LIMIT 2 BY languages
+| KEEP first_name, last_name, languages, is_rehired
+;
+
+first_name:keyword | last_name:keyword | languages:integer | is_rehired:boolean
+Georgi             | Facello           | 2                 | [false, true]
+Bezalel            | Simmel            | 5                 | [false, false]
+Kyoichi            | Maliniak          | 1                 | [false, false, false, true]
+Tzvetan            | Zielinski         | 4                 | [false, false, true, true]
+Saniya             | Kalloufi          | 2                 | [false, true]
+Duangkaew          | Piveteau          | 4                 | [false, false, true, true]
+Patricio           | Bridgland         | 5                 | [false, false, true, true]
+Lillian            | Haddadi           | 1                 | [false, false]
+Mayuko             | Warwick           | null              | [false, true, true]
+Shahaf             | Famili            | null              | [false, true]
+null               | Demeyer           | 3                 | [false, false, true]
+null               | Reistad           | 3                 | [false, false]        
+;
+
+sortLimitByExpression
+required_capability: esql_topn_by
+
+FROM employees
+| SORT salary DESC
+| LIMIT 5 BY languages * 2
+| KEEP first_name, last_name, salary, languages
+| SORT languages DESC nulls last, salary DESC
+;
+
+first_name:keyword | last_name:keyword | salary:integer | languages:integer
+Arumugam           | Ossenbruggen      | 66817          | 5
+Bezalel            | Simmel            | 56371          | 5
+Hironoby           | Sidou             | 54518          | 5
+Premal             | Baek              | 52833          | 5
+Gao                | Dolinsky          | 51956          | 5
+Tzvetan            | Zielinski         | 74572          | 4
+Hironobu           | Haraldson         | 68431          | 4
+Mayumi             | Schueller         | 65367          | 4
+Parto              | Bamford           | 61805          | 4
+null               | Portugali         | 60781          | 4
+Moss               | Shanbhogue        | 74970          | 3
+Remzi              | Waschkowski       | 71165          | 3
+null               | Demeyer           | 67492          | 3
+Anoosh             | Peyn              | 65030          | 3
+Erez               | Ritzmann          | 62405          | 3
+Valter             | Sullins           | 73578          | 2
+Danel              | Mondadori         | 69904          | 2
+Kazuhito           | Cappelletti       | 61358          | 2
+Cristinel          | Bouloucos         | 58715          | 2
+Georgi             | Facello           | 57305          | 2
+Lillian            | Haddadi           | 73717          | 1
+null               | Merlo             | 70011          | 1
+Somnath            | Foote             | 68547          | 1
+Sumant             | Peac              | 66174          | 1
+Kyoichi            | Maliniak          | 63528          | 1
+Otmar              | Herbst            | 74999          | null
+Divier             | Reistad           | 73851          | null
+Suzette            | Pettey            | 64675          | null
+Ramzi              | Erde              | 60408          | null
+Shahaf             | Famili            | 48233          | null
+;
+
+sortLimitByMixed
+required_capability: esql_topn_by
+
+FROM employees
+| SORT salary DESC
+| LIMIT 2 BY languages, gender
+| KEEP first_name, last_name, salary, languages, gender
+| SORT languages DESC nulls last, salary DESC
+;
+
+first_name:keyword | last_name:keyword | salary:integer | languages:integer | gender:keyword
+Arumugam           | Ossenbruggen      | 66817          | 5                 | F
+Bezalel            | Simmel            | 56371          | 5                 | F
+Premal             | Baek              | 52833          | 5                 | M
+Georgy             | Dredge            | 49281          | 5                 | M
+Patricio           | Bridgland         | 48942          | 5                 | null
+Berni              | Genin             | 37137          | 5                 | null
+Tzvetan            | Zielinski         | 74572          | 4                 | F
+Hironobu           | Haraldson         | 68431          | 4                 | F
+Mayumi             | Schueller         | 65367          | 4                 | M
+Parto              | Bamford           | 61805          | 4                 | M
+Duangkaew          | Piveteau          | 45797          | 4                 | null
+Moss               | Shanbhogue        | 74970          | 3                 | M
+Remzi              | Waschkowski       | 71165          | 3                 | M
+Erez               | Ritzmann          | 62405          | 3                 | F
+null               | Reistad           | 62233          | 3                 | F
+Valter             | Sullins           | 73578          | 2                 | F
+Danel              | Mondadori         | 69904          | 2                 | F
+Kazuhito           | Cappelletti       | 61358          | 2                 | null
+Cristinel          | Bouloucos         | 58715          | 2                 | null
+Georgi             | Facello           | 57305          | 2                 | M
+Claudi             | Stavenow          | 52044          | 2                 | M
+Lillian            | Haddadi           | 73717          | 1                 | null
+null               | Merlo             | 70011          | 1                 | M
+Somnath            | Foote             | 68547          | 1                 | M
+Sumant             | Peac              | 66174          | 1                 | F
+Uri                | Lenart            | 56415          | 1                 | F
+Eberhardt          | Terkki            | 48735          | 1                 | null
+Otmar              | Herbst            | 74999          | null              | M
+Divier             | Reistad           | 73851          | null              | F
+Suzette            | Pettey            | 64675          | null              | F
+Ramzi              | Erde              | 60408          | null              | M
+;
+
+sortLimitByConstant
+required_capability: esql_topn_by
+
+FROM employees
+| SORT salary DESC
+| LIMIT 5 BY 20 * 5, 10
+| KEEP first_name, last_name, salary, languages
+;
+
+first_name:keyword | last_name:keyword | salary:integer | languages:integer
+Otmar              | Herbst            | 74999          | null
+Moss               | Shanbhogue        | 74970          | 3
+Tzvetan            | Zielinski         | 74572          | 4
+Divier             | Reistad           | 73851          | null
+Lillian            | Haddadi           | 73717          | 1
+;
+
+sortLimitByMixedFoldableAndAttribute
+required_capability: esql_topn_by
+
+FROM employees
+| SORT salary DESC
+| LIMIT 5 BY languages, 42
+| KEEP first_name, last_name, salary, languages
+| SORT languages DESC nulls last, salary DESC
+;
+
+first_name:keyword | last_name:keyword | salary:integer | languages:integer
+Arumugam           | Ossenbruggen      | 66817          | 5
+Bezalel            | Simmel            | 56371          | 5
+Hironoby           | Sidou             | 54518          | 5
+Premal             | Baek              | 52833          | 5
+Gao                | Dolinsky          | 51956          | 5
+Tzvetan            | Zielinski         | 74572          | 4
+Hironobu           | Haraldson         | 68431          | 4
+Mayumi             | Schueller         | 65367          | 4
+Parto              | Bamford           | 61805          | 4
+null               | Portugali         | 60781          | 4
+Moss               | Shanbhogue        | 74970          | 3
+Remzi              | Waschkowski       | 71165          | 3
+null               | Demeyer           | 67492          | 3
+Anoosh             | Peyn              | 65030          | 3
+Erez               | Ritzmann          | 62405          | 3
+Valter             | Sullins           | 73578          | 2
+Danel              | Mondadori         | 69904          | 2
+Kazuhito           | Cappelletti       | 61358          | 2
+Cristinel          | Bouloucos         | 58715          | 2
+Georgi             | Facello           | 57305          | 2
+Lillian            | Haddadi           | 73717          | 1
+null               | Merlo             | 70011          | 1
+Somnath            | Foote             | 68547          | 1
+Sumant             | Peac              | 66174          | 1
+Kyoichi            | Maliniak          | 63528          | 1
+Otmar              | Herbst            | 74999          | null
+Divier             | Reistad           | 73851          | null
+Suzette            | Pettey            | 64675          | null
+Ramzi              | Erde              | 60408          | null
+Shahaf             | Famili            | 48233          | null
+;
+
+sortLimitByMixedFoldableAndExpression
+required_capability: esql_topn_by
+
+FROM employees
+| SORT salary DESC
+| LIMIT 5 BY languages * 2, 42
+| KEEP first_name, last_name, salary, languages
+| SORT languages DESC nulls last, salary DESC
+;
+
+first_name:keyword | last_name:keyword | salary:integer | languages:integer
+Arumugam           | Ossenbruggen      | 66817          | 5
+Bezalel            | Simmel            | 56371          | 5
+Hironoby           | Sidou             | 54518          | 5
+Premal             | Baek              | 52833          | 5
+Gao                | Dolinsky          | 51956          | 5
+Tzvetan            | Zielinski         | 74572          | 4
+Hironobu           | Haraldson         | 68431          | 4
+Mayumi             | Schueller         | 65367          | 4
+Parto              | Bamford           | 61805          | 4
+null               | Portugali         | 60781          | 4
+Moss               | Shanbhogue        | 74970          | 3
+Remzi              | Waschkowski       | 71165          | 3
+null               | Demeyer           | 67492          | 3
+Anoosh             | Peyn              | 65030          | 3
+Erez               | Ritzmann          | 62405          | 3
+Valter             | Sullins           | 73578          | 2
+Danel              | Mondadori         | 69904          | 2
+Kazuhito           | Cappelletti       | 61358          | 2
+Cristinel          | Bouloucos         | 58715          | 2
+Georgi             | Facello           | 57305          | 2
+Lillian            | Haddadi           | 73717          | 1
+null               | Merlo             | 70011          | 1
+Somnath            | Foote             | 68547          | 1
+Sumant             | Peac              | 66174          | 1
+Kyoichi            | Maliniak          | 63528          | 1
+Otmar              | Herbst            | 74999          | null
+Divier             | Reistad           | 73851          | null
+Suzette            | Pettey            | 64675          | null
+Ramzi              | Erde              | 60408          | null
+Shahaf             | Famili            | 48233          | null
+;
+
+sortLimitBySeveralSorts
+required_capability: esql_topn_by
+
+FROM employees
+| SORT emp_no DESC
+| SORT salary DESC
+| LIMIT 5 BY languages
+| KEEP first_name, last_name, salary, languages
+;
+
+first_name:keyword | last_name:keyword | salary:integer | languages:integer
+Otmar              | Herbst            | 74999          | null
+Moss               | Shanbhogue        | 74970          | 3
+Tzvetan            | Zielinski         | 74572          | 4
+Divier             | Reistad           | 73851          | null
+Lillian            | Haddadi           | 73717          | 1
+Valter             | Sullins           | 73578          | 2
+Remzi              | Waschkowski       | 71165          | 3
+null               | Merlo             | 70011          | 1
+Danel              | Mondadori         | 69904          | 2
+Somnath            | Foote             | 68547          | 1
+Hironobu           | Haraldson         | 68431          | 4
+null               | Demeyer           | 67492          | 3
+Arumugam           | Ossenbruggen      | 66817          | 5
+Sumant             | Peac              | 66174          | 1
+Mayumi             | Schueller         | 65367          | 4
+Anoosh             | Peyn              | 65030          | 3
+Suzette            | Pettey            | 64675          | null
+Kyoichi            | Maliniak          | 63528          | 1
+Erez               | Ritzmann          | 62405          | 3
+Parto              | Bamford           | 61805          | 4
+Kazuhito           | Cappelletti       | 61358          | 2
+null               | Portugali         | 60781          | 4
+Ramzi              | Erde              | 60408          | null
+Cristinel          | Bouloucos         | 58715          | 2
+Georgi             | Facello           | 57305          | 2
+Bezalel            | Simmel            | 56371          | 5
+Hironoby           | Sidou             | 54518          | 5
+Premal             | Baek              | 52833          | 5
+Gao                | Dolinsky          | 51956          | 5
+Shahaf             | Famili            | 48233          | null
+;
+
+sortLimitByNonContiguousSorts
+required_capability: esql_topn_by
+
+FROM employees
+| SORT emp_no DESC
+| KEEP emp_no, salary, languages
+| SORT salary DESC
+| LIMIT 5 BY languages
+| KEEP emp_no, salary, languages
+| SORT languages DESC nulls last, salary DESC
+;
+
+emp_no:integer | salary:integer | languages:integer
+10094             | 66817          | 5
+10002             | 56371          | 5
+10072             | 54518          | 5
+10080             | 52833          | 5
+10075             | 51956          | 5
+10007             | 74572          | 4
+10100             | 68431          | 4
+10054             | 65367          | 4
+10003             | 61805          | 4
+10036             | 60781          | 4
+10045             | 74970          | 3
+10097             | 71165          | 3
+10030             | 67492          | 3
+10062             | 65030          | 3
+10076             | 62405          | 3
+10099             | 73578          | 2
+10078             | 69904          | 2
+10016             | 61358          | 2
+10017             | 58715          | 2
+10001             | 57305          | 2
+10019             | 73717          | 1
+10033             | 70011          | 1
+10086             | 68547          | 1
+10009             | 66174          | 1
+10005             | 63528          | 1
+10029             | 74999          | null
+10027             | 73851          | null
+10024             | 64675          | null
+10021             | 60408          | null
+10022             | 48233          | null
+;
+
+sortLimitByEvalAndNonEvalGroupings
+required_capability: esql_topn_by
+
+FROM employees
+| SORT emp_no DESC
+| KEEP emp_no, salary, languages, gender
+| SORT salary DESC
+| LIMIT 3 BY languages * 2, gender
+| SORT languages DESC nulls last, gender DESC nulls last, salary DESC
+;
+
+emp_no:integer | salary:integer | languages:integer | gender:keyword
+10080          | 52833          | 5                 | M
+10055          | 49281          | 5                 | M
+10077          | 46595          | 5                 | M
+10094          | 66817          | 5                 | F
+10002          | 56371          | 5                 | F
+10072          | 54518          | 5                 | F
+10012          | 48942          | 5                 | null
+10014          | 37137          | 5                 | null
+10011          | 31120          | 5                 | null
+10054          | 65367          | 4                 | M
+10003          | 61805          | 4                 | M
+10036          | 60781          | 4                 | M
+10007          | 74572          | 4                 | F
+10100          | 68431          | 4                 | F
+10098          | 44817          | 4                 | F
+10010          | 45797          | 4                 | null
+10045          | 74970          | 3                 | M
+10097          | 71165          | 3                 | M
+10030          | 67492          | 3                 | M
+10076          | 62405          | 3                 | F
+10032          | 62233          | 3                 | F
+10006          | 60335          | 3                 | F
+10001          | 57305          | 2                 | M
+10067          | 52044          | 2                 | M
+10065          | 50249          | 2                 | M
+10099          | 73578          | 2                 | F
+10078          | 69904          | 2                 | F
+10059          | 44307          | 2                 | F
+10016          | 61358          | 2                 | null
+10017          | 58715          | 2                 | null
+10018          | 56760          | 2                 | null
+10033          | 70011          | 1                 | M
+10086          | 68547          | 1                 | M
+10005          | 63528          | 1                 | M
+10009          | 66174          | 1                 | F
+10041          | 56415          | 1                 | F
+10044          | 39728          | 1                 | F
+10019          | 73717          | 1                 | null
+10013          | 48735          | 1                 | null
+10029          | 74999          | null              | M
+10021          | 60408          | null              | M
+10022          | 48233          | null              | M
+10027          | 73851          | null              | F
+10024          | 64675          | null              | F
+10023          | 47896          | null              | F
+;
+
+sortLimitByMultivalueGroupKeySimple
+required_capability: esql_topn_by
+
+ROW x = 1, g = [10, 20, 30]
+| SORT x DESC
+| LIMIT 1 BY g
+| SORT g ASC
+| KEEP x, g
+;
+
+x:integer | g:integer
+1         | [10, 20, 30]
+;
+
+sortLimitByMultivalueGroupKeySimpleFiltered
+required_capability: esql_topn_by
+
+ROW x = 1, g = [10, 20, 30]
+| SORT x DESC
+| LIMIT 1 BY g
+| WHERE g == 20
+| KEEP x, g
+;
+warning:Line 4:9: evaluation of [g == 20] failed, treating result as null. Only first 20 failures recorded.
+warning:Line 4:9: java.lang.IllegalArgumentException: single-value function encountered multi-value
+
+x:integer | g:integer
+;
+
+sortLimitByTwoMultivalueGroupKeysSimple
+required_capability: esql_topn_by
+
+ROW x = 1, g1 = [1, 2], g2 = [10, 20]
+| SORT x DESC
+| LIMIT 1 BY g1, g2
+| KEEP x, g1, g2
+| SORT g1 ASC, g2 ASC
+;
+
+x:integer | g1:integer | g2:integer
+1         | [1, 2]     | [10, 20]
+;
+
+sortLimitByMultivalueGroupKey
+required_capability: esql_topn_by
+
+FROM employees
+| WHERE emp_no IN (10001, 10002, 10006)
+| SORT salary DESC
+| LIMIT 2 BY job_positions
+| SORT emp_no, job_positions ASC
+| KEEP emp_no, first_name, salary, job_positions
+;
+
+emp_no:integer | first_name:keyword | salary:integer | job_positions:keyword
+10001          | Georgi             | 57305          | [Accountant, Senior Python Developer]
+10002          | Bezalel            | 56371          | [Senior Team Lead]
+10006          | Anneke             | 60335          | [Principal Support Engineer, Senior Team Lead, Tech Lead]
+;
+
+sortLimitByMultivalueGroupKeyFiltered
+required_capability: esql_topn_by
+
+FROM employees
+| WHERE emp_no IN (10001, 10002, 10006)
+| SORT salary DESC
+| LIMIT 1 BY job_positions
+| WHERE job_positions == "Senior Team Lead"
+| KEEP emp_no, first_name, salary, job_positions
+;
+warningRegex:Line 5:9: evaluation of \[job_positions == \\\"Senior Team Lead\\\"\] failed, treating result as null. Only first 20 failures recorded.
+warningRegex:Line 5:9: java.lang.IllegalArgumentException: single-value function encountered multi-value
+
+emp_no:integer | first_name:keyword | salary:integer | job_positions:keyword
+10002          | Bezalel            | 56371          | Senior Team Lead
+;
+
+sortLimitByMultivalueGroupKeyWithIntersection
+required_capability: esql_topn_by
+
+FROM employees
+| WHERE emp_no IN (10001, 10008)
+| SORT salary DESC
+| LIMIT 1 BY job_positions
+| KEEP emp_no, first_name, salary, job_positions
+;
+
+emp_no:integer | first_name:keyword | salary:integer | job_positions:keyword
+10001          | Georgi             | 57305          | [Accountant, Senior Python Developer]
+10008          | Saniya             | 43906          | [Internship, Junior Developer, Purchase Manager, Senior Python Developer]
+;
+
+sortLimitByMultipleMultivalueGroupKeys
+required_capability: esql_topn_by
+
+FROM employees
+| WHERE emp_no IN (10001, 10002)
+| SORT salary DESC
+| LIMIT 1 BY job_positions, is_rehired
+| KEEP emp_no, first_name, salary, job_positions, is_rehired
+;
+
+emp_no:integer | first_name:keyword | salary:integer | job_positions:keyword                 | is_rehired:boolean
+10001          | Georgi             | 57305          | [Accountant, Senior Python Developer] | [false, true]
+10002          | Bezalel            | 56371          | Senior Team Lead                      | [false, false]
+;
+
+sortLimitByWithLookupJoin
+required_capability: esql_topn_by
+required_capability: join_lookup_v12
+
+FROM employees
+| WHERE emp_no IN (10001, 10002, 10003, 10004, 10005)
+| EVAL language_code = languages
+| LOOKUP JOIN languages_lookup_non_unique_key ON language_code
+| SORT emp_no, language_code, language_name
+| LIMIT 2 BY emp_no
+| KEEP emp_no, language_code, language_name
+;
+
+emp_no:integer | language_code:integer | language_name:keyword
+10001          | 2                     | German
+10001          | 2                     | German
+10002          | 5                     | null
+10003          | 4                     | Quenya
+10004          | 5                     | null
+10005          | 1                     | English
+10005          | 1                     | English
+;
+
+sortLimitByShadowedNonJoinField
+required_capability: esql_topn_by
+required_capability: join_lookup_v12
+
+FROM employees
+| WHERE emp_no IN (10001, 10002, 10003, 10004, 10005)
+| EVAL language_code = languages
+| EVAL language_name = 2*salary
+| LOOKUP JOIN languages_lookup_non_unique_key ON language_code
+| SORT emp_no, language_code, language_name
+| LIMIT 2 BY language_name
+| KEEP emp_no, language_code, language_name
+;
+
+emp_no:integer | language_code:integer | language_name:keyword
+10001          | 2                     | German
+10001          | 2                     | German
+10002          | 5                     | null
+10003          | 4                     | Quenya
+10004          | 5                     | null
+10005          | 1                     | English
+10005          | 1                     | English
+;
+
+limitByWithEnrich
+required_capability: enrich_load
+required_capability: limit_by_enrich_fix
+
+FROM *
+| ENRICH languages_policy on street
+| KEEP abbrev, integer, year
+| LIMIT 1 BY abbrev
+| SORT abbrev
+| LIMIT 5
+;
+
+abbrev:keyword | integer:integer | year:integer
+ABJ            | null            | null
+ABQ            | null            | null
+ABV            | null            | null
+ACA            | null            | null
+ACC            | null            | null
+;
+
+limitByWithGrok
+required_capability: esql_topn_by
+
+FROM employees
+| SORT emp_no
+| GROK first_name "(?.)(?.*)"
+| LIMIT 2 BY first_letter
+| KEEP first_name, first_letter, emp_no
+| LIMIT 10
+;
+
+first_name:keyword | first_letter:keyword | emp_no:integer
+Georgi             | G                    | 10001
+Bezalel            | B                    | 10002
+Parto              | P                    | 10003
+Chirstian          | C                    | 10004
+Kyoichi            | K                    | 10005
+Anneke             | A                    | 10006
+Tzvetan            | T                    | 10007
+Saniya             | S                    | 10008
+Sumant             | S                    | 10009
+Duangkaew          | D                    | 10010
+;
+
+limitByWithUriParts
+required_capability: esql_topn_by
+
+FROM web_logs
+| SORT uri
+| URI_PARTS p = uri
+| LIMIT 1 BY p.domain
+| KEEP p.scheme, p.domain, p.path, p.query
+;
+
+p.scheme:keyword | p.domain:keyword   | p.path:keyword           | p.query:keyword
+null             | null               | /api/v1/users/123        | null
+ftp              | files.internal     | /data.zip                | null
+https            | discuss.elastic.co | /c/elasticsearch         | null
+https            | github.com         | /elastic/elasticsearch   | null
+https            | www.elastic.co     | /downloads/elasticsearch | null
+https            | www.google.com     | /search                  | q=elasticsearch
+https            | www.iana.org       | /domains/reserved        | null
+;
+
+limitByWithRerank
+required_capability: esql_topn_by
+required_capability: rerank
+required_capability: match_operator_colon
+
+FROM books
+| SORT book_no
+| LIMIT 5
+| RERANK "war and peace" ON title WITH { "inference_id" : "test_reranker" }
+| LIMIT 3 BY _score
+| KEEP book_no, title, author, _score
+;
+
+book_no:keyword | title:text                                            | author:text              | _score:double
+1211            | The brothers Karamazov                                | Fyodor Dostoevsky        | 0.04545454680919647
+1463            | Realms of Tolkien: Images of Middle-earth             | J. R. R. Tolkien         | 0.024390242993831635
+1502            | Selected Passages from Correspondence with Friends    | Nikolai Vasilevich Gogol | 0.019999999552965164
+1937            | The Best Short Stories of Dostoevsky (Modern Library) | Fyodor Dostoevsky        | 0.01886792480945587
+1985            | Brothers Karamazov                                    | Fyodor Dostoevsky        | 0.0555555559694767
+;

From 9965b011ba1efe0ecacdd9f47a1d0574e34d9f87 Mon Sep 17 00:00:00 2001
From: ncordon 
Date: Wed, 1 Apr 2026 13:48:11 +0200
Subject: [PATCH 6/7] Fixes issue with auto-generated docs

---
 .../esql/_snippets/commands/examples/limit.csv-spec/limitBy.md  | 2 +-
 .../commands/examples/limit.csv-spec/limitByMultipleGroups.md   | 2 +-
 2 files changed, 2 insertions(+), 2 deletions(-)

diff --git a/docs/reference/query-languages/esql/_snippets/commands/examples/limit.csv-spec/limitBy.md b/docs/reference/query-languages/esql/_snippets/commands/examples/limit.csv-spec/limitBy.md
index 89ff59c1766c7..699e9c2a3c395 100644
--- a/docs/reference/query-languages/esql/_snippets/commands/examples/limit.csv-spec/limitBy.md
+++ b/docs/reference/query-languages/esql/_snippets/commands/examples/limit.csv-spec/limitBy.md
@@ -1,4 +1,4 @@
-% This is generated by ESQL's AbstractFunctionTestCase. Do not edit it. See ../README.md for how to regenerate it.
+% This is generated by ESQL's CommandDocsTests. Do not edit it. See ../README.md for how to regenerate it.
 
 ```esql
 FROM employees
diff --git a/docs/reference/query-languages/esql/_snippets/commands/examples/limit.csv-spec/limitByMultipleGroups.md b/docs/reference/query-languages/esql/_snippets/commands/examples/limit.csv-spec/limitByMultipleGroups.md
index 329d4a0781617..0e39aaf6d0c04 100644
--- a/docs/reference/query-languages/esql/_snippets/commands/examples/limit.csv-spec/limitByMultipleGroups.md
+++ b/docs/reference/query-languages/esql/_snippets/commands/examples/limit.csv-spec/limitByMultipleGroups.md
@@ -1,4 +1,4 @@
-% This is generated by ESQL's AbstractFunctionTestCase. Do not edit it. See ../README.md for how to regenerate it.
+% This is generated by ESQL's CommandDocsTests. Do not edit it. See ../README.md for how to regenerate it.
 
 ```esql
 FROM employees

From b786e91689e447bdb481ed59ea3b955d3adc8cdc Mon Sep 17 00:00:00 2001
From: ncordon 
Date: Wed, 1 Apr 2026 17:29:16 +0200
Subject: [PATCH 7/7] Gates tests using a qualified name

---
 .../esql/qa/testFixtures/src/main/resources/limit.csv-spec       | 1 +
 .../xpack/esql/optimizer/LogicalPlanOptimizerTests.java          | 1 +
 .../elasticsearch/xpack/esql/parser/StatementParserTests.java    | 1 +
 3 files changed, 3 insertions(+)

diff --git a/x-pack/plugin/esql/qa/testFixtures/src/main/resources/limit.csv-spec b/x-pack/plugin/esql/qa/testFixtures/src/main/resources/limit.csv-spec
index 0379e0e2a01b5..31f72490214b2 100644
--- a/x-pack/plugin/esql/qa/testFixtures/src/main/resources/limit.csv-spec
+++ b/x-pack/plugin/esql/qa/testFixtures/src/main/resources/limit.csv-spec
@@ -404,6 +404,7 @@ Mayumi             | Schueller         | 65367          | 4                 | M
 
 sortLimitByQualifiedName
 required_capability: esql_topn_by
+required_capability: name_qualifiers
 
 FROM employees
 | SORT salary DESC
diff --git a/x-pack/plugin/esql/src/test/java/org/elasticsearch/xpack/esql/optimizer/LogicalPlanOptimizerTests.java b/x-pack/plugin/esql/src/test/java/org/elasticsearch/xpack/esql/optimizer/LogicalPlanOptimizerTests.java
index 6b82da7cc19bc..11dc594f16ab6 100644
--- a/x-pack/plugin/esql/src/test/java/org/elasticsearch/xpack/esql/optimizer/LogicalPlanOptimizerTests.java
+++ b/x-pack/plugin/esql/src/test/java/org/elasticsearch/xpack/esql/optimizer/LogicalPlanOptimizerTests.java
@@ -11092,6 +11092,7 @@ public void testOnlyLastNonContiguousSortPreservedTopNByWithExprs() {
     }
 
     public void testTopNByWorksWithQualifiedNames() {
+        assumeTrue("Requires qualifier support", EsqlCapabilities.Cap.NAME_QUALIFIERS.isEnabled());
         var query = """
             FROM employees
             | SORT salary DESC
diff --git a/x-pack/plugin/esql/src/test/java/org/elasticsearch/xpack/esql/parser/StatementParserTests.java b/x-pack/plugin/esql/src/test/java/org/elasticsearch/xpack/esql/parser/StatementParserTests.java
index ae8aac74e103f..5e78fbdaceaf1 100644
--- a/x-pack/plugin/esql/src/test/java/org/elasticsearch/xpack/esql/parser/StatementParserTests.java
+++ b/x-pack/plugin/esql/src/test/java/org/elasticsearch/xpack/esql/parser/StatementParserTests.java
@@ -1123,6 +1123,7 @@ public void testLimitBy() {
     }
 
     public void testLimitByQualifiedName() {
+        assumeTrue("Requires qualifier support", EsqlCapabilities.Cap.NAME_QUALIFIERS.isEnabled());
         LogicalPlan plan = query("""
                 FROM foo
                 | SORT @timestamp DESC